Rev Author Line No. Line
130 kaklik 1 <?php
2 # vim:et:ts=3:sts=3:sw=3:fdm=marker:
3  
4 // WebSVN - Subversion repository viewing via the web using PHP
5 // Copyright © 2004-2006 Tim Armes, Matt Sicker
6 //
7 // This program is free software; you can redistribute it and/or modify
8 // it under the terms of the GNU General Public License as published by
9 // the Free Software Foundation; either version 2 of the License, or
10 // (at your option) any later version.
11 //
12 // This program is distributed in the hope that it will be useful,
13 // but WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 // GNU General Public License for more details.
16 //
17 // You should have received a copy of the GNU General Public License
18 // along with this program; if not, write to the Free Software
19 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 //
21 // --
22 //
23 // config.inc
24 //
25 // Configuration parameters
26  
27 // --- FOLLOW THE INSTRUCTIONS BELOW TO CONFIGURE YOUR SETUP ---
28  
29 // {{{ PLATFORM CONFIGURATION ---
30  
31 // Uncomment the next line if your running a windows server
32 //
33 // $config->setServerIsWindows();
34  
35 // Configure these lines if your commands aren't on your path.
36 //
37 // $config->setSVNCommandPath('Path/to/svn and svnlook/ e.g. c:\\program files\\subversion\\bin');
38 // $config->setDiffPath('Path/to/diff/command/');
39  
40 // For syntax colouring, if option enabled...
41 // $config->setEnscriptPath('Path/to/enscript/command/');
42 // $config->setSedPath('Path/to/sed/command/');
43  
44 // For delivered tarballs, if option enabled...
45 // $config->setTarPath('Path/to/tar/command/');
46  
47 // For delivered GZIP'd files and tarballs, if option enabled...
48 // $config->setGZipPath('Path/to/gzip/command/');
49  
50 // }}}
51  
52 // {{{ REPOSITORY SETUP ---
53  
54 // There are 2 methods for defining the repositiories available on the system. Either you list
55 // them by hand, in which case you can give each one the name of your choice, or you use the
56 // parent path function, in which case the name of the directory is used as the repository name.
57 //
58 // In all cases, you may optionally supply a group name to the repositories. This is useful in the
59 // case that you need to separate your projects. Grouped Repositories are referred to using the
60 // convention GroupName.RepositoryName
61 //
62 // Performance is much better on local repositories (e.g. accessed by file:///). However, you
63 // can also provide an interface onto a remote repository. In this case you should supply the
64 // username and password needed to access it.
65 //
66 // To configure the repositories by hand, copy the appropriate line below, uncomment it and
67 // replace the name and URL of your repository.
68  
69 // Local repositories (without and with optional group):
70 //
71 // $config->addRepository('NameToDisplay', 'URL to repository (e.g. file:///c:/svn/proj)');
72 // $config->addRepository('NameToDisplay', 'URL to repository (e.g. file:///c:/svn/proj)', 'group');
139 root 73 $config->addRepository('MLAB', 'file:///home/MLAB');
74 $config->addRepository('TEST1', 'file:///home/MLAB');
75 $config->addRepository('TEST2', 'file:///home/MLAB');
130 kaklik 76 //
77 // Remote repositories (without and with optional group):
78 //
79 // $config->addRepository('NameToDisplay', 'URL (e.g. http://path/to/rep)', NULL, 'username', 'password');
80 // $config->addRepository('NameToDisplay', 'URL (e.g. http://path/to/rep)', 'group', 'username', 'password');
81 //
82 // To use the parent path method, uncomment the newt line and and replace the path with your one. You
83 // can call the function several times if you have several parent paths. Note that in this case the
84 // path is a filesystem path
85 //
86 // $config->parentPath('Path/to/parent (e.g. c:\\svn)');
87  
88 // }}}
89  
90 // {{{ LOOK AND FEEL ---
91 //
92 // Uncomment ONLY the template file that you want.
93  
139 root 94 // $config->setTemplatePath("$locwebsvnreal/templates/Standard/");
130 kaklik 95 // $config->setTemplatePath("$locwebsvnreal/templates/BlueGrey/");
96 // $config->setTemplatePath("$locwebsvnreal/templates/Zinn/");
97  
98 // You may also specify a per repository template file by uncommenting and changing the following
99 // line as necessary. Use the convention "groupname.myrep" if your repository is in a group.
100  
101 // $config->setTemplatePath('$locwebsvnreal/templates/Standard/', 'myrep'); // Access file for myrep
139 root 102 $config->setTemplatePath("$locwebsvnreal/templates/MLAB/", "MLAB");
103 $config->setTemplatePath("$locwebsvnreal/templates/BlueGrey/", "TEST1");
104 $config->setTemplatePath("$locwebsvnreal/templates/Standard/", "TEST2");
130 kaklik 105  
106 // The index page containing the projects may either be displayed as a flat view (the default),
107 // where grouped repositories are displayed as "GroupName.RepName" or as a tree view.
108 // In the case of a tree view, you may choose whether the entire tree is open by default.
109  
110 // $config->useTreeIndex(false); // Tree index, closed by default
111 // $config->useTreeIndex(true); // Tree index, open by default
112  
113 // By default, WebSVN displays a tree view onto the current directory. You can however
114 // choose to display a flat view of the current directory only, which may make the display
115 // load faster. Uncomment this line if you want that.
116  
117 // $config->useFlatView();
118  
119 // }}}
120  
121 // {{{ LANGUAGE SETUP ---
122  
123 // WebSVN uses the iconv module to convert messages from your system's character set to the
124 // UTF-8 output encoding. If you find that your log messages aren't displayed correctly then
125 // you'll need to change the value here.
126 //
127 // You may also specify the character encoding of the repository contents if different from
128 // the system encoding. This is typically the case for windows users, whereby the command
129 // line returns, for example, CP850 encoded strings, whereas the source files are encoded
130 // as iso-8859-1 by Windows based text editors. When display text file, WebSVN will convert
131 // them from the content encoding to the output encoding (UTF-8).
132 //
133 // WebSVN does its best to automate all this, so only use the following if it doesn't work
134 // "out of the box". Uncomment and change one of the examples below.
135 //
136 // $config->setInputEncoding('CP850'); // Encoding of result returned by svn command line, etc.
137 // $config->setContentEncoding('iso-8859-1'); // Content encoding of all your repositories // repositories
138  
139 // You may also specify a content encoding on a per repository basis. Uncomment and copy this
140 // line as necessary.
141 //
142 // $config->setContentEncoding('iso-8859-1', 'MyEnc');
143  
144 // Note for Windows users: To enable iconv you'll need to enable the extension in your php.ini file
145 // AND copy iconv.dll (not php_iconv.dll) to your Windows system folder. In most cases the correct
146 // encoding is set when you call $config->setServerIsWindows();.
147  
148 // Note for *nix users. You'll need to have iconv compiled into your binary. The default input and
149 // output encodings are taken from your locale informations. Override these if they aren't correct.
150  
151 // Uncomment the default language. If you want English then don't do anything here.
152 //
257 kakl 153  
139 root 154 include 'languages/czech.inc';
155 // include 'languages/catalan.inc';
156 // include 'languages/danish.inc';
157 // include 'languages/dutch.inc';
158 // include 'languages/finnish.inc';
159 // include 'languages/french.inc';
160 // include 'languages/german.inc';
161 // include 'languages/japanese.inc';
162 // include 'languages/korean.inc';
163 // include 'languages/norwegian.inc';
164 // include 'languages/polish.inc';
165 // include 'languages/portuguese.inc';
130 kaklik 166 // include 'languages/russian.inc';
139 root 167 // include 'languages/schinese.inc';
168 // include 'languages/slovenian.inc';
169 // include 'languages/spanish.inc';
170 // include 'languages/swedish.inc';
171 // include 'languages/tchinese.inc';
172 // include 'languages/turkish.inc';
130 kaklik 173  
174 // }}}
175  
176 // {{{ MULTIVIEWS ---
177  
178 // Uncomment this line if you want to use MultiView to access the repository by, for example:
179 //
180 // http://servername/wsvn/repname/path/in/repository
181 //
182 // Note: The websvn directory will need to have Multiviews turned on in Apache, and you'll need to configure
183 // wsvn.php
184  
185 // $config->useMultiViews();
186  
187 // }}}
188  
189 // {{{ ACCESS RIGHTS ---
190  
191 // Uncomment this line if you want to use your Subversion access file to control access
192 // rights via WebSVN. For this to work, you'll need to set up the same Apache based authentication
193 // to the WebSVN (or wsvn) directory as you have for Subversion itself. More information can be
194 // found in install.txt
195  
196 // $config->useAuthenticationFile('/path/to/accessfile'); // Global access file
197  
198 // You may also specify a per repository access file by uncommenting and copying the following
199 // line as necessary. Use the convention 'groupname.myrep' if your repository is in a group.
200  
201 // $config->useAuthenticationFile('/path/to/accessfile', 'myrep'); // Access file for myrep
202  
203 // }}}
204  
205 // {{{ FILE CONTENT ---
206 //
207 // You may wish certain file types to be GZIP'd and delieved to the user when clicked apon.
208 // This is useful for binary files and the like that don't display well in a browser window!
209 // Copy, uncomment and modify this line for each extension to which this rule should apply.
210 // (Don't forget the . before the extension. You don't need an index between the []'s).
211 // If you'd rather that the files were delivered uncompressed with the associated MIME type,
212 // then read below.
213 //
214 // $zipped[] = '.dll';
215  
216 // Subversion controlled files have an svn:mime-type property that can
217 // be set on a file indicating its mime type. By default binary files
218 // are set to the generic appcliation/octet-stream, and other files
219 // don't have it set at all. WebSVN also has a built-in list of
220 // associations from file extension to MIME content type. (You can
221 // view this list in setup.inc).
222 //
223 // Determining the content-type: By default, if the svn:mime-type
224 // property exists and is different from application/octet-stream, it
225 // is used. Otherwise, if the built-in list has a contentType entry
226 // for the extension of the file, that is used. Otherwise, if the
227 // svn:mime-type property exists has the generic binary value of
228 // application/octet-stream, the file will be served as a binary
229 // file. Otherwise, the file will be brought up as ASCII text in the
230 // browser window (although this text may optionally be colourised.
231 // See below).
232 //
233 // Uncomment this if you want to ignore any svn:mime-type property on your
234 // files.
235 //
236 // $config->ignoreSvnMimeTypes();
237 //
238 // Uncomment this if you want skip WebSVN's custom mime-type handling
239 //
240 // $config->ignoreWebSVNContentTypes();
241 //
242 // Following the examples below, you can add new associations, modify
243 // the default ones or even delete them entirely (to show them in
244 // ASCII via WebSVN).
245  
246 // $contentType['.c'] = 'plain/text'; // Create a new association
247 // $contentType['.doc'] = 'plain/text'; // Modify an existing one
248 // unset($contentType['.m'] // Remove a default association
249  
250 // }}}
251  
252 // {{{ TARBALLS ---
253  
254 // You need tar and gzip installed on your system. Set the paths above if necessary
255 //
256 // Uncomment the line below to offer a tarball download option across all your
257 // repositories.
258 //
259 $config->allowDownload();
260 //
261 // To change the global option for individual repositories, uncomment and replicate
262 // the required line below (replacing 'myrep' for the name of the repository to be changed).
263 // Use the convention 'groupname.myrep' if your repository is in a group.
264  
265 // $config->allowDownload('myrep'); // Specifically allow downloading for 'myrep'
266 // $config->disallowDownload('myrep'); // Specifically disallow downloading for 'myrep'
267  
268 // You can also choose the minimum directory level from which you'll allow downloading.
269 // A value of zero will allow downloading from the root. 1 will allow downloding of directories
270 // in the root, etc.
271 //
272 // If your project is arranged with trunk, tags and branches at the root level, then a value of 2
273 // would allow the downloading of directories within branches/tags while disallowing the download
274 // of the entire branches or tags directories. This would also stop downloading of the trunk, but
275 // see after for path exceptions.
276 //
277 // Change the line below to set the download level across all your repositories.
278  
265 kakl 279 $config->setMinDownloadLevel(2);
130 kaklik 280  
281 // To change the level for individual repositories, uncomment and replicate
282 // the required line below (replacing 'myrep' for the name of the repository to be changed).
283 // Use the convention 'groupname.myrep' if your repository is in a group.
284  
285 // $config->setMinDownloadLevel(2, 'myrep');
286  
287 // Finally, you may add or remove certain directories (and their contents) either globally
288 // or on a per repository basis. Uncomment and copy the following lines as necessary. Note
289 // that the these are searched in the order than you give them until a match is made (with the
290 // exception that all the per repository exceptions are tested before the global ones). This means
291 // that you must disallow /a/b/c/ before you allow /a/b/ otherwise the allowed match on /a/b/ will
292 // stop any further searching, thereby allowing downloads on /a/b/c/.
293  
294 // Global exceptions possibilties:
295 //
296 // $config->addAllowedDownloadException('/path/to/allowed/directory/');
297 // $config->addDisAllowedDownloadException('/path/to/disallowed/directory/');
298 //
299 // Per repository exception possibilties:
300 // Use the convention 'groupname.myrep' if your repository is in a group.
301 //
302 // $config->addAllowedDownloadException('/path/to/allowed/directory/', 'myrep');
303 // $config->addDisAllowedDownloadException('/path/to/disallowed/directory/', 'myrep');
304  
305 // }}}
306  
307 // {{{ COLOURISATION ---
308  
309 // Uncomment this line if you want to use Enscript to colourise your file listings
310 //
311 // You'll need Enscript version 1.6 or higher AND Sed installed to use this feature.
312 // Set the path above.
313 //
314 // $config->useEnscript();
315  
316 // Enscript need to be told what the contents of a file are so that it can be colourised
317 // correctly. WebSVN includes a predefined list of mappings from file extension to Enscript
318 // file type (viewable in setup.inc).
319 //
320 // Here you should add and other extensions not already listed or redefine the default ones. eg:
321 //
322 // $extEnscript['.pas'] = 'pascal';
323 //
324 // Note that extensions are case sensitive.
325  
326 // }}}
327  
328 // {{{ RSSFEED ---
329  
330 // Uncomment this line if you wish to hide the RSS feed links across all repositories
331 //
267 kakl 332 $config->hideRSS();
130 kaklik 333 //
334 // To change the global option for individual repositories, uncomment and replicate
335 // the required line below (replacing 'myrep' for the name of the repository to be changed).
336 // Use the convention 'groupname.myrep' if your repository is in a group.
337  
338 // $config->hideRSS('myrep'); // Specifically hide RSS links for 'myrep'
339 // $config->showRSS('myrep'); // Specifically show RSS links for 'myrep'
340  
341 // }}}
342  
343 // {{{ BUGTRAQ ---
344  
345 // Uncomment this line if you wish to use bugtraq: properties to show links to your BugTracker
346 // from the log messages.
347 //
348 // $config->useBugtraqProperties();
349 //
350 // To change the global option for individual repositories, uncomment and replicate
351 // the required line below (replacing 'myrep' for the name of the repository to be changed).
352 // Use the convention 'groupname.myrep' if your repository is in a group.
353  
354 // $config->useBugtraqProperties('myrep'); // Specifically use bugtraq properties for 'myrep'
355 // $config->ignoreBugtraqProperties('myrep'); // Specifically ignore bugtraq properties for 'myrep'
356  
357 // }}}
358  
359 // {{{ MISCELLANEOUS ---
360  
361 // Comment out this if you don't have the right to use it. Be warned that you may need it however!
362 set_time_limit(0);
363  
364 // Comment this line to turn off caching of repo information. This will slow down your browsing.
365 $config->setCachingOn();
366  
367 // Number of spaces to expand tabs to in diff/listing view across all repositories
368  
369 $config->expandTabsBy(8);
370  
371 // To change the global option for individual repositories, uncomment and replicate
372 // the required line below (replacing 'myrep' for the name of the repository to be changed).
373 // Use the convention 'groupname.myrep' if your repository is in a group.
374  
375 // $config->expandTabsBy(3, 'myrep'); // Expand Tabs by 3 for repository 'myrep'
376  
377 // For installations without PHP5, a copy of PEAR's PHP Compat library is included.
378 // If you have your own version of Compat you wish to use, go ahead and specify here.
379  
380 // $config->setPHPCompatPath('/usr/share/php/PHP/');
381  
382 // }}}
383 ?>