2006-09-18 05:50:02 +00:00
< ? php
2004-09-26 05:10:38 +00:00
/**
* adminlib . php - Contains functions that only administrators will ever need to use
*
2006-09-18 05:50:02 +00:00
* @ author Martin Dougiamas and many others
2004-09-26 05:10:38 +00:00
* @ version $Id $
* @ license http :// www . gnu . org / copyleft / gpl . html GNU Public License
* @ package moodlecore
*/
2007-10-10 13:14:56 +00:00
function upgrade_main_savepoint ( $result , $version ) {
global $CFG ;
if ( $result ) {
if ( $CFG -> version >= $version ) {
// something really wrong is going on in main upgrade script
error ( " Upgrade savepoint: Can not upgrade main version from $CFG->version to $version . " );
}
set_config ( 'version' , $version );
} else {
notify ( " Upgrade savepoint: Error during main upgrade to version $version " );
}
}
function upgrade_mod_savepoint ( $result , $version , $type ) {
//TODO
}
function upgrade_plugin_savepoint ( $result , $version , $type , $dir ) {
//TODO
}
function upgrade_backup_savepoint ( $result , $version ) {
//TODO
}
function upgrade_blocks_savepoint ( $result , $version , $type ) {
//TODO
}
2004-09-26 05:10:38 +00:00
/**
2006-03-22 10:44:54 +00:00
* Upgrade plugins
2004-09-26 05:10:38 +00:00
*
* @ uses $db
* @ uses $CFG
2006-03-22 10:44:54 +00:00
* @ param string $type The type of plugins that should be updated ( e . g . 'enrol' , 'qtype' )
* @ param string $dir The directory where the plugins are located ( e . g . 'question/questiontypes' )
* @ param string $return The url to prompt the user to continue to
2006-09-20 21:00:45 +00:00
*/
2006-03-22 10:44:54 +00:00
function upgrade_plugins ( $type , $dir , $return ) {
2004-08-24 04:58:06 +00:00
global $CFG , $db ;
2004-08-19 09:37:42 +00:00
2007-09-10 17:13:12 +00:00
/// Let's know if the header has been printed, so the funcion is being called embedded in an outer page
$embedded = defined ( 'HEADER_PRINTED' );
2007-07-27 11:31:34 +00:00
$plugs = get_list_of_plugins ( $dir );
2006-08-01 07:46:19 +00:00
$updated_plugins = false ;
$strpluginsetup = get_string ( 'pluginsetup' );
2006-03-22 10:44:54 +00:00
foreach ( $plugs as $plug ) {
2004-08-19 09:37:42 +00:00
2006-03-22 10:44:54 +00:00
$fullplug = $CFG -> dirroot . '/' . $dir . '/' . $plug ;
2004-08-19 09:37:42 +00:00
2006-03-22 10:44:54 +00:00
unset ( $plugin );
2004-08-19 09:37:42 +00:00
2006-08-08 05:13:06 +00:00
if ( is_readable ( $fullplug . '/version.php' )) {
2006-03-22 10:44:54 +00:00
include_once ( $fullplug . '/version.php' ); // defines $plugin with version etc
2004-08-19 09:37:42 +00:00
} else {
continue ; // Nothing to do.
}
2006-08-30 19:52:16 +00:00
$oldupgrade = false ;
$newupgrade = false ;
2006-08-30 20:13:46 +00:00
if ( is_readable ( $fullplug . '/db/' . $CFG -> dbtype . '.php' )) {
include_once ( $fullplug . '/db/' . $CFG -> dbtype . '.php' ); // defines old upgrading function
2006-08-30 19:52:16 +00:00
$oldupgrade = true ;
}
2006-09-20 22:36:21 +00:00
if ( is_readable ( $fullplug . '/db/upgrade.php' )) {
2006-08-30 20:13:46 +00:00
include_once ( $fullplug . '/db/upgrade.php' ); // defines new upgrading function
2006-08-30 19:52:16 +00:00
$newupgrade = true ;
}
2006-03-22 10:44:54 +00:00
if ( ! isset ( $plugin )) {
2004-08-19 09:37:42 +00:00
continue ;
}
2006-03-22 10:44:54 +00:00
if ( ! empty ( $plugin -> requires )) {
if ( $plugin -> requires > $CFG -> version ) {
2007-01-15 19:16:29 +00:00
$info = new object ();
2006-03-22 10:44:54 +00:00
$info -> pluginname = $plug ;
$info -> pluginversion = $plugin -> version ;
2004-08-19 09:37:42 +00:00
$info -> currentmoodle = $CFG -> version ;
2006-03-22 10:44:54 +00:00
$info -> requiremoodle = $plugin -> requires ;
2007-09-10 17:13:12 +00:00
if ( ! $updated_plugins && ! $embedded ) {
2007-08-17 19:09:11 +00:00
print_header ( $strpluginsetup , $strpluginsetup ,
build_navigation ( array ( array ( 'name' => $strpluginsetup , 'link' => null , 'type' => 'misc' ))), '' ,
2007-01-22 20:15:12 +00:00
upgrade_get_javascript (), false , ' ' , ' ' );
2006-08-01 07:46:19 +00:00
}
upgrade_log_start ();
2006-03-22 10:44:54 +00:00
notify ( get_string ( 'pluginrequirementsnotmet' , 'error' , $info ));
2006-08-01 07:46:19 +00:00
$updated_plugins = true ;
2004-08-19 09:37:42 +00:00
continue ;
}
}
2006-03-22 10:44:54 +00:00
$plugin -> name = $plug ; // The name MUST match the directory
2004-08-19 09:37:42 +00:00
2006-03-22 10:44:54 +00:00
$pluginversion = $type . '_' . $plug . '_version' ;
2004-08-19 09:37:42 +00:00
2006-03-22 10:44:54 +00:00
if ( ! isset ( $CFG -> $pluginversion )) {
set_config ( $pluginversion , 0 );
2004-08-19 09:37:42 +00:00
}
2006-09-20 21:00:45 +00:00
2006-03-22 10:44:54 +00:00
if ( $CFG -> $pluginversion == $plugin -> version ) {
2004-08-19 09:37:42 +00:00
// do nothing
2006-03-22 10:44:54 +00:00
} else if ( $CFG -> $pluginversion < $plugin -> version ) {
2007-09-10 17:13:12 +00:00
if ( ! $updated_plugins && ! $embedded ) {
2007-08-17 19:09:11 +00:00
print_header ( $strpluginsetup , $strpluginsetup ,
build_navigation ( array ( array ( 'name' => $strpluginsetup , 'link' => null , 'type' => 'misc' ))), '' ,
2007-01-22 20:15:12 +00:00
upgrade_get_javascript (), false , ' ' , ' ' );
2004-08-19 09:37:42 +00:00
}
2006-08-30 19:52:16 +00:00
$updated_plugins = true ;
2006-08-01 07:46:19 +00:00
upgrade_log_start ();
2007-07-25 07:08:07 +00:00
print_heading ( $dir . '/' . $plugin -> name . ' plugin needs upgrading' );
2006-08-30 19:52:16 +00:00
$db -> debug = true ;
@ set_time_limit ( 0 ); // To allow slow databases to complete the long SQL
2006-04-16 16:50:55 +00:00
if ( $CFG -> $pluginversion == 0 ) { // It's a new install of this plugin
2006-08-30 19:52:16 +00:00
/// Both old .sql files and new install.xml are supported
/// but we priorize install.xml (XMLDB) if present
$status = false ;
2006-09-20 22:36:21 +00:00
if ( file_exists ( $fullplug . '/db/install.xml' )) {
2006-08-30 20:27:29 +00:00
$status = install_from_xmldb_file ( $fullplug . '/db/install.xml' ); //New method
2006-08-30 19:52:16 +00:00
} else if ( file_exists ( $fullplug . '/db/' . $CFG -> dbtype . '.sql' )) {
$status = modify_database ( $fullplug . '/db/' . $CFG -> dbtype . '.sql' ); //Old method
2006-09-20 21:00:45 +00:00
} else {
2006-08-30 20:13:46 +00:00
$status = true ;
2006-04-16 16:50:55 +00:00
}
2006-08-30 19:52:16 +00:00
$db -> debug = false ;
2006-09-20 21:00:45 +00:00
/// Continue with the instalation, roles and other stuff
2006-08-30 19:52:16 +00:00
if ( $status ) {
2007-06-19 16:35:41 +00:00
/// OK so far, now update the plugins record
2006-08-30 19:52:16 +00:00
set_config ( $pluginversion , $plugin -> version );
2007-06-19 16:35:41 +00:00
/// Install capabilities
2006-12-11 15:47:23 +00:00
if ( ! update_capabilities ( $type . '/' . $plug )) {
2007-06-19 16:35:41 +00:00
error ( 'Could not set up the capabilities for ' . $plugin -> name . '!' );
2006-08-30 19:52:16 +00:00
}
2007-06-19 16:35:41 +00:00
/// Install events
2007-04-19 08:45:30 +00:00
events_update_definition ( $type . '/' . $plug );
2007-06-19 16:35:41 +00:00
/// Run local install function if there is one
if ( is_readable ( $fullplug . '/lib.php' )) {
2007-07-27 13:38:06 +00:00
include_once ( $fullplug . '/lib.php' );
2007-06-19 16:35:41 +00:00
$installfunction = $plugin -> name . '_install' ;
if ( function_exists ( $installfunction )) {
if ( ! $installfunction () ) {
notify ( 'Encountered a problem running install function for ' . $module -> name . '!' );
}
}
}
2007-07-27 13:38:06 +00:00
2006-08-30 19:52:16 +00:00
notify ( get_string ( 'modulesuccess' , '' , $plugin -> name ), 'notifysuccess' );
} else {
notify ( 'Installing ' . $plugin -> name . ' FAILED!' );
}
2006-04-16 16:50:55 +00:00
} else { // Upgrade existing install
2006-08-30 19:52:16 +00:00
/// Run de old and new upgrade functions for the module
$oldupgrade_function = $type . '_' . $plugin -> name . '_upgrade' ;
$newupgrade_function = 'xmldb_' . $type . '_' . $plugin -> name . '_upgrade' ;
/// First, the old function if exists
$oldupgrade_status = true ;
if ( $oldupgrade && function_exists ( $oldupgrade_function )) {
$db -> debug = true ;
$oldupgrade_status = $oldupgrade_function ( $CFG -> $pluginversion );
} else if ( $oldupgrade ) {
notify ( 'Upgrade function ' . $oldupgrade_function . ' was not available in ' .
$fullplug . '/db/' . $CFG -> dbtype . '.php' );
}
/// Then, the new function if exists and the old one was ok
$newupgrade_status = true ;
if ( $newupgrade && function_exists ( $newupgrade_function ) && $oldupgrade_status ) {
$db -> debug = true ;
$newupgrade_status = $newupgrade_function ( $CFG -> $pluginversion );
} else if ( $newupgrade ) {
notify ( 'Upgrade function ' . $newupgrade_function . ' was not available in ' .
$fullplug . '/db/upgrade.php' );
}
$db -> debug = false ;
/// Now analyze upgrade results
if ( $oldupgrade_status && $newupgrade_status ) { // No upgrading failed
// OK so far, now update the plugins record
set_config ( $pluginversion , $plugin -> version );
2006-12-11 15:47:23 +00:00
if ( ! update_capabilities ( $type . '/' . $plug )) {
2006-08-30 19:52:16 +00:00
error ( 'Could not update ' . $plugin -> name . ' capabilities!' );
2006-04-16 16:50:55 +00:00
}
2007-04-19 08:45:30 +00:00
events_update_definition ( $type . '/' . $plug );
2006-08-30 19:52:16 +00:00
notify ( get_string ( 'modulesuccess' , '' , $plugin -> name ), 'notifysuccess' );
} else {
notify ( 'Upgrading ' . $plugin -> name . ' from ' . $CFG -> $pluginversion . ' to ' . $plugin -> version . ' FAILED!' );
2004-08-19 09:37:42 +00:00
}
}
2006-04-16 16:50:55 +00:00
echo '<hr />' ;
2004-08-19 09:37:42 +00:00
} else {
2006-08-01 07:46:19 +00:00
upgrade_log_start ();
2006-03-22 10:44:54 +00:00
error ( 'Version mismatch: ' . $plugin -> name . ' can\'t downgrade ' . $CFG -> $pluginversion . ' -> ' . $plugin -> version . ' !' );
2004-08-19 09:37:42 +00:00
}
}
2006-08-01 07:46:19 +00:00
upgrade_log_finish ();
2007-09-10 17:13:12 +00:00
if ( $updated_plugins && ! $embedded ) {
2004-08-19 09:37:42 +00:00
print_continue ( $return );
2007-01-15 19:16:29 +00:00
print_footer ( 'none' );
2004-08-19 09:37:42 +00:00
die ;
}
}
2004-09-26 05:10:38 +00:00
/**
* Find and check all modules and load them up or upgrade them if necessary
*
* @ uses $db
* @ uses $CFG
* @ param string $return The url to prompt the user to continue to
* @ todo Finish documenting this function
2006-09-20 21:00:45 +00:00
*/
2004-08-19 09:37:42 +00:00
function upgrade_activity_modules ( $return ) {
2004-08-24 04:58:06 +00:00
global $CFG , $db ;
2004-08-19 09:37:42 +00:00
2004-09-26 05:10:38 +00:00
if ( ! $mods = get_list_of_plugins ( 'mod' ) ) {
error ( 'No modules installed!' );
2004-08-19 09:37:42 +00:00
}
2006-08-01 07:46:19 +00:00
$updated_modules = false ;
$strmodulesetup = get_string ( 'modulesetup' );
2004-08-19 09:37:42 +00:00
foreach ( $mods as $mod ) {
2004-09-26 05:10:38 +00:00
if ( $mod == 'NEWMODULE' ) { // Someone has unzipped the template, ignore it
2004-08-19 09:37:42 +00:00
continue ;
}
2004-09-26 05:10:38 +00:00
$fullmod = $CFG -> dirroot . '/mod/' . $mod ;
2004-08-19 09:37:42 +00:00
unset ( $module );
2004-09-26 05:10:38 +00:00
if ( is_readable ( $fullmod . '/version.php' )) {
include_once ( $fullmod . '/version.php' ); // defines $module with version etc
2004-08-19 09:37:42 +00:00
} else {
2004-09-26 05:10:38 +00:00
notify ( 'Module ' . $mod . ': ' . $fullmod . '/version.php was not readable' );
2004-08-19 09:37:42 +00:00
continue ;
}
2006-08-27 09:00:23 +00:00
$oldupgrade = false ;
$newupgrade = false ;
2006-08-30 20:13:46 +00:00
if ( is_readable ( $fullmod . '/db/' . $CFG -> dbtype . '.php' )) {
include_once ( $fullmod . '/db/' . $CFG -> dbtype . '.php' ); // defines old upgrading function
2006-08-27 09:00:23 +00:00
$oldupgrade = true ;
}
2006-09-20 22:36:21 +00:00
if ( is_readable ( $fullmod . '/db/upgrade.php' )) {
2006-08-30 20:13:46 +00:00
include_once ( $fullmod . '/db/upgrade.php' ); // defines new upgrading function
2006-08-27 09:00:23 +00:00
$newupgrade = true ;
2004-08-19 09:37:42 +00:00
}
if ( ! isset ( $module )) {
continue ;
}
if ( ! empty ( $module -> requires )) {
if ( $module -> requires > $CFG -> version ) {
2007-01-15 19:16:29 +00:00
$info = new object ();
2004-08-19 09:37:42 +00:00
$info -> modulename = $mod ;
$info -> moduleversion = $module -> version ;
$info -> currentmoodle = $CFG -> version ;
$info -> requiremoodle = $module -> requires ;
2006-08-01 07:46:19 +00:00
if ( ! $updated_modules ) {
2007-08-17 19:09:11 +00:00
print_header ( $strmodulesetup , $strmodulesetup ,
build_navigation ( array ( array ( 'name' => $strmodulesetup , 'link' => null , 'type' => 'misc' ))), '' ,
2007-01-22 20:15:12 +00:00
upgrade_get_javascript (), false , ' ' , ' ' );
2006-08-01 07:46:19 +00:00
}
upgrade_log_start ();
2004-08-19 09:37:42 +00:00
notify ( get_string ( 'modulerequirementsnotmet' , 'error' , $info ));
2006-08-01 07:46:19 +00:00
$updated_modules = true ;
2004-08-19 09:37:42 +00:00
continue ;
}
}
$module -> name = $mod ; // The name MUST match the directory
2006-09-20 21:00:45 +00:00
2007-06-18 03:59:47 +00:00
include_once ( $fullmod . '/lib.php' ); // defines upgrading and/or installing functions
2004-09-26 05:10:38 +00:00
if ( $currmodule = get_record ( 'modules' , 'name' , $module -> name )) {
2004-08-19 09:37:42 +00:00
if ( $currmodule -> version == $module -> version ) {
// do nothing
} else if ( $currmodule -> version < $module -> version ) {
2006-08-27 09:00:23 +00:00
/// If versions say that we need to upgrade but no upgrade files are available, notify and continue
if ( ! $oldupgrade && ! $newupgrade ) {
notify ( 'Upgrade files ' . $mod . ': ' . $fullmod . '/db/' . $CFG -> dbtype . '.php or ' .
$fullmod . '/db/upgrade.php were not readable' );
continue ;
}
2006-08-01 07:46:19 +00:00
if ( ! $updated_modules ) {
2007-08-17 19:09:11 +00:00
print_header ( $strmodulesetup , $strmodulesetup ,
build_navigation ( array ( array ( 'name' => $strmodulesetup , 'link' => null , 'type' => 'misc' ))), '' ,
2007-01-22 20:15:12 +00:00
upgrade_get_javascript (), false , ' ' , ' ' );
2004-08-19 09:37:42 +00:00
}
2006-08-01 07:46:19 +00:00
upgrade_log_start ();
2004-09-26 05:10:38 +00:00
print_heading ( $module -> name . ' module needs upgrading' );
2006-08-27 09:00:23 +00:00
/// Run de old and new upgrade functions for the module
$oldupgrade_function = $module -> name . '_upgrade' ;
$newupgrade_function = 'xmldb_' . $module -> name . '_upgrade' ;
/// First, the old function if exists
$oldupgrade_status = true ;
if ( $oldupgrade && function_exists ( $oldupgrade_function )) {
$db -> debug = true ;
$oldupgrade_status = $oldupgrade_function ( $currmodule -> version , $module );
2006-08-28 15:47:45 +00:00
} else if ( $oldupgrade ) {
2006-08-27 09:00:23 +00:00
notify ( 'Upgrade function ' . $oldupgrade_function . ' was not available in ' .
$mod . ': ' . $fullmod . '/db/' . $CFG -> dbtype . '.php' );
}
/// Then, the new function if exists and the old one was ok
$newupgrade_status = true ;
2006-08-28 15:47:45 +00:00
if ( $newupgrade && function_exists ( $newupgrade_function ) && $oldupgrade_status ) {
2006-08-27 09:00:23 +00:00
$db -> debug = true ;
$newupgrade_status = $newupgrade_function ( $currmodule -> version , $module );
2006-08-28 15:47:45 +00:00
} else if ( $newupgrade ) {
2006-08-27 09:00:23 +00:00
notify ( 'Upgrade function ' . $newupgrade_function . ' was not available in ' .
$mod . ': ' . $fullmod . '/db/upgrade.php' );
}
2006-08-30 19:52:16 +00:00
$db -> debug = false ;
2006-08-27 09:00:23 +00:00
/// Now analyze upgrade results
2006-08-28 02:10:23 +00:00
if ( $oldupgrade_status && $newupgrade_status ) { // No upgrading failed
2006-08-27 09:00:23 +00:00
// OK so far, now update the modules record
$module -> id = $currmodule -> id ;
if ( ! update_record ( 'modules' , $module )) {
error ( 'Could not update ' . $module -> name . ' record in modules table!' );
2004-08-19 09:37:42 +00:00
}
2006-08-27 09:00:23 +00:00
remove_dir ( $CFG -> dataroot . '/cache' , true ); // flush cache
notify ( get_string ( 'modulesuccess' , '' , $module -> name ), 'notifysuccess' );
echo '<hr />' ;
} else {
notify ( 'Upgrading ' . $module -> name . ' from ' . $currmodule -> version . ' to ' . $module -> version . ' FAILED!' );
2004-08-19 09:37:42 +00:00
}
2006-08-08 05:13:06 +00:00
2006-08-27 09:00:23 +00:00
/// Update the capabilities table?
2006-08-08 05:13:06 +00:00
if ( ! update_capabilities ( 'mod/' . $module -> name )) {
error ( 'Could not update ' . $module -> name . ' capabilities!' );
}
2007-04-19 08:45:30 +00:00
events_update_definition ( 'mod/' . $module -> name );
2006-08-08 05:13:06 +00:00
2004-08-19 09:37:42 +00:00
$updated_modules = true ;
2006-09-20 21:00:45 +00:00
2004-08-19 09:37:42 +00:00
} else {
2006-08-01 07:46:19 +00:00
upgrade_log_start ();
2004-09-26 05:10:38 +00:00
error ( 'Version mismatch: ' . $module -> name . ' can\'t downgrade ' . $currmodule -> version . ' -> ' . $module -> version . ' !' );
2004-08-19 09:37:42 +00:00
}
2006-09-20 21:00:45 +00:00
2004-08-19 09:37:42 +00:00
} else { // module not installed yet, so install it
2006-08-01 07:46:19 +00:00
if ( ! $updated_modules ) {
2007-08-17 19:09:11 +00:00
print_header ( $strmodulesetup , $strmodulesetup ,
build_navigation ( array ( array ( 'name' => $strmodulesetup , 'link' => null , 'type' => 'misc' ))), '' ,
2007-01-22 20:15:12 +00:00
upgrade_get_javascript (), false , ' ' , ' ' );
2004-08-19 09:37:42 +00:00
}
2006-08-01 07:46:19 +00:00
upgrade_log_start ();
2004-08-19 09:37:42 +00:00
print_heading ( $module -> name );
$updated_modules = true ;
$db -> debug = true ;
@ set_time_limit ( 0 ); // To allow slow databases to complete the long SQL
2006-08-27 09:00:23 +00:00
/// Both old .sql files and new install.xml are supported
/// but we priorize install.xml (XMLDB) if present
2006-09-20 22:36:21 +00:00
if ( file_exists ( $fullmod . '/db/install.xml' )) {
2006-08-27 09:00:23 +00:00
$status = install_from_xmldb_file ( $fullmod . '/db/install.xml' ); //New method
} else {
$status = modify_database ( $fullmod . '/db/' . $CFG -> dbtype . '.sql' ); //Old method
}
2006-08-30 19:52:16 +00:00
$db -> debug = false ;
2007-06-18 03:59:47 +00:00
/// Continue with the installation, roles and other stuff
2006-08-27 09:00:23 +00:00
if ( $status ) {
2004-09-26 05:10:38 +00:00
if ( $module -> id = insert_record ( 'modules' , $module )) {
2007-06-18 03:59:47 +00:00
2007-07-27 13:38:06 +00:00
/// Capabilities
2006-08-08 05:13:06 +00:00
if ( ! update_capabilities ( 'mod/' . $module -> name )) {
error ( 'Could not set up the capabilities for ' . $module -> name . '!' );
}
2007-07-27 13:38:06 +00:00
2007-06-18 03:59:47 +00:00
/// Events
2007-04-19 08:45:30 +00:00
events_update_definition ( 'mod/' . $module -> name );
2007-06-18 03:59:47 +00:00
/// Run local install function if there is one
$installfunction = $module -> name . '_install' ;
if ( function_exists ( $installfunction )) {
if ( ! $installfunction () ) {
notify ( 'Encountered a problem running install function for ' . $module -> name . '!' );
}
}
2005-02-08 17:09:41 +00:00
notify ( get_string ( 'modulesuccess' , '' , $module -> name ), 'notifysuccess' );
2004-09-26 05:10:38 +00:00
echo '<hr />' ;
2004-08-19 09:37:42 +00:00
} else {
2004-09-26 05:10:38 +00:00
error ( $module -> name . ' module could not be added to the module list!' );
2004-08-19 09:37:42 +00:00
}
2006-09-20 21:00:45 +00:00
} else {
2004-09-26 05:10:38 +00:00
error ( $module -> name . ' tables could NOT be set up successfully!' );
2004-08-19 09:37:42 +00:00
}
}
2005-07-15 17:28:45 +00:00
/// Check submodules of this module if necessary
$submoduleupgrade = $module -> name . '_upgrade_submodules' ;
if ( function_exists ( $submoduleupgrade )) {
$submoduleupgrade ();
}
/// Run any defaults or final code that is necessary for this module
2004-12-23 07:09:33 +00:00
if ( is_readable ( $fullmod . '/defaults.php' )) {
// Insert default values for any important configuration variables
2004-12-23 09:07:43 +00:00
unset ( $defaults );
2006-09-20 21:00:45 +00:00
include_once ( $fullmod . '/defaults.php' );
2005-04-26 07:45:09 +00:00
if ( ! empty ( $defaults )) {
foreach ( $defaults as $name => $value ) {
if ( ! isset ( $CFG -> $name )) {
set_config ( $name , $value );
}
2004-12-23 07:09:33 +00:00
}
}
}
2004-08-19 09:37:42 +00:00
}
2006-08-01 07:46:19 +00:00
upgrade_log_finish (); // finish logging if started
if ( $updated_modules ) {
2004-08-19 09:37:42 +00:00
print_continue ( $return );
2007-01-15 19:16:29 +00:00
print_footer ( 'none' );
2004-08-19 09:37:42 +00:00
die ;
}
}
2006-09-20 21:00:45 +00:00
/**
2005-09-01 04:14:31 +00:00
* This function will return FALSE if the lock fails to be set ( ie , if it ' s already locked )
2005-12-13 03:44:08 +00:00
*
* @ param string $name ?
* @ param bool $value ?
* @ param int $staleafter ?
* @ param bool $clobberstale ?
* @ todo Finish documenting this function
2005-09-01 04:14:31 +00:00
*/
function set_cron_lock ( $name , $value = true , $staleafter = 7200 , $clobberstale = false ) {
if ( empty ( $name )) {
mtrace ( " Tried to get a cron lock for a null fieldname " );
return false ;
}
if ( empty ( $value )) {
set_config ( $name , 0 );
return true ;
}
if ( $config = get_record ( 'config' , 'name' , $name )) {
if ( empty ( $config -> value )) {
set_config ( $name , time ());
} else {
// check for stale.
if (( time () - $staleafter ) > $config -> value ) {
mtrace ( " STALE LOCKFILE FOR $name - was $config->value " );
if ( ! empty ( $clobberstale )) {
set_config ( $name , time ());
return true ;
}
} else {
return false ; // was not stale - ie, we're ok to still be running.
}
}
}
else {
set_config ( $name , time ());
}
return true ;
}
2006-01-27 02:54:51 +00:00
2006-06-18 10:09:58 +00:00
function print_progress ( $done , $total , $updatetime = 5 , $sleeptime = 1 , $donetext = '' ) {
2006-01-27 02:54:51 +00:00
static $starttime ;
static $lasttime ;
2006-09-30 13:52:15 +00:00
if ( $total < 2 ) { // No need to show anything
return ;
}
2006-01-27 02:54:51 +00:00
if ( empty ( $starttime )) {
$starttime = $lasttime = time ();
$lasttime = $starttime - $updatetime ;
echo '<table width="500" cellpadding="0" cellspacing="0" align="center"><tr><td width="500">' ;
2006-09-29 06:19:47 +00:00
echo '<div id="bar' . $total . '" style="border-style:solid;border-width:1px;width:500px;height:50px;">' ;
echo '<div id="slider' . $total . '" style="border-style:solid;border-width:1px;height:48px;width:10px;background-color:green;"></div>' ;
2006-01-27 02:54:51 +00:00
echo '</div>' ;
2006-09-29 06:19:47 +00:00
echo '<div id="text' . $total . '" align="center" style="width:500px;"></div>' ;
2006-01-27 02:54:51 +00:00
echo '</td></tr></table>' ;
echo '</div>' ;
}
$now = time ();
if ( $done && (( $now - $lasttime ) >= $updatetime )) {
$elapsedtime = $now - $starttime ;
$projectedtime = ( int )((( float ) $total / ( float ) $done ) * $elapsedtime ) - $elapsedtime ;
2007-08-10 15:00:35 +00:00
$percentage = round (( float ) $done / ( float ) $total , 2 );
2006-01-27 02:54:51 +00:00
$width = ( int )( 500 * $percentage );
2006-06-18 10:09:58 +00:00
if ( $projectedtime > 10 ) {
$projectedtext = ' Ending: ' . format_time ( $projectedtime );
} else {
$projectedtext = '' ;
}
2006-01-27 02:54:51 +00:00
echo '<script>' ;
2006-09-29 06:41:10 +00:00
echo 'document.getElementById("text' . $total . '").innerHTML = "' . addslashes ( $donetext ) . ' (' . $done . '/' . $total . ') ' . $projectedtext . '";' . " \n " ;
echo 'document.getElementById("slider' . $total . '").style.width = \'' . $width . 'px\';' . " \n " ;
2006-01-27 02:54:51 +00:00
echo '</script>' ;
$lasttime = $now ;
sleep ( $sleeptime );
}
}
2006-08-01 07:46:19 +00:00
2007-01-22 20:15:12 +00:00
function upgrade_get_javascript () {
global $CFG ;
if ( ! empty ( $_SESSION [ 'installautopilot' ])) {
$linktoscrolltoerrors = '<script type="text/javascript">var installautopilot = true;</script>' . " \n " ;
} else {
$linktoscrolltoerrors = '<script type="text/javascript">var installautopilot = false;</script>' . " \n " ;
}
$linktoscrolltoerrors .= '<script type="text/javascript" src="' . $CFG -> wwwroot . '/lib/scroll_to_errors.js"></script>' ;
return $linktoscrolltoerrors ;
}
2007-01-25 00:04:02 +00:00
function create_admin_user () {
global $CFG , $USER ;
if ( empty ( $CFG -> rolesactive )) { // No admin user yet.
$user = new object ();
$user -> auth = 'manual' ;
$user -> firstname = get_string ( 'admin' );
$user -> lastname = get_string ( 'user' );
$user -> username = 'admin' ;
$user -> password = hash_internal_user_password ( 'admin' );
$user -> email = 'root@localhost' ;
$user -> confirmed = 1 ;
$user -> mnethostid = $CFG -> mnet_localhost_id ;
$user -> lang = $CFG -> lang ;
$user -> maildisplay = 1 ;
$user -> timemodified = time ();
if ( ! $user -> id = insert_record ( 'user' , $user )) {
error ( 'SERIOUS ERROR: Could not create admin user record !!!' );
}
if ( ! $user = get_record ( 'user' , 'id' , $user -> id )) { // Double check.
error ( 'User ID was incorrect (can\'t find it)' );
}
// Assign the default admin roles to the new user.
if ( ! $adminroles = get_roles_with_capability ( 'moodle/legacy:admin' , CAP_ALLOW )) {
error ( 'No admin role could be found' );
}
2007-01-29 21:29:27 +00:00
$sitecontext = get_context_instance ( CONTEXT_SYSTEM );
2007-01-25 00:04:02 +00:00
foreach ( $adminroles as $adminrole ) {
role_assign ( $adminrole -> id , $user -> id , 0 , $sitecontext -> id );
}
set_config ( 'rolesactive' , 1 );
// Log the user in.
$USER = get_complete_user_data ( 'username' , 'admin' );
$USER -> newadminuser = 1 ;
load_all_capabilities ();
redirect ( " $CFG->wwwroot /user/editadvanced.php?id= $user->id " ); // Edit thyself
} else {
error ( 'Can not create admin!' );
}
}
2006-08-01 07:46:19 +00:00
////////////////////////////////////////////////
/// upgrade logging functions
////////////////////////////////////////////////
$upgradeloghandle = false ;
2006-08-17 23:50:18 +00:00
$upgradelogbuffer = '' ;
// I did not find out how to use static variable in callback function,
// the problem was that I could not flush the static buffer :-(
global $upgradeloghandle , $upgradelogbuffer ;
2006-08-01 07:46:19 +00:00
/**
* Check if upgrade is already running .
*
* If anything goes wrong due to missing call to upgrade_log_finish ()
* just restart the browser .
*
* @ param string warning message indicating upgrade is already running
* @ param int page reload timeout
*/
function upgrade_check_running ( $message , $timeout ) {
if ( ! empty ( $_SESSION [ 'upgraderunning' ])) {
print_header ();
redirect ( me (), $message , $timeout );
}
}
/**
* Start logging of output into file ( if not disabled ) and
* prevent aborting and concurrent execution of upgrade script .
*
* Please note that you can not write into session variables after calling this function !
*
* This function may be called repeatedly .
*/
function upgrade_log_start () {
2006-08-25 20:50:44 +00:00
global $CFG , $upgradeloghandle ;
2006-08-01 07:46:19 +00:00
if ( ! empty ( $_SESSION [ 'upgraderunning' ])) {
return ; // logging already started
}
@ ignore_user_abort ( true ); // ignore if user stops or otherwise aborts page loading
$_SESSION [ 'upgraderunning' ] = 1 ; // set upgrade indicator
2006-08-25 20:50:44 +00:00
if ( empty ( $CFG -> dbsessions )) { // workaround for bug in adodb, db session can not be restarted
session_write_close (); // from now on user can reload page - will be displayed warning
}
2006-08-01 07:46:19 +00:00
make_upload_directory ( 'upgradelogs' );
ob_start ( 'upgrade_log_callback' , 2 ); // function for logging to disk; flush each line of text ASAP
2006-08-17 22:37:34 +00:00
register_shutdown_function ( 'upgrade_log_finish' ); // in case somebody forgets to stop logging
2006-08-01 07:46:19 +00:00
}
/**
* Terminate logging of output , flush all data , allow script aborting
* and reopen session for writing . Function error () does terminate the logging too .
*
* Please make sure that each upgrade_log_start () is properly terminated by
* this function or error () .
*
* This function may be called repeatedly .
*/
function upgrade_log_finish () {
2006-08-25 20:50:44 +00:00
global $CFG , $upgradeloghandle , $upgradelogbuffer ;
2006-08-01 07:46:19 +00:00
if ( empty ( $_SESSION [ 'upgraderunning' ])) {
return ; // logging already terminated
}
@ ob_end_flush ();
2006-08-17 23:50:18 +00:00
if ( $upgradelogbuffer !== '' ) {
@ fwrite ( $upgradeloghandle , $upgradelogbuffer );
2006-08-18 00:01:37 +00:00
$upgradelogbuffer = '' ;
2006-08-17 23:50:18 +00:00
}
if ( $upgradeloghandle and ( $upgradeloghandle !== 'error' )) {
@ fclose ( $upgradeloghandle );
2006-08-18 00:01:37 +00:00
$upgradeloghandle = false ;
2006-08-17 23:50:18 +00:00
}
2006-08-25 20:50:44 +00:00
if ( empty ( $CFG -> dbsessions )) {
@ session_start (); // ignore header errors, we only need to reopen session
}
2006-08-01 07:46:19 +00:00
$_SESSION [ 'upgraderunning' ] = 0 ; // clear upgrade indicator
if ( connection_aborted ()) {
die ;
}
@ ignore_user_abort ( false );
}
/**
* Callback function for logging into files . Not more than one file is created per minute ,
* upgrade session ( terminated by upgrade_log_finish ()) is always stored in one file .
*
* This function must not output any characters or throw warnigns and errors !
*/
function upgrade_log_callback ( $string ) {
2006-08-17 23:50:18 +00:00
global $CFG , $upgradeloghandle , $upgradelogbuffer ;
2006-08-01 07:46:19 +00:00
if ( empty ( $CFG -> disableupgradelogging ) and ( $string != '' ) and ( $upgradeloghandle !== 'error' )) {
if ( $upgradeloghandle or ( $upgradeloghandle = @ fopen ( $CFG -> dataroot . '/upgradelogs/upg_' . date ( 'Ymd-Hi' ) . '.html' , 'a' ))) {
2006-08-17 23:50:18 +00:00
$upgradelogbuffer .= $string ;
if ( strlen ( $upgradelogbuffer ) > 2048 ) { // 2kB write buffer
@ fwrite ( $upgradeloghandle , $upgradelogbuffer );
$upgradelogbuffer = '' ;
}
2006-08-01 07:46:19 +00:00
} else {
$upgradeloghandle = 'error' ;
}
}
return $string ;
}
2006-08-28 20:11:24 +00:00
/**
* Try to verify that dataroot is not accessible from web .
* It is not 100 % correct but might help to reduce number of vulnerable sites .
*
* Protection from httpd . conf and . htaccess is not detected properly .
*/
function is_dataroot_insecure () {
global $CFG ;
$siteroot = str_replace ( '\\' , '/' , strrev ( $CFG -> dirroot . '/' )); // win32 backslash workaround
$rp = preg_replace ( '|https?://[^/]+|i' , '' , $CFG -> wwwroot , 1 );
$rp = strrev ( trim ( $rp , '/' ));
$rp = explode ( '/' , $rp );
foreach ( $rp as $r ) {
if ( strpos ( $siteroot , '/' . $r . '/' ) === 0 ) {
$siteroot = substr ( $siteroot , strlen ( $r ) + 1 ); // moodle web in subdirectory
} else {
break ; // probably alias root
}
}
$siteroot = strrev ( $siteroot );
$dataroot = str_replace ( '\\' , '/' , $CFG -> dataroot . '/' );
if ( strpos ( $dataroot , $siteroot ) === 0 ) {
return true ;
}
return false ;
}
2006-09-02 13:14:57 +00:00
/// =============================================================================================================
/// administration tree classes and functions
// n.b. documentation is still in progress for this code
/// INTRODUCTION
/// This file performs the following tasks:
/// -it defines the necessary objects and interfaces to build the Moodle
/// admin hierarchy
2006-09-20 21:00:45 +00:00
/// -it defines the admin_externalpage_setup(), admin_externalpage_print_header(),
2006-09-02 13:14:57 +00:00
/// and admin_externalpage_print_footer() functions used on admin pages
/// ADMIN_SETTING OBJECTS
2006-09-20 21:00:45 +00:00
/// Moodle settings are represented by objects that inherit from the admin_setting
2006-09-02 13:14:57 +00:00
/// class. These objects encapsulate how to read a setting, how to write a new value
/// to a setting, and how to appropriately display the HTML to modify the setting.
/// ADMIN_SETTINGPAGE OBJECTS
/// The admin_setting objects are then grouped into admin_settingpages. The latter
/// appear in the Moodle admin tree block. All interaction with admin_settingpage
/// objects is handled by the admin/settings.php file.
/// ADMIN_EXTERNALPAGE OBJECTS
/// There are some settings in Moodle that are too complex to (efficiently) handle
/// with admin_settingpages. (Consider, for example, user management and displaying
/// lists of users.) In this case, we use the admin_externalpage object. This object
/// places a link to an external PHP file in the admin tree block.
/// If you're using an admin_externalpage object for some settings, you can take
/// advantage of the admin_externalpage_* functions. For example, suppose you wanted
/// to add a foo.php file into admin. First off, you add the following line to
/// admin/settings/first.php (at the end of the file) or to some other file in
/// admin/settings:
2006-09-20 21:00:45 +00:00
/// $ADMIN->add('userinterface', new admin_externalpage('foo', get_string('foo'),
2006-09-02 13:14:57 +00:00
/// $CFG->wwwdir . '/' . '$CFG->admin . '/foo.php', 'some_role_permission'));
/// Next, in foo.php, your file structure would resemble the following:
/// require_once('.../config.php');
/// require_once($CFG->libdir.'/adminlib.php');
2007-04-30 17:08:34 +00:00
/// admin_externalpage_setup('foo');
2006-09-02 13:14:57 +00:00
/// // functionality like processing form submissions goes here
2007-04-30 17:08:34 +00:00
/// admin_externalpage_print_header();
2006-09-02 13:14:57 +00:00
/// // your HTML goes here
2007-04-30 17:08:34 +00:00
/// admin_externalpage_print_footer();
2006-09-02 13:14:57 +00:00
/// The admin_externalpage_setup() function call ensures the user is logged in,
/// and makes sure that they have the proper role permission to access the page.
/// The admin_externalpage_print_header() function prints the header (it figures
/// out what category and subcategories the page is classified under) and ensures
/// that you're using the admin pagelib (which provides the admin tree block and
/// the admin bookmarks block).
/// The admin_externalpage_print_footer() function properly closes the tables
/// opened up by the admin_externalpage_print_header() function and prints the
/// standard Moodle footer.
/// ADMIN_CATEGORY OBJECTS
/// Above and beyond all this, we have admin_category objects. These objects
/// appear as folders in the admin tree block. They contain admin_settingpage's,
/// admin_externalpage's, and other admin_category's.
/// OTHER NOTES
/// admin_settingpage's, admin_externalpage's, and admin_category's all inherit
/// from part_of_admin_tree (a pseudointerface). This interface insists that
/// a class has a check_access method for access permissions, a locate method
/// used to find a specific node in the admin tree, and a path method used
/// to determine the path to a specific node in the $ADMIN tree.
/// admin_category's inherit from parentable_part_of_admin_tree. This pseudo-
/// interface ensures that the class implements a recursive add function which
/// accepts a part_of_admin_tree object and searches for the proper place to
/// put it. parentable_part_of_admin_tree implies part_of_admin_tree.
/// Please note that the $this->name field of any part_of_admin_tree must be
/// UNIQUE throughout the ENTIRE admin tree.
/// The $this->name field of an admin_setting object (which is *not* part_of_
/// admin_tree) must be unique on the respective admin_settingpage where it is
/// used.
/// MISCELLANEOUS STUFF (used by classes defined below) ///////////////////////
include_once ( $CFG -> dirroot . '/backup/lib.php' );
/// CLASS DEFINITIONS /////////////////////////////////////////////////////////
/**
* Pseudointerface for anything appearing in the admin tree
*
* The pseudointerface that is implemented by anything that appears in the admin tree
* block . It forces inheriting classes to define a method for checking user permissions
* and methods for finding something in the admin tree .
*
* @ author Vincenzo K . Marcovecchio
* @ package admin
*/
class part_of_admin_tree {
/**
* Finds a named part_of_admin_tree .
*
* Used to find a part_of_admin_tree . If a class only inherits part_of_admin_tree
* and not parentable_part_of_admin_tree , then this function should only check if
* $this -> name matches $name . If it does , it should return a reference to $this ,
* otherwise , it should return a reference to NULL .
*
* If a class inherits parentable_part_of_admin_tree , this method should be called
* recursively on all child objects ( assuming , of course , the parent object ' s name
* doesn ' t match the search criterion ) .
*
* @ param string $name The internal name of the part_of_admin_tree we ' re searching for .
* @ return mixed An object reference or a NULL reference .
*/
2006-09-20 21:00:45 +00:00
function & locate ( $name ) {
trigger_error ( 'Admin class does not implement method <strong>locate()</strong>' , E_USER_WARNING );
return ;
2006-09-02 13:14:57 +00:00
}
2006-09-02 19:30:54 +00:00
/**
* Removes named part_of_admin_tree .
*
* @ param string $name The internal name of the part_of_admin_tree we want to remove .
2006-09-24 20:23:40 +00:00
* @ return bool success .
2006-09-02 19:30:54 +00:00
*/
function prune ( $name ) {
2006-09-20 21:00:45 +00:00
trigger_error ( 'Admin class does not implement method <strong>prune()</strong>' , E_USER_WARNING );
2006-09-02 19:30:54 +00:00
return ;
2006-09-20 21:00:45 +00:00
}
2006-09-02 19:30:54 +00:00
2006-09-02 13:14:57 +00:00
/**
* Verifies current user ' s access to this part_of_admin_tree .
*
* Used to check if the current user has access to this part of the admin tree or
* not . If a class only inherits part_of_admin_tree and not parentable_part_of_admin_tree ,
* then this method is usually just a call to has_capability () in the site context .
*
* If a class inherits parentable_part_of_admin_tree , this method should return the
* logical OR of the return of check_access () on all child objects .
*
* @ return bool True if the user has access , false if she doesn ' t .
*/
2006-09-20 21:00:45 +00:00
function check_access () {
trigger_error ( 'Admin class does not implement method <strong>check_access()</strong>' , E_USER_WARNING );
return ;
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-24 20:23:40 +00:00
/**
* Mostly usefull for removing of some parts of the tree in admin tree block .
*
* @ return True is hidden from normal list view
*/
function is_hidden () {
trigger_error ( 'Admin class does not implement method <strong>is_hidden()</strong>' , E_USER_WARNING );
return ;
}
2006-09-02 13:14:57 +00:00
/**
* Determines the path to $name in the admin tree .
*
* Used to determine the path to $name in the admin tree . If a class inherits only
* part_of_admin_tree and not parentable_part_of_admin_tree , then this method should
* check if $this -> name matches $name . If it does , $name is pushed onto the $path
* array ( at the end ), and $path should be returned . If it doesn ' t , NULL should be
* returned .
*
* If a class inherits parentable_part_of_admin_tree , it should do the above , but not
* return NULL on failure . Instead , it pushes $this -> name onto $path , and then
* recursively calls path () on its child objects . If any are non - NULL , it should
* return $path ( being certain that the last element of $path is equal to $name ) .
* If they are all NULL , it returns NULL .
*
* @ param string $name The internal name of the part_of_admin_tree we ' re searching for .
* @ param array $path Not used on external calls . Defaults to empty array .
* @ return mixed If found , an array containing the internal names of each part_of_admin_tree that leads to $name . If not found , NULL .
*/
2006-09-20 21:00:45 +00:00
function path ( $name , $path = array ()) {
trigger_error ( 'Admin class does not implement method <strong>path()</strong>' , E_USER_WARNING );
return ;
2006-09-02 13:14:57 +00:00
}
}
/**
* Pseudointerface implemented by any part_of_admin_tree that has children .
*
* The pseudointerface implemented by any part_of_admin_tree that can be a parent
* to other part_of_admin_tree ' s . ( For now , this only includes admin_category . ) Apart
2006-09-20 21:00:45 +00:00
* from ensuring part_of_admin_tree compliancy , it also ensures inheriting methods
2006-09-02 13:14:57 +00:00
* include an add method for adding other part_of_admin_tree objects as children .
*
* @ author Vincenzo K . Marcovecchio
* @ package admin
*/
class parentable_part_of_admin_tree extends part_of_admin_tree {
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
/**
* Adds a part_of_admin_tree object to the admin tree .
*
* Used to add a part_of_admin_tree object to this object or a child of this
* object . $something should only be added if $destinationname matches
* $this -> name . If it doesn ' t , add should be called on child objects that are
* also parentable_part_of_admin_tree ' s .
*
* @ param string $destinationname The internal name of the new parent for $something .
* @ param part_of_admin_tree & $something The object to be added .
* @ return bool True on success , false on failure .
*/
2006-09-20 21:00:45 +00:00
function add ( $destinationname , & $something ) {
trigger_error ( 'Admin class does not implement method <strong>add()</strong>' , E_USER_WARNING );
return ;
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
/**
* The object used to represent folders ( a . k . a . categories ) in the admin tree block .
2006-09-20 21:00:45 +00:00
*
2006-09-02 13:14:57 +00:00
* Each admin_category object contains a number of part_of_admin_tree objects .
*
* @ author Vincenzo K . Marcovecchio
* @ package admin
*/
class admin_category extends parentable_part_of_admin_tree {
/**
* @ var mixed An array of part_of_admin_tree objects that are this object ' s children
*/
var $children ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
/**
* @ var string An internal name for this category . Must be unique amongst ALL part_of_admin_tree objects
*/
var $name ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
/**
* @ var string The displayed name for this category . Usually obtained through get_string ()
*/
var $visiblename ;
2006-09-20 21:00:45 +00:00
2006-09-24 20:23:40 +00:00
/**
* @ var bool Should this category be hidden in admin tree block ?
*/
var $hidden ;
2006-09-02 13:14:57 +00:00
// constructor for an empty admin category
// $name is the internal name of the category. it MUST be unique in the entire hierarchy
// $visiblename is the displayed name of the category. use a get_string for this
/**
* Constructor for an empty admin category
*
* @ param string $name The internal name for this category . Must be unique amongst ALL part_of_admin_tree objects
* @ param string $visiblename The displayed named for this category . Usually obtained through get_string ()
2006-09-24 20:23:40 +00:00
* @ param bool $hidden hide category in admin tree block
2006-09-02 13:14:57 +00:00
* @ return mixed Returns the new object .
*/
2006-09-24 20:23:40 +00:00
function admin_category ( $name , $visiblename , $hidden = false ) {
2006-09-02 13:14:57 +00:00
$this -> children = array ();
$this -> name = $name ;
$this -> visiblename = $visiblename ;
2006-09-24 20:23:40 +00:00
$this -> hidden = $hidden ;
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
/**
* Finds the path to the part_of_admin_tree called $name .
*
* @ param string $name The internal name that we ' re searching for .
* @ param array $path Used internally for recursive calls . Do not specify on external calls . Defaults to array () .
* @ return mixed An array of internal names that leads to $name , or NULL if not found .
*/
function path ( $name , $path = array ()) {
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
$path [ count ( $path )] = $this -> name ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
if ( $this -> name == $name ) {
return $path ;
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
foreach ( $this -> children as $child ) {
if ( $return = $child -> path ( $name , $path )) {
return $return ;
}
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
return NULL ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
/**
* Returns a reference to the part_of_admin_tree object with internal name $name .
*
* @ param string $name The internal name of the object we want .
* @ return mixed A reference to the object with internal name $name if found , otherwise a reference to NULL .
*/
function & locate ( $name ) {
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
if ( $this -> name == $name ) {
return $this ;
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
foreach ( $this -> children as $child ) {
if ( $return =& $child -> locate ( $name )) {
return $return ;
}
}
$return = NULL ;
return $return ;
}
2006-09-02 19:30:54 +00:00
/**
* Removes part_of_admin_tree object with internal name $name .
*
* @ param string $name The internal name of the object we want to remove .
2006-09-24 20:23:40 +00:00
* @ return bool success
2006-09-02 19:30:54 +00:00
*/
function prune ( $name ) {
if ( $this -> name == $name ) {
return false ; //can not remove itself
}
foreach ( $this -> children as $precedence => $child ) {
if ( $child -> name == $name ) {
// found it!
2006-09-20 21:00:45 +00:00
unset ( $this -> children [ $precedence ]);
2006-09-02 19:30:54 +00:00
return true ;
}
if ( $this -> children [ $precedence ] -> prune ( $name )) {
return true ;
}
}
return false ;
}
2006-09-02 13:14:57 +00:00
/**
* Adds a part_of_admin_tree to a child or grandchild ( or great - grandchild , and so forth ) of this object .
*
* @ param string $destinationame The internal name of the immediate parent that we want for & $something .
* @ param mixed & $something A part_of_admin_tree object to be added .
* @ param int $precedence The precedence of & $something when displayed . Smaller numbers mean it 'll be displayed higher up in the admin menu. Defaults to ' ' , meaning " next available position " .
* @ return bool True if successfully added , false if & $something is not a part_of_admin_tree or if $name is not found .
*/
function add ( $destinationname , & $something , $precedence = '' ) {
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
if ( ! is_a ( $something , 'part_of_admin_tree' )) {
return false ;
}
if ( $destinationname == $this -> name ) {
if ( $precedence === '' ) {
$this -> children [] = $something ;
} else {
if ( isset ( $this -> children [ $precedence ])) { // this should never, ever be triggered in a release version of moodle.
echo ( '<font style="color: red;">There is a precedence conflict in the category ' . $this -> name . '. The object named ' . $something -> name . ' is overwriting the object named ' . $this -> children [ $precedence ] -> name . '.</font><br />' );
}
$this -> children [ $precedence ] = $something ;
}
return true ;
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
unset ( $entries );
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
$entries = array_keys ( $this -> children );
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
foreach ( $entries as $entry ) {
$child =& $this -> children [ $entry ];
if ( is_a ( $child , 'parentable_part_of_admin_tree' )) {
if ( $child -> add ( $destinationname , $something , $precedence )) {
return true ;
}
}
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
return false ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
/**
* Checks if the user has access to anything in this category .
*
* @ return bool True if the user has access to atleast one child in this category , false otherwise .
*/
function check_access () {
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
$return = false ;
foreach ( $this -> children as $child ) {
$return = $return || $child -> check_access ();
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
return $return ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-24 20:23:40 +00:00
/**
* Is this category hidden in admin tree block ?
*
* @ return bool True if hidden
*/
function is_hidden () {
return $this -> hidden ;
}
2006-09-02 13:14:57 +00:00
}
/**
* Links external PHP pages into the admin tree .
*
* See detailed usage example at the top of this document ( adminlib . php )
*
* @ author Vincenzo K . Marcovecchio
* @ package admin
*/
class admin_externalpage extends part_of_admin_tree {
2006-09-20 21:00:45 +00:00
/**
2006-09-02 13:14:57 +00:00
* @ var string An internal name for this external page . Must be unique amongst ALL part_of_admin_tree objects
*/
var $name ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
/**
* @ var string The displayed name for this external page . Usually obtained through get_string () .
*/
var $visiblename ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
/**
* @ var string The external URL that we should link to when someone requests this external page .
*/
var $url ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
/**
* @ var string The role capability / permission a user must have to access this external page .
*/
2006-09-21 08:18:14 +00:00
var $req_capability ;
2006-09-20 21:00:45 +00:00
2007-01-29 21:29:27 +00:00
/**
* @ var object The context in which capability / permission should be checked , default is site context .
*/
var $context ;
2006-09-24 20:23:40 +00:00
/**
* @ var bool hidden in admin tree block .
*/
var $hidden ;
2006-09-02 13:14:57 +00:00
/**
* Constructor for adding an external page into the admin tree .
*
* @ param string $name The internal name for this external page . Must be unique amongst ALL part_of_admin_tree objects .
* @ param string $visiblename The displayed name for this external page . Usually obtained through get_string () .
* @ param string $url The external URL that we should link to when someone requests this external page .
2006-09-24 11:55:11 +00:00
* @ param mixed $req_capability The role capability / permission a user must have to access this external page . Defaults to 'moodle/site:config' .
2006-09-02 13:14:57 +00:00
*/
2007-01-30 10:33:09 +00:00
function admin_externalpage ( $name , $visiblename , $url , $req_capability = 'moodle/site:config' , $hidden = false , $context = NULL ) {
2006-09-02 13:14:57 +00:00
$this -> name = $name ;
$this -> visiblename = $visiblename ;
$this -> url = $url ;
2006-09-24 11:55:11 +00:00
if ( is_array ( $req_capability )) {
$this -> req_capability = $req_capability ;
} else {
$this -> req_capability = array ( $req_capability );
}
2006-09-24 20:23:40 +00:00
$this -> hidden = $hidden ;
2007-01-29 21:29:27 +00:00
$this -> context = $context ;
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
/**
* Finds the path to the part_of_admin_tree called $name .
*
* @ param string $name The internal name that we ' re searching for .
* @ param array $path Used internally for recursive calls . Do not specify on external calls . Defaults to array () .
* @ return mixed An array of internal names that leads to $name , or NULL if not found .
*/
function path ( $name , $path = array ()) {
if ( $name == $this -> name ) {
array_push ( $path , $this -> name );
return $path ;
} else {
return NULL ;
}
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
/**
* Returns a reference to the part_of_admin_tree object with internal name $name .
*
* @ param string $name The internal name of the object we want .
* @ return mixed A reference to the object with internal name $name if found , otherwise a reference to NULL .
*/
function & locate ( $name ) {
$return = ( $this -> name == $name ? $this : NULL );
return $return ;
}
2006-09-02 19:30:54 +00:00
function prune ( $name ) {
return false ;
}
2006-09-02 13:14:57 +00:00
/**
2006-09-21 08:18:14 +00:00
* Determines if the current user has access to this external page based on $this -> req_capability .
2006-09-02 13:14:57 +00:00
*
* @ uses CONTEXT_SYSTEM
* @ uses SITEID
* @ return bool True if user has access , false otherwise .
*/
function check_access () {
if ( ! get_site ()) {
return true ; // no access check before site is fully set up
}
2007-01-29 21:29:27 +00:00
$context = empty ( $this -> context ) ? get_context_instance ( CONTEXT_SYSTEM ) : $this -> context ;
2006-09-24 11:55:11 +00:00
foreach ( $this -> req_capability as $cap ) {
if ( has_capability ( $cap , $context )) {
return true ;
}
}
return false ;
2006-09-02 13:14:57 +00:00
}
2006-09-24 20:23:40 +00:00
/**
* Is this external page hidden in admin tree block ?
*
* @ return bool True if hidden
*/
function is_hidden () {
return $this -> hidden ;
}
2006-09-02 13:14:57 +00:00
}
/**
* Used to group a number of admin_setting objects into a page and add them to the admin tree .
*
* @ author Vincenzo K . Marcovecchio
* @ package admin
*/
class admin_settingpage extends part_of_admin_tree {
2006-09-20 21:00:45 +00:00
/**
2006-09-02 13:14:57 +00:00
* @ var string An internal name for this external page . Must be unique amongst ALL part_of_admin_tree objects
*/
var $name ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
/**
* @ var string The displayed name for this external page . Usually obtained through get_string () .
*/
var $visiblename ;
/**
* @ var mixed An array of admin_setting objects that are part of this setting page .
*/
var $settings ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
/**
* @ var string The role capability / permission a user must have to access this external page .
*/
2006-09-21 08:18:14 +00:00
var $req_capability ;
2006-09-20 21:00:45 +00:00
2007-01-29 21:29:27 +00:00
/**
* @ var object The context in which capability / permission should be checked , default is site context .
*/
var $context ;
2006-09-24 20:23:40 +00:00
/**
* @ var bool hidden in admin tree block .
*/
var $hidden ;
2006-09-02 13:14:57 +00:00
// see admin_category
function path ( $name , $path = array ()) {
if ( $name == $this -> name ) {
array_push ( $path , $this -> name );
return $path ;
} else {
return NULL ;
}
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
// see admin_category
function & locate ( $name ) {
$return = ( $this -> name == $name ? $this : NULL );
return $return ;
}
2006-09-02 19:30:54 +00:00
function prune ( $name ) {
return false ;
}
2006-09-02 13:14:57 +00:00
// see admin_externalpage
2007-01-30 10:33:09 +00:00
function admin_settingpage ( $name , $visiblename , $req_capability = 'moodle/site:config' , $hidden = false , $context = NULL ) {
2006-09-02 13:14:57 +00:00
global $CFG ;
$this -> settings = new stdClass ();
$this -> name = $name ;
$this -> visiblename = $visiblename ;
2006-09-24 11:55:11 +00:00
if ( is_array ( $req_capability )) {
$this -> req_capability = $req_capability ;
} else {
$this -> req_capability = array ( $req_capability );
}
2006-09-24 20:23:40 +00:00
$this -> hidden = false ;
2007-01-29 21:29:27 +00:00
$this -> context = $context ;
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
// not the same as add for admin_category. adds an admin_setting to this admin_settingpage. settings appear (on the settingpage) in the order in which they're added
// n.b. each admin_setting in an admin_settingpage must have a unique internal name
// &$setting is the admin_setting object you want to add
// returns true if successful, false if not (will fail if &$setting is an admin_setting or child thereof)
function add ( & $setting ) {
if ( is_a ( $setting , 'admin_setting' )) {
$this -> settings -> { $setting -> name } =& $setting ;
return true ;
}
return false ;
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
// see admin_externalpage
function check_access () {
if ( ! get_site ()) {
return true ; // no access check before site is fully set up
}
2007-01-29 21:29:27 +00:00
$context = empty ( $this -> context ) ? get_context_instance ( CONTEXT_SYSTEM ) : $this -> context ;
2006-09-24 11:55:11 +00:00
foreach ( $this -> req_capability as $cap ) {
if ( has_capability ( $cap , $context )) {
return true ;
}
}
return false ;
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
// outputs this page as html in a table (suitable for inclusion in an admin pagetype)
// returns a string of the html
function output_html () {
2006-09-27 07:49:34 +00:00
$return = '<fieldset>' . " \n " ;
2006-09-25 07:35:43 +00:00
$return .= '<div class="clearer"><!-- --></div>' . " \n " ;
2006-09-02 13:14:57 +00:00
foreach ( $this -> settings as $setting ) {
2006-09-27 07:49:34 +00:00
$return .= $setting -> output_html ();
2006-09-02 13:14:57 +00:00
}
2006-09-25 07:35:43 +00:00
$return .= '</fieldset>' ;
2006-09-02 13:14:57 +00:00
return $return ;
}
// writes settings (the ones that have been added to this admin_settingpage) to the database, or wherever else they're supposed to be written to
// -- calls write_setting() to each child setting, sending it only the data that matches each setting's internal name
// $data should be the result from data_submitted()
// returns an empty string if everything went well, otherwise returns a printable error string (that's language-specific)
function write_settings ( $data ) {
$return = '' ;
foreach ( $this -> settings as $setting ) {
if ( isset ( $data [ 's_' . $setting -> name ])) {
$return .= $setting -> write_setting ( $data [ 's_' . $setting -> name ]);
} else {
$return .= $setting -> write_setting ( '' );
}
}
return $return ;
}
2006-09-24 20:23:40 +00:00
/**
* Is this settigns page hidden in admin tree block ?
*
* @ return bool True if hidden
*/
function is_hidden () {
return $this -> hidden ;
}
2006-09-02 13:14:57 +00:00
}
// read & write happens at this level; no authentication
class admin_setting {
var $name ;
var $visiblename ;
var $description ;
var $defaultsetting ;
function admin_setting ( $name , $visiblename , $description , $defaultsetting ) {
$this -> name = $name ;
$this -> visiblename = $visiblename ;
$this -> description = $description ;
$this -> defaultsetting = $defaultsetting ;
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function get_setting () {
return NULL ; // has to be overridden
}
2006-09-20 21:00:45 +00:00
2007-10-02 21:38:53 +00:00
function get_defaultsetting () {
return $this -> defaultsetting ;
}
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
return ; // has to be overridden
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function output_html () {
return ; // has to be overridden
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
class admin_setting_configtext extends admin_setting {
var $paramtype ;
2006-09-03 13:10:56 +00:00
function admin_setting_configtext ( $name , $visiblename , $description , $defaultsetting , $paramtype = PARAM_RAW ) {
2006-09-02 13:14:57 +00:00
$this -> paramtype = $paramtype ;
parent :: admin_setting ( $name , $visiblename , $description , $defaultsetting );
}
2006-09-18 02:41:14 +00:00
// returns a string or NULL
2006-09-02 13:14:57 +00:00
function get_setting () {
global $CFG ;
2006-09-17 12:11:23 +00:00
return ( isset ( $CFG -> { $this -> name }) ? $CFG -> { $this -> name } : NULL );
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-18 02:41:14 +00:00
// $data is a string
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
2006-09-26 08:16:17 +00:00
if ( ! $this -> validate ( $data )) {
return get_string ( 'validateerror' , 'admin' ) . $this -> visiblename . '<br />' ;
2006-09-11 05:06:38 +00:00
}
2006-09-02 13:14:57 +00:00
return ( set_config ( $this -> name , $data ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
2006-09-11 05:06:38 +00:00
function validate ( $data ) {
2006-09-26 08:16:17 +00:00
if ( is_string ( $this -> paramtype )) {
return preg_match ( $this -> paramtype , $data );
} else if ( $this -> paramtype === PARAM_RAW ) {
return true ;
} else {
$cleaned = clean_param ( $data , $this -> paramtype );
return ( " $data " == " $cleaned " ); // implicit conversion to string is needed to do exact comparison
}
2006-09-11 05:06:38 +00:00
}
2006-09-02 13:14:57 +00:00
function output_html () {
2006-09-17 12:11:23 +00:00
if ( $this -> get_setting () === NULL ) {
$current = $this -> defaultsetting ;
} else {
$current = $this -> get_setting ();
}
2006-09-26 08:16:17 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename ,
2006-11-23 20:59:18 +00:00
'<input type="text" class="form-text" id="id_s_' . $this -> name . '" name="s_' . $this -> name . '" value="' . s ( $current ) . '" />' ,
2006-09-25 07:35:43 +00:00
$this -> description );
2006-09-02 13:14:57 +00:00
}
}
2007-04-30 18:03:19 +00:00
class admin_setting_configpasswordunmask extends admin_setting_configtext {
2007-04-26 07:08:12 +00:00
2007-04-30 18:03:19 +00:00
function admin_setting_configpasswordunmask ( $name , $visiblename , $description , $defaultsetting , $paramtype = PARAM_RAW ) {
2007-04-26 07:08:12 +00:00
parent :: admin_setting_configtext ( $name , $visiblename , $description , $defaultsetting , $paramtype );
}
function output_html () {
if ( $this -> get_setting () === NULL ) {
$current = $this -> defaultsetting ;
} else {
$current = $this -> get_setting ();
}
$id = 'id_s_' . $this -> name ;
2007-04-30 18:03:19 +00:00
$unmask = get_string ( 'unmaskpassword' , 'form' );
$unmaskjs = ' < script type = " text/javascript " >
2007-04-26 07:08:12 +00:00
//<![CDATA[
2007-04-30 18:03:19 +00:00
document . write ( \ '<div class="unmask"><input id="' . $id . 'unmask" value="1" type="checkbox" onclick="unmaskPassword(\\\'' . $id . '\\\')"/><label for="' . $id . 'unmask">' . addslashes_js ( $unmask ) . ' < \ / label >< \ / div > \ ' );
2007-04-26 07:08:12 +00:00
//]]>
</ script > ' ;
return format_admin_setting ( $this -> name , $this -> visiblename ,
2007-04-30 18:03:19 +00:00
'<input type="password" class="form-text" id="id_s_' . $this -> name . '" name="s_' . $this -> name . '" value="' . s ( $current ) . '" />' . $unmaskjs ,
2007-04-26 07:08:12 +00:00
$this -> description );
}
2007-07-27 13:38:06 +00:00
2007-04-26 07:08:12 +00:00
}
2006-09-02 13:14:57 +00:00
class admin_setting_configcheckbox extends admin_setting {
function admin_setting_configcheckbox ( $name , $visiblename , $description , $defaultsetting ) {
parent :: admin_setting ( $name , $visiblename , $description , $defaultsetting );
}
function get_setting () {
global $CFG ;
return ( isset ( $CFG -> { $this -> name }) ? $CFG -> { $this -> name } : NULL );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
if ( $data == '1' ) {
return ( set_config ( $this -> name , 1 ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
} else {
return ( set_config ( $this -> name , 0 ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
}
function output_html () {
2006-09-17 12:11:23 +00:00
if ( $this -> get_setting () === NULL ) {
$current = $this -> defaultsetting ;
} else {
$current = $this -> get_setting ();
}
2006-09-26 08:16:17 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename ,
2006-09-25 08:33:10 +00:00
'<input type="checkbox" class="form-checkbox" id="id_s_' . $this -> name . '" name="s_' . $this -> name . '" value="1" ' . ( $current == true ? 'checked="checked"' : '' ) . ' />' ,
2006-09-25 07:35:43 +00:00
$this -> description );
2006-09-02 13:14:57 +00:00
}
}
class admin_setting_configselect extends admin_setting {
var $choices ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function admin_setting_configselect ( $name , $visiblename , $description , $defaultsetting , $choices ) {
$this -> choices = $choices ;
parent :: admin_setting ( $name , $visiblename , $description , $defaultsetting );
}
function get_setting () {
global $CFG ;
return ( isset ( $CFG -> { $this -> name }) ? $CFG -> { $this -> name } : NULL );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
// check that what we got was in the original choices
// or that the data is the default setting - needed during install when choices can not be constructed yet
if ( $data != $this -> defaultsetting and ! in_array ( $data , array_keys ( $this -> choices ))) {
return 'Error setting ' . $this -> visiblename . '<br />' ;
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
return ( set_config ( $this -> name , $data ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function output_html () {
2006-09-17 12:11:23 +00:00
if ( $this -> get_setting () === NULL ) {
$current = $this -> defaultsetting ;
} else {
$current = $this -> get_setting ();
}
2006-09-25 08:20:14 +00:00
$return = '<select class="form-select" id="id_s_' . $this -> name . '" name="s_' . $this -> name . '">' ;
2006-09-02 13:14:57 +00:00
foreach ( $this -> choices as $key => $value ) {
2006-09-30 19:46:10 +00:00
// the string cast is needed because key may be integer - 0 is equal to most strings!
$return .= '<option value="' . $key . '"' . (( string ) $key == $current ? ' selected="selected"' : '' ) . '>' . $value . '</option>' ;
2006-09-02 13:14:57 +00:00
}
2006-09-25 07:35:43 +00:00
$return .= '</select>' ;
2006-09-25 14:18:16 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description );
2006-09-02 13:14:57 +00:00
}
}
// this is a liiitle bit messy. we're using two selects, but we're returning them as an array named after $name (so we only use $name2
// internally for the setting)
class admin_setting_configtime extends admin_setting {
var $name2 ;
var $choices ;
var $choices2 ;
function admin_setting_configtime ( $hoursname , $minutesname , $visiblename , $description , $defaultsetting ) {
$this -> name2 = $minutesname ;
$this -> choices = array ();
for ( $i = 0 ; $i < 24 ; $i ++ ) {
$this -> choices [ $i ] = $i ;
}
$this -> choices2 = array ();
for ( $i = 0 ; $i < 60 ; $i += 5 ) {
$this -> choices2 [ $i ] = $i ;
}
parent :: admin_setting ( $hoursname , $visiblename , $description , $defaultsetting );
}
function get_setting () {
global $CFG ;
2006-09-18 02:41:14 +00:00
return ( isset ( $CFG -> { $this -> name }) && isset ( $CFG -> { $this -> name2 }) ? array ( 'h' => $CFG -> { $this -> name }, 'm' => $CFG -> { $this -> name2 }) : NULL );
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
// check that what we got was in the original choices
if ( ! ( in_array ( $data [ 'h' ], array_keys ( $this -> choices )) && in_array ( $data [ 'm' ], array_keys ( $this -> choices2 )))) {
return get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' ;
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
return ( set_config ( $this -> name , $data [ 'h' ]) && set_config ( $this -> name2 , $data [ 'm' ]) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function output_html () {
2006-09-18 02:41:14 +00:00
if ( $this -> get_setting () === NULL ) {
$currentsetting = $this -> defaultsetting ;
} else {
$currentsetting = $this -> get_setting ();
2006-09-02 13:14:57 +00:00
}
2006-09-25 12:48:07 +00:00
$return = '<div class="form-group">' .
'<select class="form-select" id="id_s_' . $this -> name . 'h" name="s_' . $this -> name . '[h]">' ;
2006-09-02 13:14:57 +00:00
foreach ( $this -> choices as $key => $value ) {
2006-09-18 02:41:14 +00:00
$return .= '<option value="' . $key . '"' . ( $key == $currentsetting [ 'h' ] ? ' selected="selected"' : '' ) . '>' . $value . '</option>' ;
2006-09-02 13:14:57 +00:00
}
2006-09-25 12:48:07 +00:00
$return .= '</select>:<select class="form-select" id="id_s_' . $this -> name . 'm" name="s_' . $this -> name . '[m]">' ;
2006-09-02 13:14:57 +00:00
foreach ( $this -> choices2 as $key => $value ) {
2006-09-18 02:41:14 +00:00
$return .= '<option value="' . $key . '"' . ( $key == $currentsetting [ 'm' ] ? ' selected="selected"' : '' ) . '>' . $value . '</option>' ;
2006-09-20 21:00:45 +00:00
}
2006-09-25 12:48:07 +00:00
$return .= '</select></div>' ;
2007-02-06 08:24:37 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description , false );
2006-09-02 13:14:57 +00:00
}
}
class admin_setting_configmultiselect extends admin_setting_configselect {
function admin_setting_configmultiselect ( $name , $visiblename , $description , $defaultsetting , $choices ) {
parent :: admin_setting_configselect ( $name , $visiblename , $description , $defaultsetting , $choices );
}
function get_setting () {
global $CFG ;
2007-01-12 18:30:27 +00:00
if ( isset ( $CFG -> { $this -> name })) {
if ( $CFG -> { $this -> name }) {
return explode ( ',' , $CFG -> { $this -> name });
} else {
return array ();
2007-07-27 13:38:06 +00:00
}
2007-01-12 18:30:27 +00:00
} else {
return NULL ;
}
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
2007-01-12 18:30:27 +00:00
if ( empty ( $data )) {
$data = array ();
}
2006-09-02 13:14:57 +00:00
foreach ( $data as $datum ) {
if ( ! in_array ( $datum , array_keys ( $this -> choices ))) {
return get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' ;
}
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
return ( set_config ( $this -> name , implode ( ',' , $data )) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function output_html () {
2006-09-18 02:41:14 +00:00
if ( $this -> get_setting () === NULL ) {
$currentsetting = $this -> defaultsetting ;
2007-01-12 18:51:36 +00:00
if ( ! $currentsetting ) {
$currentsetting = array ();
}
2006-09-18 02:41:14 +00:00
} else {
$currentsetting = $this -> get_setting ();
2006-09-02 13:14:57 +00:00
}
2006-09-25 08:20:14 +00:00
$return = '<select class="form-select" id="id_s_' . $this -> name . '" name="s_' . $this -> name . '[]" size="10" multiple="multiple">' ;
2006-09-02 13:14:57 +00:00
foreach ( $this -> choices as $key => $value ) {
$return .= '<option value="' . $key . '"' . ( in_array ( $key , $currentsetting ) ? ' selected="selected"' : '' ) . '>' . $value . '</option>' ;
}
2006-09-25 07:35:43 +00:00
$return .= '</select>' ;
2006-09-25 14:18:16 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description );
2006-09-02 13:14:57 +00:00
}
}
class admin_setting_special_adminseesall extends admin_setting_configcheckbox {
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function admin_setting_special_adminseesall () {
$name = 'calendar_adminseesall' ;
$visiblename = get_string ( 'adminseesall' , 'admin' );
$description = get_string ( 'helpadminseesall' , 'admin' );
parent :: admin_setting ( $name , $visiblename , $description , 0 );
}
function write_setting ( $data ) {
global $SESSION ;
unset ( $SESSION -> cal_courses_shown );
parent :: write_setting ( $data );
}
}
class admin_setting_sitesetselect extends admin_setting_configselect {
var $id ;
function admin_setting_sitesetselect ( $name , $visiblename , $description , $defaultsetting , $choices ) {
$this -> id = SITEID ;
parent :: admin_setting_configselect ( $name , $visiblename , $description , $defaultsetting , $choices );
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function get_setting () {
$site = get_site ();
return ( isset ( $site -> { $this -> name }) ? $site -> { $this -> name } : NULL );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
if ( ! in_array ( $data , array_keys ( $this -> choices ))) {
return get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' ;
}
$record = new stdClass ();
$record -> id = $this -> id ;
$temp = $this -> name ;
$record -> $temp = $data ;
$record -> timemodified = time ();
return ( update_record ( 'course' , $record ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
2006-09-02 15:29:52 +00:00
class admin_setting_courselist_frontpage extends admin_setting_configselect {
2006-09-02 13:14:57 +00:00
2006-09-02 15:29:52 +00:00
function admin_setting_courselist_frontpage ( $loggedin ) {
2006-09-02 13:14:57 +00:00
global $CFG ;
require_once ( $CFG -> dirroot . '/course/lib.php' );
$name = 'frontpage' . ( $loggedin ? 'loggedin' : '' );
$visiblename = get_string ( 'frontpage' . ( $loggedin ? 'loggedin' : '' ), 'admin' );
$description = get_string ( 'configfrontpage' . ( $loggedin ? 'loggedin' : '' ), 'admin' );
$choices = array ( FRONTPAGENEWS => get_string ( 'frontpagenews' ),
FRONTPAGECOURSELIST => get_string ( 'frontpagecourselist' ),
FRONTPAGECATEGORYNAMES => get_string ( 'frontpagecategorynames' ),
FRONTPAGECATEGORYCOMBO => get_string ( 'frontpagecategorycombo' ),
'' => get_string ( 'none' ));
2007-01-31 22:38:27 +00:00
if ( ! $loggedin and count_records ( " course " ) > FRONTPAGECOURSELIMIT ) {
2006-09-02 13:14:57 +00:00
unset ( $choices [ FRONTPAGECOURSELIST ]);
}
2006-09-02 19:30:54 +00:00
$defaults = FRONTPAGECOURSELIST . ',,,' ;
2006-09-02 15:29:52 +00:00
parent :: admin_setting_configselect ( $name , $visiblename , $description , $defaults , $choices );
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function get_setting () {
global $CFG ;
2006-09-21 07:38:13 +00:00
return ( isset ( $CFG -> { $this -> name }) ? explode ( ',' , $CFG -> { $this -> name }) : ',1,,' );
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
if ( empty ( $data )) {
$data = array ();
2006-09-02 15:29:52 +00:00
} if ( ! is_array ( $data )) {
$data = explode ( ',' , $data );
2006-09-02 13:14:57 +00:00
}
foreach ( $data as $datum ) {
if ( ! in_array ( $datum , array_keys ( $this -> choices ))) {
return get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' ;
}
}
return ( set_config ( $this -> name , implode ( ',' , $data )) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function output_html () {
2006-09-18 02:41:14 +00:00
if ( $this -> get_setting () === NULL ) {
$currentsetting = $this -> defaultsetting ;
} else {
$currentsetting = $this -> get_setting ();
2006-09-02 13:14:57 +00:00
}
for ( $i = 0 ; $i < count ( $this -> choices ) - 1 ; $i ++ ) {
if ( ! isset ( $currentsetting [ $i ])) {
$currentsetting [ $i ] = 0 ;
}
}
2006-09-25 09:06:51 +00:00
$return = '<div class="form-group">' ;
2006-09-02 13:14:57 +00:00
for ( $i = 0 ; $i < count ( $this -> choices ) - 1 ; $i ++ ) {
2006-09-25 09:32:25 +00:00
$return .= '<select class="form-select" id="id_s_' . $this -> name . $i . '" name="s_' . $this -> name . '[]">' ;
2006-09-02 13:14:57 +00:00
foreach ( $this -> choices as $key => $value ) {
$return .= '<option value="' . $key . '"' . ( $key == $currentsetting [ $i ] ? ' selected="selected"' : '' ) . '>' . $value . '</option>' ;
}
$return .= '</select>' ;
if ( $i !== count ( $this -> choices ) - 2 ) {
2006-09-24 06:47:53 +00:00
$return .= '<br />' ;
2006-09-02 13:14:57 +00:00
}
}
2006-09-25 09:06:51 +00:00
$return .= '</div>' ;
2007-02-06 08:24:37 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description , false );
2006-09-02 13:14:57 +00:00
}
}
class admin_setting_sitesetcheckbox extends admin_setting_configcheckbox {
var $id ;
function admin_setting_sitesetcheckbox ( $name , $visiblename , $description , $defaultsetting ) {
$this -> id = SITEID ;
parent :: admin_setting_configcheckbox ( $name , $visiblename , $description , $defaultsetting );
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function get_setting () {
$site = get_site ();
2007-10-02 21:38:53 +00:00
return $site -> { $this -> name };
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
$record = new stdClass ();
$record -> id = $this -> id ;
$temp = $this -> name ;
$record -> $temp = ( $data == '1' ? 1 : 0 );
$record -> timemodified = time ();
return ( update_record ( 'course' , $record ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
class admin_setting_sitesettext extends admin_setting_configtext {
var $id ;
2006-10-16 07:37:41 +00:00
function admin_setting_sitesettext ( $name , $visiblename , $description , $defaultsetting ) {
2006-09-02 13:14:57 +00:00
$this -> id = SITEID ;
2006-10-16 07:37:41 +00:00
parent :: admin_setting_configtext ( $name , $visiblename , $description , $defaultsetting );
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function get_setting () {
$site = get_site ();
2007-10-02 21:38:53 +00:00
return $site -> { $this -> name } != '' ? $site -> { $this -> name } : NULL ;
2006-09-02 13:14:57 +00:00
}
2006-09-17 06:08:10 +00:00
2006-10-16 07:37:41 +00:00
function validate ( $data ) {
2007-03-21 07:43:04 +00:00
$cleaned = stripslashes ( clean_param ( $data , PARAM_MULTILANG ));
2006-10-16 07:37:41 +00:00
if ( $cleaned == '' ) {
return false ; // can not be empty
}
2007-03-21 07:43:04 +00:00
return ( $data == $cleaned ); // implicit conversion to string is needed to do exact comparison
2006-10-16 07:37:41 +00:00
}
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
2006-10-16 07:37:41 +00:00
$data = trim ( $data );
2006-09-26 08:16:17 +00:00
if ( ! $this -> validate ( $data )) {
return get_string ( 'validateerror' , 'admin' ) . $this -> visiblename . '<br />' ;
2006-09-17 06:08:10 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
$record = new stdClass ();
$record -> id = $this -> id ;
2007-02-05 06:52:42 +00:00
$record -> { $this -> name } = addslashes ( $data );
2006-09-02 13:14:57 +00:00
$record -> timemodified = time ();
2006-10-16 08:54:37 +00:00
return ( update_record ( 'course' , $record ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
2006-09-02 13:14:57 +00:00
}
2006-09-17 06:08:10 +00:00
2006-09-02 13:14:57 +00:00
}
class admin_setting_special_frontpagedesc extends admin_setting {
var $id ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function admin_setting_special_frontpagedesc () {
$this -> id = SITEID ;
$name = 'summary' ;
$visiblename = get_string ( 'frontpagedescription' );
$description = get_string ( 'frontpagedescriptionhelp' );
parent :: admin_setting ( $name , $visiblename , $description , '' );
}
function output_html () {
2006-09-25 07:55:10 +00:00
global $CFG ;
$CFG -> adminusehtmleditor = can_use_html_editor ();
2007-10-03 10:35:34 +00:00
$return = print_textarea ( $CFG -> adminusehtmleditor , 15 , 60 , 0 , 0 , 's_' . $this -> name , $this -> get_setting (), 0 , true );
2006-09-20 21:00:45 +00:00
2007-02-06 08:24:37 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description , false );
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function get_setting () {
$site = get_site ();
2007-10-03 10:35:34 +00:00
return $site -> { $this -> name };
}
2006-09-20 21:00:45 +00:00
2007-10-03 10:35:34 +00:00
function get_defaultsetting () {
return NULL ;
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
2007-10-03 10:35:34 +00:00
$record = new object ();
$record -> id = $this -> id ;
$record -> { $this -> name } = addslashes ( $data );
$record -> timemodified = time ();
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
return ( update_record ( 'course' , $record ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
}
class admin_setting_special_editorfontlist extends admin_setting {
var $items ;
function admin_setting_special_editorfontlist () {
global $CFG ;
$name = 'editorfontlist' ;
$visiblename = get_string ( 'editorfontlist' , 'admin' );
$description = get_string ( 'configeditorfontlist' , 'admin' );
$defaults = array ( 'k0' => 'Trebuchet' ,
'v0' => 'Trebuchet MS,Verdana,Arial,Helvetica,sans-serif' ,
'k1' => 'Arial' ,
'v1' => 'arial,helvetica,sans-serif' ,
'k2' => 'Courier New' ,
'v2' => 'courier new,courier,monospace' ,
'k3' => 'Georgia' ,
'v3' => 'georgia,times new roman,times,serif' ,
'k4' => 'Tahoma' ,
'v4' => 'tahoma,arial,helvetica,sans-serif' ,
'k5' => 'Times New Roman' ,
'v5' => 'times new roman,times,serif' ,
'k6' => 'Verdana' ,
'v6' => 'verdana,arial,helvetica,sans-serif' ,
'k7' => 'Impact' ,
'v7' => 'impact' ,
'k8' => 'Wingdings' ,
'v8' => 'wingdings' );
parent :: admin_setting ( $name , $visiblename , $description , $defaults );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function get_setting () {
2006-09-18 02:41:14 +00:00
global $CFG ;
if ( isset ( $CFG -> editorfontlist )) {
$i = 0 ;
$currentsetting = array ();
$items = explode ( ';' , $CFG -> editorfontlist );
foreach ( $items as $item ) {
$item = explode ( ':' , $item );
$currentsetting [ 'k' . $i ] = $item [ 0 ];
$currentsetting [ 'v' . $i ] = $item [ 1 ];
$i ++ ;
}
return $currentsetting ;
} else {
return NULL ;
}
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
// there miiight be an easier way to do this :)
// if this is changed, make sure the $defaults array above is modified so that this
// function processes it correctly
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
$keys = array ();
$values = array ();
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
foreach ( $data as $key => $value ) {
if ( substr ( $key , 0 , 1 ) == 'k' ) {
$keys [ substr ( $key , 1 )] = $value ;
} elseif ( substr ( $key , 0 , 1 ) == 'v' ) {
$values [ substr ( $key , 1 )] = $value ;
}
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
$result = '' ;
for ( $i = 0 ; $i < count ( $keys ); $i ++ ) {
if (( $keys [ $i ] !== '' ) && ( $values [ $i ] !== '' )) {
$result .= clean_param ( $keys [ $i ], PARAM_NOTAGS ) . ':' . clean_param ( $values [ $i ], PARAM_NOTAGS ) . ';' ;
}
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
$result = substr ( $result , 0 , - 1 ); // trim the last semicolon
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
return ( set_config ( $this -> name , $result ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function output_html () {
2006-09-20 21:00:45 +00:00
2006-09-18 02:41:14 +00:00
if ( $this -> get_setting () === NULL ) {
$currentsetting = $this -> defaultsetting ;
} else {
$currentsetting = $this -> get_setting ();
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-25 14:34:33 +00:00
$return = '<div class="form-group">' ;
2006-09-18 02:41:14 +00:00
for ( $i = 0 ; $i < count ( $currentsetting ) / 2 ; $i ++ ) {
2006-09-25 08:33:10 +00:00
$return .= '<input type="text" class="form-text" name="s_editorfontlist[k' . $i . ']" value="' . $currentsetting [ 'k' . $i ] . '" />' ;
2006-09-02 13:14:57 +00:00
$return .= ' ' ;
2006-09-25 08:33:10 +00:00
$return .= '<input type="text" class="form-text" name="s_editorfontlist[v' . $i . ']" value="' . $currentsetting [ 'v' . $i ] . '" /><br />' ;
2006-09-02 13:14:57 +00:00
}
2006-09-25 08:33:10 +00:00
$return .= '<input type="text" class="form-text" name="s_editorfontlist[k' . $i . ']" value="" />' ;
2006-09-02 13:14:57 +00:00
$return .= ' ' ;
2006-09-25 08:33:10 +00:00
$return .= '<input type="text" class="form-text" name="s_editorfontlist[v' . $i . ']" value="" /><br />' ;
$return .= '<input type="text" class="form-text" name="s_editorfontlist[k' . ( $i + 1 ) . ']" value="" />' ;
2006-09-02 13:14:57 +00:00
$return .= ' ' ;
2006-09-25 08:33:10 +00:00
$return .= '<input type="text" class="form-text" name="s_editorfontlist[v' . ( $i + 1 ) . ']" value="" />' ;
2006-09-25 14:34:33 +00:00
$return .= '</div>' ;
2006-09-25 07:35:43 +00:00
2007-02-07 07:34:53 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description , false );
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
class admin_setting_special_editordictionary extends admin_setting_configselect {
function admin_setting_special_editordictionary () {
$name = 'editordictionary' ;
$visiblename = get_string ( 'editordictionary' , 'admin' );
$description = get_string ( 'configeditordictionary' , 'admin' );
$choices = $this -> editor_get_dictionaries ();
if ( ! is_array ( $choices )) {
$choices = array ( '' );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
parent :: admin_setting_configselect ( $name , $visiblename , $description , '' , $choices );
}
// function borrowed from the old moodle/admin/editor.php, slightly modified
function editor_get_dictionaries () {
/// Get all installed dictionaries in the system
global $CFG ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
// error_reporting(E_ALL); // for debug, final version shouldn't have this...
clearstatcache ();
// If aspellpath isn't set don't even bother ;-)
if ( empty ( $CFG -> aspellpath )) {
return 'Empty aspell path!' ;
}
// Do we have access to popen function?
if ( ! function_exists ( 'popen' )) {
return 'Popen function disabled!' ;
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
$cmd = $CFG -> aspellpath ;
$output = '' ;
$dictionaries = array ();
$dicts = array ();
if ( ! ( $handle = @ popen ( escapeshellarg ( $cmd ) . ' dump dicts' , 'r' ))) {
return 'Couldn\'t create handle!' ;
}
while ( ! feof ( $handle )) {
$output .= fread ( $handle , 1024 );
}
@ pclose ( $handle );
$dictionaries = explode ( chr ( 10 ), $output );
// Get rid of possible empty values
if ( is_array ( $dictionaries )) {
$cnt = count ( $dictionaries );
for ( $i = 0 ; $i < $cnt ; $i ++ ) {
if ( ! empty ( $dictionaries [ $i ])) {
2006-12-01 17:40:47 +00:00
$dicts [ $dictionaries [ $i ]] = $dictionaries [ $i ];
2006-09-02 13:14:57 +00:00
}
}
}
if ( count ( $dicts ) >= 1 ) {
return $dicts ;
}
return 'Error! Check your aspell installation!' ;
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
class admin_setting_special_editorhidebuttons extends admin_setting {
var $name ;
var $visiblename ;
var $description ;
var $items ;
function admin_setting_special_editorhidebuttons () {
$this -> name = 'editorhidebuttons' ;
$this -> visiblename = get_string ( 'editorhidebuttons' , 'admin' );
$this -> description = get_string ( 'confeditorhidebuttons' , 'admin' );
$this -> defaultsetting = array ();
// weird array... buttonname => buttonimage (assume proper path appended). if you leave buttomimage blank, text will be printed instead
$this -> items = array ( 'fontname' => '' ,
'fontsize' => '' ,
'formatblock' => '' ,
'bold' => 'ed_format_bold.gif' ,
'italic' => 'ed_format_italic.gif' ,
'underline' => 'ed_format_underline.gif' ,
'strikethrough' => 'ed_format_strike.gif' ,
'subscript' => 'ed_format_sub.gif' ,
'superscript' => 'ed_format_sup.gif' ,
'copy' => 'ed_copy.gif' ,
'cut' => 'ed_cut.gif' ,
'paste' => 'ed_paste.gif' ,
'clean' => 'ed_wordclean.gif' ,
'undo' => 'ed_undo.gif' ,
'redo' => 'ed_redo.gif' ,
'justifyleft' => 'ed_align_left.gif' ,
'justifycenter' => 'ed_align_center.gif' ,
'justifyright' => 'ed_align_right.gif' ,
'justifyfull' => 'ed_align_justify.gif' ,
'lefttoright' => 'ed_left_to_right.gif' ,
'righttoleft' => 'ed_right_to_left.gif' ,
'insertorderedlist' => 'ed_list_num.gif' ,
'insertunorderedlist' => 'ed_list_bullet.gif' ,
'outdent' => 'ed_indent_less.gif' ,
'indent' => 'ed_indent_more.gif' ,
'forecolor' => 'ed_color_fg.gif' ,
'hilitecolor' => 'ed_color_bg.gif' ,
'inserthorizontalrule' => 'ed_hr.gif' ,
'createanchor' => 'ed_anchor.gif' ,
'createlink' => 'ed_link.gif' ,
'unlink' => 'ed_unlink.gif' ,
'insertimage' => 'ed_image.gif' ,
'inserttable' => 'insert_table.gif' ,
'insertsmile' => 'em.icon.smile.gif' ,
'insertchar' => 'icon_ins_char.gif' ,
'spellcheck' => 'spell-check.gif' ,
'htmlmode' => 'ed_html.gif' ,
'popupeditor' => 'fullscreen_maximize.gif' ,
'search_replace' => 'ed_replace.gif' );
}
function get_setting () {
global $CFG ;
return ( isset ( $CFG -> { $this -> name }) ? explode ( ' ' , $CFG -> { $this -> name }) : NULL );
}
function write_setting ( $data ) {
$result = array ();
if ( empty ( $data )) { $data = array (); }
foreach ( $data as $key => $value ) {
if ( ! in_array ( $key , array_keys ( $this -> items ))) {
return get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' ;
}
if ( $value == '1' ) {
$result [] = $key ;
}
}
return ( set_config ( $this -> name , implode ( ' ' , $result )) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
function output_html () {
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
global $CFG ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
// checkboxes with input name="$this->name[$key]" value="1"
// we do 15 fields per column
2006-09-20 21:00:45 +00:00
2006-09-18 02:41:14 +00:00
if ( $this -> get_setting () === NULL ) {
$currentsetting = $this -> defaultsetting ;
} else {
$currentsetting = $this -> get_setting ();
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-25 14:34:33 +00:00
$return = '<div class="form-group">' ;
$return .= '<table><tr><td valign="top" align="right">' ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
$count = 0 ;
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
foreach ( $this -> items as $key => $value ) {
2006-11-30 09:28:06 +00:00
if ( $count % 15 == 0 and $count != 0 ) {
$return .= '</td><td valign="top" align="right">' ;
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
$return .= ( $value == '' ? get_string ( $key , 'editor' ) : '<img width="18" height="18" src="' . $CFG -> wwwroot . '/lib/editor/htmlarea/images/' . $value . '" alt="' . get_string ( $key , 'editor' ) . '" title="' . get_string ( $key , 'editor' ) . '" />' ) . ' ' ;
2006-09-25 08:20:14 +00:00
$return .= '<input type="checkbox" class="form-checkbox" value="1" id="id_s_' . $this -> name . $key . '" name="s_' . $this -> name . '[' . $key . ']"' . ( in_array ( $key , $currentsetting ) ? ' checked="checked"' : '' ) . ' /> ' ;
2006-09-02 13:14:57 +00:00
$count ++ ;
if ( $count % 15 != 0 ) {
$return .= '<br /><br />' ;
}
}
2006-09-20 21:00:45 +00:00
$return .= '</td></tr>' ;
2006-09-02 13:14:57 +00:00
$return .= '</table>' ;
2006-09-25 14:34:33 +00:00
$return .= '</div>' ;
2006-09-02 13:14:57 +00:00
2007-02-07 07:34:53 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description , false );
2006-09-02 13:14:57 +00:00
}
}
2007-04-24 16:33:06 +00:00
class admin_setting_langlist extends admin_setting_configtext {
function admin_setting_langlist () {
parent :: admin_setting_configtext ( 'langlist' , get_string ( 'langlist' , 'admin' ), get_string ( 'configlanglist' , 'admin' ), '' , PARAM_NOTAGS );
}
function write_setting ( $data ) {
$return = parent :: write_setting ( $data );
get_list_of_languages ( true ); //refresh the list
return $return ;
}
}
2006-09-02 13:14:57 +00:00
class admin_setting_backupselect extends admin_setting_configselect {
function admin_setting_backupselect ( $name , $visiblename , $description , $default , $choices ) {
parent :: admin_setting_configselect ( $name , $visiblename , $description , $default , $choices );
}
function get_setting () {
$backup_config = backup_get_config ();
return ( isset ( $backup_config -> { $this -> name }) ? $backup_config -> { $this -> name } : NULL );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
// check that what we got was in the original choices
if ( ! in_array ( $data , array_keys ( $this -> choices ))) {
return get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' ;
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
return ( backup_set_config ( $this -> name , $data ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
}
class admin_setting_special_backupsaveto extends admin_setting_configtext {
function admin_setting_special_backupsaveto () {
$name = 'backup_sche_destination' ;
$visiblename = get_string ( 'saveto' );
$description = get_string ( 'backupsavetohelp' );
2007-02-15 09:43:14 +00:00
parent :: admin_setting_configtext ( $name , $visiblename , $description , '' );
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function get_setting () {
$backup_config = backup_get_config ();
return ( isset ( $backup_config -> { $this -> name }) ? $backup_config -> { $this -> name } : NULL );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
2007-02-15 09:43:14 +00:00
$data = trim ( $data );
if ( ! empty ( $data ) and ! is_dir ( $data )) {
2006-09-02 13:14:57 +00:00
return get_string ( 'pathnotexists' ) . '<br />' ;
}
return ( backup_set_config ( $this -> name , $data ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
}
class admin_setting_backupcheckbox extends admin_setting_configcheckbox {
function admin_setting_backupcheckbox ( $name , $visiblename , $description , $default ) {
parent :: admin_setting_configcheckbox ( $name , $visiblename , $description , $default );
}
function write_setting ( $data ) {
if ( $data == '1' ) {
return ( backup_set_config ( $this -> name , 1 ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
} else {
return ( backup_set_config ( $this -> name , 0 ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function get_setting () {
$backup_config = backup_get_config ();
return ( isset ( $backup_config -> { $this -> name }) ? $backup_config -> { $this -> name } : NULL );
}
}
class admin_setting_special_backuptime extends admin_setting_configtime {
function admin_setting_special_backuptime () {
$name = 'backup_sche_hour' ;
$name2 = 'backup_sche_minute' ;
$visiblename = get_string ( 'executeat' );
$description = get_string ( 'backupexecuteathelp' );
$default = array ( 'h' => 0 , 'm' => 0 );
parent :: admin_setting_configtime ( $name , $name2 , $visiblename , $description , $default );
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function get_setting () {
$backup_config = backup_get_config ();
2006-09-24 19:37:34 +00:00
return ( isset ( $backup_config -> { $this -> name }) && isset ( $backup_config -> { $this -> name }) ? array ( 'h' => $backup_config -> { $this -> name }, 'm' => $backup_config -> { $this -> name2 }) : NULL );
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
// check that what we got was in the original choices
if ( ! ( in_array ( $data [ 'h' ], array_keys ( $this -> choices )) && in_array ( $data [ 'm' ], array_keys ( $this -> choices2 )))) {
return get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' ;
}
2006-09-20 21:00:45 +00:00
return ( backup_set_config ( $this -> name , $data [ 'h' ]) && backup_set_config ( $this -> name2 , $data [ 'm' ]) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
class admin_setting_special_backupdays extends admin_setting {
function admin_setting_special_backupdays () {
$name = 'backup_sche_weekdays' ;
$visiblename = get_string ( 'schedule' );
$description = get_string ( 'backupschedulehelp' );
2006-09-27 22:25:15 +00:00
$default = array ( 'u' => 0 , 'm' => 0 , 't' => 0 , 'w' => 0 , 'r' => 0 , 'f' => 0 , 's' => 0 );
parent :: admin_setting ( $name , $visiblename , $description , $default );
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function get_setting () {
$backup_config = backup_get_config ();
2006-09-18 02:41:14 +00:00
if ( isset ( $backup_config -> { $this -> name })) {
$currentsetting = $backup_config -> { $this -> name };
return array ( 'u' => substr ( $currentsetting , 0 , 1 ),
'm' => substr ( $currentsetting , 1 , 1 ),
't' => substr ( $currentsetting , 2 , 1 ),
'w' => substr ( $currentsetting , 3 , 1 ),
'r' => substr ( $currentsetting , 4 , 1 ),
'f' => substr ( $currentsetting , 5 , 1 ),
's' => substr ( $currentsetting , 6 , 1 ));
} else {
return NULL ;
}
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function output_html () {
2006-09-20 21:00:45 +00:00
2006-09-18 02:41:14 +00:00
if ( $this -> get_setting () === NULL ) {
$currentsetting = $this -> defaultsetting ;
} else {
$currentsetting = $this -> get_setting ();
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-18 02:41:14 +00:00
// rewrite for simplicity
2006-09-20 21:00:45 +00:00
$currentsetting = $currentsetting [ 'u' ] . $currentsetting [ 'm' ] . $currentsetting [ 't' ] . $currentsetting [ 'w' ] .
2006-09-18 02:41:14 +00:00
$currentsetting [ 'r' ] . $currentsetting [ 'f' ] . $currentsetting [ 's' ];
2006-09-20 21:00:45 +00:00
2007-02-07 07:34:53 +00:00
$return = '<table><tr><td><div style="text-align:center"> ' . get_string ( 'sunday' , 'calendar' ) . ' </div></td><td><div style="text-align:center"> ' .
get_string ( 'monday' , 'calendar' ) . ' </div></td><td><div style="text-align:center"> ' . get_string ( 'tuesday' , 'calendar' ) . ' </div></td><td><div style="text-align:center"> ' .
get_string ( 'wednesday' , 'calendar' ) . ' </div></td><td><div style="text-align:center"> ' . get_string ( 'thursday' , 'calendar' ) . ' </div></td><td><div style="text-align:center"> ' .
get_string ( 'friday' , 'calendar' ) . ' </div></td><td><div style="text-align:center"> ' . get_string ( 'saturday' , 'calendar' ) . ' </div></td></tr><tr>' .
'<td><div style="text-align:center"><input type="checkbox" class="form-checkbox" id="id_s_' . $this -> name . 'u" name="s_' . $this -> name . '[u]" value="1" ' . ( substr ( $currentsetting , 0 , 1 ) == '1' ? 'checked="checked"' : '' ) . ' /></div></td>' .
'<td><div style="text-align:center"><input type="checkbox" class="form-checkbox" id="id_s_' . $this -> name . 'm" name="s_' . $this -> name . '[m]" value="1" ' . ( substr ( $currentsetting , 1 , 1 ) == '1' ? 'checked="checked"' : '' ) . ' /></div></td>' .
'<td><div style="text-align:center"><input type="checkbox" class="form-checkbox" id="id_s_' . $this -> name . 't" name="s_' . $this -> name . '[t]" value="1" ' . ( substr ( $currentsetting , 2 , 1 ) == '1' ? 'checked="checked"' : '' ) . ' /></div></td>' .
'<td><div style="text-align:center"><input type="checkbox" class="form-checkbox" id="id_s_' . $this -> name . 'w" name="s_' . $this -> name . '[w]" value="1" ' . ( substr ( $currentsetting , 3 , 1 ) == '1' ? 'checked="checked"' : '' ) . ' /></div></td>' .
'<td><div style="text-align:center"><input type="checkbox" class="form-checkbox" id="id_s_' . $this -> name . 'r" name="s_' . $this -> name . '[r]" value="1" ' . ( substr ( $currentsetting , 4 , 1 ) == '1' ? 'checked="checked"' : '' ) . ' /></div></td>' .
'<td><div style="text-align:center"><input type="checkbox" class="form-checkbox" id="id_s_' . $this -> name . 'f" name="s_' . $this -> name . '[f]" value="1" ' . ( substr ( $currentsetting , 5 , 1 ) == '1' ? 'checked="checked"' : '' ) . ' /></div></td>' .
'<td><div style="text-align:center"><input type="checkbox" class="form-checkbox" id="id_s_' . $this -> name . 's" name="s_' . $this -> name . '[s]" value="1" ' . ( substr ( $currentsetting , 6 , 1 ) == '1' ? 'checked="checked"' : '' ) . ' /></div></td>' .
2006-09-25 07:35:43 +00:00
'</tr></table>' ;
2007-02-07 07:34:53 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description , false );
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
// we're using the array trick (see http://ca.php.net/manual/en/faq.html.php#faq.html.arrays) to get the data passed to use without having to modify
// admin_settingpage (note that admin_settingpage only calls write_setting with the data that matches $this->name... so if we have multiple form fields,
// they MUST go into an array named $this->name, or else we won't receive them here
function write_setting ( $data ) {
$week = 'umtwrfs' ;
$result = array ( 0 => 0 , 1 => 0 , 2 => 0 , 3 => 0 , 4 => 0 , 5 => 0 , 6 => 0 );
2006-09-24 19:37:34 +00:00
if ( ! empty ( $data )) {
foreach ( $data as $key => $value ) {
if ( $value == '1' ) {
$result [ strpos ( $week , $key )] = 1 ;
}
}
2006-09-02 13:14:57 +00:00
}
return ( backup_set_config ( $this -> name , implode ( '' , $result )) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
}
2006-09-13 09:22:16 +00:00
class admin_setting_special_debug extends admin_setting_configselect {
2006-09-02 13:14:57 +00:00
function admin_setting_special_debug () {
$name = 'debug' ;
$visiblename = get_string ( 'debug' , 'admin' );
$description = get_string ( 'configdebug' , 'admin' );
2006-09-23 09:38:39 +00:00
$choices = array ( DEBUG_NONE => get_string ( 'debugnone' , 'admin' ),
DEBUG_MINIMAL => get_string ( 'debugminimal' , 'admin' ),
DEBUG_NORMAL => get_string ( 'debugnormal' , 'admin' ),
2006-09-24 11:55:11 +00:00
DEBUG_ALL => get_string ( 'debugall' , 'admin' ),
DEBUG_DEVELOPER => get_string ( 'debugdeveloper' , 'admin' )
2006-09-13 09:22:16 +00:00
);
parent :: admin_setting_configselect ( $name , $visiblename , $description , '' , $choices );
2006-09-02 13:14:57 +00:00
}
2006-09-13 09:22:16 +00:00
function get_setting () {
global $CFG ;
2006-09-18 02:41:14 +00:00
if ( isset ( $CFG -> debug )) {
return $CFG -> debug ;
} else {
return NULL ;
2006-09-13 09:22:16 +00:00
}
2006-09-02 13:14:57 +00:00
}
2006-09-13 09:22:16 +00:00
function write_setting ( $data ) {
return ( set_config ( $this -> name , $data ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
2006-09-02 13:14:57 +00:00
}
}
class admin_setting_special_calendar_weekend extends admin_setting {
function admin_setting_special_calendar_weekend () {
$name = 'calendar_weekend' ;
$visiblename = get_string ( 'calendar_weekend' , 'admin' );
$description = get_string ( 'helpweekenddays' , 'admin' );
2007-03-05 11:57:15 +00:00
$default = array ( '0' , '6' ); // Saturdays and Sundays
2006-12-18 18:07:03 +00:00
parent :: admin_setting ( $name , $visiblename , $description , $default );
2006-09-02 13:14:57 +00:00
}
function get_setting () {
global $CFG ;
2007-02-27 12:42:08 +00:00
return isset ( $CFG -> { $this -> name }) ? $CFG -> { $this -> name } : 0 ;
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function write_setting ( $data ) {
2007-02-27 12:42:08 +00:00
$result = 0 ;
2006-12-18 18:07:03 +00:00
if ( ! empty ( $data )) {
2007-02-27 12:42:08 +00:00
foreach ( $data as $index ) {
$result |= 1 << $index ;
2006-12-18 18:07:03 +00:00
}
2006-09-02 13:14:57 +00:00
}
2007-02-27 12:42:08 +00:00
return ( set_config ( $this -> name , $result ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
2006-09-02 13:14:57 +00:00
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
function output_html () {
2006-09-18 02:41:14 +00:00
if ( $this -> get_setting () === NULL ) {
$currentsetting = $this -> defaultsetting ;
} else {
$currentsetting = $this -> get_setting ();
2006-09-02 13:14:57 +00:00
}
2006-09-18 02:41:14 +00:00
2007-02-27 12:42:08 +00:00
// The order matters very much because of the implied numeric keys
$days = array ( 'sunday' , 'monday' , 'tuesday' , 'wednesday' , 'thursday' , 'friday' , 'saturday' );
$return = '<table><thead><tr>' ;
foreach ( $days as $index => $day ) {
$return .= '<td><label for="id_s_' . $this -> name . $index . '">' . get_string ( $day , 'calendar' ) . '</label></td>' ;
}
$return .= '</tr></thead><tbody><tr>' ;
foreach ( $days as $index => $day ) {
$return .= '<td><input type="checkbox" class="form-checkbox" id="id_s_' . $this -> name . $index . '" name="s_' . $this -> name . '[]" value="' . $index . '" ' . ( $currentsetting & ( 1 << $index ) ? 'checked="checked"' : '' ) . ' /></td>' ;
}
$return .= '</tr></tbody></table>' ;
2006-09-25 07:35:43 +00:00
2007-02-08 03:04:41 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description , false );
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
}
2006-10-27 21:07:18 +00:00
/*
* this is used in config -> appearance -> gradeconfig
2006-10-25 08:51:26 +00:00
*/
2006-10-29 15:02:45 +00:00
class admin_setting_special_gradebookroles extends admin_setting {
2006-10-25 08:51:26 +00:00
2006-10-29 15:02:45 +00:00
function admin_setting_special_gradebookroles () {
$name = 'gradebookroles' ;
2006-10-27 21:07:18 +00:00
$visiblename = get_string ( 'gradebookroles' , 'admin' );
$description = get_string ( 'configgradebookroles' , 'admin' );
2006-10-31 21:52:22 +00:00
$default = array ( 5 => '1' ); // The student role in a default install
2006-10-30 03:57:08 +00:00
parent :: admin_setting ( $name , $visiblename , $description , $default );
2006-10-25 08:51:26 +00:00
}
function get_setting () {
global $CFG ;
2006-10-30 03:57:08 +00:00
if ( ! empty ( $CFG -> { $this -> name })) {
2006-11-08 02:42:48 +00:00
$result = explode ( ',' , $CFG -> { $this -> name });
foreach ( $result as $roleid ) {
2007-07-27 13:38:06 +00:00
$array [ $roleid ] = 1 ;
2006-11-08 02:42:48 +00:00
}
return $array ;
2006-10-25 08:51:26 +00:00
} else {
2006-10-30 08:44:53 +00:00
return null ;
2006-10-25 08:51:26 +00:00
}
}
function write_setting ( $data ) {
if ( ! empty ( $data )) {
$str = '' ;
2006-10-29 15:02:45 +00:00
foreach ( $data as $key => $value ) {
2006-10-25 08:51:26 +00:00
if ( $value ) {
$str .= $key . ',' ;
}
}
return set_config ( $this -> name , rtrim ( $str , " , " )) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' ;
} else {
2006-10-27 21:07:18 +00:00
return set_config ( $this -> name , '' ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' ;
}
2006-10-25 08:51:26 +00:00
}
function output_html () {
if ( $this -> get_setting () === NULL ) {
$currentsetting = $this -> defaultsetting ;
} else {
$currentsetting = $this -> get_setting ();
}
// from to process which roles to display
if ( $roles = get_records ( 'role' )) {
2006-10-27 21:07:18 +00:00
$return = '<div class="form-group">' ;
$first = true ;
foreach ( $roles as $roleid => $role ) {
2006-11-08 02:42:48 +00:00
if ( is_array ( $currentsetting ) && in_array ( $roleid , array_keys ( $currentsetting ))) {
2006-12-11 11:29:19 +00:00
$checked = ' checked="checked"' ;
2006-10-25 08:51:26 +00:00
} else {
2006-10-27 21:07:18 +00:00
$checked = '' ;
2006-10-25 08:51:26 +00:00
}
2006-10-27 21:07:18 +00:00
if ( $first ) {
$first = false ;
} else {
$return .= '<br />' ;
}
2007-03-21 07:43:04 +00:00
$return .= '<input type="checkbox" name="s_' . $this -> name . '[' . $roleid . ']" value="1"' . $checked . ' /> ' . format_string ( $role -> name );
2006-10-25 08:51:26 +00:00
}
2006-10-27 21:07:18 +00:00
$return .= '</div>' ;
2006-10-25 08:51:26 +00:00
}
2006-10-27 21:07:18 +00:00
2007-02-07 07:34:53 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description , false );
2006-10-25 08:51:26 +00:00
}
}
2006-09-02 13:14:57 +00:00
2006-11-17 08:57:50 +00:00
/*
* this is used in config -> appearance -> coursemanager
* ( which roles to show on course decription page )
*/
class admin_setting_special_coursemanager extends admin_setting {
function admin_setting_special_coursemanager () {
$name = 'coursemanager' ;
$visiblename = get_string ( 'coursemanager' , 'admin' );
$description = get_string ( 'configcoursemanager' , 'admin' );
$default = array ( 3 => '1' ); // The teahcer role in a default install
parent :: admin_setting ( $name , $visiblename , $description , $default );
}
function get_setting () {
global $CFG ;
if ( ! empty ( $CFG -> { $this -> name })) {
$result = explode ( ',' , $CFG -> { $this -> name });
foreach ( $result as $roleid ) {
2007-07-27 13:38:06 +00:00
$array [ $roleid ] = 1 ;
2006-11-17 08:57:50 +00:00
}
return $array ;
2007-04-01 15:59:04 +00:00
} else if ( isset ( $CFG -> { $this -> name })) {
return array ();
2006-11-17 08:57:50 +00:00
} else {
return null ;
}
}
function write_setting ( $data ) {
if ( ! empty ( $data )) {
$str = '' ;
foreach ( $data as $key => $value ) {
if ( $value ) {
$str .= $key . ',' ;
}
}
return set_config ( $this -> name , rtrim ( $str , " , " )) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' ;
} else {
return set_config ( $this -> name , '' ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' ;
}
}
function output_html () {
if ( $this -> get_setting () === NULL ) {
$currentsetting = $this -> defaultsetting ;
} else {
$currentsetting = $this -> get_setting ();
}
// from to process which roles to display
2007-07-17 13:13:35 +00:00
if ( $roles = get_records_select ( 'role' , '' , 'sortorder' )) {
2006-11-17 08:57:50 +00:00
$return = '<div class="form-group">' ;
$first = true ;
foreach ( $roles as $roleid => $role ) {
if ( is_array ( $currentsetting ) && in_array ( $roleid , array_keys ( $currentsetting ))) {
$checked = 'checked="checked"' ;
} else {
$checked = '' ;
}
if ( $first ) {
$first = false ;
} else {
$return .= '<br />' ;
}
2006-11-30 09:32:46 +00:00
$return .= '<input type="checkbox" name="s_' . $this -> name . '[' . $roleid . ']" value="1" ' . $checked . ' /> ' . $role -> name ;
2006-11-17 08:57:50 +00:00
}
$return .= '</div>' ;
}
2007-02-07 07:34:53 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description , false );
2006-11-17 08:57:50 +00:00
}
}
2007-05-10 08:23:44 +00:00
/*
* this is used in config -> courses -> gradeexports
* ( which roles to show on course decription page )
*/
class admin_setting_special_gradeexport extends admin_setting {
function admin_setting_special_gradeexport () {
$name = 'gradeexport' ;
$visiblename = get_string ( 'gradeexport' , 'admin' );
$description = get_string ( 'configgradeexport' , 'admin' );
$default = array ( 3 => '1' ); // The teahcer role in a default install
parent :: admin_setting ( $name , $visiblename , $description , $default );
}
function get_setting () {
global $CFG ;
if ( ! empty ( $CFG -> { $this -> name })) {
$result = explode ( ',' , $CFG -> { $this -> name });
foreach ( $result as $plugin ) {
2007-07-27 13:38:06 +00:00
$array [ $plugin ] = 1 ;
2007-05-10 08:23:44 +00:00
}
return $array ;
} else if ( isset ( $CFG -> { $this -> name })) {
return array ();
} else {
return null ;
}
}
function write_setting ( $data ) {
if ( ! empty ( $data )) {
$str = '' ;
foreach ( $data as $key => $value ) {
if ( $value ) {
$str .= $key . ',' ;
}
}
return set_config ( $this -> name , rtrim ( $str , " , " )) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' ;
} else {
return set_config ( $this -> name , '' ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' ;
}
}
function output_html () {
if ( $this -> get_setting () === NULL ) {
$currentsetting = $this -> defaultsetting ;
} else {
$currentsetting = $this -> get_setting ();
}
// from to process which roles to display
if ( $exports = get_list_of_plugins ( 'grade/export' )) {
$return = '<div class="form-group">' ;
$first = true ;
foreach ( $exports as $export ) {
if ( is_array ( $currentsetting ) && in_array ( $export , array_keys ( $currentsetting ))) {
$checked = 'checked="checked"' ;
} else {
$checked = '' ;
}
if ( $first ) {
$first = false ;
} else {
$return .= '<br />' ;
}
$return .= '<input type="checkbox" name="s_' . $this -> name . '[' . $export . ']" value="1" ' . $checked . ' /> ' . $export ;
}
$return .= '</div>' ;
}
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description , false );
}
}
2006-09-02 13:14:57 +00:00
class admin_setting_special_perfdebug extends admin_setting_configcheckbox {
function admin_setting_special_perfdebug () {
$name = 'perfdebug' ;
$visiblename = get_string ( 'perfdebug' , 'admin' );
$description = get_string ( 'configperfdebug' , 'admin' );
parent :: admin_setting_configcheckbox ( $name , $visiblename , $description , '' );
}
function write_setting ( $data ) {
2006-11-17 08:57:50 +00:00
2006-09-02 13:14:57 +00:00
if ( $data == '1' ) {
return ( set_config ( $this -> name , 15 ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
} else {
return ( set_config ( $this -> name , 7 ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
}
function output_html () {
2006-11-17 08:57:50 +00:00
2006-09-18 02:41:14 +00:00
if ( $this -> get_setting () === NULL ) {
$currentsetting = $this -> defaultsetting ;
} else {
$currentsetting = $this -> get_setting ();
}
2006-09-20 21:00:45 +00:00
2006-09-25 08:33:10 +00:00
$return = '<input type="checkbox" class="form-checkbox" id="id_s_' . $this -> name . '" name="s_' . $this -> name . '" value="1" ' . ( $currentsetting == 15 ? 'checked="checked"' : '' ) . ' />' ;
2006-09-25 14:18:16 +00:00
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description );
2006-09-02 13:14:57 +00:00
}
}
2006-12-21 04:30:03 +00:00
class admin_setting_special_debugdisplay extends admin_setting_configcheckbox {
function admin_setting_special_debugdisplay () {
$name = 'debugdisplay' ;
$visiblename = get_string ( 'debugdisplay' , 'admin' );
$description = get_string ( 'configdebugdisplay' , 'admin' );
2007-02-01 21:11:50 +00:00
$default = ini_get ( 'display_errors' );
parent :: admin_setting_configcheckbox ( $name , $visiblename , $description , $default );
2006-12-21 04:30:03 +00:00
}
function write_setting ( $data ) {
if ( $data == '1' ) {
return ( set_config ( $this -> name , 1 ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
} else {
return ( set_config ( $this -> name , 0 ) ? '' : get_string ( 'errorsetting' , 'admin' ) . $this -> visiblename . '<br />' );
}
}
function output_html () {
if ( $this -> get_setting () === NULL ) {
2007-02-01 21:11:50 +00:00
$currentsetting = $this -> defaultsetting ;
2006-12-21 04:30:03 +00:00
} else {
$currentsetting = $this -> get_setting ();
}
$return = '<input type="checkbox" class="form-checkbox" id="id_s_' . $this -> name . '" name="s_' . $this -> name . '" value="1" ' . ( $currentsetting == 1 ? 'checked="checked"' : '' ) . ' />' ;
return format_admin_setting ( $this -> name , $this -> visiblename , $return , $this -> description );
}
}
2006-09-02 13:14:57 +00:00
// Code for a function that helps externalpages print proper headers and footers
// N.B.: THIS FUNCTION HANDLES AUTHENTICATION
2007-04-30 17:08:34 +00:00
function admin_externalpage_setup ( $section ) {
2006-09-02 13:14:57 +00:00
global $CFG , $PAGE , $USER ;
2006-09-20 21:00:45 +00:00
2007-04-30 17:08:34 +00:00
$adminroot = admin_get_root ();
2006-09-02 13:14:57 +00:00
require_once ( $CFG -> libdir . '/blocklib.php' );
2006-09-02 23:55:56 +00:00
require_once ( $CFG -> dirroot . '/' . $CFG -> admin . '/pagelib.php' );
2006-09-20 21:00:45 +00:00
2006-09-02 23:55:56 +00:00
page_map_class ( PAGE_ADMIN , 'page_admin' );
2006-09-02 13:14:57 +00:00
2006-09-03 17:46:27 +00:00
$PAGE = page_create_object ( PAGE_ADMIN , 0 ); // there must be any constant id number
2006-09-02 13:14:57 +00:00
2006-09-02 23:55:56 +00:00
$PAGE -> init_extra ( $section ); // hack alert!
2006-09-02 13:14:57 +00:00
$root = $adminroot -> locate ( $PAGE -> section );
if ( $site = get_site ()) {
require_login ();
} else {
2006-09-26 21:10:14 +00:00
redirect ( $CFG -> wwwroot . '/' . $CFG -> admin . '/index.php' );
2006-09-02 13:14:57 +00:00
die ;
}
if ( ! is_a ( $root , 'admin_externalpage' )) {
error ( get_string ( 'sectionerror' , 'admin' ));
die ;
}
// this eliminates our need to authenticate on the actual pages
if ( ! ( $root -> check_access ())) {
error ( get_string ( 'accessdenied' , 'admin' ));
die ;
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
$adminediting = optional_param ( 'adminedit' , - 1 , PARAM_BOOL );
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
if ( ! isset ( $USER -> adminediting )) {
$USER -> adminediting = false ;
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
if ( $PAGE -> user_allowed_editing ()) {
if ( $adminediting == 1 ) {
$USER -> adminediting = true ;
} elseif ( $adminediting == 0 ) {
$USER -> adminediting = false ;
}
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
}
2007-08-17 07:25:47 +00:00
/**
* TODO document
*/
2007-04-30 17:08:34 +00:00
function admin_externalpage_print_header () {
2006-09-02 13:14:57 +00:00
2007-02-07 08:11:31 +00:00
global $CFG , $PAGE , $SITE , $THEME ;
2007-07-27 13:38:06 +00:00
2007-05-09 15:03:01 +00:00
if ( ! empty ( $THEME -> customcorners )) {
require_once ( $CFG -> dirroot . '/lib/custom_corners_lib.php' );
}
2006-09-20 21:00:45 +00:00
2007-04-30 17:08:34 +00:00
define ( 'ADMIN_EXT_HEADER_PRINTED' , 'true' );
2006-09-12 09:22:27 +00:00
if ( ! empty ( $SITE -> fullname )) {
$pageblocks = blocks_setup ( $PAGE );
2006-09-02 13:14:57 +00:00
2007-01-15 07:29:25 +00:00
$preferred_width_left = bounded_number ( BLOCK_L_MIN_WIDTH ,
blocks_preferred_width ( $pageblocks [ BLOCK_POS_LEFT ]),
2006-09-12 09:22:27 +00:00
BLOCK_L_MAX_WIDTH );
$PAGE -> print_header ();
2007-01-15 21:28:25 +00:00
echo '<table id="layout-table" summary=""><tr>' ;
2007-08-17 07:25:47 +00:00
2007-08-07 07:34:21 +00:00
$lt = ( empty ( $THEME -> layouttable )) ? array ( 'left' , 'middle' , 'right' ) : $THEME -> layouttable ;
foreach ( $lt as $column ) {
$lt1 [] = $column ;
if ( $column == 'middle' ) break ;
}
foreach ( $lt1 as $column ) {
switch ( $column ) {
case 'left' :
2006-09-12 09:22:27 +00:00
echo '<td style="width: ' . $preferred_width_left . 'px;" id="left-column">' ;
2007-05-09 15:03:01 +00:00
if ( ! empty ( $THEME -> customcorners )) print_custom_corners_start ();
2006-09-12 09:22:27 +00:00
blocks_print_group ( $PAGE , $pageblocks , BLOCK_POS_LEFT );
2007-05-09 15:03:01 +00:00
if ( ! empty ( $THEME -> customcorners )) print_custom_corners_end ();
2006-09-12 09:22:27 +00:00
echo '</td>' ;
2007-08-07 07:34:21 +00:00
break ;
2007-08-17 07:25:47 +00:00
2007-08-07 07:34:21 +00:00
case 'middle' :
2006-09-25 14:40:26 +00:00
echo '<td id="middle-column">' ;
2007-05-09 15:03:01 +00:00
if ( ! empty ( $THEME -> customcorners )) print_custom_corners_start ();
2007-08-07 07:34:21 +00:00
break ;
2007-08-17 07:25:47 +00:00
2007-08-07 07:34:21 +00:00
case 'right' :
if ( blocks_have_content ( $pageblocks , BLOCK_POS_RIGHT )) {
echo '<td style="width: ' . $preferred_width_right . 'px;" id="right-column">' ;
if ( ! empty ( $THEME -> customcorners )) print_custom_corners_start ();
blocks_print_group ( $PAGE , $pageblocks , BLOCK_POS_RIGHT );
if ( ! empty ( $THEME -> customcorners )) print_custom_corners_end ();
echo '</td>' ;
}
break ;
}
}
2006-09-12 09:22:27 +00:00
} else {
print_header ();
}
2006-09-02 13:14:57 +00:00
}
2007-04-30 17:08:34 +00:00
function admin_externalpage_print_footer () {
2006-09-02 13:14:57 +00:00
2007-02-07 08:11:31 +00:00
global $CFG , $PAGE , $SITE , $THEME ;
2007-07-27 13:38:06 +00:00
2007-05-09 15:03:01 +00:00
if ( ! empty ( $THEME -> customcorners )) {
require_once ( $CFG -> dirroot . '/lib/custom_corners_lib.php' );
}
2007-07-27 13:38:06 +00:00
2007-04-30 17:08:34 +00:00
define ( 'ADMIN_EXT_FOOTER_PRINTED' , 'true' );
2006-09-12 09:22:27 +00:00
if ( ! empty ( $SITE -> fullname )) {
$pageblocks = blocks_setup ( $PAGE );
2007-01-15 07:29:25 +00:00
$preferred_width_right = bounded_number ( BLOCK_R_MIN_WIDTH ,
blocks_preferred_width ( $pageblocks [ BLOCK_POS_RIGHT ]),
2006-09-12 09:22:27 +00:00
BLOCK_R_MAX_WIDTH );
2007-08-07 07:34:21 +00:00
$lt = ( empty ( $THEME -> layouttable )) ? array ( 'left' , 'middle' , 'right' ) : $THEME -> layouttable ;
foreach ( $lt as $column ) {
if ( $column != 'middle' ) {
array_shift ( $lt );
} else if ( $column == 'middle' ) {
break ;
}
}
foreach ( $lt as $column ) {
switch ( $column ) {
case 'left' :
echo '<td style="width: ' . $preferred_width_left . 'px;" id="left-column">' ;
if ( ! empty ( $THEME -> customcorners )) print_custom_corners_start ();
blocks_print_group ( $PAGE , $pageblocks , BLOCK_POS_LEFT );
2007-05-09 15:03:01 +00:00
if ( ! empty ( $THEME -> customcorners )) print_custom_corners_end ();
2006-09-12 09:22:27 +00:00
echo '</td>' ;
2007-08-07 07:34:21 +00:00
break ;
2007-08-17 07:25:47 +00:00
2007-08-07 07:34:21 +00:00
case 'middle' :
if ( ! empty ( $THEME -> customcorners )) print_custom_corners_end ();
echo '</td>' ;
break ;
2007-08-17 07:25:47 +00:00
2007-08-07 07:34:21 +00:00
case 'right' :
2007-02-08 01:11:05 +00:00
if ( blocks_have_content ( $pageblocks , BLOCK_POS_RIGHT )) {
2007-02-07 08:22:20 +00:00
echo '<td style="width: ' . $preferred_width_right . 'px;" id="right-column">' ;
2007-05-09 15:03:01 +00:00
if ( ! empty ( $THEME -> customcorners )) print_custom_corners_start ();
2007-02-07 08:22:20 +00:00
blocks_print_group ( $PAGE , $pageblocks , BLOCK_POS_RIGHT );
2007-08-07 07:34:21 +00:00
2007-05-09 15:03:01 +00:00
if ( ! empty ( $THEME -> customcorners )) print_custom_corners_end ();
2007-02-07 08:22:20 +00:00
echo '</td>' ;
2007-08-07 07:34:21 +00:00
}
break ;
}
2007-02-07 08:11:31 +00:00
}
2007-02-07 08:22:20 +00:00
echo '</tr></table>' ;
2006-09-12 09:22:27 +00:00
}
2006-09-02 13:14:57 +00:00
print_footer ();
}
function admin_get_root () {
global $CFG ;
static $ADMIN ;
if ( ! isset ( $ADMIN )) {
// start the admin tree!
2006-10-18 05:41:45 +00:00
$ADMIN = new admin_category ( 'root' , get_string ( " administration " ));
2006-09-02 13:14:57 +00:00
// we process this file first to get categories up and running
2006-09-26 21:10:14 +00:00
include ( $CFG -> dirroot . '/' . $CFG -> admin . '/settings/top.php' );
2006-09-02 13:14:57 +00:00
// now we process all other files in admin/settings to build the
// admin tree
2006-09-26 21:10:14 +00:00
foreach ( glob ( $CFG -> dirroot . '/' . $CFG -> admin . '/settings/*.php' ) as $file ) {
if ( $file != $CFG -> dirroot . '/' . $CFG -> admin . '/settings/top.php' ) {
2006-09-02 13:14:57 +00:00
include_once ( $file );
}
}
}
2006-09-20 21:00:45 +00:00
2006-09-02 13:14:57 +00:00
return $ADMIN ;
}
2007-10-02 21:38:53 +00:00
/// settings utility functions
2006-09-02 13:14:57 +00:00
2007-10-02 21:38:53 +00:00
/**
* This function applies default settings .
* @ param object $node
* @ param bool $uncoditional if true overrides all values with defaults
* @ return void
*/
function apply_default_settings ( & $node , $unconditional = true ) {
2006-09-02 13:14:57 +00:00
global $CFG ;
if ( is_a ( $node , 'admin_category' )) {
$entries = array_keys ( $node -> children );
foreach ( $entries as $entry ) {
apply_default_settings ( $node -> children [ $entry ]);
}
return ;
2006-09-20 21:00:45 +00:00
}
2006-09-02 13:14:57 +00:00
2006-09-20 21:00:45 +00:00
if ( is_a ( $node , 'admin_settingpage' )) {
2006-09-02 13:14:57 +00:00
foreach ( $node -> settings as $setting ) {
2007-10-02 21:38:53 +00:00
if ( ! $unconditional and ! is_null ( $setting -> get_setting )) {
//do not override existing defaults
continue ;
}
$defaultsetting = $setting -> get_defaultsetting ();
if ( is_null ( $defaultsetting )) {
// no value yet - default maybe applied after admin user creation or in upgradesettings
continue ;
}
$CFG -> { $setting -> name } = $defaultsetting ;
$setting -> write_setting ( $defaultsetting );
2006-09-02 13:14:57 +00:00
unset ( $setting ); // needed to prevent odd (imho) reference behaviour
// see http://www.php.net/manual/en/language.references.whatdo.php#AEN6399
}
return ;
}
return ;
}
// n.b. this function unconditionally applies default settings
function apply_default_exception_settings ( $defaults ) {
global $CFG ;
foreach ( $defaults as $key => $value ) {
$CFG -> $key = $value ;
set_config ( $key , $value );
}
}
2007-02-06 08:24:37 +00:00
function format_admin_setting ( $name , $title = '' , $form = '' , $description = '' , $label = true ) {
2007-07-27 13:38:06 +00:00
2007-02-06 08:24:37 +00:00
// sometimes the id is not id_s_name, but id_s_name_m or something, and this does not validate
if ( $label ) {
2007-07-27 13:38:06 +00:00
$labelfor = 'for = "id_s_' . $name . '"' ;
2007-02-06 08:24:37 +00:00
} else {
2007-07-27 13:38:06 +00:00
$labelfor = '' ;
2007-02-06 08:24:37 +00:00
}
2007-07-27 13:38:06 +00:00
2007-02-06 08:24:37 +00:00
$str = " \n " .
2006-09-25 14:18:16 +00:00
'<div class="form-item" id="admin-' . $name . '">' . " \n " .
2007-02-06 08:24:37 +00:00
'<label ' . $labelfor . '>' . $title . " \n " .
2006-09-25 07:35:43 +00:00
' <span class="form-shortname">' . $name . '</span>' . " \n " .
'</label>' . " \n " .
$form . " \n " .
2006-09-25 07:45:02 +00:00
'<div class="description">' . $description . '</div>' . " \n " .
2006-09-25 07:40:50 +00:00
'</div>' .
" \n \n " ;
2007-07-27 13:38:06 +00:00
2007-02-06 08:24:37 +00:00
return $str ;
2006-09-24 11:11:40 +00:00
}
2007-07-27 13:38:06 +00:00
/*
2006-11-06 12:51:27 +00:00
* Try to upgrade the given language pack ( or current language )
* If it doesn ' t work , fail silently and return false
*/
function upgrade_language_pack ( $lang = '' ) {
global $CFG ;
if ( empty ( $lang )) {
$lang = current_language ();
}
if ( $lang == 'en_utf8' ) {
return true ; // Nothing to do
}
notify ( get_string ( 'langimport' , 'admin' ) . ': ' . $lang . ' ... ' , 'notifysuccess' );
@ mkdir ( $CFG -> dataroot . '/temp/' ); //make it in case it's a fresh install, it might not be there
@ mkdir ( $CFG -> dataroot . '/lang/' );
require_once ( $CFG -> libdir . '/componentlib.class.php' );
if ( $cd = new component_installer ( 'http://download.moodle.org' , 'lang16' , $lang . '.zip' , 'languages.md5' , 'lang' )) {
$status = $cd -> install (); //returns ERROR | UPTODATE | INSTALLED
if ( $status == INSTALLED ) {
debugging ( 'Downloading successful: ' . $lang );
@ unlink ( $CFG -> dataroot . '/cache/languages' );
return true ;
}
}
return false ;
}
2007-04-18 09:39:49 +00:00
/**
* Based on find_new_settings { @ link ()} in upgradesettings . php
* Looks to find any admin settings that have not been initialized . Returns 1 if it finds any .
*
2007-07-27 13:38:06 +00:00
* @ param string & $node The node at which to start searching .
2007-04-18 09:39:49 +00:00
* @ return int Returns 1 if any settings haven ' t been initialised , 0 if they all have
*/
function any_new_admin_settings ( & $node ) {
if ( is_a ( $node , 'admin_category' )) {
$entries = array_keys ( $node -> children );
foreach ( $entries as $entry ) {
if ( any_new_admin_settings ( $node -> children [ $entry ]) ){
return 1 ;
}
}
}
if ( is_a ( $node , 'admin_settingpage' )) {
foreach ( $node -> settings as $setting ) {
if ( $setting -> get_setting () === NULL ) {
return 1 ;
}
}
}
return 0 ;
}
2006-09-25 07:35:43 +00:00
?>