Manual:$wgLocalFileRepo

Details
This config is for customizing the local (primary) file repo that MediaWiki uses. Most users will not want to customize this or will customize this indirectly via other variables such as $wgUploadDirectory.

More complex setups may requiring customizing this variable. For example, if you want to use a custom file backend, in order to replicate file storage amongst multiple data centers.

Properties required for all repos

 * class
 * The class name for the repository. May come from the core or an extension.  The core repository classes are FileRepo, LocalRepo, ForeignDBRepo.  (FSRepo is also supported for backwards compatibility.)


 * name
 * Should be set to.


 * backend
 * A file backend name (see  ). For $wgLocalFileRepo and , a name is automatically generated in  if not defined.

General parameters for LocalRepo class

 * zones
 * Config of where to store files (different zones like public vs deleted). An array of zone descriptions containing: container, url, directory, urlsByExt. Some other config options may override this one in specific cases


 * url
 * Base public URL


 * hashLevels
 * The number of directory levels for hash-based division of files (see  for info)


 * deletedHashLevels


 * thumbScriptUrl
 * The URL for thumb.php (optional, not recommended)


 * transformVia404
 * Whether to skip media file transformation on parse and rely on a 404 handler instead.


 * thumbProxyUrl


 * thumbProxySecret


 * disableLocalTransform
 * Do not resize images on local machine, but instead use some other system to do so


 * initialCapital
 * Equivalent to , determines whether filenames implicitly start with a capital letter. The current implementation may give incorrect description page links when the local  and initialCapital are mismatched.


 * pathDisclosureProtection
 * May be 'paranoid' to remove all parameters from error messages, 'none' to leave the paths in unchanged, or 'simple' to replace paths with placeholders. Default for LocalRepo is 'simple'.


 * fileMode
 * Used by FileBackend to set the unix permissions on created files.


 * directory
 * Used by FileBackend to determine upload directory


 * thumbUrl
 * URL to server thumbmails from (if not overridden by zone directive)


 * isPrivate
 * Is this repo private (E.g. its a private repo). Steps are taken to prevent direct access, but may not be sufficient and you should still make sure the files aren't somewhere served by webserver.


 * useJsonMetadata
 * Store serialized metadata as JSON instead of php-serialized format. Default: true.


 * useSplitMetadata
 * Store large chunks of FileMetadata in external storage. Some files have their entire text layer as metadata, which can cause memory issues if stored directly on the file. Default: false.


 * splitMetadataThreshold
 * threshold above which metadata items should be split into external storage. Default: 1000.


 * updateCompatibleMetadata
 * Automatically regenerate file metadata if it is detected metadata is out of date. Default: false.


 * reserializeMetadata
 * Automatically change metadata format (E.g. to JSON) or split it to separate storage, if it is detected as needed. Default: false.

Default value
This code, in Setup.php, generates a default value for $wgLocalFileRepo based on the values of other configuration settings:

