3 // essential internal stuff -- skip it. Go down to Part One. There
4 // are four parts to this file that interest you, all labeled Part
5 // One, Two, Three and Four.
7 set_magic_quotes_runtime(0);
8 error_reporting(E_ALL ^ E_NOTICE);
10 if (!function_exists('rcs_id')) {
11 function rcs_id($id) { echo "<!-- $id -->\n"; };
13 rcs_id('$Id: config.php,v 1.24.2.13 2002-02-08 15:46:30 dairiki Exp $');
14 // end essential internal stuff
17 /////////////////////////////////////////////////////////////////////
19 // Constants and settings. Edit the values below for your site.
20 /////////////////////////////////////////////////////////////////////
23 // URL of index.php e.g. http://yoursite.com/phpwiki/index.php
24 // you can leave this empty - it will be calculated automatically
26 // URL of admin.php e.g. http://yoursite.com/phpwiki/admin.php
27 // you can leave this empty - it will be calculated automatically
28 // if you fill in $ScriptUrl you *MUST* fill in $AdminUrl as well!
31 // Select your language - default language "C": English
32 // other languages available: Dutch "nl", Spanish "es", German "de",
36 /////////////////////////////////////////////////////////////////////
39 // set your database here and edit the according section below.
40 // For PHP 4.0.4 and later you must use "dba" if you are using
41 // DBM files for storage. "dbm" uses the older deprecated interface.
42 // The option 'default' will choose either dbm or dba, depending on
43 // the version of PHP you are running.
44 /////////////////////////////////////////////////////////////////////
46 $WhichDatabase = 'default'; // use one of "dbm", "dba", "mysql",
47 // "pgsql", "msql", "mssql", or "file"
49 // DBM and DBA settings (default)
50 if ($WhichDatabase == 'dbm' or $WhichDatabase == 'dba' or
51 $WhichDatabase == 'default') {
53 $WikiPageStore = "wiki";
54 $ArchivePageStore = "archive";
55 $WikiDB['wiki'] = "$DBMdir/wikipagesdb";
56 $WikiDB['archive'] = "$DBMdir/wikiarchivedb";
57 $WikiDB['wikilinks'] = "$DBMdir/wikilinksdb";
58 $WikiDB['hottopics'] = "$DBMdir/wikihottopicsdb";
59 $WikiDB['hitcount'] = "$DBMdir/wikihitcountdb";
61 // this is the type of DBM file on your system. For most Linuxen
62 // 'gdbm' is fine; 'db2' is another common type. 'ndbm' appears
63 // on Solaris but won't work because it won't store pages larger
65 define("DBM_FILE_TYPE", 'gdbm');
67 // try this many times if the dbm is unavailable
68 define("MAX_DBM_ATTEMPTS", 20);
70 // for PHP3 use dbmlib, else use dbalib for PHP4
71 if ($WhichDatabase == 'default') {
72 if ( floor(phpversion()) == 3) {
73 $WhichDatabase = 'dbm';
75 $WhichDatabase = 'dba';
79 if ($WhichDatabase == 'dbm') {
80 include "lib/dbmlib.php";
82 include "lib/dbalib.php";
85 // MySQL settings -- see INSTALL.mysql for details on using MySQL
86 } elseif ($WhichDatabase == 'mysql') {
88 $mysql_server = 'localhost';
90 // username as used in step 2 of INSTALL.mysql:
91 $mysql_user = 'wikiuser';
93 // password of above user (or leave blank if none):
96 // name of the mysql database
97 // (this used to default to 'wiki' prior to phpwiki-1.2.2)
98 $mysql_db = 'phpwiki';
100 // Names of the tables.
101 // You probably don't need to change these. If you do change
102 // them you will also have to make corresponding changes in
103 // schemas/schema.mysql before you initialize the database.
104 $WikiPageStore = "wiki";
105 $ArchivePageStore = "archive";
106 $WikiLinksStore = "wikilinks";
107 $WikiScoreStore = "wikiscore";
108 $HitCountStore = "hitcount";
110 include "lib/mysql.php";
112 // PostgreSQL settings -- see INSTALL.pgsql for more details
113 } elseif ($WhichDatabase == 'pgsql') {
114 $pg_dbhost = "localhost";
116 $WikiDataBase = "wiki"; // name of the database in Postgresql
117 $WikiPageStore = "wiki";
118 $ArchivePageStore = "archive";
119 $WikiLinksPageStore = "wikilinks";
120 $HotTopicsPageStore = "hottopics";
121 $HitCountPageStore = "hitcount";
122 include "lib/pgsql.php";
124 // MiniSQL (mSQL) settings -- see INSTALL.msql for details on using mSQL
125 } elseif ($WhichDatabase == 'msql') {
127 $WikiPageStore = array();
128 $ArchivePageStore = array();
129 $WikiPageStore['table'] = "wiki";
130 $WikiPageStore['page_table'] = "wikipages";
131 $ArchivePageStore['table'] = "archive";
132 $ArchivePageStore['page_table'] = "archivepages";
133 // should be the same as wikipages.line
134 define("MSQL_MAX_LINE_LENGTH", 128);
135 include "lib/msql.php";
137 // Filesystem DB settings
138 } elseif ($WhichDatabase == 'file') {
139 $DBdir = "/tmp/wiki";
140 $WikiPageStore = "wiki";
141 $ArchivePageStore = "archive";
142 $WikiDB['wiki'] = "$DBdir/pages";
143 $WikiDB['archive'] = "$DBdir/archive";
144 $WikiDB['wikilinks'] = "$DBdir/links";
145 $WikiDB['hottopics'] = "$DBdir/hottopics";
146 $WikiDB['hitcount'] = "$DBdir/hitcount";
147 include "lib/db_filesystem.php";
149 // MS SQLServer settings
150 } elseif ($WhichDatabase == 'mssql') {
151 $WikiPageStore = "wiki";
152 $ArchivePageStore = "archive";
153 $WikiLinksStore = "wikilinks";
154 $WikiScoreStore = "wikiscore";
155 $HitCountStore = "hitcount";
156 $mssql_server = 'servername';
160 include "lib/mssql.php";
162 } else die("Invalid '\$WhichDatabase' in lib/config.php");
165 /////////////////////////////////////////////////////////////////////
168 /////////////////////////////////////////////////////////////////////
170 // logo image (path relative to index.php)
171 $logo = "images/wikibase.png";
173 // Signature image which is shown after saving an edited page
174 // If this is left blank (or unset), the signature will be omitted.
175 $SignatureImg = "images/signature.png";
177 // this turns on url indicator icons, inserted before embedded links
178 //define("USE_LINK_ICONS", 1);
179 //define("DATA_PATH", "/wiki");
181 // date & time formats used to display modification times, etc.
182 // formats are given as format strings to PHP date() function
183 $datetimeformat = "F j, Y"; // may contain time of day
184 $dateformat = "F j, Y"; // must not contain time
186 // this defines how many page names to list when displaying
187 // the MostPopular pages; the default is to show the 20 most popular pages
188 define("MOST_POPULAR_LIST_LENGTH", 20);
190 // this defines how many page names to list when displaying related pages
191 define("NUM_RELATED_PAGES", 5);
193 // number of user-defined external references, i.e. "[1]"
194 define("NUM_LINKS", 12);
196 // allowed protocols for links - be careful not to allow "javascript:"
197 // within a named link [name|uri] one more protocol is defined: phpwiki
198 $AllowedProtocols = "http|https|mailto|ftp|news|nntp|gopher";
200 // URLs ending with the following extension should be inlined as images
201 $InlineImages = "png|jpg|gif";
203 // Uncomment this to automatically split WikiWords by inserting spaces.
204 // The default is to leave WordsSmashedTogetherLikeSo in the body text.
205 //define("autosplit_wikiwords", 1);
207 // Perl regexp for WikiNames
208 // (?<!..) & (?!...) used instead of '\b' because \b matches '_' as well
209 //$WikiNameRegexp = "(?<![A-Za-z0-9])([A-Z][a-z]+){2,}(?![A-Za-z0-9])";
210 // This should work for all ISO-8859-1 languages:
211 $WikiNameRegexp = "(?<![A-Za-z0-9µÀ-ÖØ-öø-ÿ])([A-ZÀ-ÖØ-Þ][a-zµß-öø-ÿ]+){2,}(?![A-Za-z0-9µÀ-ÖØ-öø-ÿ])";
213 /////////////////////////////////////////////////////////////////////
215 // Original pages and layout
216 /////////////////////////////////////////////////////////////////////
218 // need to define localization function first -- skip this
219 if (!function_exists ('gettext')) {
220 $lcfile = "locale/$LANG/LC_MESSAGES/phpwiki.php";
221 if (file_exists($lcfile)) { include($lcfile); }
222 else { $locale = array(); }
224 function gettext ($text) {
226 if (!empty ($locale[$text]))
227 return $locale[$text];
231 // This putenv() fails when safe_mode is on.
232 // I think it is unnecessary.
233 //putenv ("LANG=$LANG");
234 bindtextdomain ("phpwiki", "./locale");
235 textdomain ("phpwiki");
236 if (!defined("LC_ALL")) {
237 // Backwards compatibility (for PHP < 4.0.5)
238 define("LC_ALL", "LC_ALL");
240 setlocale(LC_ALL, "$LANG");
242 // end of localization function
244 // Template files (filenames are relative to script position)
246 "BROWSE" => gettext("templates/browse.html"),
247 "EDITPAGE" => gettext("templates/editpage.html"),
248 "EDITLINKS" => gettext("templates/editlinks.html"),
249 "MESSAGE" => gettext("templates/message.html")
252 /* WIKI_PGSRC -- specifies the source for the initial page contents
253 * of the Wiki. The setting of WIKI_PGSRC only has effect when
254 * the wiki is accessed for the first time (or after clearing the
255 * database.) WIKI_PGSRC can either name a directory or a zip file.
256 * In either case WIKI_PGSRC is scanned for files --- one file per page.
258 * If the files appear to be MIME formatted messages, they are
259 * scanned for application/x-phpwiki content-types. Any suitable
260 * content is added to the wiki.
261 * The files can also be plain text files, in which case the page name
262 * is taken from the file name.
265 define('WIKI_PGSRC', gettext("./pgsrc")); // Default (old) behavior.
266 //define('WIKI_PGSRC', './wiki.zip'); // New style.
268 // DEFAULT_WIKI_PGSRC is only used when the language is *not*
269 // the default (English) and when reading from a directory:
270 // in that case some English pages are inserted into the wiki as well
271 // DEFAULT_WIKI_PGSRC defines where the English pages reside
272 define('DEFAULT_WIKI_PGSRC', "./pgsrc");
276 //////////////////////////////////////////////////////////////////////
277 // you shouldn't have to edit anyting below this line
278 function compute_default_scripturl() {
279 global $SERVER_PORT, $SERVER_NAME, $SCRIPT_NAME, $HTTPS;
280 if (!empty($HTTPS) && $HTTPS != 'off') {
288 $port = ($SERVER_PORT == $dflt_port) ? '' : ":$SERVER_PORT";
289 return $proto . '://' . $SERVER_NAME . $port . $SCRIPT_NAME;
292 if (empty($ScriptUrl)) {
293 $ScriptUrl = compute_default_scripturl();
295 if (defined('WIKI_ADMIN') && !empty($AdminUrl))
296 $ScriptUrl = $AdminUrl;
298 $FieldSeparator = "\263";
300 if (isset($PHP_AUTH_USER)) {
301 $remoteuser = $PHP_AUTH_USER;
304 // Apache won't show REMOTE_HOST unless the admin configured it
305 // properly. We'll be nice and see if it's there.
307 getenv('REMOTE_HOST') ? ($remoteuser = getenv('REMOTE_HOST'))
308 : ($remoteuser = getenv('REMOTE_ADDR'));
311 // constants used for HTML output. HTML tags may allow nesting
312 // other tags always start at level 0
313 define("ZERO_LEVEL", 0);
314 define("NESTED_LEVEL", 1);
316 // constants for flags in $pagehash
317 define("FLAG_PAGE_LOCKED", 1);