Commit | Line | Data |
---|---|---|
a084ac0d | 1 | <?php |
6077020a | 2 | /////////////////////////////////////////////////////////////////////////// |
3 | // // | |
4 | // Moodle configuration file // | |
5 | // // | |
6 | // This file should be renamed "config.php" in the top-level directory // | |
7 | // // | |
8 | /////////////////////////////////////////////////////////////////////////// | |
9 | // // | |
10 | // NOTICE OF COPYRIGHT // | |
11 | // // | |
12 | // Moodle - Modular Object-Oriented Dynamic Learning Environment // | |
c6b456f6 | 13 | // http://moodle.org // |
6077020a | 14 | // // |
3b365361 | 15 | // Copyright (C) 1999 onwards Martin Dougiamas http://moodle.com // |
6077020a | 16 | // // |
17 | // This program is free software; you can redistribute it and/or modify // | |
18 | // it under the terms of the GNU General Public License as published by // | |
554a3c4c | 19 | // the Free Software Foundation; either version 3 of the License, or // |
6077020a | 20 | // (at your option) any later version. // |
21 | // // | |
22 | // This program is distributed in the hope that it will be useful, // | |
23 | // but WITHOUT ANY WARRANTY; without even the implied warranty of // | |
24 | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // | |
25 | // GNU General Public License for more details: // | |
26 | // // | |
27 | // http://www.gnu.org/copyleft/gpl.html // | |
28 | // // | |
29 | /////////////////////////////////////////////////////////////////////////// | |
30 | unset($CFG); // Ignore this line | |
b30fa335 | 31 | global $CFG; // This is necessary here for PHPUnit execution |
c57e9015 | 32 | $CFG = new stdClass(); |
6077020a | 33 | |
34 | //========================================================================= | |
35 | // 1. DATABASE SETUP | |
36 | //========================================================================= | |
37 | // First, you need to configure the database where all Moodle data // | |
38 | // will be stored. This database must already have been created // | |
39 | // and a username/password created to access it. // | |
6077020a | 40 | |
26101906 | 41 | $CFG->dbtype = 'pgsql'; // 'pgsql', 'mariadb', 'mysqli', 'sqlsrv' or 'oci' |
d0bf00e0 DM |
42 | $CFG->dblibrary = 'native'; // 'native' only at the moment |
43 | $CFG->dbhost = 'localhost'; // eg 'localhost' or 'db.isp.com' or IP | |
44 | $CFG->dbname = 'moodle'; // database name, eg moodle | |
45 | $CFG->dbuser = 'username'; // your database username | |
46 | $CFG->dbpass = 'password'; // your database password | |
47 | $CFG->prefix = 'mdl_'; // prefix to use for all table names | |
48 | $CFG->dboptions = array( | |
49 | 'dbpersist' => false, // should persistent database connections be | |
50 | // used? set to 'false' for the most stable | |
51 | // setting, 'true' can improve performance | |
52 | // sometimes | |
3c1293fe PS |
53 | 'dbsocket' => false, // should connection via UNIX socket be used? |
54 | // if you set it to 'true' or custom path | |
55 | // here set dbhost to 'localhost', | |
56 | // (please note mysql is always using socket | |
57 | // if dbhost is 'localhost' - if you need | |
58 | // local port connection use '127.0.0.1') | |
d0bf00e0 DM |
59 | 'dbport' => '', // the TCP port number to use when connecting |
60 | // to the server. keep empty string for the | |
61 | // default port | |
f834a8f5 RS |
62 | 'dbhandlesoptions' => false,// On PostgreSQL poolers like pgbouncer don't |
63 | // support advanced options on connection. | |
64 | // If you set those in the database then | |
65 | // the advanced settings will not be sent. | |
0bbefd81 AG |
66 | 'dbcollation' => 'utf8mb4_unicode_ci', // MySQL has partial and full UTF-8 |
67 | // support. If you wish to use partial UTF-8 | |
68 | // (three bytes) then set this option to | |
69 | // 'utf8_unicode_ci', otherwise this option | |
70 | // can be removed for MySQL (by default it will | |
71 | // use 'utf8mb4_unicode_ci'. This option should | |
72 | // be removed for all other databases. | |
34aeacad | 73 | // 'fetchbuffersize' => 100000, // On PostgreSQL, this option sets a limit |
74 | // on the number of rows that are fetched into | |
75 | // memory when doing a large recordset query | |
76 | // (e.g. search indexing). Default is 100000. | |
77 | // Uncomment and set to a value to change it, | |
78 | // or zero to turn off the limit. You need to | |
79 | // set to zero if you are using pg_bouncer in | |
80 | // 'transaction' mode (it is fine in 'session' | |
81 | // mode). | |
46cfde3d S |
82 | /* |
83 | 'connecttimeout' => null, // Set connect timeout in seconds. Not all drivers support it. | |
84 | 'readonly' => [ // Set to read-only slave details, to get safe reads | |
85 | // from there instead of the master node. Optional. | |
86 | // Currently supported by pgsql and mysqli variety classes. | |
87 | // If not supported silently ignored. | |
88 | 'instance' => [ // Readonly slave connection parameters | |
89 | [ | |
90 | 'dbhost' => 'slave.dbhost', | |
91 | 'dbport' => '', // Defaults to master port | |
92 | 'dbuser' => '', // Defaults to master user | |
93 | 'dbpass' => '', // Defaults to master password | |
94 | ], | |
95 | [...], | |
96 | ], | |
97 | ||
98 | Instance(s) can alternatively be specified as: | |
99 | ||
100 | 'instance' => 'slave.dbhost', | |
101 | 'instance' => ['slave.dbhost1', 'slave.dbhost2'], | |
102 | 'instance' => ['dbhost' => 'slave.dbhost', 'dbport' => '', 'dbuser' => '', 'dbpass' => ''], | |
103 | ||
104 | 'connecttimeout' => 2, // Set read-only slave connect timeout in seconds. See above. | |
105 | 'latency' => 0.5, // Set read-only slave sync latency in seconds. | |
106 | // When 'latency' seconds have lapsed after an update to a table | |
107 | // it is deemed safe to use readonly slave for reading from the table. | |
108 | // It is optional. If omitted once written to a table it will always | |
109 | // use master handle for reading. | |
110 | // Lower values increase the performance, but setting it too low means | |
111 | // missing the master-slave sync. | |
112 | 'exclude_tables' => [ // Tables to exclude from read-only slave feature. | |
113 | 'table1', // Should not be used, unless in rare cases when some area of the system | |
114 | 'table2', // is malfunctioning and you still want to use readonly feature. | |
115 | ], // Then one can exclude offending tables while investigating. | |
116 | ||
117 | More info available in lib/dml/moodle_read_slave_trait.php where the feature is implemented. | |
118 | ] | |
119 | */ | |
120 | // For all database config settings see https://docs.moodle.org/en/Database_settings | |
d0bf00e0 | 121 | ); |
1e55ed26 | 122 | |
6077020a | 123 | |
9d975de4 | 124 | //========================================================================= |
ec2d8ceb | 125 | // 2. WEB SITE LOCATION |
6077020a | 126 | //========================================================================= |
127 | // Now you need to tell Moodle where it is located. Specify the full | |
eb2042f6 | 128 | // web address to where moodle has been installed. If your web site |
129 | // is accessible via multiple URLs then choose the most natural one | |
6077020a | 130 | // that your students would use. Do not include a trailing slash |
11e7b506 | 131 | // |
132 | // If you need both intranet and Internet access please read | |
133 | // http://docs.moodle.org/en/masquerading | |
6077020a | 134 | |
135 | $CFG->wwwroot = 'http://example.com/moodle'; | |
136 | ||
137 | ||
6077020a | 138 | //========================================================================= |
ec2d8ceb | 139 | // 3. DATA FILES LOCATION |
6077020a | 140 | //========================================================================= |
141 | // Now you need a place where Moodle can save uploaded files. This | |
eb2042f6 | 142 | // directory should be readable AND WRITEABLE by the web server user |
143 | // (usually 'nobody' or 'apache'), but it should not be accessible | |
6077020a | 144 | // directly via the web. |
145 | // | |
146 | // - On hosting systems you might need to make sure that your "group" has | |
147 | // no permissions at all, but that "others" have full permissions. | |
148 | // | |
149 | // - On Windows systems you might specify something like 'c:\moodledata' | |
150 | ||
151 | $CFG->dataroot = '/home/example/moodledata'; | |
152 | ||
153 | ||
154 | //========================================================================= | |
ec2d8ceb | 155 | // 4. DATA FILES PERMISSIONS |
6077020a | 156 | //========================================================================= |
157 | // The following parameter sets the permissions of new directories | |
eb2042f6 | 158 | // created by Moodle within the data directory. The format is in |
6077020a | 159 | // octal format (as used by the Unix utility chmod, for example). |
eb2042f6 | 160 | // The default is usually OK, but you may want to change it to 0750 |
6077020a | 161 | // if you are concerned about world-access to the files (you will need |
162 | // to make sure the web server process (eg Apache) can access the files. | |
163 | // NOTE: the prefixed 0 is important, and don't use quotes. | |
164 | ||
d99bab2d | 165 | $CFG->directorypermissions = 02777; |
6077020a | 166 | |
167 | ||
168 | //========================================================================= | |
ec2d8ceb | 169 | // 5. DIRECTORY LOCATION (most people can just ignore this setting) |
6077020a | 170 | //========================================================================= |
eb2042f6 | 171 | // A very few webhosts use /admin as a special URL for you to access a |
172 | // control panel or something. Unfortunately this conflicts with the | |
a36d42a5 PS |
173 | // standard location for the Moodle admin pages. You can work around this |
174 | // by renaming the admin directory in your installation, and putting that | |
175 | // new name here. eg "moodleadmin". This should fix all admin links in Moodle. | |
176 | // After any change you need to visit your new admin directory | |
177 | // and purge all caches. | |
6077020a | 178 | |
179 | $CFG->admin = 'admin'; | |
180 | ||
181 | ||
182 | //========================================================================= | |
ec2d8ceb | 183 | // 6. OTHER MISCELLANEOUS SETTINGS (ignore these for new installations) |
21d1d077 | 184 | //========================================================================= |
185 | // | |
c9ca1fa5 | 186 | // These are additional tweaks for which no GUI exists in Moodle yet. |
187 | // | |
9c733e86 | 188 | // Starting in PHP 5.3 administrators should specify default timezone |
189 | // in PHP.ini, you can also specify it here if needed. | |
190 | // See details at: http://php.net/manual/en/function.date-default-timezone-set.php | |
191 | // List of time zones at: http://php.net/manual/en/timezones.php | |
192 | // date_default_timezone_set('Australia/Perth'); | |
c9ca1fa5 | 193 | // |
1ed96821 | 194 | // Change the key pair lifetime for Moodle Networking |
195 | // The default is 28 days. You would only want to change this if the key | |
196 | // was not getting regenerated for any reason. You would probably want | |
197 | // make it much longer. Note that you'll need to delete and manually update | |
198 | // any existing key. | |
199 | // $CFG->mnetkeylifetime = 28; | |
200 | // | |
77218e4a | 201 | // Not recommended: Set the following to true to allow the use |
202 | // off non-Moodle standard characters in usernames. | |
203 | // $CFG->extendedusernamechars = true; | |
204 | // | |
29ba20ac MD |
205 | // Allow user passwords to be included in backup files. Very dangerous |
206 | // setting as far as it publishes password hashes that can be unencrypted | |
207 | // if the backup file is publicy available. Use it only if you can guarantee | |
208 | // that all your backup files remain only privacy available and are never | |
209 | // shared out from your site/institution! | |
210 | // $CFG->includeuserpasswordsinbackup = true; | |
211 | // | |
b0ccfc5c HF |
212 | // Completely disable user creation when restoring a course, bypassing any |
213 | // permissions granted via roles and capabilities. Enabling this setting | |
214 | // results in the restore process stopping when a user attempts to restore a | |
215 | // course requiring users to be created. | |
5e934890 EL |
216 | // $CFG->disableusercreationonrestore = true; |
217 | // | |
2de3539b EL |
218 | // Keep the temporary directories used by backup and restore without being |
219 | // deleted at the end of the process. Use it if you want to debug / view | |
220 | // all the information stored there after the process has ended. Note that | |
221 | // those directories may be deleted (after some ttl) both by cron and / or | |
222 | // by new backup / restore invocations. | |
223 | // $CFG->keeptempdirectoriesonbackup = true; | |
224 | // | |
5e934890 | 225 | // Modify the restore process in order to force the "user checks" to assume |
b0ccfc5c HF |
226 | // that the backup originated from a different site, so detection of matching |
227 | // users is performed with different (more "relaxed") rules. Note that this is | |
228 | // only useful if the backup file has been created using Moodle < 1.9.4 and the | |
229 | // site has been rebuilt from scratch using backup files (not the best way btw). | |
230 | // If you obtain user conflicts on restore, rather than enabling this setting | |
231 | // permanently, try restoring the backup on a different site, back it up again | |
232 | // and then restore on the target server. | |
5e934890 EL |
233 | // $CFG->forcedifferentsitecheckingusersonrestore = true; |
234 | // | |
c803fa68 EM |
235 | // Force the backup system to continue to create backups in the legacy zip |
236 | // format instead of the new tgz format. Does not affect restore, which | |
237 | // auto-detects the underlying file format. | |
238 | // $CFG->usezipbackups = true; | |
239 | // | |
72df7e1e | 240 | // Prevent stats processing and hide the GUI |
241 | // $CFG->disablestatsprocessing = true; | |
242 | // | |
7758d00f | 243 | // Setting this to true will enable admins to edit any post at any time |
244 | // $CFG->admineditalways = true; | |
cec0a0fc | 245 | // |
5fd1a5d8 | 246 | // These variables define DEFAULT block variables for new courses |
247 | // If this one is set it overrides all others and is the only one used. | |
1ce19cc3 | 248 | // $CFG->defaultblocks_override = 'activity_modules,search_forums,course_list:news_items,calendar_upcoming,recent_activity'; |
3eecaaf4 | 249 | // |
250 | // These variables define the specific settings for defined course formats. | |
5fd1a5d8 | 251 | // They override any settings defined in the formats own config file. |
9574c2ef | 252 | // $CFG->defaultblocks_site = 'site_main_menu,course_list:course_summary,calendar_month'; |
1ce19cc3 AB |
253 | // $CFG->defaultblocks_social = 'search_forums,calendar_month,calendar_upcoming,social_activities,recent_activity,course_list'; |
254 | // $CFG->defaultblocks_topics = 'activity_modules,search_forums,course_list:news_items,calendar_upcoming,recent_activity'; | |
255 | // $CFG->defaultblocks_weeks = 'activity_modules,search_forums,course_list:news_items,calendar_upcoming,recent_activity'; | |
3eecaaf4 | 256 | // |
5fd1a5d8 | 257 | // These blocks are used when no other default setting is found. |
1ce19cc3 | 258 | // $CFG->defaultblocks = 'activity_modules,search_forums,course_list:news_items,calendar_upcoming,recent_activity'; |
3eecaaf4 | 259 | // |
86b5ea0f | 260 | // You can specify a different class to be created for the $PAGE global, and to |
261 | // compute which blocks appear on each page. However, I cannot think of any good | |
262 | // reason why you would need to change that. It just felt wrong to hard-code the | |
3edc37cb | 263 | // the class name. You are strongly advised not to use these to settings unless |
86b5ea0f | 264 | // you are absolutely sure you know what you are doing. |
265 | // $CFG->moodlepageclass = 'moodle_page'; | |
3edc37cb | 266 | // $CFG->moodlepageclassfile = "$CFG->dirroot/local/myplugin/mypageclass.php"; |
86b5ea0f | 267 | // $CFG->blockmanagerclass = 'block_manager'; |
3edc37cb | 268 | // $CFG->blockmanagerclassfile = "$CFG->dirroot/local/myplugin/myblockamanagerclass.php"; |
c81c6d0e | 269 | // |
6b29ba60 | 270 | // Seconds for files to remain in caches. Decrease this if you are worried |
271 | // about students being served outdated versions of uploaded files. | |
0c431257 | 272 | // $CFG->filelifetime = 60*60*6; |
88fea1ca | 273 | // |
d5dd0540 PS |
274 | // Some web servers can offload the file serving from PHP process, |
275 | // comment out one the following options to enable it in Moodle: | |
276 | // $CFG->xsendfile = 'X-Sendfile'; // Apache {@see https://tn123.org/mod_xsendfile/} | |
277 | // $CFG->xsendfile = 'X-LIGHTTPD-send-file'; // Lighttpd {@see http://redmine.lighttpd.net/projects/lighttpd/wiki/X-LIGHTTPD-send-file} | |
278 | // $CFG->xsendfile = 'X-Accel-Redirect'; // Nginx {@see http://wiki.nginx.org/XSendfile} | |
f7d26a05 PS |
279 | // If your X-Sendfile implementation (usually Nginx) uses directory aliases specify them |
280 | // in the following array setting: | |
281 | // $CFG->xsendfilealiases = array( | |
282 | // '/dataroot/' => $CFG->dataroot, | |
283 | // '/cachedir/' => '/var/www/moodle/cache', // for custom $CFG->cachedir locations | |
85b38061 | 284 | // '/localcachedir/' => '/var/local/cache', // for custom $CFG->localcachedir locations |
f7d26a05 PS |
285 | // '/tempdir/' => '/var/www/moodle/temp', // for custom $CFG->tempdir locations |
286 | // '/filedir' => '/var/www/moodle/filedir', // for custom $CFG->filedir locations | |
287 | // ); | |
288 | // | |
7953149e PS |
289 | // YUI caching may be sometimes improved by slasharguments: |
290 | // $CFG->yuislasharguments = 1; | |
291 | // Some servers may need a special rewrite rule to work around internal path length limitations: | |
292 | // RewriteRule (^.*/theme/yui_combo\.php)(/.*) $1?file=$2 | |
f7d26a05 | 293 | // |
d5dd0540 | 294 | // |
d79d5ac2 PS |
295 | // Following settings may be used to select session driver, uncomment only one of the handlers. |
296 | // Database session handler (not compatible with MyISAM): | |
297 | // $CFG->session_handler_class = '\core\session\database'; | |
298 | // $CFG->session_database_acquire_lock_timeout = 120; | |
299 | // | |
300 | // File session handler (file system locking required): | |
301 | // $CFG->session_handler_class = '\core\session\file'; | |
302 | // $CFG->session_file_save_path = $CFG->dataroot.'/sessions'; | |
303 | // | |
304 | // Memcached session handler (requires memcached server and extension): | |
305 | // $CFG->session_handler_class = '\core\session\memcached'; | |
306 | // $CFG->session_memcached_save_path = '127.0.0.1:11211'; | |
307 | // $CFG->session_memcached_prefix = 'memc.sess.key.'; | |
6ec361c6 | 308 | // $CFG->session_memcached_acquire_lock_timeout = 120; |
774c00c7 | 309 | // $CFG->session_memcached_lock_expire = 7200; // Ignored if PECL memcached is below version 2.2.0 |
bd035b98 FW |
310 | // $CFG->session_memcached_lock_retry_sleep = 150; // Spin-lock retry sleeptime (msec). Only effective |
311 | // // for tuning php-memcached 3.0.x (PHP 7) | |
d79d5ac2 | 312 | // |
7f8a816a RS |
313 | // Redis session handler (requires redis server and redis extension): |
314 | // $CFG->session_handler_class = '\core\session\redis'; | |
315 | // $CFG->session_redis_host = '127.0.0.1'; | |
316 | // $CFG->session_redis_port = 6379; // Optional. | |
317 | // $CFG->session_redis_database = 0; // Optional, default is db 0. | |
7782e661 | 318 | // $CFG->session_redis_auth = ''; // Optional, default is don't set one. |
7f8a816a RS |
319 | // $CFG->session_redis_prefix = ''; // Optional, default is don't set one. |
320 | // $CFG->session_redis_acquire_lock_timeout = 120; | |
321 | // $CFG->session_redis_lock_expire = 7200; | |
8eab4f77 BH |
322 | // $CFG->session_redis_lock_retry = 100; // Optional wait between lock attempts in ms, default is 100. |
323 | // // After 5 seconds it will throttle down to once per second. | |
88671590 | 324 | // Use the igbinary serializer instead of the php default one. Note that phpredis must be compiled with |
325 | // igbinary support to make the setting to work. Also, if you change the serializer you have to flush the database! | |
326 | // $CFG->session_redis_serializer_use_igbinary = false; // Optional, default is PHP builtin serializer. | |
f2ee4599 JS |
327 | // $CFG->session_redis_compressor = 'none'; // Optional, possible values are: |
328 | // // 'gzip' - PHP GZip compression | |
329 | // // 'zstd' - PHP Zstandard compression | |
7f8a816a | 330 | // |
89aff0d8 AN |
331 | // Please be aware that when selecting Memcached for sessions that it is advised to use a dedicated |
332 | // memcache server. The memcached extension does not provide isolated environments for individual uses. | |
2c0eb5e6 SH |
333 | // Using the same server for other purposes (MUC for example) can lead to sessions being prematurely removed should |
334 | // the other uses of the server purge the cache. | |
335 | // | |
d79d5ac2 PS |
336 | // Following setting allows you to alter how frequently is timemodified updated in sessions table. |
337 | // $CFG->session_update_timemodified_frequency = 20; // In seconds. | |
46a86dbb | 338 | // |
c57e9015 | 339 | // If this setting is set to true, then Moodle will track the IP of the |
340 | // current user to make sure it hasn't changed during a session. This | |
341 | // will prevent the possibility of sessions being hijacked via XSS, but it | |
366dfa60 | 342 | // may break things for users coming using proxies that change all the time, |
343 | // like AOL. | |
344 | // $CFG->tracksessionip = true; | |
bb64b51a | 345 | // |
bb64b51a | 346 | // The following lines are for handling email bounces. |
5fd1a5d8 | 347 | // $CFG->handlebounces = true; |
348 | // $CFG->minbounces = 10; | |
349 | // $CFG->bounceratio = .20; | |
bb64b51a | 350 | // The next lines are needed both for bounce handling and any other email to module processing. |
351 | // mailprefix must be EXACTLY four characters. | |
c57e9015 | 352 | // Uncomment and customise this block for Postfix |
5fd1a5d8 | 353 | // $CFG->mailprefix = 'mdl+'; // + is the separator for Exim and Postfix. |
c57e9015 | 354 | // $CFG->mailprefix = 'mdl-'; // - is the separator for qmail |
5fd1a5d8 | 355 | // $CFG->maildomain = 'youremaildomain.com'; |
f93426cf | 356 | // |
f11f8ba2 PS |
357 | // Enable when setting up advanced reverse proxy load balancing configurations, |
358 | // it may be also necessary to enable this when using port forwarding. | |
11e7b506 | 359 | // $CFG->reverseproxy = true; |
360 | // | |
361 | // Enable when using external SSL appliance for performance reasons. | |
750688c7 | 362 | // Please note that site may be accessible via http: or https:, but not both! |
11e7b506 | 363 | // $CFG->sslproxy = true; |
364 | // | |
c57e9015 | 365 | // This setting will cause the userdate() function not to fix %d in |
1ac7ee24 | 366 | // date strings, and just let them show with a zero prefix. |
367 | // $CFG->nofixday = true; | |
ce5e431b | 368 | // |
369 | // This setting will make some graphs (eg user logs) use lines instead of bars | |
370 | // $CFG->preferlinegraphs = true; | |
9d5ef892 | 371 | // |
2ab797c9 BH |
372 | // This setting allows you to specify a class to rewrite outgoing urls |
373 | // enabling 'clean urls' in conjunction with an apache / nginx handler. | |
374 | // The handler must implement \core\output\url_rewriter. | |
375 | // $CFG->urlrewriteclass = '\local_cleanurls\url_rewriter'; | |
376 | // | |
18259d4f | 377 | // Enabling this will allow custom scripts to replace existing moodle scripts. |
9677eb79 | 378 | // For example: if $CFG->customscripts/course/view.php exists then |
18259d4f | 379 | // it will be used instead of $CFG->wwwroot/course/view.php |
380 | // At present this will only work for files that include config.php and are called | |
381 | // as part of the url (index.php is implied). | |
382 | // Some examples are: | |
383 | // http://my.moodle.site/course/view.php | |
384 | // http://my.moodle.site/index.php | |
385 | // http://my.moodle.site/admin (index.php implied) | |
386 | // Custom scripts should not include config.php | |
387 | // Warning: Replacing standard moodle scripts may pose security risks and/or may not | |
388 | // be compatible with upgrades. Use this option only if you are aware of the risks | |
c57e9015 | 389 | // involved. |
9677eb79 | 390 | // Specify the full directory path to the custom scripts |
391 | // $CFG->customscripts = '/home/example/customscripts'; | |
18259d4f | 392 | // |
c57e9015 | 393 | // Performance profiling |
394 | // | |
853df85e | 395 | // If you set Debug to "Yes" in the Configuration->Variables page some |
396 | // performance profiling data will show up on your footer (in default theme). | |
397 | // With these settings you get more granular control over the capture | |
398 | // and printout of the data | |
399 | // | |
400 | // Capture performance profiling data | |
401 | // define('MDL_PERF' , true); | |
402 | // | |
403 | // Capture additional data from DB | |
404 | // define('MDL_PERFDB' , true); | |
405 | // | |
406 | // Print to log (for passive profiling of production servers) | |
407 | // define('MDL_PERFTOLOG' , true); | |
408 | // | |
409 | // Print to footer (works with the default theme) | |
410 | // define('MDL_PERFTOFOOT', true); | |
411 | // | |
c646dd26 EL |
412 | // Enable earlier profiling that causes more code to be covered |
413 | // on every request (db connections, config load, other inits...). | |
414 | // Requires extra configuration to be defined in config.php like: | |
415 | // profilingincluded, profilingexcluded, profilingautofrec, | |
416 | // profilingallowme, profilingallowall, profilinglifetime | |
417 | // $CFG->earlyprofilingenabled = true; | |
418 | // | |
05f6ed00 PG |
419 | // Disable database storage for profile data. |
420 | // When using an exernal plugin to store profiling data it is often | |
421 | // desirable to not store the data in the database. | |
422 | // | |
423 | // $CFG->disableprofilingtodatabase = true; | |
424 | // | |
4c202228 | 425 | // Force displayed usernames |
c57e9015 | 426 | // A little hack to anonymise user names for all students. If you set these |
4c202228 | 427 | // then all non-teachers will always see these for every person. |
428 | // $CFG->forcefirstname = 'Bruce'; | |
429 | // $CFG->forcelastname = 'Simpson'; | |
acd2279e | 430 | // |
5c5c16bb | 431 | // The following setting will turn on username logging into Apache log. For full details regarding setting |
432 | // up of this function please refer to the install section of the document. | |
433 | // $CFG->apacheloguser = 0; // Turn this feature off. Default value. | |
434 | // $CFG->apacheloguser = 1; // Log user id. | |
435 | // $CFG->apacheloguser = 2; // Log full name in cleaned format. ie, Darth Vader will be displayed as darth_vader. | |
c57e9015 | 436 | // $CFG->apacheloguser = 3; // Log username. |
bd10cc11 | 437 | // To get the values logged in Apache's log, add to your httpd.conf |
438 | // the following statements. In the General part put: | |
220776ac | 439 | // LogFormat "%h %l %{MOODLEUSER}n %t \"%r\" %s %b \"%{Referer}i\" \"%{User-Agent}i\"" moodleformat |
bd10cc11 | 440 | // And in the part specific to your Moodle install / virtualhost: |
441 | // CustomLog "/your/path/to/log" moodleformat | |
c31a35b5 BH |
442 | // |
443 | // Alternatively for other webservers such as nginx, you can instead have the username sent via a http header | |
444 | // 'X-MOODLEUSER' which can be saved in the logfile and then stripped out before being sent to the browser: | |
445 | // $CFG->headerloguser = 0; // Turn this feature off. Default value. | |
446 | // $CFG->headerloguser = 1; // Log user id. | |
447 | // $CFG->headerloguser = 2; // Log full name in cleaned format. ie, Darth Vader will be displayed as darth_vader. | |
448 | // $CFG->headerloguser = 3; // Log username. | |
449 | // | |
450 | // CAUTION: Use of this option will expose usernames in the Apache / nginx log, | |
bd10cc11 | 451 | // If you are going to publish your log, or the output of your web stats analyzer |
452 | // this will weaken the security of your website. | |
c57e9015 | 453 | // |
454 | // Email database connection errors to someone. If Moodle cannot connect to the | |
880a6f6b | 455 | // database, then email this address with a notice. |
456 | // | |
6b25f553 | 457 | // $CFG->emailconnectionerrorsto = 'your@emailaddress.com'; |
c57e9015 | 458 | // |
6f93e96c | 459 | // Set the priority of themes from highest to lowest. This is useful (for |
460 | // example) in sites where the user theme should override all other theme | |
461 | // settings for accessibility reasons. You can also disable types of themes | |
b7009474 | 462 | // (other than site) by removing them from the array. The default setting is: |
88cb8b78 SA |
463 | // |
464 | // $CFG->themeorder = array('course', 'category', 'session', 'user', 'cohort', 'site'); | |
465 | // | |
466 | // NOTE: course, category, session, user, cohort themes still require the | |
6f93e96c | 467 | // respective settings to be enabled |
468 | // | |
73e504bc PS |
469 | // It is possible to add extra themes directory stored outside of $CFG->dirroot. |
470 | // This local directory does not have to be accessible from internet. | |
471 | // | |
472 | // $CFG->themedir = '/location/of/extra/themes'; | |
473 | // | |
2752739c PS |
474 | // It is possible to specify different cache and temp directories, use local fast filesystem |
475 | // for normal web servers. Server clusters MUST use shared filesystem for cachedir! | |
85b38061 | 476 | // Localcachedir is intended for server clusters, it does not have to be shared by cluster nodes. |
32db0f0d PS |
477 | // The directories must not be accessible via web. |
478 | // | |
ef844148 | 479 | // $CFG->tempdir = '/var/www/moodle/temp'; // Directory MUST BE SHARED by all cluster nodes. |
85b38061 PS |
480 | // $CFG->cachedir = '/var/www/moodle/cache'; // Directory MUST BE SHARED by all cluster nodes, locking required. |
481 | // $CFG->localcachedir = '/var/local/cache'; // Intended for local node caching. | |
9fabe1dd | 482 | // $CFG->localrequestdir = '/tmp'; // Intended for local only temporary files. The defaults uses sys_get_temp_dir(). |
32db0f0d | 483 | // |
ef844148 MS |
484 | // It is possible to specify a different backup temp directory, use local fast filesystem |
485 | // for normal web servers. Server clusters MUST use shared filesystem for backuptempdir! | |
486 | // The directory must not be accessible via web. | |
487 | // | |
488 | // $CFG->backuptempdir = '/var/www/moodle/backuptemp'; // Directory MUST BE SHARED by all cluster nodes. | |
489 | // | |
f0bf9ffe PS |
490 | // Some filesystems such as NFS may not support file locking operations. |
491 | // Locking resolves race conditions and is strongly recommended for production servers. | |
492 | // $CFG->preventfilelocking = false; | |
493 | // | |
56fb6963 DM |
494 | // Site default language can be set via standard administration interface. If you |
495 | // want to have initial error messages for eventual database connection problems | |
496 | // localized too, you have to set your language code here. | |
497 | // | |
498 | // $CFG->lang = 'yourlangcode'; // for example 'cs' | |
499 | // | |
49084fe1 SH |
500 | // When Moodle is about to perform an intensive operation it raises PHP's memory |
501 | // limit. The following setting should be used on large sites to set the raised | |
502 | // memory limit to something higher. | |
503 | // The value for the settings should be a valid PHP memory value. e.g. 512M, 1G | |
e99033b0 | 504 | // |
0a08cb40 | 505 | // $CFG->extramemorylimit = '1024M'; |
e99033b0 | 506 | // |
bb250f02 SH |
507 | // Moodle 2.4 introduced a new cache API. |
508 | // The cache API stores a configuration file within the Moodle data directory and | |
509 | // uses that rather than the database in order to function in a stand-alone manner. | |
510 | // Using altcacheconfigpath you can change the location where this config file is | |
511 | // looked for. | |
512 | // It can either be a directory in which to store the file, or the full path to the | |
513 | // file if you want to take full control. Either way it must be writable by the | |
514 | // webserver. | |
515 | // | |
516 | // $CFG->altcacheconfigpath = '/var/www/shared/moodle.cache.config.php | |
517 | // | |
5aab24ef DM |
518 | // Use the following flag to completely disable the Available update notifications |
519 | // feature and hide it from the server administration UI. | |
520 | // | |
521 | // $CFG->disableupdatenotifications = true; | |
522 | // | |
9137a89a | 523 | // Use the following flag to completely disable the installation of plugins |
b0fc7898 DM |
524 | // (new plugins, available updates and missing dependencies) and related |
525 | // features (such as cancelling the plugin installation or upgrade) via the | |
526 | // server administration web interface. | |
c2c4f722 | 527 | // |
b0fc7898 | 528 | // $CFG->disableupdateautodeploy = true; |
c2c4f722 | 529 | // |
f3807433 AB |
530 | // Use the following flag to disable the warning on the system notifications page |
531 | // about present development libraries. This flag will not disable the warning within | |
532 | // the security overview report. Use this flag only if you really have prohibited web | |
533 | // access to the development libraries in your webserver configuration. | |
534 | // | |
535 | // $CFG->disabledevlibdirscheck = true; | |
536 | // | |
f12f3416 AN |
537 | // Use the following flag to disable modifications to scheduled tasks |
538 | // whilst still showing the state of tasks. | |
539 | // | |
540 | // $CFG->preventscheduledtaskchanges = true; | |
541 | // | |
436dbeec SH |
542 | // As of version 2.4 Moodle serves icons as SVG images if the users browser appears |
543 | // to support SVG. | |
544 | // For those wanting to control the serving of SVG images the following setting can | |
545 | // be defined in your config.php. | |
546 | // If it is not defined then the default (browser detection) will occur. | |
547 | // | |
548 | // To ensure they are always used when available: | |
549 | // $CFG->svgicons = true; | |
550 | // | |
551 | // To ensure they are never used even when available: | |
552 | // $CFG->svgicons = false; | |
553 | // | |
9a2b5e0b HD |
554 | // Some administration options allow setting the path to executable files. This can |
555 | // potentially cause a security risk. Set this option to true to disable editing | |
556 | // those config settings via the web. They will need to be set explicitly in the | |
557 | // config.php file | |
558 | // $CFG->preventexecpath = true; | |
559 | // | |
3bcf6b3c RT |
560 | // Use the following flag to set userid for noreply user. If not set then moodle will |
561 | // create dummy user and use -ve value as user id. | |
562 | // $CFG->noreplyuserid = -10; | |
563 | // | |
564 | // As of version 2.6 Moodle supports admin to set support user. If not set, all mails | |
565 | // will be sent to supportemail. | |
566 | // $CFG->supportuserid = -20; | |
567 | // | |
9843e5ec | 568 | // Moodle 2.7 introduces a locking api for critical tasks (e.g. cron). |
262061d6 BH |
569 | // The default locking system to use is DB locking for Postgres, MySQL, MariaDB and |
570 | // file locking for Oracle and SQLServer. If $CFG->preventfilelocking is set, then the | |
571 | // default will always be DB locking. It can be manually set to one of the lock | |
9843e5ec DW |
572 | // factory classes listed below, or one of your own custom classes implementing the |
573 | // \core\lock\lock_factory interface. | |
574 | // | |
575 | // $CFG->lock_factory = "auto"; | |
576 | // | |
577 | // The list of available lock factories is: | |
578 | // | |
579 | // "\\core\\lock\\file_lock_factory" - File locking | |
580 | // Uses lock files stored by default in the dataroot. Whether this | |
581 | // works on clusters depends on the file system used for the dataroot. | |
582 | // | |
308e481c | 583 | // "\\core\\lock\\db_record_lock_factory" - DB locking based on table rows. |
9843e5ec | 584 | // |
262061d6 BH |
585 | // "\\core\\lock\\mysql_lock_factory" - DB locking based on MySQL / MariaDB locks. |
586 | // | |
9843e5ec DW |
587 | // "\\core\\lock\\postgres_lock_factory" - DB locking based on postgres advisory locks. |
588 | // | |
9843e5ec DW |
589 | // Settings used by the lock factories |
590 | // | |
591 | // Location for lock files used by the File locking factory. This must exist | |
592 | // on a shared file system that supports locking. | |
092acd53 | 593 | // $CFG->file_lock_root = $CFG->dataroot . '/lock'; |
9843e5ec | 594 | // |
4b71596f AN |
595 | // |
596 | // Alternative task logging. | |
597 | // Since Moodle 3.7 the output of al scheduled and adhoc tasks is stored in the database and it is possible to use an | |
598 | // alternative task logging mechanism. | |
599 | // To set the alternative task logging mechanism in config.php you can use the following settings, providing the | |
600 | // alternative class name that will be auto-loaded. | |
601 | // | |
602 | // $CFG->task_log_class = '\\local_mytasklogger\\logger'; | |
603 | // | |
91fed57a | 604 | // Moodle 2.9 allows administrators to customise the list of supported file types. |
605 | // To add a new filetype or override the definition of an existing one, set the | |
606 | // customfiletypes variable like this: | |
607 | // | |
608 | // $CFG->customfiletypes = array( | |
609 | // (object)array( | |
610 | // 'extension' => 'frog', | |
611 | // 'icon' => 'archive', | |
612 | // 'type' => 'application/frog', | |
613 | // 'customdescription' => 'Amphibian-related file archive' | |
614 | // ) | |
615 | // ); | |
616 | // | |
617 | // The extension, icon, and type fields are required. The icon field can refer to | |
618 | // any icon inside the pix/f folder. You can also set the customdescription field | |
619 | // (shown above) and (for advanced use) the groups, string, and defaulticon fields. | |
620 | // | |
98b32c9e DM |
621 | // Upgrade key |
622 | // | |
df15a718 DP |
623 | // If the upgrade key is defined here, then the value must be provided every time |
624 | // the site is being upgraded though the web interface, regardless of whether the | |
625 | // administrator is logged in or not. This prevents anonymous access to the upgrade | |
626 | // screens where the real authentication and authorization mechanisms can not be | |
627 | // relied on. | |
98b32c9e DM |
628 | // |
629 | // It is strongly recommended to use a value different from your real account | |
630 | // password. | |
631 | // | |
632 | // $CFG->upgradekey = 'put_some_password-like_value_here'; | |
633 | // | |
b722a457 AO |
634 | // Document conversion limit |
635 | // | |
636 | // How many times the background task should attempt to convert a given attempt | |
637 | // before removing it from the queue. Currently this limit is only used by the | |
638 | // mod_assign conversion task. | |
639 | // | |
640 | // $CFG->conversionattemptlimit = 3; | |
641 | // | |
490e48a4 DW |
642 | // Font used in exported PDF files. When generating a PDF, Moodle embeds a subset of |
643 | // the font in the PDF file so it will be readable on the widest range of devices. | |
644 | // The default font is 'freesans' which is part of the GNU FreeFont collection. | |
645 | // | |
646 | // $CFG->pdfexportfont = 'freesans'; | |
647 | // | |
32791416 SA |
648 | // Use the following flag to enable messagingallusers and set the default preference |
649 | // value for existing users to allow them to be contacted by other site users. | |
650 | // | |
651 | // $CFG->keepmessagingallusersenabled = true; | |
652 | // | |
6dfe4283 DW |
653 | // Disable login token validation for login pages. Login token validation is enabled |
654 | // by default unless $CFG->alternateloginurl is set. | |
655 | // | |
656 | // $CFG->disablelogintoken = true; | |
657 | // | |
ff13ae59 | 658 | // Moodle 3.7+ checks that cron is running frequently. If the time between cron runs |
659 | // is greater than this value (in seconds), you get a warning on the admin page. (This | |
660 | // setting only controls whether or not the warning appears, it has no other effect.) | |
661 | // | |
662 | // $CFG->expectedcronfrequency = 200; | |
663 | // | |
59a44a5b BH |
664 | // Moodle 3.9+ checks how old tasks are in the ad hoc queue and warns at 10 minutes |
665 | // and errors at 4 hours. Set these to override these limits: | |
666 | // | |
667 | // $CFG->adhoctaskagewarn = 10 * 60; | |
668 | // $CFG->adhoctaskageerror = 4 * 60 * 60; | |
669 | // | |
fdb9c321 TM |
670 | // Session lock warning threshold. Long running pages should release the session using \core\session\manager::write_close(). |
671 | // Set this threshold to any value greater than 0 to add developer warnings when a page locks the session for too long. | |
672 | // The session should rarely be locked for more than 1 second. The input should be in seconds and may be a float. | |
673 | // | |
674 | // $CFG->debugsessionlock = 5; | |
675 | // | |
4400ed3e MN |
676 | // There are times when a session lock is not required during a request. For a page/service to opt-in whether or not a |
677 | // session lock is required this setting must first be set to 'true'. | |
678 | // This is an experimental issue. The session store can not be in the session, please | |
679 | // see https://docs.moodle.org/en/Session_handling#Read_only_sessions. | |
680 | // | |
681 | // $CFG->enable_read_only_sessions = true; | |
682 | // | |
1dadeaeb BH |
683 | // To help expose all the edge cases bugs a debug mode is available which shows the same |
684 | // runtime write during readonly errors without actually turning on the readonly sessions: | |
685 | // | |
686 | // $CFG->enable_read_only_sessions_debug = true; | |
687 | // | |
442eeac3 PB |
688 | // Uninstall plugins from CLI only. This stops admins from uninstalling plugins from the graphical admin |
689 | // user interface, and forces plugins to be uninstalled from the Command Line tool only, found at | |
690 | // admin/cli/plugin_uninstall.php. | |
691 | // | |
692 | // $CFG->uninstallclionly = true; | |
693 | // | |
5aacd5e7 TH |
694 | // |
695 | // Customise question bank display | |
696 | // | |
697 | // The display of Moodle's question bank is made up of a number of columns. | |
698 | // You can customise this display by giving a comma-separated list of column class | |
699 | // names here. Each class must be a subclass of \core_question\bank\column_base. | |
700 | // For example you might define a class like | |
701 | // class \local_qbank_extensions\my_column extends \core_question\bank\column_base | |
702 | // in a local plugin, then add it to the list here. At the time of writing, | |
703 | // the default question bank display is equivalent to the following, but you might like | |
704 | // to check the latest default in question/classes/bank/view.php before setting this. | |
705 | // | |
706 | // $CFG->questionbankcolumns = 'checkbox_column,question_type_column,' | |
c11c8892 | 707 | // . 'question_name_idnumber_tags_column,edit_menu_column,' |
701ae1eb TH |
708 | // . 'tags_action_column,edit_action_column,copy_action_column,' |
709 | // . 'preview_action_column,delete_action_column,export_xml_action_column,' | |
c11c8892 | 710 | // . 'creator_name_column,modifier_name_column'; |
5aacd5e7 | 711 | // |
d21d6baa MH |
712 | // Forum summary report |
713 | // | |
714 | // In order for the forum summary report to calculate word count and character count data, those details are now stored | |
715 | // for each post in the database when posts are created or updated. For posts that existed prior to a Moodle 3.8 upgrade, | |
716 | // these are calculated by the refresh_forum_post_counts ad-hoc task in chunks of 5000 posts per batch by default. | |
717 | // That default can be overridden by setting an integer value for $CFG->forumpostcountchunksize. | |
718 | // | |
719 | // $CFG->forumpostcountchunksize = 5000; | |
720 | // | |
10db3a0b NN |
721 | // Course and category sorting |
722 | // | |
723 | // If the number of courses in a category exceeds $CFG->maxcoursesincategory (10000 by default), it may lead to duplicate | |
724 | // sort orders of courses in separated categories. For example: | |
725 | // - Category A has the sort order of 10000, and has 10000 courses. The last course will have the sort order of 20000. | |
726 | // - Category B has the sort order of 20000, and has a course with the sort order of 20001. | |
727 | // - If we add another course in category A, it will have a sort order of 20001, | |
728 | // which is the same as the course in category B | |
729 | // The duplicate will cause sorting issue and hence we need to increase $CFG->maxcoursesincategory | |
730 | // to fix the duplicate sort order | |
731 | // Please also make sure $CFG->maxcoursesincategory * MAX_COURSE_CATEGORIES less than max integer. | |
732 | // | |
733 | // $CFG->maxcoursesincategory = 10000; | |
734 | // | |
ddbafce0 | 735 | // Admin setting encryption |
736 | // | |
737 | // $CFG->secretdataroot = '/var/www/my_secret_folder'; | |
738 | // | |
739 | // Location to store encryption keys. By default this is $CFG->dataroot/secret; set this if | |
740 | // you want to use a different location for increased security (e.g. if too many people have access | |
741 | // to the main dataroot, or if you want to avoid using shared storage). Your web server user needs | |
742 | // read access to this location, and write access unless you manually create the keys. | |
743 | // | |
744 | // $CFG->nokeygeneration = false; | |
745 | // | |
746 | // If you change this to true then the server will give an error if keys don't exist, instead of | |
747 | // automatically generating them. This is only needed if you want to ensure that keys are consistent | |
748 | // across a cluster when not using shared storage. If you stop the server generating keys, you will | |
749 | // need to manually generate them by running 'php admin/cli/generate_key.php'. | |
750 | ||
84ebf08d | 751 | //========================================================================= |
ec2d8ceb | 752 | // 7. SETTINGS FOR DEVELOPMENT SERVERS - not intended for production use!!! |
84ebf08d | 753 | //========================================================================= |
f4fa5a63 | 754 | // |
91ee8a67 | 755 | // Force a debugging mode regardless the settings in the site administration |
d9d61fa3 PS |
756 | // @error_reporting(E_ALL | E_STRICT); // NOT FOR PRODUCTION SERVERS! |
757 | // @ini_set('display_errors', '1'); // NOT FOR PRODUCTION SERVERS! | |
758 | // $CFG->debug = (E_ALL | E_STRICT); // === DEBUG_DEVELOPER - NOT FOR PRODUCTION SERVERS! | |
759 | // $CFG->debugdisplay = 1; // NOT FOR PRODUCTION SERVERS! | |
91ee8a67 | 760 | // |
0ed26d12 PS |
761 | // You can specify a comma separated list of user ids that that always see |
762 | // debug messages, this overrides the debug flag in $CFG->debug and $CFG->debugdisplay | |
763 | // for these users only. | |
764 | // $CFG->debugusers = '2'; | |
765 | // | |
91ee8a67 | 766 | // Prevent theme caching |
770a25c6 | 767 | // $CFG->themedesignermode = true; // NOT FOR PRODUCTION SERVERS! |
91ee8a67 | 768 | // |
644f44cf BH |
769 | // Enable verbose debug information during fetching of email messages from IMAP server. |
770 | // $CFG->debugimap = true; | |
771 | // | |
22dfa6d3 DM |
772 | // Enable verbose debug information during sending of email messages to SMTP server. |
773 | // Note: also requires $CFG->debug set to DEBUG_DEVELOPER. | |
774 | // $CFG->debugsmtp = true; | |
775 | // | |
a45e8fd3 | 776 | // Prevent JS caching |
770a25c6 | 777 | // $CFG->cachejs = false; // NOT FOR PRODUCTION SERVERS! |
a45e8fd3 | 778 | // |
5beb3885 MN |
779 | // Prevent Template caching |
780 | // $CFG->cachetemplates = false; // NOT FOR PRODUCTION SERVERS! | |
781 | // | |
fa64202a AN |
782 | // Restrict which YUI logging statements are shown in the browser console. |
783 | // For details see the upstream documentation: | |
784 | // http://yuilibrary.com/yui/docs/api/classes/config.html#property_logInclude | |
785 | // http://yuilibrary.com/yui/docs/api/classes/config.html#property_logExclude | |
786 | // $CFG->yuiloginclude = array( | |
fa64202a AN |
787 | // 'moodle-course-categoryexpander' => true, |
788 | // ); | |
789 | // $CFG->yuilogexclude = array( | |
fa64202a AN |
790 | // 'moodle-core-notification' => true, |
791 | // ); | |
792 | // | |
793 | // Set the minimum log level for YUI logging statements. | |
794 | // For details see the upstream documentation: | |
795 | // http://yuilibrary.com/yui/docs/api/classes/config.html#property_logLevel | |
796 | // $CFG->yuiloglevel = 'debug'; | |
797 | // | |
598a82c9 | 798 | // Prevent core_string_manager application caching |
e799e819 | 799 | // $CFG->langstringcache = false; // NOT FOR PRODUCTION SERVERS! |
f53fde9f | 800 | // |
38d93cb0 PS |
801 | // When working with production data on test servers, no emails or other messages |
802 | // should ever be send to real users | |
91ee8a67 | 803 | // $CFG->noemailever = true; // NOT FOR PRODUCTION SERVERS! |
49da4a5f DM |
804 | // |
805 | // Divert all outgoing emails to this address to test and debug emailing features | |
91ee8a67 | 806 | // $CFG->divertallemailsto = 'root@localhost.local'; // NOT FOR PRODUCTION SERVERS! |
1045a007 | 807 | // |
eca8cf67 BH |
808 | // Except for certain email addresses you want to let through for testing. Accepts |
809 | // a comma separated list of regexes. | |
810 | // $CFG->divertallemailsexcept = 'tester@dev.com, fred(\+.*)?@example.com'; // NOT FOR PRODUCTION SERVERS! | |
811 | // | |
76f2fcde | 812 | // Uncomment if you want to allow empty comments when modifying install.xml files. |
91ee8a67 | 813 | // $CFG->xmldbdisablecommentchecking = true; // NOT FOR PRODUCTION SERVERS! |
1045a007 | 814 | // |
815 | // Since 2.0 sql queries are not shown during upgrade by default. | |
816 | // Please note that this setting may produce very long upgrade page on large sites. | |
91ee8a67 | 817 | // $CFG->upgradeshowsql = true; // NOT FOR PRODUCTION SERVERS! |
12bb0c3e | 818 | // |
ddd11b6c PS |
819 | // Add SQL queries to the output of cron, just before their execution |
820 | // $CFG->showcronsql = true; | |
821 | // | |
822 | // Force developer level debug and add debug info to the output of cron | |
823 | // $CFG->showcrondebugging = true; | |
824 | // | |
16f05b5c PH |
825 | // Force result of checks used to determine whether a site is considered "public" or not (such as for site registration). |
826 | // $CFG->site_is_public = false; | |
827 | // | |
12bb0c3e | 828 | //========================================================================= |
ec2d8ceb | 829 | // 8. FORCED SETTINGS |
12bb0c3e PS |
830 | //========================================================================= |
831 | // It is possible to specify normal admin settings here, the point is that | |
832 | // they can not be changed through the standard admin settings pages any more. | |
833 | // | |
834 | // Core settings are specified directly via assignment to $CFG variable. | |
835 | // Example: | |
836 | // $CFG->somecoresetting = 'value'; | |
837 | // | |
838 | // Plugin settings have to be put into a special array. | |
839 | // Example: | |
840 | // $CFG->forced_plugin_settings = array('pluginname' => array('settingname' => 'value', 'secondsetting' => 'othervalue'), | |
841 | // 'otherplugin' => array('mysetting' => 'myvalue', 'thesetting' => 'thevalue')); | |
3c88a678 DW |
842 | // Module default settings with advanced/locked checkboxes can be set too. To do this, add |
843 | // an extra config with '_adv' or '_locked' as a suffix and set the value to true or false. | |
844 | // Example: | |
845 | // $CFG->forced_plugin_settings = array('pluginname' => array('settingname' => 'value', 'settingname_locked' => true, 'settingname_adv' => true)); | |
5bd40408 PS |
846 | // |
847 | //========================================================================= | |
ec2d8ceb | 848 | // 9. PHPUNIT SUPPORT |
5bd40408 PS |
849 | //========================================================================= |
850 | // $CFG->phpunit_prefix = 'phpu_'; | |
851 | // $CFG->phpunit_dataroot = '/home/example/phpu_moodledata'; | |
852 | // $CFG->phpunit_directorypermissions = 02777; // optional | |
8f7dcb34 | 853 | // $CFG->phpunit_profilingenabled = true; // optional to profile PHPUnit runs. |
a09534f4 | 854 | // |
ec2d8ceb SC |
855 | // |
856 | //========================================================================= | |
857 | // 10. SECRET PASSWORD SALT | |
858 | //========================================================================= | |
6780a1d3 PŠ |
859 | // A site-wide password salt is no longer used in new installations. |
860 | // If upgrading from 2.6 or older, keep all existing salts in config.php file. | |
ec2d8ceb SC |
861 | // |
862 | // $CFG->passwordsaltmain = 'a_very_long_random_string_of_characters#@6&*1'; | |
863 | // | |
864 | // You may also have some alternative salts to allow migration from previously | |
865 | // used salts. | |
866 | // | |
867 | // $CFG->passwordsaltalt1 = ''; | |
868 | // $CFG->passwordsaltalt2 = ''; | |
869 | // $CFG->passwordsaltalt3 = ''; | |
870 | // .... | |
871 | // $CFG->passwordsaltalt19 = ''; | |
872 | // $CFG->passwordsaltalt20 = ''; | |
873 | // | |
874 | // | |
a09534f4 DM |
875 | //========================================================================= |
876 | // 11. BEHAT SUPPORT | |
877 | //========================================================================= | |
60129d5d | 878 | // Behat test site needs a unique www root, data directory and database prefix: |
f8cb3e62 | 879 | // |
60129d5d | 880 | // $CFG->behat_wwwroot = 'http://127.0.0.1/moodle'; |
f8cb3e62 PS |
881 | // $CFG->behat_prefix = 'bht_'; |
882 | // $CFG->behat_dataroot = '/home/example/bht_moodledata'; | |
883 | // | |
d6abac76 DM |
884 | // You can override default Moodle configuration for Behat and add your own |
885 | // params; here you can add more profiles, use different Mink drivers than Selenium... | |
096858ed DM |
886 | // These params would be merged with the default Moodle behat.yml, giving priority |
887 | // to the ones specified here. The array format is YAML, following the Behat | |
d6abac76 DM |
888 | // params hierarchy. More info: http://docs.behat.org/guides/7.config.html |
889 | // Example: | |
bd770617 | 890 | // $CFG->behat_config = array( |
ae689a96 | 891 | // 'Mac-Firefox' => array( |
42ad096f RT |
892 | // 'suites' => array ( |
893 | // 'default' => array( | |
894 | // 'filters' => array( | |
895 | // 'tags' => '~@_file_upload' | |
896 | // ), | |
897 | // ), | |
898 | // ), | |
ae689a96 | 899 | // 'extensions' => array( |
42ad096f | 900 | // 'Behat\MinkExtension' => array( |
230896b7 | 901 | // 'webddriver' => array( |
ae689a96 DM |
902 | // 'browser' => 'firefox', |
903 | // 'capabilities' => array( | |
904 | // 'platform' => 'OS X 10.6', | |
905 | // 'version' => 20 | |
906 | // ) | |
907 | // ) | |
908 | // ) | |
909 | // ) | |
910 | // ), | |
911 | // 'Mac-Safari' => array( | |
912 | // 'extensions' => array( | |
42ad096f | 913 | // 'Behat\MinkExtension' => array( |
230896b7 | 914 | // 'webddriver' => array( |
ae689a96 DM |
915 | // 'browser' => 'safari', |
916 | // 'capabilities' => array( | |
917 | // 'platform' => 'OS X 10.8', | |
918 | // 'version' => 6 | |
919 | // ) | |
920 | // ) | |
921 | // ) | |
922 | // ) | |
d6abac76 DM |
923 | // ) |
924 | // ); | |
0e1c34e5 RT |
925 | // You can also use the following config to override default Moodle configuration for Behat. |
926 | // This config is limited to default suite and will be supported in later versions. | |
927 | // It will have precedence over $CFG->behat_config. | |
928 | // $CFG->behat_profiles = array( | |
929 | // 'phantomjs' => array( | |
930 | // 'browser' => 'phantomjs', | |
931 | // 'tags' => '~@_file_upload&&~@_alert&&~@_bug_phantomjs', | |
932 | // 'wd_host' => 'http://127.0.0.1:4443/wd/hub', | |
933 | // 'capabilities' => array( | |
934 | // 'platform' => 'Linux', | |
935 | // 'version' => 2.1 | |
936 | // ) | |
937 | // ), | |
938 | // ); | |
d6abac76 | 939 | // |
401f60d5 DM |
940 | // All this page's extra Moodle settings are compared against a white list of allowed settings |
941 | // (the basic and behat_* ones) to avoid problems with production environments. This setting can be | |
942 | // used to expand the default white list with an array of extra settings. | |
943 | // Example: | |
d0c2bc64 | 944 | // $CFG->behat_extraallowedsettings = array('somecoresetting', ...); |
1325d493 | 945 | // |
c3a40dea DM |
946 | // You should explicitly allow the usage of the deprecated behat steps, otherwise an exception will |
947 | // be thrown when using them. The setting is disabled by default. | |
948 | // Example: | |
949 | // $CFG->behat_usedeprecated = true; | |
950 | // | |
05a5d547 | 951 | // If you are using a slow machine, it may help to increase the timeouts that Behat uses. The |
952 | // following example will increase timeouts by a factor of 3 (using 30 seconds instead of 10 | |
953 | // seconds, for instance). | |
954 | // Example: | |
955 | // $CFG->behat_increasetimeout = 3; | |
956 | // | |
ddb0a1b0 AB |
957 | // Including feature files from directories outside the dirroot is possible if required. The setting |
958 | // requires that the running user has executable permissions on all parent directories in the paths. | |
959 | // Example: | |
960 | // $CFG->behat_additionalfeatures = array('/home/developer/code/wipfeatures'); | |
961 | // | |
a964ead0 AN |
962 | // You can make behat save several dumps when a scenario fails. The dumps currently saved are: |
963 | // * a dump of the DOM in it's state at the time of failure; and | |
964 | // * a screenshot (JavaScript is required for the screenshot functionality, so not all browsers support this option) | |
5c0dfe32 | 965 | // Example: |
a964ead0 | 966 | // $CFG->behat_faildump_path = '/my/path/to/save/failure/dumps'; |
5c0dfe32 | 967 | // |
0b07ea42 AN |
968 | // You can make behat pause upon failure to help you diagnose and debug problems with your tests. |
969 | // | |
970 | // $CFG->behat_pause_on_fail = true; | |
971 | // | |
3c71c15c RT |
972 | // You can specify db, selenium wd_host etc. for behat parallel run by setting following variable. |
973 | // Example: | |
974 | // $CFG->behat_parallel_run = array ( | |
975 | // array ( | |
976 | // 'dbtype' => 'mysqli', | |
977 | // 'dblibrary' => 'native', | |
978 | // 'dbhost' => 'localhost', | |
979 | // 'dbname' => 'moodletest', | |
980 | // 'dbuser' => 'moodle', | |
981 | // 'dbpass' => 'moodle', | |
982 | // 'behat_prefix' => 'mdl_', | |
5b9e6b55 RT |
983 | // 'wd_host' => 'http://127.0.0.1:4444/wd/hub', |
984 | // 'behat_wwwroot' => 'http://127.0.0.1/moodle', | |
985 | // 'behat_dataroot' => '/home/example/bht_moodledata' | |
3c71c15c RT |
986 | // ), |
987 | // ); | |
988 | // | |
52acb7c9 RT |
989 | // To change name of behat parallel run site, define BEHAT_PARALLEL_SITE_NAME and parallel run sites will be suffixed |
990 | // with this value | |
991 | // Example: | |
992 | // define('BEHAT_PARALLEL_SITE_NAME', 'behatparallelsite'); | |
993 | // | |
994 | // Command line output for parallel behat install is limited to 80 chars, if you are installing more then 4 sites and | |
995 | // want to expand output to more then 80 chars, then define BEHAT_MAX_CMD_LINE_OUTPUT | |
996 | // Example: | |
997 | // define('BEHAT_MAX_CMD_LINE_OUTPUT', 120); | |
998 | // | |
999 | // Behat feature files will be distributed randomly between the processes by default. If you have timing file or want | |
1000 | // to create timing file then define BEHAT_FEATURE_TIMING_FILE with path to timing file. It will be updated for each | |
1001 | // run with latest time taken to execute feature. | |
1002 | // Example: | |
1003 | // define('BEHAT_FEATURE_TIMING_FILE', '/PATH_TO_TIMING_FILE/timing.json'); | |
1004 | // | |
1005 | // If you don't have timing file and want some stable distribution of features, then you can use step counts to | |
1006 | // distribute the features. You can generate step file by executing php admin/tool/behat/cli/util.php --updatesteps | |
1007 | // this will update step file which is defined by BEHAT_FEATURE_STEP_FILE. | |
1008 | // Example: | |
1009 | // define('BEHAT_FEATURE_STEP_FILE', '/PATH_TO_FEATURE_STEP_COUNT_FILE/stepcount.json'); | |
1010 | // | |
1011 | // Feature distribution for each process is displayed as histogram. you can disable it by setting | |
1012 | // BEHAT_DISABLE_HISTOGRAM | |
1013 | // Example: | |
1014 | // define('BEHAT_DISABLE_HISTOGRAM', true); | |
1015 | // | |
aafe220a PFO |
1016 | // Mobile app Behat testing requires this option, pointing to a developer Moodle app directory: |
1017 | // $CFG->behat_ionic_dirroot = '/where/I/keep/my/git/checkouts/moodleapp'; | |
1959e164 | 1018 | // |
1019 | // The following option can be used to indicate a running Ionic server (otherwise Behat will start | |
1020 | // one automatically for each test run, which is convenient but takes ages): | |
ff3ccab5 | 1021 | // $CFG->behat_ionic_wwwroot = 'http://localhost:8100'; |
1959e164 | 1022 | // |
1325d493 DM |
1023 | //========================================================================= |
1024 | // 12. DEVELOPER DATA GENERATOR | |
1025 | //========================================================================= | |
1026 | // | |
1027 | // The developer data generator tool is intended to be used only in development or testing sites and | |
1028 | // it's usage in production environments is not recommended; if it is used to create JMeter test plans | |
1029 | // is even less recommended as JMeter needs to log in as site course users. JMeter needs to know the | |
1030 | // users passwords but would be dangerous to have a default password as everybody would know it, which would | |
1031 | // be specially dangerouse if somebody uses this tool in a production site, so in order to prevent unintended | |
1032 | // uses of the tool and undesired accesses as well, is compulsory to set a password for the users | |
1033 | // generated by this tool, but only in case you want to generate a JMeter test. The value should be a string. | |
1034 | // Example: | |
1035 | // $CFG->tool_generator_users_password = 'examplepassword'; | |
1bce3a70 RT |
1036 | // |
1037 | //========================================================================= | |
1038 | // 13. SYSTEM PATHS (You need to set following, depending on your system) | |
1039 | //========================================================================= | |
1040 | // Ghostscript path. | |
1041 | // On most Linux installs, this can be left as '/usr/bin/gs'. | |
1042 | // On Windows it will be something like 'c:\gs\bin\gswin32c.exe' (make sure | |
1043 | // there are no spaces in the path - if necessary copy the files 'gswin32c.exe' | |
1044 | // and 'gsdll32.dll' to a new folder without a space in the path) | |
1045 | // $CFG->pathtogs = '/usr/bin/gs'; | |
1046 | // | |
c759ae5d TBM |
1047 | // Path to PHP CLI. |
1048 | // Probably something like /usr/bin/php. If you enter this, cron scripts can be | |
1049 | // executed from admin web interface. | |
1050 | // $CFG->pathtophp = ''; | |
1051 | // | |
1bce3a70 RT |
1052 | // Path to du. |
1053 | // Probably something like /usr/bin/du. If you enter this, pages that display | |
1054 | // directory contents will run much faster for directories with a lot of files. | |
1055 | // $CFG->pathtodu = ''; | |
1056 | // | |
1057 | // Path to aspell. | |
1058 | // To use spell-checking within the editor, you MUST have aspell 0.50 or later | |
1059 | // installed on your server, and you must specify the correct path to access the | |
1060 | // aspell binary. On Unix/Linux systems, this path is usually /usr/bin/aspell, | |
1061 | // but it might be something else. | |
1062 | // $CFG->aspellpath = ''; | |
1063 | // | |
1064 | // Path to dot. | |
1065 | // Probably something like /usr/bin/dot. To be able to generate graphics from | |
1066 | // DOT files, you must have installed the dot executable and point to it here. | |
1067 | // Note that, for now, this only used by the profiling features | |
1068 | // (Development->Profiling) built into Moodle. | |
1069 | // $CFG->pathtodot = ''; | |
2e76c14e | 1070 | // |
1356d851 DW |
1071 | // Path to unoconv. |
1072 | // Probably something like /usr/bin/unoconv. Used as a fallback to convert between document formats. | |
1073 | // Unoconv is used convert between file formats supported by LibreOffice. | |
1074 | // Use a recent version of unoconv ( >= 0.7 ), older versions have trouble running from a webserver. | |
1075 | // $CFG->pathtounoconv = ''; | |
e6a1843e SL |
1076 | // |
1077 | //========================================================================= | |
1078 | // 14. ALTERNATIVE FILE SYSTEM SETTINGS | |
1079 | //========================================================================= | |
1080 | // | |
1081 | // Alternative file system. | |
1082 | // Since 3.3 it is possible to override file_storage and file_system API and use alternative storage systems (e.g. S3, | |
1083 | // Rackspace Cloud Files, Google Cloud Storage, Azure Storage, etc.). | |
1084 | // To set the alternative file storage system in config.php you can use the following setting, providing the | |
1085 | // alternative system class name that will be auto-loaded by file_storage API. | |
1086 | // | |
1087 | // $CFG->alternative_file_system_class = '\\local_myfilestorage\\file_system'; | |
1088 | // | |
6077020a | 1089 | //========================================================================= |
ed7cd552 SL |
1090 | // 15. CAMPAIGN CONTENT |
1091 | //========================================================================= | |
1092 | // | |
1093 | // We have added a campaign content to the notifications page, in case you want to hide that from your site you just | |
1094 | // need to set showcampaigncontent setting to false. | |
1095 | // | |
1096 | // $CFG->showcampaigncontent = true; | |
1097 | // | |
1098 | //========================================================================= | |
ba9fc5ed PB |
1099 | // 16. ALTERNATIVE CACHE CONFIG SETTINGS |
1100 | //========================================================================= | |
1101 | // | |
1102 | // Alternative cache config. | |
1103 | // Since 3.10 it is possible to override the cache_factory class with an alternative caching factory. | |
1104 | // This overridden factory can provide alternative classes for caching such as cache_config, | |
1105 | // cache_config_writer and core_cache\local\administration_display_helper. | |
1106 | // The autoloaded factory class name can be specified to use. | |
1107 | // | |
1108 | // $CFG->alternative_cache_factory_class = 'tool_alternativecache_cache_factory'; | |
1109 | // | |
1110 | //========================================================================= | |
3a232840 JS |
1111 | // 17. SCHEDULED TASK OVERRIDES |
1112 | //========================================================================= | |
1113 | // | |
1114 | // It is now possible to define scheduled tasks directly within config. | |
1115 | // The overridden value will take precedence over the values that have been set VIA the UI from the | |
1116 | // next time the task is run. | |
1117 | // | |
1118 | // Tasks are configured as an array of tasks that can override a task's schedule, as well as setting | |
1119 | // the task as disabled. I.e: | |
1120 | // | |
1121 | // $CFG->scheduled_tasks = [ | |
1122 | // '\local_plugin\task\my_task' => [ | |
1123 | // 'schedule' => '*/15 0 0 0 0', | |
1124 | // 'disabled' => 0, | |
1125 | // ], | |
1126 | // ]; | |
1127 | // | |
1128 | // The format for the schedule definition is: '{minute} {hour} {day} {dayofweek} {month}'. | |
1129 | // | |
1130 | // The classname of the task also supports wildcards: | |
1131 | // | |
1132 | // $CFG->scheduled_tasks = [ | |
1133 | // '\local_plugin\*' => [ | |
1134 | // 'schedule' => '*/15 0 0 0 0', | |
1135 | // 'disabled' => 0, | |
1136 | // ], | |
1137 | // '*' => [ | |
1138 | // 'schedule' => '0 0 0 0 0', | |
1139 | // 'disabled' => 0, | |
1140 | // ], | |
1141 | // ]; | |
1142 | // | |
1143 | // In this example, any task classnames matching '\local_plugin\*' would match the first rule and | |
1144 | // use that schedule the next time the task runs. Note that even though the 'local_plugin' tasks match | |
1145 | // the second rule as well, the highest rule takes precedence. Therefore, the second rule would be | |
1146 | // applied to all tasks, except for tasks within '\local_plugin\'. | |
1147 | // | |
1148 | // When the full classname is used, this rule always takes priority over any wildcard rules. | |
1149 | // | |
1150 | //========================================================================= | |
6077020a | 1151 | // ALL DONE! To continue installation, visit your main page with a browser |
1152 | //========================================================================= | |
c781942f | 1153 | |
1fcf0ca8 | 1154 | require_once(__DIR__ . '/lib/setup.php'); // Do not edit |
3b5ff37f | 1155 | |
fa4556c5 | 1156 | // There is no php closing tag in this file, |
1157 | // it is intentional because it prevents trailing whitespace problems! |