xref: /dokuwiki/lib/plugins/config/settings/config.metadata.php (revision 38dc5fa6df9a0cd5afd16dc95600d7cf11b08877)
110449332Schris<?php
210449332Schris/**
310449332Schris * Metadata for configuration manager plugin
410449332Schris *
510449332Schris * Note:  This file should be included within a function to ensure it
6862763f2Schris *        doesn't clash with the settings it is describing.
710449332Schris *
810449332Schris * Format:
910449332Schris *   $meta[<setting name>] = array(<handler class id>,<param name> => <param value>);
1010449332Schris *
1110449332Schris *   <handler class id>  is the handler class name without the "setting_" prefix
1210449332Schris *
1310449332Schris * Defined classes:
14306ca8aaSchris *   Generic (source: settings/config.class.php)
15306ca8aaSchris *   -------------------------------------------
16e8a6bae4Schris *   ''             - default class ('setting'), textarea, minimal input validation, setting output in quotes
17e8a6bae4Schris *   'string'       - single line text input, minimal input validation, setting output in quotes
1810449332Schris *   'numeric'      - text input, accepts numbers and arithmetic operators, setting output without quotes
19*38dc5fa6SMichael Hamann *                    if given the '_min' and '_max' parameters are used for validation
2076ae5803SAndreas Gohr *   'numericopt'   - like above, but accepts empty values
2110449332Schris *   'onoff'        - checkbox input, setting output  0|1
2210449332Schris *   'multichoice'  - select input (single choice), setting output with quotes, required _choices parameter
2310449332Schris *   'email'        - text input, input must conform to email address format, setting output in quotes
249291cf33SAndreas Gohr *   'richemail'    - text input, input must conform to email address format but accepts variables and
259291cf33SAndreas Gohr *                    emails with a real name prepended (when email address is given in <>)
263994772aSChris Smith *   'password'     - password input, minimal input validation, setting output text in quotes, maybe encoded
273994772aSChris Smith *                    according to the _code parameter
2810449332Schris *   'dirchoice'    - as multichoice, selection choices based on folders found at location specified in _dir
29f7589b08SChris Smith *                    parameter (required). A pattern can be used to restrict the folders to only those which
30f7589b08SChris Smith *                    match the pattern.
31306ca8aaSchris *   'multicheckbox'- a checkbox for each choice plus an "other" string input, config file setting is a comma
32306ca8aaSchris *                    separated list of checked choices
334fa2dffcSBen Coburn *   'fieldset'     - used to group configuration settings, but is not itself a setting. To make this clear in
344fa2dffcSBen Coburn *                    the language files the keys for this type should start with '_'.
3510449332Schris *
36306ca8aaSchris *  Single Setting (source: settings/extra.class.php)
37306ca8aaSchris *  -------------------------------------------------
3810449332Schris *   'savedir'     - as 'setting', input tested against initpath() (inc/init.php)
3910449332Schris *   'sepchar'     - as multichoice, selection constructed from string of valid values
4010449332Schris *   'authtype'    - as 'setting', input validated against a valid php file at expected location for auth files
4110449332Schris *   'im_convert'  - as 'setting', input must exist and be an im_convert module
42306ca8aaSchris *   'disableactions' - as 'setting'
431b95bfdfSChris Smith *   'compression' - no additional parameters. checks php installation supports possible compression alternatives
4410449332Schris *
4510449332Schris *  Any setting commented or missing will use 'setting' class - text input, minimal validation, quoted output
4610449332Schris *
4710449332Schris * Defined parameters:
4810449332Schris *   '_pattern'    - string, a preg pattern. input is tested against this pattern before being accepted
49f7589b08SChris Smith *                   optional all classes, except onoff & multichoice which ignore it
5010449332Schris *   '_choices'    - array of choices. used to populate a selection box. choice will be replaced by a localised
5110449332Schris *                   language string, indexed by  <setting name>_o_<choice>, if one exists
52306ca8aaSchris *                   required by 'multichoice' & 'multicheckbox' classes, ignored by others
5310449332Schris *   '_dir'        - location of directory to be used to populate choice list
5410449332Schris *                   required by 'dirchoice' class, ignored by other classes
55306ca8aaSchris *   '_combine'    - complimentary output setting values which can be combined into a single display checkbox
56306ca8aaSchris *                   optional for 'multicheckbox', ignored by other classes
573994772aSChris Smith *   '_code'       - encoding method to use, accepted values: 'base64','uuencode','plain'.  defaults to plain.
58*38dc5fa6SMichael Hamann *   '_min'        - minimum numeric value, optional for 'numeric' and 'numericopt', ignored by others
59*38dc5fa6SMichael Hamann *   '_max'        - maximum numeric value, optional for 'numeric' and 'numericopt', ignored by others
6010449332Schris *
6110449332Schris * @author    Chris Smith <chris@jalakai.co.uk>
6210449332Schris */
6310449332Schris// ---------------[ settings for settings ]------------------------------
6410449332Schris$config['format']  = 'php';      // format of setting files, supported formats: php
6510449332Schris$config['varname'] = 'conf';     // name of the config variable, sans $
6610449332Schris
6710449332Schris// this string is written at the top of the rewritten settings file,
6810449332Schris// !! do not include any comment indicators !!
6910449332Schris// this value can be overriden when calling save_settings() method
7010449332Schris$config['heading'] = 'Dokuwiki\'s Main Configuration File - Local Settings';
7110449332Schris
72cb043f52SChris Smith/* DEPRECATED
7310449332Schris// ---------------[ setting files ]--------------------------------------
7410449332Schris// these values can be string expressions, they will be eval'd before use
7510449332Schris$file['local']     = "DOKU_CONF.'local.php'";            // mandatory (file doesn't have to exist)
7610449332Schris$file['default']   = "DOKU_CONF.'dokuwiki.php'";         // optional
7710449332Schris$file['protected'] = "DOKU_CONF.'local.protected.php'";  // optional
78cb043f52SChris Smith */
7910449332Schris
8010449332Schris// test value (FIXME, remove before publishing)
8110449332Schris//$meta['test']     = array('multichoice','_choices' => array(''));
8210449332Schris
8310449332Schris// --------------[ setting metadata ]------------------------------------
8410449332Schris// - for description of format and fields see top of file
8510449332Schris// - order the settings in the order you wish them to appear
8610449332Schris// - any settings not mentioned will come after the last setting listed and
8710449332Schris//   will use the default class with no parameters
8810449332Schris
894fa2dffcSBen Coburn$meta['_basic']   = array('fieldset');
9091f04971SAndreas Gohr$meta['title']    = array('string');
9185313d6fSGina Haeussge$meta['start']    = array('string','_pattern' => '!^[^:;/]+$!'); // don't accept namespaces
9210449332Schris$meta['lang']     = array('dirchoice','_dir' => DOKU_INC.'inc/lang/');
93f7589b08SChris Smith$meta['template'] = array('dirchoice','_dir' => DOKU_INC.'lib/tpl/','_pattern' => '/^[\w-]+$/');
94066fee30SAndreas Gohr$meta['license']  = array('license');
954fa2dffcSBen Coburn$meta['savedir']  = array('savedir');
9691f04971SAndreas Gohr$meta['basedir']  = array('string');
9791f04971SAndreas Gohr$meta['baseurl']  = array('string');
982f97bef5Schris$meta['dmode']    = array('numeric','_pattern' => '/0[0-7]{3,4}/'); // only accept octal representation
992f97bef5Schris$meta['fmode']    = array('numeric','_pattern' => '/0[0-7]{3,4}/'); // only accept octal representation
1004fa2dffcSBen Coburn$meta['allowdebug']  = array('onoff');
10110449332Schris
1024fa2dffcSBen Coburn$meta['_display']    = array('fieldset');
10310449332Schris$meta['recent']      = array('numeric');
10410449332Schris$meta['breadcrumbs'] = array('numeric');
10591f04971SAndreas Gohr$meta['youarehere']  = array('onoff');
1064fa2dffcSBen Coburn$meta['fullpath']    = array('onoff');
1079426a41aSAndreas Gohr$meta['typography']  = array('multichoice','_choices' => array(0,1,2));
10891f04971SAndreas Gohr$meta['dformat']     = array('string');
10991f04971SAndreas Gohr$meta['signature']   = array('string');
110dc58b6f4SAndy Webber$meta['showuseras']  = array('multichoice','_choices' => array('loginname','username','email','email_link'));
11110449332Schris$meta['toptoclevel'] = array('multichoice','_choices' => array(1,2,3,4,5));   // 5 toc levels
112c69534d4SAnika Henke$meta['tocminheads'] = array('multichoice','_choices' => array(0,1,2,3,4,5,10,15,20));
113220c8709Schris$meta['maxtoclevel'] = array('multichoice','_choices' => array(0,1,2,3,4,5));
11410449332Schris$meta['maxseclevel'] = array('multichoice','_choices' => array(0,1,2,3,4,5)); // 0 for no sec edit buttons
11510449332Schris$meta['camelcase']   = array('onoff');
1164de01997Schris$meta['deaccent']    = array('multichoice','_choices' => array(0,1,2));
117fe9ec250SChris Smith$meta['useheading']  = array('multichoice','_choices' => array(0,'navigation','content',1));
11810449332Schris$meta['refcheck']    = array('onoff');
11910449332Schris$meta['refshow']     = array('numeric');
12010449332Schris
1214fa2dffcSBen Coburn$meta['_authentication'] = array('fieldset');
12210449332Schris$meta['useacl']      = array('onoff');
12310449332Schris$meta['autopasswd']  = array('onoff');
12410449332Schris$meta['authtype']    = array('authtype');
12543ee7484SAndreas Gohr$meta['passcrypt']   = array('multichoice','_choices' => array('smd5','md5','apr1','sha1','ssha','crypt','mysql','my411','kmd5'));
12691f04971SAndreas Gohr$meta['defaultgroup']= array('string');
12791f04971SAndreas Gohr$meta['superuser']   = array('string');
128f8cc712eSAndreas Gohr$meta['manager']     = array('string');
12910449332Schris$meta['profileconfirm'] = array('onoff');
1305430c4beSAndreas Gohr$meta['rememberme'] = array('onoff');
1318a1f5d50SAndreas Gohr$meta['registernotify'] = array('email');
132306ca8aaSchris$meta['disableactions'] = array('disableactions',
133f3718805SAdrian Lang                                '_choices' => array('backlink','index','recent','revisions','search','subscription','register','resendpwd','profile','edit','wikicode','check'),
134f3718805SAdrian Lang                                '_combine' => array('subscription' => array('subscribe','unsubscribe'), 'wikicode' => array('source','export_raw')));
135d1c7b6ecSAndreas Gohr$meta['sneaky_index'] = array('onoff');
1364c989037SChris Smith$meta['auth_security_timeout'] = array('numeric');
137f5c6743cSAndreas Gohr$meta['securecookie'] = array('onoff');
1383ee5b583SAndreas Gohr$meta['xmlrpc']       = array('onoff');
1393ee5b583SAndreas Gohr$meta['xmlrpcuser']   = array('string');
14010449332Schris
1414fa2dffcSBen Coburn$meta['_anti_spam']  = array('fieldset');
1424fa2dffcSBen Coburn$meta['usewordblock']= array('onoff');
1434fa2dffcSBen Coburn$meta['relnofollow'] = array('onoff');
1444fa2dffcSBen Coburn$meta['indexdelay']  = array('numeric');
1454fa2dffcSBen Coburn$meta['mailguard']   = array('multichoice','_choices' => array('visible','hex','none'));
14626ceae18SAndreas Gohr$meta['iexssprotect']= array('onoff');
1474fa2dffcSBen Coburn
1484fa2dffcSBen Coburn$meta['_editing']    = array('fieldset');
14917e7a281SBen Coburn$meta['usedraft']    = array('onoff');
1504fa2dffcSBen Coburn$meta['htmlok']      = array('onoff');
1514fa2dffcSBen Coburn$meta['phpok']       = array('onoff');
1521f4a7341SGina Haeussge$meta['notify']      = array('email', '_multiple' => true);
1534fa2dffcSBen Coburn$meta['subscribers'] = array('onoff');
154eee44352SAdrian Lang$meta['subscribe_time'] = array('numeric');
15510449332Schris$meta['locktime']    = array('numeric');
1564fa2dffcSBen Coburn$meta['cachetime']   = array('numeric');
15710449332Schris
1584fa2dffcSBen Coburn$meta['_links']    = array('fieldset');
15991f04971SAndreas Gohr$meta['target____wiki']      = array('string');
16091f04971SAndreas Gohr$meta['target____interwiki'] = array('string');
16191f04971SAndreas Gohr$meta['target____extern']    = array('string');
16291f04971SAndreas Gohr$meta['target____media']     = array('string');
16391f04971SAndreas Gohr$meta['target____windows']   = array('string');
16410449332Schris
1652b03e74dSBen Coburn$meta['_media']      = array('fieldset');
1662b03e74dSBen Coburn$meta['gdlib']       = array('multichoice','_choices' => array(0,1,2));
1672b03e74dSBen Coburn$meta['im_convert']  = array('im_convert');
1682b03e74dSBen Coburn$meta['jpg_quality'] = array('numeric','_pattern' => '/^100$|^[1-9]?[0-9]$/');  //(0-100)
1698a1f5d50SAndreas Gohr$meta['fetchsize']   = array('numeric');
1702b03e74dSBen Coburn
1714fa2dffcSBen Coburn$meta['_advanced']   = array('fieldset');
172c29dc6e4SAndreas Gohr$meta['updatecheck'] = array('onoff');
1734fa2dffcSBen Coburn$meta['userewrite']  = array('multichoice','_choices' => array(0,1,2));
1744fa2dffcSBen Coburn$meta['useslash']    = array('onoff');
1754fa2dffcSBen Coburn$meta['sepchar']     = array('sepchar');
1764fa2dffcSBen Coburn$meta['canonical']   = array('onoff');
177f03fd957SAndreas Gohr$meta['fnencode']    = array('multichoice','_choices' => array('url','safe','utf-8'));
1784fa2dffcSBen Coburn$meta['autoplural']  = array('onoff');
1799291cf33SAndreas Gohr$meta['mailfrom']    = array('richemail');
1804fa2dffcSBen Coburn$meta['compress']    = array('onoff');
181524be65dSBen Coburn$meta['gzip_output'] = array('onoff');
1824fa2dffcSBen Coburn$meta['hidepages']   = array('string');
1834fa2dffcSBen Coburn$meta['send404']     = array('onoff');
1841b95bfdfSChris Smith$meta['compression'] = array('compression');
1854fa2dffcSBen Coburn$meta['sitemap']     = array('numeric');
1864ab889eaSAndreas Gohr$meta['rss_type']    = array('multichoice','_choices' => array('rss','rss1','rss2','atom','atom1'));
1874fa2dffcSBen Coburn$meta['rss_linkto']  = array('multichoice','_choices' => array('diff','page','rev','current'));
1884ab889eaSAndreas Gohr$meta['rss_content'] = array('multichoice','_choices' => array('abstract','diff','htmldiff','html'));
1894fa2dffcSBen Coburn$meta['rss_update']  = array('numeric');
19071726d78SBen Coburn$meta['recent_days'] = array('numeric');
191657541cbSAndreas Gohr$meta['rss_show_summary'] = array('onoff');
192cde6a01bSAndreas Gohr$meta['broken_iua']  = array('onoff');
193deec6eb9Spierre.pracht$meta['xsendfile']   = array('multichoice','_choices' => array(0,1,2,3));
1940ceb549dSChris Smith$meta['renderer_xhtml'] = array('renderer','_format' => 'xhtml','_choices' => array('xhtml'));
19522952965SYoBoY$meta['readdircache'] = array('numeric');
1964fa2dffcSBen Coburn
1974fa2dffcSBen Coburn$meta['_network']    = array('fieldset');
19876ae5803SAndreas Gohr$meta['proxy____host'] = array('string','_pattern' => '#^(|[a-z0-9\-\.+]+)$#i');
19976ae5803SAndreas Gohr$meta['proxy____port'] = array('numericopt');
20091f04971SAndreas Gohr$meta['proxy____user'] = array('string');
2013994772aSChris Smith$meta['proxy____pass'] = array('password','_code' => 'base64');
20210449332Schris$meta['proxy____ssl']  = array('onoff');
2037aeda574SAndreas Gohr$meta['proxy____except'] = array('string');
20410449332Schris$meta['safemodehack'] = array('onoff');
20576ae5803SAndreas Gohr$meta['ftp____host']  = array('string','_pattern' => '#^(|[a-z0-9\-\.+]+)$#i');
20676ae5803SAndreas Gohr$meta['ftp____port']  = array('numericopt');
20791f04971SAndreas Gohr$meta['ftp____user']  = array('string');
2083994772aSChris Smith$meta['ftp____pass']  = array('password','_code' => 'base64');
20991f04971SAndreas Gohr$meta['ftp____root']  = array('string');
21010449332Schris
211