Revert r16860
[lhc/web/wiklou.git] / includes / DefaultSettings.php
1 <?php
2 /**
3 *
4 * NEVER EDIT THIS FILE
5 *
6 *
7 * To customize your installation, edit "LocalSettings.php". If you make
8 * changes here, they will be lost on next upgrade of MediaWiki!
9 *
10 * Note that since all these string interpolations are expanded
11 * before LocalSettings is included, if you localize something
12 * like $wgScriptPath, you must also localize everything that
13 * depends on it.
14 *
15 * Documentation is in the source and on:
16 * http://www.mediawiki.org/wiki/Help:Configuration_settings
17 *
18 * @package MediaWiki
19 */
20
21 # This is not a valid entry point, perform no further processing unless MEDIAWIKI is defined
22 if( !defined( 'MEDIAWIKI' ) ) {
23 echo "This file is part of MediaWiki and is not a valid entry point\n";
24 die( 1 );
25 }
26
27 /**
28 * Create a site configuration object
29 * Not used for much in a default install
30 */
31 require_once( 'includes/SiteConfiguration.php' );
32 $wgConf = new SiteConfiguration;
33
34 /** MediaWiki version number */
35 $wgVersion = '1.8alpha';
36
37 /** Name of the site. It must be changed in LocalSettings.php */
38 $wgSitename = 'MediaWiki';
39
40 /**
41 * Name of the project namespace. If left set to false, $wgSitename will be
42 * used instead.
43 */
44 $wgMetaNamespace = false;
45
46 /**
47 * Name of the project talk namespace. If left set to false, a name derived
48 * from the name of the project namespace will be used.
49 */
50 $wgMetaNamespaceTalk = false;
51
52
53 /** URL of the server. It will be automatically built including https mode */
54 $wgServer = '';
55
56 if( isset( $_SERVER['SERVER_NAME'] ) ) {
57 $wgServerName = $_SERVER['SERVER_NAME'];
58 } elseif( isset( $_SERVER['HOSTNAME'] ) ) {
59 $wgServerName = $_SERVER['HOSTNAME'];
60 } elseif( isset( $_SERVER['HTTP_HOST'] ) ) {
61 $wgServerName = $_SERVER['HTTP_HOST'];
62 } elseif( isset( $_SERVER['SERVER_ADDR'] ) ) {
63 $wgServerName = $_SERVER['SERVER_ADDR'];
64 } else {
65 $wgServerName = 'localhost';
66 }
67
68 # check if server use https:
69 $wgProto = (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') ? 'https' : 'http';
70
71 $wgServer = $wgProto.'://' . $wgServerName;
72 # If the port is a non-standard one, add it to the URL
73 if( isset( $_SERVER['SERVER_PORT'] )
74 && !strpos( $wgServerName, ':' )
75 && ( ( $wgProto == 'http' && $_SERVER['SERVER_PORT'] != 80 )
76 || ( $wgProto == 'https' && $_SERVER['SERVER_PORT'] != 443 ) ) ) {
77
78 $wgServer .= ":" . $_SERVER['SERVER_PORT'];
79 }
80
81
82 /**
83 * The path we should point to.
84 * It might be a virtual path in case with use apache mod_rewrite for example
85 */
86 $wgScriptPath = '/wiki';
87
88 /**
89 * Whether to support URLs like index.php/Page_title
90 * @global bool $wgUsePathInfo
91 */
92 $wgUsePathInfo = ( strpos( php_sapi_name(), 'cgi' ) === false );
93
94
95 /**#@+
96 * Script users will request to get articles
97 * ATTN: Old installations used wiki.phtml and redirect.phtml -
98 * make sure that LocalSettings.php is correctly set!
99 * @deprecated
100 */
101 /**
102 * @global string $wgScript
103 */
104 $wgScript = "{$wgScriptPath}/index.php";
105 /**
106 * @global string $wgRedirectScript
107 */
108 $wgRedirectScript = "{$wgScriptPath}/redirect.php";
109 /**#@-*/
110
111
112 /**#@+
113 * @global string
114 */
115 /**
116 * style path as seen by users
117 * @global string $wgStylePath
118 */
119 $wgStylePath = "{$wgScriptPath}/skins";
120 /**
121 * filesystem stylesheets directory
122 * @global string $wgStyleDirectory
123 */
124 $wgStyleDirectory = "{$IP}/skins";
125 $wgStyleSheetPath = &$wgStylePath;
126 $wgArticlePath = "{$wgScript}?title=$1";
127 $wgUploadPath = "{$wgScriptPath}/images";
128 $wgUploadDirectory = "{$IP}/images";
129 $wgHashedUploadDirectory = true;
130 $wgLogo = "{$wgUploadPath}/wiki.png";
131 $wgFavicon = '/favicon.ico';
132 $wgMathPath = "{$wgUploadPath}/math";
133 $wgMathDirectory = "{$wgUploadDirectory}/math";
134 $wgTmpDirectory = "{$wgUploadDirectory}/tmp";
135 $wgUploadBaseUrl = "";
136 /**#@-*/
137
138
139 /**
140 * By default deleted files are simply discarded; to save them and
141 * make it possible to undelete images, create a directory which
142 * is writable to the web server but is not exposed to the internet.
143 *
144 * Set $wgSaveDeletedFiles to true and set up the save path in
145 * $wgFileStore['deleted']['directory'].
146 */
147 $wgSaveDeletedFiles = false;
148
149 /**
150 * New file storage paths; currently used only for deleted files.
151 * Set it like this:
152 *
153 * $wgFileStore['deleted']['directory'] = '/var/wiki/private/deleted';
154 *
155 */
156 $wgFileStore = array();
157 $wgFileStore['deleted']['directory'] = null; // Don't forget to set this.
158 $wgFileStore['deleted']['url'] = null; // Private
159 $wgFileStore['deleted']['hash'] = 3; // 3-level subdirectory split
160
161 /**
162 * Allowed title characters -- regex character class
163 * Don't change this unless you know what you're doing
164 *
165 * Problematic punctuation:
166 * []{}|# Are needed for link syntax, never enable these
167 * % Enabled by default, minor problems with path to query rewrite rules, see below
168 * + Enabled by default, but doesn't work with path to query rewrite rules, corrupted by apache
169 * ? Enabled by default, but doesn't work with path to PATH_INFO rewrites
170 *
171 * All three of these punctuation problems can be avoided by using an alias, instead of a
172 * rewrite rule of either variety.
173 *
174 * The problem with % is that when using a path to query rewrite rule, URLs are
175 * double-unescaped: once by Apache's path conversion code, and again by PHP. So
176 * %253F, for example, becomes "?". Our code does not double-escape to compensate
177 * for this, indeed double escaping would break if the double-escaped title was
178 * passed in the query string rather than the path. This is a minor security issue
179 * because articles can be created such that they are hard to view or edit.
180 *
181 * In some rare cases you may wish to remove + for compatibility with old links.
182 *
183 * Theoretically 0x80-0x9F of ISO 8859-1 should be disallowed, but
184 * this breaks interlanguage links
185 */
186 $wgLegalTitleChars = " %!\"$&'()*,\\-.\\/0-9:;=?@A-Z\\\\^_`a-z~\\x80-\\xFF+";
187
188
189 /**
190 * The external URL protocols
191 */
192 $wgUrlProtocols = array(
193 'http://',
194 'https://',
195 'ftp://',
196 'irc://',
197 'gopher://',
198 'telnet://', // Well if we're going to support the above.. -ævar
199 'nntp://', // @bug 3808 RFC 1738
200 'worldwind://',
201 'mailto:',
202 'news:'
203 );
204
205 /** internal name of virus scanner. This servers as a key to the $wgAntivirusSetup array.
206 * Set this to NULL to disable virus scanning. If not null, every file uploaded will be scanned for viruses.
207 * @global string $wgAntivirus
208 */
209 $wgAntivirus= NULL;
210
211 /** Configuration for different virus scanners. This an associative array of associative arrays:
212 * it contains on setup array per known scanner type. The entry is selected by $wgAntivirus, i.e.
213 * valid values for $wgAntivirus are the keys defined in this array.
214 *
215 * The configuration array for each scanner contains the following keys: "command", "codemap", "messagepattern";
216 *
217 * "command" is the full command to call the virus scanner - %f will be replaced with the name of the
218 * file to scan. If not present, the filename will be appended to the command. Note that this must be
219 * overwritten if the scanner is not in the system path; in that case, plase set
220 * $wgAntivirusSetup[$wgAntivirus]['command'] to the desired command with full path.
221 *
222 * "codemap" is a mapping of exit code to return codes of the detectVirus function in SpecialUpload.
223 * An exit code mapped to AV_SCAN_FAILED causes the function to consider the scan to be failed. This will pass
224 * the file if $wgAntivirusRequired is not set.
225 * An exit code mapped to AV_SCAN_ABORTED causes the function to consider the file to have an usupported format,
226 * which is probably imune to virusses. This causes the file to pass.
227 * An exit code mapped to AV_NO_VIRUS will cause the file to pass, meaning no virus was found.
228 * All other codes (like AV_VIRUS_FOUND) will cause the function to report a virus.
229 * You may use "*" as a key in the array to catch all exit codes not mapped otherwise.
230 *
231 * "messagepattern" is a perl regular expression to extract the meaningful part of the scanners
232 * output. The relevant part should be matched as group one (\1).
233 * If not defined or the pattern does not match, the full message is shown to the user.
234 *
235 * @global array $wgAntivirusSetup
236 */
237 $wgAntivirusSetup= array(
238
239 #setup for clamav
240 'clamav' => array (
241 'command' => "clamscan --no-summary ",
242
243 'codemap'=> array (
244 "0"=> AV_NO_VIRUS, #no virus
245 "1"=> AV_VIRUS_FOUND, #virus found
246 "52"=> AV_SCAN_ABORTED, #unsupported file format (probably imune)
247 "*"=> AV_SCAN_FAILED, #else scan failed
248 ),
249
250 'messagepattern'=> '/.*?:(.*)/sim',
251 ),
252
253 #setup for f-prot
254 'f-prot' => array (
255 'command' => "f-prot ",
256
257 'codemap'=> array (
258 "0"=> AV_NO_VIRUS, #no virus
259 "3"=> AV_VIRUS_FOUND, #virus found
260 "6"=> AV_VIRUS_FOUND, #virus found
261 "*"=> AV_SCAN_FAILED, #else scan failed
262 ),
263
264 'messagepattern'=> '/.*?Infection:(.*)$/m',
265 ),
266 );
267
268
269 /** Determines if a failed virus scan (AV_SCAN_FAILED) will cause the file to be rejected.
270 * @global boolean $wgAntivirusRequired
271 */
272 $wgAntivirusRequired= true;
273
274 /** Determines if the mime type of uploaded files should be checked
275 * @global boolean $wgVerifyMimeType
276 */
277 $wgVerifyMimeType= true;
278
279 /** Sets the mime type definition file to use by MimeMagic.php.
280 * @global string $wgMimeTypeFile
281 */
282 #$wgMimeTypeFile= "/etc/mime.types";
283 $wgMimeTypeFile= "includes/mime.types";
284 #$wgMimeTypeFile= NULL; #use built-in defaults only.
285
286 /** Sets the mime type info file to use by MimeMagic.php.
287 * @global string $wgMimeInfoFile
288 */
289 $wgMimeInfoFile= "includes/mime.info";
290 #$wgMimeInfoFile= NULL; #use built-in defaults only.
291
292 /** Switch for loading the FileInfo extension by PECL at runtime.
293 * This should be used only if fileinfo is installed as a shared object / dynamic libary
294 * @global string $wgLoadFileinfoExtension
295 */
296 $wgLoadFileinfoExtension= false;
297
298 /** Sets an external mime detector program. The command must print only the mime type to standard output.
299 * the name of the file to process will be appended to the command given here.
300 * If not set or NULL, mime_content_type will be used if available.
301 */
302 $wgMimeDetectorCommand= NULL; # use internal mime_content_type function, available since php 4.3.0
303 #$wgMimeDetectorCommand= "file -bi"; #use external mime detector (Linux)
304
305 /** Switch for trivial mime detection. Used by thumb.php to disable all fance things,
306 * because only a few types of images are needed and file extensions can be trusted.
307 */
308 $wgTrivialMimeDetection= false;
309
310 /**
311 * To set 'pretty' URL paths for actions other than
312 * plain page views, add to this array. For instance:
313 * 'edit' => "$wgScriptPath/edit/$1"
314 *
315 * There must be an appropriate script or rewrite rule
316 * in place to handle these URLs.
317 */
318 $wgActionPaths = array();
319
320 /**
321 * If you operate multiple wikis, you can define a shared upload path here.
322 * Uploads to this wiki will NOT be put there - they will be put into
323 * $wgUploadDirectory.
324 * If $wgUseSharedUploads is set, the wiki will look in the shared repository if
325 * no file of the given name is found in the local repository (for [[Image:..]],
326 * [[Media:..]] links). Thumbnails will also be looked for and generated in this
327 * directory.
328 */
329 $wgUseSharedUploads = false;
330 /** Full path on the web server where shared uploads can be found */
331 $wgSharedUploadPath = "http://commons.wikimedia.org/shared/images";
332 /** Fetch commons image description pages and display them on the local wiki? */
333 $wgFetchCommonsDescriptions = false;
334 /** Path on the file system where shared uploads can be found. */
335 $wgSharedUploadDirectory = "/var/www/wiki3/images";
336 /** DB name with metadata about shared directory. Set this to false if the uploads do not come from a wiki. */
337 $wgSharedUploadDBname = false;
338 /** Optional table prefix used in database. */
339 $wgSharedUploadDBprefix = '';
340 /** Cache shared metadata in memcached. Don't do this if the commons wiki is in a different memcached domain */
341 $wgCacheSharedUploads = true;
342 /** Allow for upload to be copied from an URL. Requires Special:Upload?source=web */
343 $wgAllowCopyUploads = false;
344 /** Max size for uploads, in bytes */
345 $wgMaxUploadSize = 1024*1024*100; # 100MB
346
347 /**
348 * Point the upload navigation link to an external URL
349 * Useful if you want to use a shared repository by default
350 * without disabling local uploads (use $wgEnableUploads = false for that)
351 * e.g. $wgUploadNavigationUrl = 'http://commons.wikimedia.org/wiki/Special:Upload';
352 */
353 $wgUploadNavigationUrl = false;
354
355 /**
356 * Give a path here to use thumb.php for thumbnail generation on client request, instead of
357 * generating them on render and outputting a static URL. This is necessary if some of your
358 * apache servers don't have read/write access to the thumbnail path.
359 *
360 * Example:
361 * $wgThumbnailScriptPath = "{$wgScriptPath}/thumb.php";
362 */
363 $wgThumbnailScriptPath = false;
364 $wgSharedThumbnailScriptPath = false;
365
366 /**
367 * Set the following to false especially if you have a set of files that need to
368 * be accessible by all wikis, and you do not want to use the hash (path/a/aa/)
369 * directory layout.
370 */
371 $wgHashedSharedUploadDirectory = true;
372
373 /**
374 * Base URL for a repository wiki. Leave this blank if uploads are just stored
375 * in a shared directory and not meant to be accessible through a separate wiki.
376 * Otherwise the image description pages on the local wiki will link to the
377 * image description page on this wiki.
378 *
379 * Please specify the namespace, as in the example below.
380 */
381 $wgRepositoryBaseUrl="http://commons.wikimedia.org/wiki/Image:";
382
383
384 #
385 # Email settings
386 #
387
388 /**
389 * Site admin email address
390 * Default to wikiadmin@SERVER_NAME
391 * @global string $wgEmergencyContact
392 */
393 $wgEmergencyContact = 'wikiadmin@' . $wgServerName;
394
395 /**
396 * Password reminder email address
397 * The address we should use as sender when a user is requesting his password
398 * Default to apache@SERVER_NAME
399 * @global string $wgPasswordSender
400 */
401 $wgPasswordSender = 'MediaWiki Mail <apache@' . $wgServerName . '>';
402
403 /**
404 * dummy address which should be accepted during mail send action
405 * It might be necessay to adapt the address or to set it equal
406 * to the $wgEmergencyContact address
407 */
408 #$wgNoReplyAddress = $wgEmergencyContact;
409 $wgNoReplyAddress = 'reply@not.possible';
410
411 /**
412 * Set to true to enable the e-mail basic features:
413 * Password reminders, etc. If sending e-mail on your
414 * server doesn't work, you might want to disable this.
415 * @global bool $wgEnableEmail
416 */
417 $wgEnableEmail = true;
418
419 /**
420 * Set to true to enable user-to-user e-mail.
421 * This can potentially be abused, as it's hard to track.
422 * @global bool $wgEnableUserEmail
423 */
424 $wgEnableUserEmail = true;
425
426 /**
427 * SMTP Mode
428 * For using a direct (authenticated) SMTP server connection.
429 * Default to false or fill an array :
430 * <code>
431 * "host" => 'SMTP domain',
432 * "IDHost" => 'domain for MessageID',
433 * "port" => "25",
434 * "auth" => true/false,
435 * "username" => user,
436 * "password" => password
437 * </code>
438 *
439 * @global mixed $wgSMTP
440 */
441 $wgSMTP = false;
442
443
444 /**#@+
445 * Database settings
446 */
447 /** database host name or ip address */
448 $wgDBserver = 'localhost';
449 /** database port number */
450 $wgDBport = '';
451 /** name of the database */
452 $wgDBname = 'wikidb';
453 /** */
454 $wgDBconnection = '';
455 /** Database username */
456 $wgDBuser = 'wikiuser';
457 /** Database type
458 */
459 $wgDBtype = "mysql";
460 /** Search type
461 * Leave as null to select the default search engine for the
462 * selected database type (eg SearchMySQL4), or set to a class
463 * name to override to a custom search engine.
464 */
465 $wgSearchType = null;
466 /** Table name prefix */
467 $wgDBprefix = '';
468 /**#@-*/
469
470 /** Live high performance sites should disable this - some checks acquire giant mysql locks */
471 $wgCheckDBSchema = true;
472
473
474 /**
475 * Shared database for multiple wikis. Presently used for storing a user table
476 * for single sign-on. The server for this database must be the same as for the
477 * main database.
478 * EXPERIMENTAL
479 */
480 $wgSharedDB = null;
481
482 # Database load balancer
483 # This is a two-dimensional array, an array of server info structures
484 # Fields are:
485 # host: Host name
486 # dbname: Default database name
487 # user: DB user
488 # password: DB password
489 # type: "mysql" or "postgres"
490 # load: ratio of DB_SLAVE load, must be >=0, the sum of all loads must be >0
491 # groupLoads: array of load ratios, the key is the query group name. A query may belong
492 # to several groups, the most specific group defined here is used.
493 #
494 # flags: bit field
495 # DBO_DEFAULT -- turns on DBO_TRX only if !$wgCommandLineMode (recommended)
496 # DBO_DEBUG -- equivalent of $wgDebugDumpSql
497 # DBO_TRX -- wrap entire request in a transaction
498 # DBO_IGNORE -- ignore errors (not useful in LocalSettings.php)
499 # DBO_NOBUFFER -- turn off buffering (not useful in LocalSettings.php)
500 #
501 # max lag: (optional) Maximum replication lag before a slave will taken out of rotation
502 # max threads: (optional) Maximum number of running threads
503 #
504 # These and any other user-defined properties will be assigned to the mLBInfo member
505 # variable of the Database object.
506 #
507 # Leave at false to use the single-server variables above
508 $wgDBservers = false;
509
510 /** How long to wait for a slave to catch up to the master */
511 $wgMasterWaitTimeout = 10;
512
513 /** File to log database errors to */
514 $wgDBerrorLog = false;
515
516 /** When to give an error message */
517 $wgDBClusterTimeout = 10;
518
519 /**
520 * wgDBminWordLen :
521 * MySQL 3.x : used to discard words that MySQL will not return any results for
522 * shorter values configure mysql directly.
523 * MySQL 4.x : ignore it and configure mySQL
524 * See: http://dev.mysql.com/doc/mysql/en/Fulltext_Fine-tuning.html
525 */
526 $wgDBminWordLen = 4;
527 /** Set to true if using InnoDB tables */
528 $wgDBtransactions = false;
529 /** Set to true for compatibility with extensions that might be checking.
530 * MySQL 3.23.x is no longer supported. */
531 $wgDBmysql4 = true;
532
533 /**
534 * Set to true to engage MySQL 4.1/5.0 charset-related features;
535 * for now will just cause sending of 'SET NAMES=utf8' on connect.
536 *
537 * WARNING: THIS IS EXPERIMENTAL!
538 *
539 * May break if you're not using the table defs from mysql5/tables.sql.
540 * May break if you're upgrading an existing wiki if set differently.
541 * Broken symptoms likely to include incorrect behavior with page titles,
542 * usernames, comments etc containing non-ASCII characters.
543 * Might also cause failures on the object cache and other things.
544 *
545 * Even correct usage may cause failures with Unicode supplementary
546 * characters (those not in the Basic Multilingual Plane) unless MySQL
547 * has enhanced their Unicode support.
548 */
549 $wgDBmysql5 = false;
550
551 /**
552 * Other wikis on this site, can be administered from a single developer
553 * account.
554 * Array numeric key => database name
555 */
556 $wgLocalDatabases = array();
557
558 /**
559 * Object cache settings
560 * See Defines.php for types
561 */
562 $wgMainCacheType = CACHE_NONE;
563 $wgMessageCacheType = CACHE_ANYTHING;
564 $wgParserCacheType = CACHE_ANYTHING;
565
566 $wgParserCacheExpireTime = 86400;
567
568 $wgSessionsInMemcached = false;
569 $wgLinkCacheMemcached = false; # Not fully tested
570
571 /**
572 * Memcached-specific settings
573 * See docs/memcached.txt
574 */
575 $wgUseMemCached = false;
576 $wgMemCachedDebug = false; # Will be set to false in Setup.php, if the server isn't working
577 $wgMemCachedServers = array( '127.0.0.1:11000' );
578 $wgMemCachedDebug = false;
579 $wgMemCachedPersistent = false;
580
581 /**
582 * Directory for local copy of message cache, for use in addition to memcached
583 */
584 $wgLocalMessageCache = false;
585 /**
586 * Defines format of local cache
587 * true - Serialized object
588 * false - PHP source file (Warning - security risk)
589 */
590 $wgLocalMessageCacheSerialized = true;
591
592 /**
593 * Directory for compiled constant message array databases
594 * WARNING: turning anything on will just break things, aaaaaah!!!!
595 */
596 $wgCachedMessageArrays = false;
597
598 # Language settings
599 #
600 /** Site language code, should be one of ./languages/Language(.*).php */
601 $wgLanguageCode = 'en';
602
603 /**
604 * Some languages need different word forms, usually for different cases.
605 * Used in Language::convertGrammar().
606 */
607 $wgGrammarForms = array();
608 #$wgGrammarForms['en']['genitive']['car'] = 'car\'s';
609
610 /** Treat language links as magic connectors, not inline links */
611 $wgInterwikiMagic = true;
612
613 /** Hide interlanguage links from the sidebar */
614 $wgHideInterlanguageLinks = false;
615
616
617 /** We speak UTF-8 all the time now, unless some oddities happen */
618 $wgInputEncoding = 'UTF-8';
619 $wgOutputEncoding = 'UTF-8';
620 $wgEditEncoding = '';
621
622 # Set this to eg 'ISO-8859-1' to perform character set
623 # conversion when loading old revisions not marked with
624 # "utf-8" flag. Use this when converting wiki to UTF-8
625 # without the burdensome mass conversion of old text data.
626 #
627 # NOTE! This DOES NOT touch any fields other than old_text.
628 # Titles, comments, user names, etc still must be converted
629 # en masse in the database before continuing as a UTF-8 wiki.
630 $wgLegacyEncoding = false;
631
632 /**
633 * If set to true, the MediaWiki 1.4 to 1.5 schema conversion will
634 * create stub reference rows in the text table instead of copying
635 * the full text of all current entries from 'cur' to 'text'.
636 *
637 * This will speed up the conversion step for large sites, but
638 * requires that the cur table be kept around for those revisions
639 * to remain viewable.
640 *
641 * maintenance/migrateCurStubs.php can be used to complete the
642 * migration in the background once the wiki is back online.
643 *
644 * This option affects the updaters *only*. Any present cur stub
645 * revisions will be readable at runtime regardless of this setting.
646 */
647 $wgLegacySchemaConversion = false;
648
649 $wgMimeType = 'text/html';
650 $wgJsMimeType = 'text/javascript';
651 $wgDocType = '-//W3C//DTD XHTML 1.0 Transitional//EN';
652 $wgDTD = 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd';
653
654 /** Enable to allow rewriting dates in page text.
655 * DOES NOT FORMAT CORRECTLY FOR MOST LANGUAGES */
656 $wgUseDynamicDates = false;
657 /** Enable dates like 'May 12' instead of '12 May', this only takes effect if
658 * the interface is set to English
659 */
660 $wgAmericanDates = false;
661 /**
662 * For Hindi and Arabic use local numerals instead of Western style (0-9)
663 * numerals in interface.
664 */
665 $wgTranslateNumerals = true;
666
667
668 # Translation using MediaWiki: namespace
669 # This will increase load times by 25-60% unless memcached is installed
670 # Interface messages will be loaded from the database.
671 $wgUseDatabaseMessages = true;
672 $wgMsgCacheExpiry = 86400;
673
674 # Whether to enable language variant conversion.
675 $wgDisableLangConversion = false;
676
677 /**
678 * Show a bar of language selection links in the user login and user
679 * registration forms; edit the "loginlanguagelinks" message to
680 * customise these
681 */
682 $wgLoginLanguageSelector = false;
683
684 # Whether to use zhdaemon to perform Chinese text processing
685 # zhdaemon is under developement, so normally you don't want to
686 # use it unless for testing
687 $wgUseZhdaemon = false;
688 $wgZhdaemonHost="localhost";
689 $wgZhdaemonPort=2004;
690
691 /** Normally you can ignore this and it will be something
692 like $wgMetaNamespace . "_talk". In some languages, you
693 may want to set this manually for grammatical reasons.
694 It is currently only respected by those languages
695 where it might be relevant and where no automatic
696 grammar converter exists.
697 */
698 $wgMetaNamespaceTalk = false;
699
700 # Miscellaneous configuration settings
701 #
702
703 $wgLocalInterwiki = 'w';
704 $wgInterwikiExpiry = 10800; # Expiry time for cache of interwiki table
705
706 /** Interwiki caching settings.
707 $wgInterwikiCache specifies path to constant database file
708 This cdb database is generated by dumpInterwiki from maintenance
709 and has such key formats:
710 dbname:key - a simple key (e.g. enwiki:meta)
711 _sitename:key - site-scope key (e.g. wiktionary:meta)
712 __global:key - global-scope key (e.g. __global:meta)
713 __sites:dbname - site mapping (e.g. __sites:enwiki)
714 Sites mapping just specifies site name, other keys provide
715 "local url" data layout.
716 $wgInterwikiScopes specify number of domains to check for messages:
717 1 - Just wiki(db)-level
718 2 - wiki and global levels
719 3 - site levels
720 $wgInterwikiFallbackSite - if unable to resolve from cache
721 */
722 $wgInterwikiCache = false;
723 $wgInterwikiScopes = 3;
724 $wgInterwikiFallbackSite = 'wiki';
725
726 /**
727 * If local interwikis are set up which allow redirects,
728 * set this regexp to restrict URLs which will be displayed
729 * as 'redirected from' links.
730 *
731 * It might look something like this:
732 * $wgRedirectSources = '!^https?://[a-z-]+\.wikipedia\.org/!';
733 *
734 * Leave at false to avoid displaying any incoming redirect markers.
735 * This does not affect intra-wiki redirects, which don't change
736 * the URL.
737 */
738 $wgRedirectSources = false;
739
740
741 $wgShowIPinHeader = true; # For non-logged in users
742 $wgMaxNameChars = 255; # Maximum number of bytes in username
743 $wgMaxArticleSize = 2048; # Maximum article size in kilobytes
744
745 $wgExtraSubtitle = '';
746 $wgSiteSupportPage = ''; # A page where you users can receive donations
747
748 $wgReadOnlyFile = "{$wgUploadDirectory}/lock_yBgMBwiR";
749
750 /**
751 * The debug log file should be not be publicly accessible if it is used, as it
752 * may contain private data. */
753 $wgDebugLogFile = '';
754
755 /**#@+
756 * @global bool
757 */
758 $wgDebugRedirects = false;
759 $wgDebugRawPage = false; # Avoid overlapping debug entries by leaving out CSS
760
761 $wgDebugComments = false;
762 $wgReadOnly = null;
763 $wgLogQueries = false;
764
765 /**
766 * Write SQL queries to the debug log
767 */
768 $wgDebugDumpSql = false;
769
770 /**
771 * Set to an array of log group keys to filenames.
772 * If set, wfDebugLog() output for that group will go to that file instead
773 * of the regular $wgDebugLogFile. Useful for enabling selective logging
774 * in production.
775 */
776 $wgDebugLogGroups = array();
777
778 /**
779 * Whether to show "we're sorry, but there has been a database error" pages.
780 * Displaying errors aids in debugging, but may display information useful
781 * to an attacker.
782 */
783 $wgShowSQLErrors = false;
784
785 /**
786 * If true, some error messages will be colorized when running scripts on the
787 * command line; this can aid picking important things out when debugging.
788 * Ignored when running on Windows or when output is redirected to a file.
789 */
790 $wgColorErrors = true;
791
792 /**
793 * disable experimental dmoz-like category browsing. Output things like:
794 * Encyclopedia > Music > Style of Music > Jazz
795 */
796 $wgUseCategoryBrowser = false;
797
798 /**
799 * Keep parsed pages in a cache (objectcache table, turck, or memcached)
800 * to speed up output of the same page viewed by another user with the
801 * same options.
802 *
803 * This can provide a significant speedup for medium to large pages,
804 * so you probably want to keep it on.
805 */
806 $wgEnableParserCache = true;
807
808 /**
809 * If on, the sidebar navigation links are cached for users with the
810 * current language set. This can save a touch of load on a busy site
811 * by shaving off extra message lookups.
812 *
813 * However it is also fragile: changing the site configuration, or
814 * having a variable $wgArticlePath, can produce broken links that
815 * don't update as expected.
816 */
817 $wgEnableSidebarCache = false;
818
819 /**
820 * Under which condition should a page in the main namespace be counted
821 * as a valid article? If $wgUseCommaCount is set to true, it will be
822 * counted if it contains at least one comma. If it is set to false
823 * (default), it will only be counted if it contains at least one [[wiki
824 * link]]. See http://meta.wikimedia.org/wiki/Help:Article_count
825 *
826 * Retroactively changing this variable will not affect
827 * the existing count (cf. maintenance/recount.sql).
828 */
829 $wgUseCommaCount = false;
830
831 /**#@-*/
832
833 /**
834 * wgHitcounterUpdateFreq sets how often page counters should be updated, higher
835 * values are easier on the database. A value of 1 causes the counters to be
836 * updated on every hit, any higher value n cause them to update *on average*
837 * every n hits. Should be set to either 1 or something largish, eg 1000, for
838 * maximum efficiency.
839 */
840 $wgHitcounterUpdateFreq = 1;
841
842 # Basic user rights and block settings
843 $wgSysopUserBans = true; # Allow sysops to ban logged-in users
844 $wgSysopRangeBans = true; # Allow sysops to ban IP ranges
845 $wgAutoblockExpiry = 86400; # Number of seconds before autoblock entries expire
846 $wgBlockAllowsUTEdit = false; # Blocks allow users to edit their own user talk page
847
848 # Pages anonymous user may see as an array, e.g.:
849 # array ( "Main Page", "Special:Userlogin", "Wikipedia:Help");
850 # NOTE: This will only work if $wgGroupPermissions['*']['read']
851 # is false -- see below. Otherwise, ALL pages are accessible,
852 # regardless of this setting.
853 # Also note that this will only protect _pages in the wiki_.
854 # Uploaded files will remain readable. Make your upload
855 # directory name unguessable, or use .htaccess to protect it.
856 $wgWhitelistRead = false;
857
858 /**
859 * Should editors be required to have a validated e-mail
860 * address before being allowed to edit?
861 */
862 $wgEmailConfirmToEdit=false;
863
864 /**
865 * Permission keys given to users in each group.
866 * All users are implicitly in the '*' group including anonymous visitors;
867 * logged-in users are all implicitly in the 'user' group. These will be
868 * combined with the permissions of all groups that a given user is listed
869 * in in the user_groups table.
870 *
871 * Functionality to make pages inaccessible has not been extensively tested
872 * for security. Use at your own risk!
873 *
874 * This replaces wgWhitelistAccount and wgWhitelistEdit
875 */
876 $wgGroupPermissions = array();
877
878 // Implicit group for all visitors
879 $wgGroupPermissions['*' ]['createaccount'] = true;
880 $wgGroupPermissions['*' ]['read'] = true;
881 $wgGroupPermissions['*' ]['edit'] = true;
882 $wgGroupPermissions['*' ]['createpage'] = true;
883 $wgGroupPermissions['*' ]['createtalk'] = true;
884
885 // Implicit group for all logged-in accounts
886 $wgGroupPermissions['user' ]['move'] = true;
887 $wgGroupPermissions['user' ]['read'] = true;
888 $wgGroupPermissions['user' ]['edit'] = true;
889 $wgGroupPermissions['user' ]['createpage'] = true;
890 $wgGroupPermissions['user' ]['createtalk'] = true;
891 $wgGroupPermissions['user' ]['upload'] = true;
892 $wgGroupPermissions['user' ]['reupload'] = true;
893 $wgGroupPermissions['user' ]['reupload-shared'] = true;
894 $wgGroupPermissions['user' ]['minoredit'] = true;
895
896 // Implicit group for accounts that pass $wgAutoConfirmAge
897 $wgGroupPermissions['autoconfirmed']['autoconfirmed'] = true;
898
899 // Implicit group for accounts with confirmed email addresses
900 // This has little use when email address confirmation is off
901 $wgGroupPermissions['emailconfirmed']['emailconfirmed'] = true;
902
903 // Users with bot privilege can have their edits hidden
904 // from various log pages by default
905 $wgGroupPermissions['bot' ]['bot'] = true;
906 $wgGroupPermissions['bot' ]['autoconfirmed'] = true;
907
908 // Most extra permission abilities go to this group
909 $wgGroupPermissions['sysop']['block'] = true;
910 $wgGroupPermissions['sysop']['createaccount'] = true;
911 $wgGroupPermissions['sysop']['delete'] = true;
912 $wgGroupPermissions['sysop']['deletedhistory'] = true; // can view deleted history entries, but not see or restore the text
913 $wgGroupPermissions['sysop']['editinterface'] = true;
914 $wgGroupPermissions['sysop']['import'] = true;
915 $wgGroupPermissions['sysop']['importupload'] = true;
916 $wgGroupPermissions['sysop']['move'] = true;
917 $wgGroupPermissions['sysop']['patrol'] = true;
918 $wgGroupPermissions['sysop']['protect'] = true;
919 $wgGroupPermissions['sysop']['proxyunbannable'] = true;
920 $wgGroupPermissions['sysop']['rollback'] = true;
921 $wgGroupPermissions['sysop']['trackback'] = true;
922 $wgGroupPermissions['sysop']['upload'] = true;
923 $wgGroupPermissions['sysop']['reupload'] = true;
924 $wgGroupPermissions['sysop']['reupload-shared'] = true;
925 $wgGroupPermissions['sysop']['unwatchedpages'] = true;
926 $wgGroupPermissions['sysop']['autoconfirmed'] = true;
927 $wgGroupPermissions['sysop']['upload_by_url'] = true;
928
929 // Permission to change users' group assignments
930 $wgGroupPermissions['bureaucrat']['userrights'] = true;
931
932 // Experimental permissions, not ready for production use
933 //$wgGroupPermissions['sysop']['deleterevision'] = true;
934 //$wgGroupPermissions['bureaucrat']['hiderevision'] = true;
935
936 /**
937 * The developer group is deprecated, but can be activated if need be
938 * to use the 'lockdb' and 'unlockdb' special pages. Those require
939 * that a lock file be defined and creatable/removable by the web
940 * server.
941 */
942 # $wgGroupPermissions['developer']['siteadmin'] = true;
943
944 /**
945 * Set of available actions that can be restricted via Special:Protect
946 * You probably shouldn't change this.
947 * Translated trough restriction-* messages.
948 */
949 $wgRestrictionTypes = array( 'edit', 'move' );
950
951 /**
952 * Set of permission keys that can be selected via Special:Protect.
953 * 'autoconfirm' allows all registerd users if $wgAutoConfirmAge is 0.
954 */
955 $wgRestrictionLevels = array( '', 'autoconfirmed', 'sysop' );
956
957
958 /**
959 * Number of seconds an account is required to age before
960 * it's given the implicit 'autoconfirm' group membership.
961 * This can be used to limit privileges of new accounts.
962 *
963 * Accounts created by earlier versions of the software
964 * may not have a recorded creation date, and will always
965 * be considered to pass the age test.
966 *
967 * When left at 0, all registered accounts will pass.
968 */
969 $wgAutoConfirmAge = 0;
970 //$wgAutoConfirmAge = 600; // ten minutes
971 //$wgAutoConfirmAge = 3600*24; // one day
972
973
974
975 # Proxy scanner settings
976 #
977
978 /**
979 * If you enable this, every editor's IP address will be scanned for open HTTP
980 * proxies.
981 *
982 * Don't enable this. Many sysops will report "hostile TCP port scans" to your
983 * ISP and ask for your server to be shut down.
984 *
985 * You have been warned.
986 */
987 $wgBlockOpenProxies = false;
988 /** Port we want to scan for a proxy */
989 $wgProxyPorts = array( 80, 81, 1080, 3128, 6588, 8000, 8080, 8888, 65506 );
990 /** Script used to scan */
991 $wgProxyScriptPath = "$IP/proxy_check.php";
992 /** */
993 $wgProxyMemcExpiry = 86400;
994 /** This should always be customised in LocalSettings.php */
995 $wgSecretKey = false;
996 /** big list of banned IP addresses, in the keys not the values */
997 $wgProxyList = array();
998 /** deprecated */
999 $wgProxyKey = false;
1000
1001 /** Number of accounts each IP address may create, 0 to disable.
1002 * Requires memcached */
1003 $wgAccountCreationThrottle = 0;
1004
1005 # Client-side caching:
1006
1007 /** Allow client-side caching of pages */
1008 $wgCachePages = true;
1009
1010 /**
1011 * Set this to current time to invalidate all prior cached pages. Affects both
1012 * client- and server-side caching.
1013 * You can get the current date on your server by using the command:
1014 * date +%Y%m%d%H%M%S
1015 */
1016 $wgCacheEpoch = '20030516000000';
1017
1018
1019 # Server-side caching:
1020
1021 /**
1022 * This will cache static pages for non-logged-in users to reduce
1023 * database traffic on public sites.
1024 * Must set $wgShowIPinHeader = false
1025 */
1026 $wgUseFileCache = false;
1027 /** Directory where the cached page will be saved */
1028 $wgFileCacheDirectory = "{$wgUploadDirectory}/cache";
1029
1030 /**
1031 * When using the file cache, we can store the cached HTML gzipped to save disk
1032 * space. Pages will then also be served compressed to clients that support it.
1033 * THIS IS NOT COMPATIBLE with ob_gzhandler which is now enabled if supported in
1034 * the default LocalSettings.php! If you enable this, remove that setting first.
1035 *
1036 * Requires zlib support enabled in PHP.
1037 */
1038 $wgUseGzip = false;
1039
1040 /** Whether MediaWiki should send an ETag header */
1041 $wgUseETag = false;
1042
1043 # Email notification settings
1044 #
1045
1046 /** For email notification on page changes */
1047 $wgPasswordSender = $wgEmergencyContact;
1048
1049 # true: from page editor if s/he opted-in
1050 # false: Enotif mails appear to come from $wgEmergencyContact
1051 $wgEnotifFromEditor = false;
1052
1053 // TODO move UPO to preferences probably ?
1054 # If set to true, users get a corresponding option in their preferences and can choose to enable or disable at their discretion
1055 # If set to false, the corresponding input form on the user preference page is suppressed
1056 # It call this to be a "user-preferences-option (UPO)"
1057 $wgEmailAuthentication = true; # UPO (if this is set to false, texts referring to authentication are suppressed)
1058 $wgEnotifWatchlist = false; # UPO
1059 $wgEnotifUserTalk = false; # UPO
1060 $wgEnotifRevealEditorAddress = false; # UPO; reply-to address may be filled with page editor's address (if user allowed this in the preferences)
1061 $wgEnotifMinorEdits = true; # UPO; false: "minor edits" on pages do not trigger notification mails.
1062 # # Attention: _every_ change on a user_talk page trigger a notification mail (if the user is not yet notified)
1063
1064
1065 /** Show watching users in recent changes, watchlist and page history views */
1066 $wgRCShowWatchingUsers = false; # UPO
1067 /** Show watching users in Page views */
1068 $wgPageShowWatchingUsers = false;
1069 /**
1070 * Show "Updated (since my last visit)" marker in RC view, watchlist and history
1071 * view for watched pages with new changes */
1072 $wgShowUpdatedMarker = true;
1073
1074 $wgCookieExpiration = 2592000;
1075
1076 /** Clock skew or the one-second resolution of time() can occasionally cause cache
1077 * problems when the user requests two pages within a short period of time. This
1078 * variable adds a given number of seconds to vulnerable timestamps, thereby giving
1079 * a grace period.
1080 */
1081 $wgClockSkewFudge = 5;
1082
1083 # Squid-related settings
1084 #
1085
1086 /** Enable/disable Squid */
1087 $wgUseSquid = false;
1088
1089 /** If you run Squid3 with ESI support, enable this (default:false): */
1090 $wgUseESI = false;
1091
1092 /** Internal server name as known to Squid, if different */
1093 # $wgInternalServer = 'http://yourinternal.tld:8000';
1094 $wgInternalServer = $wgServer;
1095
1096 /**
1097 * Cache timeout for the squid, will be sent as s-maxage (without ESI) or
1098 * Surrogate-Control (with ESI). Without ESI, you should strip out s-maxage in
1099 * the Squid config. 18000 seconds = 5 hours, more cache hits with 2678400 = 31
1100 * days
1101 */
1102 $wgSquidMaxage = 18000;
1103
1104 /**
1105 * A list of proxy servers (ips if possible) to purge on changes don't specify
1106 * ports here (80 is default)
1107 */
1108 # $wgSquidServers = array('127.0.0.1');
1109 $wgSquidServers = array();
1110 $wgSquidServersNoPurge = array();
1111
1112 /** Maximum number of titles to purge in any one client operation */
1113 $wgMaxSquidPurgeTitles = 400;
1114
1115 /** HTCP multicast purging */
1116 $wgHTCPPort = 4827;
1117 $wgHTCPMulticastTTL = 1;
1118 # $wgHTCPMulticastAddress = "224.0.0.85";
1119
1120 # Cookie settings:
1121 #
1122 /**
1123 * Set to set an explicit domain on the login cookies eg, "justthis.domain. org"
1124 * or ".any.subdomain.net"
1125 */
1126 $wgCookieDomain = '';
1127 $wgCookiePath = '/';
1128 $wgCookieSecure = ($wgProto == 'https');
1129 $wgDisableCookieCheck = false;
1130
1131 /** Override to customise the session name */
1132 $wgSessionName = false;
1133
1134 /** Whether to allow inline image pointing to other websites */
1135 $wgAllowExternalImages = false;
1136
1137 /** If the above is false, you can specify an exception here. Image URLs
1138 * that start with this string are then rendered, while all others are not.
1139 * You can use this to set up a trusted, simple repository of images.
1140 *
1141 * Example:
1142 * $wgAllowExternalImagesFrom = 'http://127.0.0.1/';
1143 */
1144 $wgAllowExternalImagesFrom = '';
1145
1146 /** Disable database-intensive features */
1147 $wgMiserMode = false;
1148 /** Disable all query pages if miser mode is on, not just some */
1149 $wgDisableQueryPages = false;
1150 /** Generate a watchlist once every hour or so */
1151 $wgUseWatchlistCache = false;
1152 /** The hour or so mentioned above */
1153 $wgWLCacheTimeout = 3600;
1154 /** Number of links to a page required before it is deemed "wanted" */
1155 $wgWantedPagesThreshold = 1;
1156 /** Enable slow parser functions */
1157 $wgAllowSlowParserFunctions = false;
1158
1159 /**
1160 * To use inline TeX, you need to compile 'texvc' (in the 'math' subdirectory of
1161 * the MediaWiki package and have latex, dvips, gs (ghostscript), andconvert
1162 * (ImageMagick) installed and available in the PATH.
1163 * Please see math/README for more information.
1164 */
1165 $wgUseTeX = false;
1166 /** Location of the texvc binary */
1167 $wgTexvc = './math/texvc';
1168
1169 #
1170 # Profiling / debugging
1171 #
1172 # You have to create a 'profiling' table in your database before using
1173 # profiling see maintenance/archives/patch-profiling.sql .
1174 #
1175 # To enable profiling, edit StartProfiler.php
1176
1177 /** Only record profiling info for pages that took longer than this */
1178 $wgProfileLimit = 0.0;
1179 /** Don't put non-profiling info into log file */
1180 $wgProfileOnly = false;
1181 /** Log sums from profiling into "profiling" table in db. */
1182 $wgProfileToDatabase = false;
1183 /** If true, print a raw call tree instead of per-function report */
1184 $wgProfileCallTree = false;
1185 /** Should application server host be put into profiling table */
1186 $wgProfilePerHost = false;
1187
1188 /** Settings for UDP profiler */
1189 $wgUDPProfilerHost = '127.0.0.1';
1190 $wgUDPProfilerPort = '3811';
1191
1192 /** Detects non-matching wfProfileIn/wfProfileOut calls */
1193 $wgDebugProfiling = false;
1194 /** Output debug message on every wfProfileIn/wfProfileOut */
1195 $wgDebugFunctionEntry = 0;
1196 /** Lots of debugging output from SquidUpdate.php */
1197 $wgDebugSquid = false;
1198
1199 $wgDisableCounters = false;
1200 $wgDisableTextSearch = false;
1201 $wgDisableSearchContext = false;
1202 /**
1203 * If you've disabled search semi-permanently, this also disables updates to the
1204 * table. If you ever re-enable, be sure to rebuild the search table.
1205 */
1206 $wgDisableSearchUpdate = false;
1207 /** Uploads have to be specially set up to be secure */
1208 $wgEnableUploads = false;
1209 /**
1210 * Show EXIF data, on by default if available.
1211 * Requires PHP's EXIF extension: http://www.php.net/manual/en/ref.exif.php
1212 */
1213 $wgShowEXIF = function_exists( 'exif_read_data' );
1214
1215 /**
1216 * Set to true to enable the upload _link_ while local uploads are disabled.
1217 * Assumes that the special page link will be bounced to another server where
1218 * uploads do work.
1219 */
1220 $wgRemoteUploads = false;
1221 $wgDisableAnonTalk = false;
1222 /**
1223 * Do DELETE/INSERT for link updates instead of incremental
1224 */
1225 $wgUseDumbLinkUpdate = false;
1226
1227 /**
1228 * Anti-lock flags - bitfield
1229 * ALF_PRELOAD_LINKS
1230 * Preload links during link update for save
1231 * ALF_PRELOAD_EXISTENCE
1232 * Preload cur_id during replaceLinkHolders
1233 * ALF_NO_LINK_LOCK
1234 * Don't use locking reads when updating the link table. This is
1235 * necessary for wikis with a high edit rate for performance
1236 * reasons, but may cause link table inconsistency
1237 * ALF_NO_BLOCK_LOCK
1238 * As for ALF_LINK_LOCK, this flag is a necessity for high-traffic
1239 * wikis.
1240 */
1241 $wgAntiLockFlags = 0;
1242
1243 /**
1244 * Path to the GNU diff3 utility. If the file doesn't exist, edit conflicts will
1245 * fall back to the old behaviour (no merging).
1246 */
1247 $wgDiff3 = '/usr/bin/diff3';
1248
1249 /**
1250 * We can also compress text in the old revisions table. If this is set on, old
1251 * revisions will be compressed on page save if zlib support is available. Any
1252 * compressed revisions will be decompressed on load regardless of this setting
1253 * *but will not be readable at all* if zlib support is not available.
1254 */
1255 $wgCompressRevisions = false;
1256
1257 /**
1258 * This is the list of preferred extensions for uploading files. Uploading files
1259 * with extensions not in this list will trigger a warning.
1260 */
1261 $wgFileExtensions = array( 'png', 'gif', 'jpg', 'jpeg' );
1262
1263 /** Files with these extensions will never be allowed as uploads. */
1264 $wgFileBlacklist = array(
1265 # HTML may contain cookie-stealing JavaScript and web bugs
1266 'html', 'htm', 'js', 'jsb',
1267 # PHP scripts may execute arbitrary code on the server
1268 'php', 'phtml', 'php3', 'php4', 'phps',
1269 # Other types that may be interpreted by some servers
1270 'shtml', 'jhtml', 'pl', 'py', 'cgi',
1271 # May contain harmful executables for Windows victims
1272 'exe', 'scr', 'dll', 'msi', 'vbs', 'bat', 'com', 'pif', 'cmd', 'vxd', 'cpl' );
1273
1274 /** Files with these mime types will never be allowed as uploads
1275 * if $wgVerifyMimeType is enabled.
1276 */
1277 $wgMimeTypeBlacklist= array(
1278 # HTML may contain cookie-stealing JavaScript and web bugs
1279 'text/html', 'text/javascript', 'text/x-javascript', 'application/x-shellscript',
1280 # PHP scripts may execute arbitrary code on the server
1281 'application/x-php', 'text/x-php',
1282 # Other types that may be interpreted by some servers
1283 'text/x-python', 'text/x-perl', 'text/x-bash', 'text/x-sh', 'text/x-csh',
1284 # Windows metafile, client-side vulnerability on some systems
1285 'application/x-msmetafile'
1286 );
1287
1288 /** This is a flag to determine whether or not to check file extensions on upload. */
1289 $wgCheckFileExtensions = true;
1290
1291 /**
1292 * If this is turned off, users may override the warning for files not covered
1293 * by $wgFileExtensions.
1294 */
1295 $wgStrictFileExtensions = true;
1296
1297 /** Warn if uploaded files are larger than this (in bytes)*/
1298 $wgUploadSizeWarning = 150 * 1024;
1299
1300 /** For compatibility with old installations set to false */
1301 $wgPasswordSalt = true;
1302
1303 /** Which namespaces should support subpages?
1304 * See Language.php for a list of namespaces.
1305 */
1306 $wgNamespacesWithSubpages = array(
1307 NS_TALK => true,
1308 NS_USER => true,
1309 NS_USER_TALK => true,
1310 NS_PROJECT_TALK => true,
1311 NS_IMAGE_TALK => true,
1312 NS_MEDIAWIKI_TALK => true,
1313 NS_TEMPLATE_TALK => true,
1314 NS_HELP_TALK => true,
1315 NS_CATEGORY_TALK => true
1316 );
1317
1318 $wgNamespacesToBeSearchedDefault = array(
1319 NS_MAIN => true,
1320 );
1321
1322 /** If set, a bold ugly notice will show up at the top of every page. */
1323 $wgSiteNotice = '';
1324
1325
1326 #
1327 # Images settings
1328 #
1329
1330 /** dynamic server side image resizing ("Thumbnails") */
1331 $wgUseImageResize = false;
1332
1333 /**
1334 * Resizing can be done using PHP's internal image libraries or using
1335 * ImageMagick or another third-party converter, e.g. GraphicMagick.
1336 * These support more file formats than PHP, which only supports PNG,
1337 * GIF, JPG, XBM and WBMP.
1338 *
1339 * Use Image Magick instead of PHP builtin functions.
1340 */
1341 $wgUseImageMagick = false;
1342 /** The convert command shipped with ImageMagick */
1343 $wgImageMagickConvertCommand = '/usr/bin/convert';
1344
1345 /**
1346 * Use another resizing converter, e.g. GraphicMagick
1347 * %s will be replaced with the source path, %d with the destination
1348 * %w and %h will be replaced with the width and height
1349 *
1350 * An example is provided for GraphicMagick
1351 * Leave as false to skip this
1352 */
1353 #$wgCustomConvertCommand = "gm convert %s -resize %wx%h %d"
1354 $wgCustomConvertCommand = false;
1355
1356 # Scalable Vector Graphics (SVG) may be uploaded as images.
1357 # Since SVG support is not yet standard in browsers, it is
1358 # necessary to rasterize SVGs to PNG as a fallback format.
1359 #
1360 # An external program is required to perform this conversion:
1361 $wgSVGConverters = array(
1362 'ImageMagick' => '$path/convert -background white -geometry $width $input $output',
1363 'sodipodi' => '$path/sodipodi -z -w $width -f $input -e $output',
1364 'inkscape' => '$path/inkscape -z -w $width -f $input -e $output',
1365 'batik' => 'java -Djava.awt.headless=true -jar $path/batik-rasterizer.jar -w $width -d $output $input',
1366 'rsvg' => '$path/rsvg -w$width -h$height $input $output',
1367 );
1368 /** Pick one of the above */
1369 $wgSVGConverter = 'ImageMagick';
1370 /** If not in the executable PATH, specify */
1371 $wgSVGConverterPath = '';
1372 /** Don't scale a SVG larger than this */
1373 $wgSVGMaxSize = 1024;
1374 /**
1375 * Don't thumbnail an image if it will use too much working memory
1376 * Default is 50 MB if decompressed to RGBA form, which corresponds to
1377 * 12.5 million pixels or 3500x3500
1378 */
1379 $wgMaxImageArea = 1.25e7;
1380 /**
1381 * If rendered thumbnail files are older than this timestamp, they
1382 * will be rerendered on demand as if the file didn't already exist.
1383 * Update if there is some need to force thumbs and SVG rasterizations
1384 * to rerender, such as fixes to rendering bugs.
1385 */
1386 $wgThumbnailEpoch = '20030516000000';
1387
1388 /**
1389 * If set, inline scaled images will still produce <img> tags ready for
1390 * output instead of showing an error message.
1391 *
1392 * This may be useful if errors are transitory, especially if the site
1393 * is configured to automatically render thumbnails on request.
1394 *
1395 * On the other hand, it may obscure error conditions from debugging.
1396 * Enable the debug log or the 'thumbnail' log group to make sure errors
1397 * are logged to a file for review.
1398 */
1399 $wgIgnoreImageErrors = false;
1400
1401 /**
1402 * Allow thumbnail rendering on page view. If this is false, a valid
1403 * thumbnail URL is still output, but no file will be created at
1404 * the target location. This may save some time if you have a
1405 * thumb.php or 404 handler set up which is faster than the regular
1406 * webserver(s).
1407 */
1408 $wgGenerateThumbnailOnParse = true;
1409
1410 /** Set $wgCommandLineMode if it's not set already, to avoid notices */
1411 if( !isset( $wgCommandLineMode ) ) {
1412 $wgCommandLineMode = false;
1413 }
1414
1415
1416 #
1417 # Recent changes settings
1418 #
1419
1420 /** Log IP addresses in the recentchanges table */
1421 $wgPutIPinRC = true;
1422
1423 /**
1424 * Recentchanges items are periodically purged; entries older than this many
1425 * seconds will go.
1426 * For one week : 7 * 24 * 3600
1427 */
1428 $wgRCMaxAge = 7 * 24 * 3600;
1429
1430
1431 # Send RC updates via UDP
1432 $wgRC2UDPAddress = false;
1433 $wgRC2UDPPort = false;
1434 $wgRC2UDPPrefix = '';
1435
1436 #
1437 # Copyright and credits settings
1438 #
1439
1440 /** RDF metadata toggles */
1441 $wgEnableDublinCoreRdf = false;
1442 $wgEnableCreativeCommonsRdf = false;
1443
1444 /** Override for copyright metadata.
1445 * TODO: these options need documentation
1446 */
1447 $wgRightsPage = NULL;
1448 $wgRightsUrl = NULL;
1449 $wgRightsText = NULL;
1450 $wgRightsIcon = NULL;
1451
1452 /** Set this to some HTML to override the rights icon with an arbitrary logo */
1453 $wgCopyrightIcon = NULL;
1454
1455 /** Set this to true if you want detailed copyright information forms on Upload. */
1456 $wgUseCopyrightUpload = false;
1457
1458 /** Set this to false if you want to disable checking that detailed copyright
1459 * information values are not empty. */
1460 $wgCheckCopyrightUpload = true;
1461
1462 /**
1463 * Set this to the number of authors that you want to be credited below an
1464 * article text. Set it to zero to hide the attribution block, and a negative
1465 * number (like -1) to show all authors. Note that this will require 2-3 extra
1466 * database hits, which can have a not insignificant impact on performance for
1467 * large wikis.
1468 */
1469 $wgMaxCredits = 0;
1470
1471 /** If there are more than $wgMaxCredits authors, show $wgMaxCredits of them.
1472 * Otherwise, link to a separate credits page. */
1473 $wgShowCreditsIfMax = true;
1474
1475
1476
1477 /**
1478 * Set this to false to avoid forcing the first letter of links to capitals.
1479 * WARNING: may break links! This makes links COMPLETELY case-sensitive. Links
1480 * appearing with a capital at the beginning of a sentence will *not* go to the
1481 * same place as links in the middle of a sentence using a lowercase initial.
1482 */
1483 $wgCapitalLinks = true;
1484
1485 /**
1486 * List of interwiki prefixes for wikis we'll accept as sources for
1487 * Special:Import (for sysops). Since complete page history can be imported,
1488 * these should be 'trusted'.
1489 *
1490 * If a user has the 'import' permission but not the 'importupload' permission,
1491 * they will only be able to run imports through this transwiki interface.
1492 */
1493 $wgImportSources = array();
1494
1495 /**
1496 * Optional default target namespace for interwiki imports.
1497 * Can use this to create an incoming "transwiki"-style queue.
1498 * Set to numeric key, not the name.
1499 *
1500 * Users may override this in the Special:Import dialog.
1501 */
1502 $wgImportTargetNamespace = null;
1503
1504 /**
1505 * If set to false, disables the full-history option on Special:Export.
1506 * This is currently poorly optimized for long edit histories, so is
1507 * disabled on Wikimedia's sites.
1508 */
1509 $wgExportAllowHistory = true;
1510
1511 /**
1512 * If set nonzero, Special:Export requests for history of pages with
1513 * more revisions than this will be rejected. On some big sites things
1514 * could get bogged down by very very long pages.
1515 */
1516 $wgExportMaxHistory = 0;
1517
1518 $wgExportAllowListContributors = false ;
1519
1520
1521 /** Text matching this regular expression will be recognised as spam
1522 * See http://en.wikipedia.org/wiki/Regular_expression */
1523 $wgSpamRegex = false;
1524 /** Similarly if this function returns true */
1525 $wgFilterCallback = false;
1526
1527 /** Go button goes straight to the edit screen if the article doesn't exist. */
1528 $wgGoToEdit = false;
1529
1530 /** Allow limited user-specified HTML in wiki pages?
1531 * It will be run through a whitelist for security. Set this to false if you
1532 * want wiki pages to consist only of wiki markup. Note that replacements do not
1533 * yet exist for all HTML constructs.*/
1534 $wgUserHtml = true;
1535
1536 /** Allow raw, unchecked HTML in <html>...</html> sections.
1537 * THIS IS VERY DANGEROUS on a publically editable site, so USE wgGroupPermissions
1538 * TO RESTRICT EDITING to only those that you trust
1539 */
1540 $wgRawHtml = false;
1541
1542 /**
1543 * $wgUseTidy: use tidy to make sure HTML output is sane.
1544 * This should only be enabled if $wgUserHtml is true.
1545 * tidy is a free tool that fixes broken HTML.
1546 * See http://www.w3.org/People/Raggett/tidy/
1547 * $wgTidyBin should be set to the path of the binary and
1548 * $wgTidyConf to the path of the configuration file.
1549 * $wgTidyOpts can include any number of parameters.
1550 *
1551 * $wgTidyInternal controls the use of the PECL extension to use an in-
1552 * process tidy library instead of spawning a separate program.
1553 * Normally you shouldn't need to override the setting except for
1554 * debugging. To install, use 'pear install tidy' and add a line
1555 * 'extension=tidy.so' to php.ini.
1556 */
1557 $wgUseTidy = false;
1558 $wgAlwaysUseTidy = false;
1559 $wgTidyBin = 'tidy';
1560 $wgTidyConf = $IP.'/extensions/tidy/tidy.conf';
1561 $wgTidyOpts = '';
1562 $wgTidyInternal = function_exists( 'tidy_load_config' );
1563
1564 /** See list of skins and their symbolic names in languages/Language.php */
1565 $wgDefaultSkin = 'monobook';
1566
1567 /** Whether or not to allow and use real name fields. Defaults to true. */
1568 $wgAllowRealName = true;
1569
1570 /*****************************************************************************
1571 * Extensions
1572 */
1573
1574 /**
1575 * A list of callback functions which are called once MediaWiki is fully initialised
1576 */
1577 $wgExtensionFunctions = array();
1578
1579 /**
1580 * Extension functions for initialisation of skins. This is called somewhat earlier
1581 * than $wgExtensionFunctions.
1582 */
1583 $wgSkinExtensionFunctions = array();
1584
1585 /**
1586 * List of valid skin names.
1587 * The key should be the name in all lower case, the value should be a display name.
1588 * The default skins will be added later, by Skin::getSkinNames(). Use
1589 * Skin::getSkinNames() as an accessor if you wish to have access to the full list.
1590 */
1591 $wgValidSkinNames = array();
1592
1593 /**
1594 * Special page list.
1595 * See the top of SpecialPage.php for documentation.
1596 */
1597 $wgSpecialPages = array();
1598
1599 /**
1600 * Array mapping class names to filenames, for autoloading.
1601 */
1602 $wgAutoloadClasses = array();
1603
1604 /**
1605 * An array of extension types and inside that their names, versions, authors
1606 * and urls, note that the version and url key can be omitted.
1607 *
1608 * <code>
1609 * $wgExtensionCredits[$type][] = array(
1610 * 'name' => 'Example extension',
1611 * 'version' => 1.9,
1612 * 'author' => 'Foo Barstein',
1613 * 'url' => 'http://wwww.example.com/Example%20Extension/',
1614 * );
1615 * </code>
1616 *
1617 * Where $type is 'specialpage', 'parserhook', or 'other'.
1618 */
1619 $wgExtensionCredits = array();
1620 /*
1621 * end extensions
1622 ******************************************************************************/
1623
1624 /**
1625 * Allow user Javascript page?
1626 * This enables a lot of neat customizations, but may
1627 * increase security risk to users and server load.
1628 */
1629 $wgAllowUserJs = false;
1630
1631 /**
1632 * Allow user Cascading Style Sheets (CSS)?
1633 * This enables a lot of neat customizations, but may
1634 * increase security risk to users and server load.
1635 */
1636 $wgAllowUserCss = false;
1637
1638 /** Use the site's Javascript page? */
1639 $wgUseSiteJs = true;
1640
1641 /** Use the site's Cascading Style Sheets (CSS)? */
1642 $wgUseSiteCss = true;
1643
1644 /** Filter for Special:Randompage. Part of a WHERE clause */
1645 $wgExtraRandompageSQL = false;
1646
1647 /** Allow the "info" action, very inefficient at the moment */
1648 $wgAllowPageInfo = false;
1649
1650 /** Maximum indent level of toc. */
1651 $wgMaxTocLevel = 999;
1652
1653 /** Name of the external diff engine to use */
1654 $wgExternalDiffEngine = false;
1655
1656 /** Use RC Patrolling to check for vandalism */
1657 $wgUseRCPatrol = true;
1658
1659 /** Set maximum number of results to return in syndication feeds (RSS, Atom) for
1660 * eg Recentchanges, Newpages. */
1661 $wgFeedLimit = 50;
1662
1663 /** _Minimum_ timeout for cached Recentchanges feed, in seconds.
1664 * A cached version will continue to be served out even if changes
1665 * are made, until this many seconds runs out since the last render.
1666 *
1667 * If set to 0, feed caching is disabled. Use this for debugging only;
1668 * feed generation can be pretty slow with diffs.
1669 */
1670 $wgFeedCacheTimeout = 60;
1671
1672 /** When generating Recentchanges RSS/Atom feed, diffs will not be generated for
1673 * pages larger than this size. */
1674 $wgFeedDiffCutoff = 32768;
1675
1676
1677 /**
1678 * Additional namespaces. If the namespaces defined in Language.php and
1679 * Namespace.php are insufficient, you can create new ones here, for example,
1680 * to import Help files in other languages.
1681 * PLEASE NOTE: Once you delete a namespace, the pages in that namespace will
1682 * no longer be accessible. If you rename it, then you can access them through
1683 * the new namespace name.
1684 *
1685 * Custom namespaces should start at 100 to avoid conflicting with standard
1686 * namespaces, and should always follow the even/odd main/talk pattern.
1687 */
1688 #$wgExtraNamespaces =
1689 # array(100 => "Hilfe",
1690 # 101 => "Hilfe_Diskussion",
1691 # 102 => "Aide",
1692 # 103 => "Discussion_Aide"
1693 # );
1694 $wgExtraNamespaces = NULL;
1695
1696 /**
1697 * Limit images on image description pages to a user-selectable limit. In order
1698 * to reduce disk usage, limits can only be selected from a list. This is the
1699 * list of settings the user can choose from:
1700 */
1701 $wgImageLimits = array (
1702 array(320,240),
1703 array(640,480),
1704 array(800,600),
1705 array(1024,768),
1706 array(1280,1024),
1707 array(10000,10000) );
1708
1709 /**
1710 * Adjust thumbnails on image pages according to a user setting. In order to
1711 * reduce disk usage, the values can only be selected from a list. This is the
1712 * list of settings the user can choose from:
1713 */
1714 $wgThumbLimits = array(
1715 120,
1716 150,
1717 180,
1718 200,
1719 250,
1720 300
1721 );
1722
1723 /**
1724 * On category pages, show thumbnail gallery for images belonging to that
1725 * category instead of listing them as articles.
1726 */
1727 $wgCategoryMagicGallery = true;
1728
1729 /**
1730 * Paging limit for categories
1731 */
1732 $wgCategoryPagingLimit = 200;
1733
1734 /**
1735 * Browser Blacklist for unicode non compliant browsers
1736 * Contains a list of regexps : "/regexp/" matching problematic browsers
1737 */
1738 $wgBrowserBlackList = array(
1739 /**
1740 * Netscape 2-4 detection
1741 * The minor version may contain strings such as "Gold" or "SGoldC-SGI"
1742 * Lots of non-netscape user agents have "compatible", so it's useful to check for that
1743 * with a negative assertion. The [UIN] identifier specifies the level of security
1744 * in a Netscape/Mozilla browser, checking for it rules out a number of fakers.
1745 * The language string is unreliable, it is missing on NS4 Mac.
1746 *
1747 * Reference: http://www.psychedelix.com/agents/index.shtml
1748 */
1749 '/^Mozilla\/2\.[^ ]+ .*?\((?!compatible).*; [UIN]/',
1750 '/^Mozilla\/3\.[^ ]+ .*?\((?!compatible).*; [UIN]/',
1751 '/^Mozilla\/4\.[^ ]+ .*?\((?!compatible).*; [UIN]/',
1752
1753 /**
1754 * MSIE on Mac OS 9 is teh sux0r, converts þ to <thorn>, ð to <eth>, Þ to <THORN> and Ð to <ETH>
1755 *
1756 * Known useragents:
1757 * - Mozilla/4.0 (compatible; MSIE 5.0; Mac_PowerPC)
1758 * - Mozilla/4.0 (compatible; MSIE 5.15; Mac_PowerPC)
1759 * - Mozilla/4.0 (compatible; MSIE 5.23; Mac_PowerPC)
1760 * - [...]
1761 *
1762 * @link http://en.wikipedia.org/w/index.php?title=User%3A%C6var_Arnfj%F6r%F0_Bjarmason%2Ftestme&diff=12356041&oldid=12355864
1763 * @link http://en.wikipedia.org/wiki/Template%3AOS9
1764 */
1765 '/^Mozilla\/4\.0 \(compatible; MSIE \d+\.\d+; Mac_PowerPC\)/'
1766 );
1767
1768 /**
1769 * Fake out the timezone that the server thinks it's in. This will be used for
1770 * date display and not for what's stored in the DB. Leave to null to retain
1771 * your server's OS-based timezone value. This is the same as the timezone.
1772 *
1773 * This variable is currently used ONLY for signature formatting, not for
1774 * anything else.
1775 */
1776 # $wgLocaltimezone = 'GMT';
1777 # $wgLocaltimezone = 'PST8PDT';
1778 # $wgLocaltimezone = 'Europe/Sweden';
1779 # $wgLocaltimezone = 'CET';
1780 $wgLocaltimezone = null;
1781
1782 /**
1783 * Set an offset from UTC in minutes to use for the default timezone setting
1784 * for anonymous users and new user accounts.
1785 *
1786 * This setting is used for most date/time displays in the software, and is
1787 * overrideable in user preferences. It is *not* used for signature timestamps.
1788 *
1789 * You can set it to match the configured server timezone like this:
1790 * $wgLocalTZoffset = date("Z") / 60;
1791 *
1792 * If your server is not configured for the timezone you want, you can set
1793 * this in conjunction with the signature timezone and override the TZ
1794 * environment variable like so:
1795 * $wgLocaltimezone="Europe/Berlin";
1796 * putenv("TZ=$wgLocaltimezone");
1797 * $wgLocalTZoffset = date("Z") / 60;
1798 *
1799 * Leave at NULL to show times in universal time (UTC/GMT).
1800 */
1801 $wgLocalTZoffset = null;
1802
1803
1804 /**
1805 * When translating messages with wfMsg(), it is not always clear what should be
1806 * considered UI messages and what shoud be content messages.
1807 *
1808 * For example, for regular wikipedia site like en, there should be only one
1809 * 'mainpage', therefore when getting the link of 'mainpage', we should treate
1810 * it as content of the site and call wfMsgForContent(), while for rendering the
1811 * text of the link, we call wfMsg(). The code in default behaves this way.
1812 * However, sites like common do offer different versions of 'mainpage' and the
1813 * like for different languages. This array provides a way to override the
1814 * default behavior. For example, to allow language specific mainpage and
1815 * community portal, set
1816 *
1817 * $wgForceUIMsgAsContentMsg = array( 'mainpage', 'portal-url' );
1818 */
1819 $wgForceUIMsgAsContentMsg = array();
1820
1821
1822 /**
1823 * Authentication plugin.
1824 */
1825 $wgAuth = null;
1826
1827 /**
1828 * Global list of hooks.
1829 * Add a hook by doing:
1830 * $wgHooks['event_name'][] = $function;
1831 * or:
1832 * $wgHooks['event_name'][] = array($function, $data);
1833 * or:
1834 * $wgHooks['event_name'][] = array($object, 'method');
1835 */
1836 $wgHooks = array();
1837
1838 /**
1839 * The logging system has two levels: an event type, which describes the
1840 * general category and can be viewed as a named subset of all logs; and
1841 * an action, which is a specific kind of event that can exist in that
1842 * log type.
1843 */
1844 $wgLogTypes = array( '',
1845 'block',
1846 'protect',
1847 'rights',
1848 'delete',
1849 'upload',
1850 'move',
1851 'import' );
1852
1853 /**
1854 * Lists the message key string for each log type. The localized messages
1855 * will be listed in the user interface.
1856 *
1857 * Extensions with custom log types may add to this array.
1858 */
1859 $wgLogNames = array(
1860 '' => 'log',
1861 'block' => 'blocklogpage',
1862 'protect' => 'protectlogpage',
1863 'rights' => 'rightslog',
1864 'delete' => 'dellogpage',
1865 'upload' => 'uploadlogpage',
1866 'move' => 'movelogpage',
1867 'import' => 'importlogpage' );
1868
1869 /**
1870 * Lists the message key string for descriptive text to be shown at the
1871 * top of each log type.
1872 *
1873 * Extensions with custom log types may add to this array.
1874 */
1875 $wgLogHeaders = array(
1876 '' => 'alllogstext',
1877 'block' => 'blocklogtext',
1878 'protect' => 'protectlogtext',
1879 'rights' => 'rightslogtext',
1880 'delete' => 'dellogpagetext',
1881 'upload' => 'uploadlogpagetext',
1882 'move' => 'movelogpagetext',
1883 'import' => 'importlogpagetext', );
1884
1885 /**
1886 * Lists the message key string for formatting individual events of each
1887 * type and action when listed in the logs.
1888 *
1889 * Extensions with custom log types may add to this array.
1890 */
1891 $wgLogActions = array(
1892 'block/block' => 'blocklogentry',
1893 'block/unblock' => 'unblocklogentry',
1894 'protect/protect' => 'protectedarticle',
1895 'protect/unprotect' => 'unprotectedarticle',
1896 'rights/rights' => 'rightslogentry',
1897 'delete/delete' => 'deletedarticle',
1898 'delete/restore' => 'undeletedarticle',
1899 'delete/revision' => 'revdelete-logentry',
1900 'upload/upload' => 'uploadedimage',
1901 'upload/revert' => 'uploadedimage',
1902 'move/move' => '1movedto2',
1903 'move/move_redir' => '1movedto2_redir',
1904 'import/upload' => 'import-logentry-upload',
1905 'import/interwiki' => 'import-logentry-interwiki' );
1906
1907 /**
1908 * Experimental preview feature to fetch rendered text
1909 * over an XMLHttpRequest from JavaScript instead of
1910 * forcing a submit and reload of the whole page.
1911 * Leave disabled unless you're testing it.
1912 */
1913 $wgLivePreview = false;
1914
1915 /**
1916 * Disable the internal MySQL-based search, to allow it to be
1917 * implemented by an extension instead.
1918 */
1919 $wgDisableInternalSearch = false;
1920
1921 /**
1922 * Set this to a URL to forward search requests to some external location.
1923 * If the URL includes '$1', this will be replaced with the URL-encoded
1924 * search term.
1925 *
1926 * For example, to forward to Google you'd have something like:
1927 * $wgSearchForwardUrl = 'http://www.google.com/search?q=$1' .
1928 * '&domains=http://example.com' .
1929 * '&sitesearch=http://example.com' .
1930 * '&ie=utf-8&oe=utf-8';
1931 */
1932 $wgSearchForwardUrl = null;
1933
1934 /**
1935 * If true, external URL links in wiki text will be given the
1936 * rel="nofollow" attribute as a hint to search engines that
1937 * they should not be followed for ranking purposes as they
1938 * are user-supplied and thus subject to spamming.
1939 */
1940 $wgNoFollowLinks = true;
1941
1942 /**
1943 * Namespaces in which $wgNoFollowLinks doesn't apply.
1944 * See Language.php for a list of namespaces.
1945 */
1946 $wgNoFollowNsExceptions = array();
1947
1948 /**
1949 * Robot policies for namespaces
1950 * e.g. $wgNamespaceRobotPolicies = array( NS_TALK => 'noindex' );
1951 */
1952 $wgNamespaceRobotPolicies = array();
1953
1954 /**
1955 * Specifies the minimal length of a user password. If set to
1956 * 0, empty passwords are allowed.
1957 */
1958 $wgMinimalPasswordLength = 0;
1959
1960 /**
1961 * Activate external editor interface for files and pages
1962 * See http://meta.wikimedia.org/wiki/Help:External_editors
1963 */
1964 $wgUseExternalEditor = true;
1965
1966 /** Whether or not to sort special pages in Special:Specialpages */
1967
1968 $wgSortSpecialPages = true;
1969
1970 /**
1971 * Specify the name of a skin that should not be presented in the
1972 * list of available skins.
1973 * Use for blacklisting a skin which you do not want to remove
1974 * from the .../skins/ directory
1975 */
1976 $wgSkipSkin = '';
1977 $wgSkipSkins = array(); # More of the same
1978
1979 /**
1980 * Array of disabled article actions, e.g. view, edit, dublincore, delete, etc.
1981 */
1982 $wgDisabledActions = array();
1983
1984 /**
1985 * Disable redirects to special pages and interwiki redirects, which use a 302 and have no "redirected from" link
1986 */
1987 $wgDisableHardRedirects = false;
1988
1989 /**
1990 * Use http.dnsbl.sorbs.net to check for open proxies
1991 */
1992 $wgEnableSorbs = false;
1993
1994 /**
1995 * Proxy whitelist, list of addresses that are assumed to be non-proxy despite what the other
1996 * methods might say
1997 */
1998 $wgProxyWhitelist = array();
1999
2000 /**
2001 * Simple rate limiter options to brake edit floods.
2002 * Maximum number actions allowed in the given number of seconds;
2003 * after that the violating client receives HTTP 500 error pages
2004 * until the period elapses.
2005 *
2006 * array( 4, 60 ) for a maximum of 4 hits in 60 seconds.
2007 *
2008 * This option set is experimental and likely to change.
2009 * Requires memcached.
2010 */
2011 $wgRateLimits = array(
2012 'edit' => array(
2013 'anon' => null, // for any and all anonymous edits (aggregate)
2014 'user' => null, // for each logged-in user
2015 'newbie' => null, // for each recent account; overrides 'user'
2016 'ip' => null, // for each anon and recent account
2017 'subnet' => null, // ... with final octet removed
2018 ),
2019 'move' => array(
2020 'user' => null,
2021 'newbie' => null,
2022 'ip' => null,
2023 'subnet' => null,
2024 ),
2025 'mailpassword' => array(
2026 'anon' => NULL,
2027 ),
2028 );
2029
2030 /**
2031 * Set to a filename to log rate limiter hits.
2032 */
2033 $wgRateLimitLog = null;
2034
2035 /**
2036 * Array of groups which should never trigger the rate limiter
2037 */
2038 $wgRateLimitsExcludedGroups = array( 'sysop', 'bureaucrat' );
2039
2040 /**
2041 * On Special:Unusedimages, consider images "used", if they are put
2042 * into a category. Default (false) is not to count those as used.
2043 */
2044 $wgCountCategorizedImagesAsUsed = false;
2045
2046 /**
2047 * External stores allow including content
2048 * from non database sources following URL links
2049 *
2050 * Short names of ExternalStore classes may be specified in an array here:
2051 * $wgExternalStores = array("http","file","custom")...
2052 *
2053 * CAUTION: Access to database might lead to code execution
2054 */
2055 $wgExternalStores = false;
2056
2057 /**
2058 * An array of external mysql servers, e.g.
2059 * $wgExternalServers = array( 'cluster1' => array( 'srv28', 'srv29', 'srv30' ) );
2060 */
2061 $wgExternalServers = array();
2062
2063 /**
2064 * The place to put new revisions, false to put them in the local text table.
2065 * Part of a URL, e.g. DB://cluster1
2066 *
2067 * Can be an array instead of a single string, to enable data distribution. Keys
2068 * must be consecutive integers, starting at zero. Example:
2069 *
2070 * $wgDefaultExternalStore = array( 'DB://cluster1', 'DB://cluster2' );
2071 *
2072 */
2073 $wgDefaultExternalStore = false;
2074
2075 /**
2076 * Revision text may be cached in $wgMemc to reduce load on external storage
2077 * servers and object extraction overhead for frequently-loaded revisions.
2078 *
2079 * Set to 0 to disable, or number of seconds before cache expiry.
2080 */
2081 $wgRevisionCacheExpiry = 0;
2082
2083 /**
2084 * list of trusted media-types and mime types.
2085 * Use the MEDIATYPE_xxx constants to represent media types.
2086 * This list is used by Image::isSafeFile
2087 *
2088 * Types not listed here will have a warning about unsafe content
2089 * displayed on the images description page. It would also be possible
2090 * to use this for further restrictions, like disabling direct
2091 * [[media:...]] links for non-trusted formats.
2092 */
2093 $wgTrustedMediaFormats= array(
2094 MEDIATYPE_BITMAP, //all bitmap formats
2095 MEDIATYPE_AUDIO, //all audio formats
2096 MEDIATYPE_VIDEO, //all plain video formats
2097 "image/svg", //svg (only needed if inline rendering of svg is not supported)
2098 "application/pdf", //PDF files
2099 #"application/x-shockwafe-flash", //flash/shockwave movie
2100 );
2101
2102 /**
2103 * Allow special page inclusions such as {{Special:Allpages}}
2104 */
2105 $wgAllowSpecialInclusion = true;
2106
2107 /**
2108 * Timeout for HTTP requests done via CURL
2109 */
2110 $wgHTTPTimeout = 3;
2111
2112 /**
2113 * Proxy to use for CURL requests.
2114 */
2115 $wgHTTPProxy = false;
2116
2117 /**
2118 * Enable interwiki transcluding. Only when iw_trans=1.
2119 */
2120 $wgEnableScaryTranscluding = false;
2121 /**
2122 * Expiry time for interwiki transclusion
2123 */
2124 $wgTranscludeCacheExpiry = 3600;
2125
2126 /**
2127 * Support blog-style "trackbacks" for articles. See
2128 * http://www.sixapart.com/pronet/docs/trackback_spec for details.
2129 */
2130 $wgUseTrackbacks = false;
2131
2132 /**
2133 * Enable filtering of categories in Recentchanges
2134 */
2135 $wgAllowCategorizedRecentChanges = false ;
2136
2137 /**
2138 * Number of jobs to perform per request. May be less than one in which case
2139 * jobs are performed probabalistically. If this is zero, jobs will not be done
2140 * during ordinary apache requests. In this case, maintenance/runJobs.php should
2141 * be run periodically.
2142 */
2143 $wgJobRunRate = 1;
2144
2145 /**
2146 * Number of rows to update per job
2147 */
2148 $wgUpdateRowsPerJob = 500;
2149
2150 /**
2151 * Number of rows to update per query
2152 */
2153 $wgUpdateRowsPerQuery = 10;
2154
2155 /**
2156 * Enable AJAX framework
2157 */
2158 $wgUseAjax = false;
2159
2160 /**
2161 * Enable auto suggestion for the search bar
2162 * Requires $wgUseAjax to be true too.
2163 * Causes wfSajaxSearch to be added to $wgAjaxExportList
2164 */
2165 $wgAjaxSearch = false;
2166
2167 /**
2168 * List of Ajax-callable functions.
2169 * Extensions acting as Ajax callbacks must register here
2170 */
2171 $wgAjaxExportList = array( );
2172
2173 /**
2174 * Allow DISPLAYTITLE to change title display
2175 */
2176 $wgAllowDisplayTitle = false ;
2177
2178 /**
2179 * Array of usernames which may not be registered or logged in from
2180 * Maintenance scripts can still use these
2181 */
2182 $wgReservedUsernames = array( 'MediaWiki default', 'Conversion script' );
2183
2184 /**
2185 * MediaWiki will reject HTMLesque tags in uploaded files due to idiotic browsers which can't
2186 * perform basic stuff like MIME detection and which are vulnerable to further idiots uploading
2187 * crap files as images. When this directive is on, <title> will be allowed in files with
2188 * an "image/svg" MIME type. You should leave this disabled if your web server is misconfigured
2189 * and doesn't send appropriate MIME types for SVG images.
2190 */
2191 $wgAllowTitlesInSVG = false;
2192
2193 /**
2194 * Array of namespaces which can be deemed to contain valid "content", as far
2195 * as the site statistics are concerned. Useful if additional namespaces also
2196 * contain "content" which should be considered when generating a count of the
2197 * number of articles in the wiki.
2198 */
2199 $wgContentNamespaces = array( NS_MAIN );
2200
2201 /**
2202 * Maximum amount of virtual memory available to shell processes under linux, in KB.
2203 */
2204 $wgMaxShellMemory = 102400;
2205
2206 /**
2207 * Maximum file size created by shell processes under linux, in KB
2208 * ImageMagick convert for example can be fairly hungry for scratch space
2209 */
2210 $wgMaxShellFileSize = 102400;
2211
2212 /**
2213 * DJVU settings
2214 * Path of the djvutoxml executable
2215 * Enable this and $wgDjvuRenderer to enable djvu rendering
2216 */
2217 # $wgDjvuToXML = 'djvutoxml';
2218 $wgDjvuToXML = null;
2219
2220 /**
2221 * Path of the ddjvu DJVU renderer
2222 * Enable this and $wgDjvuToXML to enable djvu rendering
2223 */
2224 # $wgDjvuRenderer = 'ddjvu';
2225 $wgDjvuRenderer = null;
2226
2227 /**
2228 * Path of the DJVU post processor
2229 * May include command line options
2230 * Default: ppmtojpeg, since ddjvu generates ppm output
2231 */
2232 $wgDjvuPostProcessor = 'ppmtojpeg';
2233
2234 ?>