1 |
<?php |
1 |
<?php |
2 |
# vim:et:ts=3:sts=3:sw=3:fdm=marker: |
2 |
# vim:et:ts=3:sts=3:sw=3:fdm=marker: |
3 |
|
3 |
|
4 |
// WebSVN - Subversion repository viewing via the web using PHP |
4 |
// WebSVN - Subversion repository viewing via the web using PHP |
5 |
// Copyright © 2004-2006 Tim Armes, Matt Sicker |
5 |
// Copyright © 2004-2006 Tim Armes, Matt Sicker |
6 |
// |
6 |
// |
7 |
// This program is free software; you can redistribute it and/or modify |
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 |
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 |
9 |
// the Free Software Foundation; either version 2 of the License, or |
10 |
// (at your option) any later version. |
10 |
// (at your option) any later version. |
11 |
// |
11 |
// |
12 |
// This program is distributed in the hope that it will be useful, |
12 |
// This program is distributed in the hope that it will be useful, |
13 |
// but WITHOUT ANY WARRANTY; without even the implied warranty of |
13 |
// but WITHOUT ANY WARRANTY; without even the implied warranty of |
14 |
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
14 |
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
15 |
// GNU General Public License for more details. |
15 |
// GNU General Public License for more details. |
16 |
// |
16 |
// |
17 |
// You should have received a copy of the GNU General Public License |
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 |
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 |
19 |
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
20 |
// |
20 |
// |
21 |
// -- |
21 |
// -- |
22 |
// |
22 |
// |
23 |
// configclass.inc4 |
23 |
// configclass.inc4 |
24 |
// |
24 |
// |
25 |
// General class for handling configuration options |
25 |
// General class for handling configuration options |
26 |
|
26 |
|
27 |
require_once("include/command.inc"); |
27 |
require_once("include/command.inc"); |
28 |
require_once("include/auth.inc"); |
28 |
require_once("include/auth.inc"); |
29 |
require_once("include/version.inc"); |
29 |
require_once("include/version.inc"); |
30 |
|
30 |
|
31 |
// Auxillary functions used to sort repositories by name/group |
31 |
// Auxillary functions used to sort repositories by name/group |
32 |
|
32 |
|
33 |
// {{{ cmpReps($a, $b) |
33 |
// {{{ cmpReps($a, $b) |
34 |
|
34 |
|
35 |
function cmpReps($a, $b) |
35 |
function cmpReps($a, $b) |
36 |
{ |
36 |
{ |
37 |
// First, sort by group |
37 |
// First, sort by group |
38 |
$g = strcasecmp($a->group, $b->group); |
38 |
$g = strcasecmp($a->group, $b->group); |
39 |
if ($g) |
39 |
if ($g) |
40 |
return $g; |
40 |
return $g; |
41 |
|
41 |
|
42 |
// Same group? Sort by name |
42 |
// Same group? Sort by name |
43 |
return strcasecmp($a->name, $b->name); |
43 |
return strcasecmp($a->name, $b->name); |
44 |
} |
44 |
} |
45 |
|
45 |
|
46 |
// }}} |
46 |
// }}} |
47 |
|
47 |
|
48 |
// {{{ cmpGroups($a, $b) |
48 |
// {{{ cmpGroups($a, $b) |
49 |
|
49 |
|
50 |
function cmpGroups($a, $b) |
50 |
function cmpGroups($a, $b) |
51 |
{ |
51 |
{ |
52 |
$g = strcasecmp($a->group, $b->group); |
52 |
$g = strcasecmp($a->group, $b->group); |
53 |
if ($g) |
53 |
if ($g) |
54 |
return $g; |
54 |
return $g; |
55 |
|
55 |
|
56 |
return 0; |
56 |
return 0; |
57 |
} |
57 |
} |
58 |
|
58 |
|
59 |
// }}} |
59 |
// }}} |
60 |
|
60 |
|
61 |
// {{{ mergesort(&$array, [$cmp_function]) |
61 |
// {{{ mergesort(&$array, [$cmp_function]) |
62 |
|
62 |
|
63 |
function mergesort(&$array, $cmp_function = 'strcmp') |
63 |
function mergesort(&$array, $cmp_function = 'strcmp') |
64 |
{ |
64 |
{ |
65 |
// Arrays of size < 2 require no action |
65 |
// Arrays of size < 2 require no action |
66 |
|
66 |
|
67 |
if (count($array) < 2) |
67 |
if (count($array) < 2) |
68 |
return; |
68 |
return; |
69 |
|
69 |
|
70 |
// Split the array in half |
70 |
// Split the array in half |
71 |
$halfway = count($array) / 2; |
71 |
$halfway = count($array) / 2; |
72 |
$array1 = array_slice($array, 0, $halfway); |
72 |
$array1 = array_slice($array, 0, $halfway); |
73 |
$array2 = array_slice($array, $halfway); |
73 |
$array2 = array_slice($array, $halfway); |
74 |
|
74 |
|
75 |
// Recurse to sort the two halves |
75 |
// Recurse to sort the two halves |
76 |
mergesort($array1, $cmp_function); |
76 |
mergesort($array1, $cmp_function); |
77 |
mergesort($array2, $cmp_function); |
77 |
mergesort($array2, $cmp_function); |
78 |
|
78 |
|
79 |
// If all of $array1 is <= all of $array2, just append them. |
79 |
// If all of $array1 is <= all of $array2, just append them. |
80 |
if (call_user_func($cmp_function, end($array1), $array2[0]) < 1) |
80 |
if (call_user_func($cmp_function, end($array1), $array2[0]) < 1) |
81 |
{ |
81 |
{ |
82 |
$array = array_merge($array1, $array2); |
82 |
$array = array_merge($array1, $array2); |
83 |
return; |
83 |
return; |
84 |
} |
84 |
} |
85 |
|
85 |
|
86 |
// Merge the two sorted arrays into a single sorted array |
86 |
// Merge the two sorted arrays into a single sorted array |
87 |
$array = array(); |
87 |
$array = array(); |
88 |
$ptr1 = $ptr2 = 0; |
88 |
$ptr1 = $ptr2 = 0; |
89 |
while ($ptr1 < count($array1) && $ptr2 < count($array2)) |
89 |
while ($ptr1 < count($array1) && $ptr2 < count($array2)) |
90 |
{ |
90 |
{ |
91 |
if (call_user_func($cmp_function, $array1[$ptr1], $array2[$ptr2]) < 1) |
91 |
if (call_user_func($cmp_function, $array1[$ptr1], $array2[$ptr2]) < 1) |
92 |
{ |
92 |
{ |
93 |
$array[] = $array1[$ptr1++]; |
93 |
$array[] = $array1[$ptr1++]; |
94 |
} |
94 |
} |
95 |
else |
95 |
else |
96 |
{ |
96 |
{ |
97 |
$array[] = $array2[$ptr2++]; |
97 |
$array[] = $array2[$ptr2++]; |
98 |
} |
98 |
} |
99 |
} |
99 |
} |
100 |
|
100 |
|
101 |
// Merge the remainder |
101 |
// Merge the remainder |
102 |
while ($ptr1 < count($array1)) $array[] = $array1[$ptr1++]; |
102 |
while ($ptr1 < count($array1)) $array[] = $array1[$ptr1++]; |
103 |
while ($ptr2 < count($array2)) $array[] = $array2[$ptr2++]; |
103 |
while ($ptr2 < count($array2)) $array[] = $array2[$ptr2++]; |
104 |
|
104 |
|
105 |
return; |
105 |
return; |
106 |
} |
106 |
} |
107 |
|
107 |
|
108 |
// }}} |
108 |
// }}} |
109 |
|
109 |
|
110 |
// A Repository configuration class |
110 |
// A Repository configuration class |
111 |
|
111 |
|
112 |
Class Repository |
112 |
Class Repository |
113 |
{ |
113 |
{ |
114 |
// {{{ Properties |
114 |
// {{{ Properties |
115 |
|
115 |
|
116 |
var $name; |
116 |
var $name; |
117 |
var $svnName; |
117 |
var $svnName; |
118 |
var $path; |
118 |
var $path; |
119 |
var $group; |
119 |
var $group; |
120 |
var $username; |
120 |
var $username; |
121 |
var $password; |
121 |
var $password; |
122 |
|
122 |
|
123 |
// Local configuration options must start off unset |
123 |
// Local configuration options must start off unset |
124 |
|
124 |
|
125 |
var $allowDownload; |
125 |
var $allowDownload; |
126 |
var $minDownloadLevel; |
126 |
var $minDownloadLevel; |
127 |
var $allowedExceptions = array(); |
127 |
var $allowedExceptions = array(); |
128 |
var $disallowedExceptions = array(); |
128 |
var $disallowedExceptions = array(); |
129 |
var $rss; |
129 |
var $rss; |
130 |
var $spaces; |
130 |
var $spaces; |
131 |
var $ignoreSvnMimeTypes; |
131 |
var $ignoreSvnMimeTypes; |
132 |
var $ignoreWebSVNContentTypes; |
132 |
var $ignoreWebSVNContentTypes; |
133 |
var $bugtraq; |
133 |
var $bugtraq; |
134 |
var $auth; |
134 |
var $auth; |
135 |
var $contentEnc; |
135 |
var $contentEnc; |
136 |
var $templatePath; |
136 |
var $templatePath; |
137 |
|
137 |
|
138 |
// }}} |
138 |
// }}} |
139 |
|
139 |
|
140 |
// {{{ __construct($name, $svnName, $path, [$group, [$username, [$password]]]) |
140 |
// {{{ __construct($name, $svnName, $path, [$group, [$username, [$password]]]) |
141 |
|
141 |
|
142 |
function Repository($name, $svnName, $path, $group = NULL, $username = NULL, $password = NULL) |
142 |
function Repository($name, $svnName, $path, $group = NULL, $username = NULL, $password = NULL) |
143 |
{ |
143 |
{ |
144 |
$this->name = $name; |
144 |
$this->name = $name; |
145 |
$this->svnName = $svnName; |
145 |
$this->svnName = $svnName; |
146 |
$this->path = $path; |
146 |
$this->path = $path; |
147 |
$this->group = $group; |
147 |
$this->group = $group; |
148 |
$this->username = $username; |
148 |
$this->username = $username; |
149 |
$this->password = $password; |
149 |
$this->password = $password; |
150 |
} |
150 |
} |
151 |
|
151 |
|
152 |
// }}} |
152 |
// }}} |
153 |
|
153 |
|
154 |
// {{{ getDisplayName() |
154 |
// {{{ getDisplayName() |
155 |
|
155 |
|
156 |
function getDisplayName() |
156 |
function getDisplayName() |
157 |
{ |
157 |
{ |
158 |
if(!empty($this->group)) |
158 |
if(!empty($this->group)) |
159 |
return $this->group.".".$this->name; |
159 |
return $this->group.".".$this->name; |
160 |
else |
160 |
else |
161 |
return $this->name; |
161 |
return $this->name; |
162 |
} |
162 |
} |
163 |
|
163 |
|
164 |
// }}} |
164 |
// }}} |
165 |
|
165 |
|
166 |
// {{{ svnParams |
166 |
// {{{ svnParams |
167 |
|
167 |
|
168 |
function svnParams() |
168 |
function svnParams() |
169 |
{ |
169 |
{ |
170 |
if (!empty($this->username)) |
170 |
if (!empty($this->username)) |
171 |
return " --username ".$this->username." --password ".$this->password." "; |
171 |
return " --username ".$this->username." --password ".$this->password." "; |
172 |
else |
172 |
else |
173 |
return " "; |
173 |
return " "; |
174 |
} |
174 |
} |
175 |
|
175 |
|
176 |
// }}} |
176 |
// }}} |
177 |
|
177 |
|
178 |
// Local configuration accessors |
178 |
// Local configuration accessors |
179 |
|
179 |
|
180 |
// {{{ RSS Feed |
180 |
// {{{ RSS Feed |
181 |
|
181 |
|
182 |
function hideRSS() |
182 |
function hideRSS() |
183 |
{ |
183 |
{ |
184 |
$this->rss = false; |
184 |
$this->rss = false; |
185 |
} |
185 |
} |
186 |
|
186 |
|
187 |
function showRSS() |
187 |
function showRSS() |
188 |
{ |
188 |
{ |
189 |
$this->rss = true; |
189 |
$this->rss = true; |
190 |
} |
190 |
} |
191 |
|
191 |
|
192 |
function getHideRSS() |
192 |
function getHideRSS() |
193 |
{ |
193 |
{ |
194 |
global $config; |
194 |
global $config; |
195 |
|
195 |
|
196 |
if (isset($this->rss)) |
196 |
if (isset($this->rss)) |
197 |
return $this->rss; |
197 |
return $this->rss; |
198 |
|
198 |
|
199 |
return $config->getHideRSS(); |
199 |
return $config->getHideRSS(); |
200 |
} |
200 |
} |
201 |
|
201 |
|
202 |
// }}} |
202 |
// }}} |
203 |
|
203 |
|
204 |
// {{{ Download |
204 |
// {{{ Download |
205 |
|
205 |
|
206 |
function allowDownload() |
206 |
function allowDownload() |
207 |
{ |
207 |
{ |
208 |
$this->allowDownload = true; |
208 |
$this->allowDownload = true; |
209 |
} |
209 |
} |
210 |
|
210 |
|
211 |
function disallowDownload() |
211 |
function disallowDownload() |
212 |
{ |
212 |
{ |
213 |
$this->allowDownload = false; |
213 |
$this->allowDownload = false; |
214 |
} |
214 |
} |
215 |
|
215 |
|
216 |
function getAllowDownload() |
216 |
function getAllowDownload() |
217 |
{ |
217 |
{ |
218 |
global $config; |
218 |
global $config; |
219 |
|
219 |
|
220 |
if (isset($this->allowDownload)) |
220 |
if (isset($this->allowDownload)) |
221 |
return $this->allowDownload; |
221 |
return $this->allowDownload; |
222 |
|
222 |
|
223 |
return $config->getAllowDownload(); |
223 |
return $config->getAllowDownload(); |
224 |
} |
224 |
} |
225 |
|
225 |
|
226 |
function setMinDownloadLevel($level) |
226 |
function setMinDownloadLevel($level) |
227 |
{ |
227 |
{ |
228 |
$this->minDownloadLevel = $level; |
228 |
$this->minDownloadLevel = $level; |
229 |
} |
229 |
} |
230 |
|
230 |
|
231 |
function getMinDownloadLevel() |
231 |
function getMinDownloadLevel() |
232 |
{ |
232 |
{ |
233 |
global $config; |
233 |
global $config; |
234 |
|
234 |
|
235 |
if (isset($this->minDownloadLevel)) |
235 |
if (isset($this->minDownloadLevel)) |
236 |
return $this->minDownloadLevel; |
236 |
return $this->minDownloadLevel; |
237 |
|
237 |
|
238 |
return $config->getMinDownloadLevel(); |
238 |
return $config->getMinDownloadLevel(); |
239 |
} |
239 |
} |
240 |
|
240 |
|
241 |
function addAllowedDownloadException($path) |
241 |
function addAllowedDownloadException($path) |
242 |
{ |
242 |
{ |
243 |
if ($path{strlen($path) - 1} != "/") |
243 |
if ($path{strlen($path) - 1} != "/") |
244 |
$path .= "/"; |
244 |
$path .= "/"; |
245 |
|
245 |
|
246 |
$this->allowedExceptions[] = $path; |
246 |
$this->allowedExceptions[] = $path; |
247 |
} |
247 |
} |
248 |
|
248 |
|
249 |
function addDisallowedDownloadException($path) |
249 |
function addDisallowedDownloadException($path) |
250 |
{ |
250 |
{ |
251 |
if ($path{strlen($path) - 1} != "/") |
251 |
if ($path{strlen($path) - 1} != "/") |
252 |
$path .= "/"; |
252 |
$path .= "/"; |
253 |
|
253 |
|
254 |
$this->disallowedExceptions[] = $path; |
254 |
$this->disallowedExceptions[] = $path; |
255 |
} |
255 |
} |
256 |
|
256 |
|
257 |
function isDownloadAllowed($path) |
257 |
function isDownloadAllowed($path) |
258 |
{ |
258 |
{ |
259 |
global $config; |
259 |
global $config; |
260 |
|
260 |
|
261 |
// Check global download option |
261 |
// Check global download option |
262 |
if (!$this->getAllowDownload()) |
262 |
if (!$this->getAllowDownload()) |
263 |
return false; |
263 |
return false; |
264 |
|
264 |
|
265 |
// Check with access module |
265 |
// Check with access module |
266 |
if (!$this->hasUnrestrictedReadAccess($path)) |
266 |
if (!$this->hasUnrestrictedReadAccess($path)) |
267 |
return false; |
267 |
return false; |
268 |
|
268 |
|
269 |
$subs = explode("/", $path); |
269 |
$subs = explode("/", $path); |
270 |
$level = count($subs) - 2; |
270 |
$level = count($subs) - 2; |
271 |
if ($level >= $this->getMinDownloadLevel()) |
271 |
if ($level >= $this->getMinDownloadLevel()) |
272 |
{ |
272 |
{ |
273 |
// Level OK, search for disallowed exceptions |
273 |
// Level OK, search for disallowed exceptions |
274 |
|
274 |
|
275 |
if ($config->findException($path, $this->disallowedExceptions)) |
275 |
if ($config->findException($path, $this->disallowedExceptions)) |
276 |
return false; |
276 |
return false; |
277 |
|
277 |
|
278 |
if ($config->findException($path, $config->disallowedExceptions)) |
278 |
if ($config->findException($path, $config->disallowedExceptions)) |
279 |
return false; |
279 |
return false; |
280 |
|
280 |
|
281 |
return true; |
281 |
return true; |
282 |
} |
282 |
} |
283 |
else |
283 |
else |
284 |
{ |
284 |
{ |
285 |
// Level not OK, search for disallowed exceptions |
285 |
// Level not OK, search for disallowed exceptions |
286 |
|
286 |
|
287 |
if ($config->findException($path, $this->allowedExceptions)) |
287 |
if ($config->findException($path, $this->allowedExceptions)) |
288 |
return true; |
288 |
return true; |
289 |
|
289 |
|
290 |
if ($config->findException($path, $config->allowedExceptions)) |
290 |
if ($config->findException($path, $config->allowedExceptions)) |
291 |
return true; |
291 |
return true; |
292 |
|
292 |
|
293 |
return false; |
293 |
return false; |
294 |
} |
294 |
} |
295 |
} |
295 |
} |
296 |
|
296 |
|
297 |
// }}} |
297 |
// }}} |
298 |
|
298 |
|
299 |
// {{{ Templates |
299 |
// {{{ Templates |
300 |
|
300 |
|
301 |
function setTemplatePath($path) |
301 |
function setTemplatePath($path) |
302 |
{ |
302 |
{ |
303 |
$lastchar = substr($path, -1, 1); |
303 |
$lastchar = substr($path, -1, 1); |
304 |
if (!($lastchar == DIRECTORY_SEPARATOR || |
304 |
if (!($lastchar == DIRECTORY_SEPARATOR || |
305 |
$lastchar == '/' || |
305 |
$lastchar == '/' || |
306 |
$lastchar == '\\')) |
306 |
$lastchar == '\\')) |
307 |
$path .= DIRECTORY_SEPARATOR; |
307 |
$path .= DIRECTORY_SEPARATOR; |
308 |
|
308 |
|
309 |
$this->templatePath = $path; |
309 |
$this->templatePath = $path; |
310 |
} |
310 |
} |
311 |
|
311 |
|
312 |
function getTemplatePath() |
312 |
function getTemplatePath() |
313 |
{ |
313 |
{ |
314 |
global $config; |
314 |
global $config; |
315 |
if (!empty($this->templatePath)) |
315 |
if (!empty($this->templatePath)) |
316 |
return $this->templatePath; |
316 |
return $this->templatePath; |
317 |
else |
317 |
else |
318 |
return $config->getTemplatePath(); |
318 |
return $config->getTemplatePath(); |
319 |
} |
319 |
} |
320 |
|
320 |
|
321 |
// }}} |
321 |
// }}} |
322 |
|
322 |
|
323 |
// {{{ Tab expansion |
323 |
// {{{ Tab expansion |
324 |
|
324 |
|
325 |
function expandTabsBy($sp) |
325 |
function expandTabsBy($sp) |
326 |
{ |
326 |
{ |
327 |
$this->spaces = $sp; |
327 |
$this->spaces = $sp; |
328 |
} |
328 |
} |
329 |
|
329 |
|
330 |
function getExpandTabsBy() |
330 |
function getExpandTabsBy() |
331 |
{ |
331 |
{ |
332 |
global $config; |
332 |
global $config; |
333 |
|
333 |
|
334 |
if (isset($this->spaces)) |
334 |
if (isset($this->spaces)) |
335 |
return $this->spaces; |
335 |
return $this->spaces; |
336 |
|
336 |
|
337 |
return $config->getExpandTabsBy(); |
337 |
return $config->getExpandTabsBy(); |
338 |
} |
338 |
} |
339 |
|
339 |
|
340 |
// }}} |
340 |
// }}} |
341 |
|
341 |
|
342 |
// {{{ MIME-Type Handing |
342 |
// {{{ MIME-Type Handing |
343 |
|
343 |
|
344 |
function ignoreSvnMimeTypes() |
344 |
function ignoreSvnMimeTypes() |
345 |
{ |
345 |
{ |
346 |
$this->ignoreSvnMimeTypes = true; |
346 |
$this->ignoreSvnMimeTypes = true; |
347 |
} |
347 |
} |
348 |
|
348 |
|
349 |
function useSvnMimeTypes() |
349 |
function useSvnMimeTypes() |
350 |
{ |
350 |
{ |
351 |
$this->ignoreSvnMimeTypes = false; |
351 |
$this->ignoreSvnMimeTypes = false; |
352 |
} |
352 |
} |
353 |
|
353 |
|
354 |
function getIgnoreSvnMimeTypes() |
354 |
function getIgnoreSvnMimeTypes() |
355 |
{ |
355 |
{ |
356 |
global $config; |
356 |
global $config; |
357 |
|
357 |
|
358 |
if (isset($this->ignoreSvnMimeTypes)) |
358 |
if (isset($this->ignoreSvnMimeTypes)) |
359 |
return $this->ignoreSvnMimeTypes; |
359 |
return $this->ignoreSvnMimeTypes; |
360 |
|
360 |
|
361 |
return $config->getIgnoreSvnMimeTypes(); |
361 |
return $config->getIgnoreSvnMimeTypes(); |
362 |
} |
362 |
} |
363 |
|
363 |
|
364 |
function ignoreWebSVNContentTypes() |
364 |
function ignoreWebSVNContentTypes() |
365 |
{ |
365 |
{ |
366 |
$this->ignoreWebSVNContentTypes = true; |
366 |
$this->ignoreWebSVNContentTypes = true; |
367 |
} |
367 |
} |
368 |
|
368 |
|
369 |
function useWebSVNContentTypes() |
369 |
function useWebSVNContentTypes() |
370 |
{ |
370 |
{ |
371 |
$this->ignoreWebSVNContentTypes = false; |
371 |
$this->ignoreWebSVNContentTypes = false; |
372 |
} |
372 |
} |
373 |
|
373 |
|
374 |
function getIgnoreWebSVNContentTypes() |
374 |
function getIgnoreWebSVNContentTypes() |
375 |
{ |
375 |
{ |
376 |
global $config; |
376 |
global $config; |
377 |
|
377 |
|
378 |
if (isset($this->ignoreWebSVNContentTypes)) |
378 |
if (isset($this->ignoreWebSVNContentTypes)) |
379 |
return $this->ignoreWebSVNContentTypes; |
379 |
return $this->ignoreWebSVNContentTypes; |
380 |
|
380 |
|
381 |
return $config->getIgnoreWebSVNContentTypes(); |
381 |
return $config->getIgnoreWebSVNContentTypes(); |
382 |
} |
382 |
} |
383 |
|
383 |
|
384 |
// }}} |
384 |
// }}} |
385 |
|
385 |
|
386 |
// {{{ Issue Tracking |
386 |
// {{{ Issue Tracking |
387 |
|
387 |
|
388 |
function useBugtraqProperties() |
388 |
function useBugtraqProperties() |
389 |
{ |
389 |
{ |
390 |
$this->bugtraq = true; |
390 |
$this->bugtraq = true; |
391 |
} |
391 |
} |
392 |
|
392 |
|
393 |
function ignoreBugtraqProperties() |
393 |
function ignoreBugtraqProperties() |
394 |
{ |
394 |
{ |
395 |
$this->bugtraq = false; |
395 |
$this->bugtraq = false; |
396 |
} |
396 |
} |
397 |
|
397 |
|
398 |
function getBugtraq() |
398 |
function getBugtraq() |
399 |
{ |
399 |
{ |
400 |
global $config; |
400 |
global $config; |
401 |
|
401 |
|
402 |
if (isset($this->bugtraq)) |
402 |
if (isset($this->bugtraq)) |
403 |
return $this->bugtraq; |
403 |
return $this->bugtraq; |
404 |
|
404 |
|
405 |
return $config->getBugtraq(); |
405 |
return $config->getBugtraq(); |
406 |
} |
406 |
} |
407 |
|
407 |
|
408 |
// }}} |
408 |
// }}} |
409 |
|
409 |
|
410 |
// {{{ Encodings |
410 |
// {{{ Encodings |
411 |
|
411 |
|
412 |
function setContentEncoding($contentEnc) |
412 |
function setContentEncoding($contentEnc) |
413 |
{ |
413 |
{ |
414 |
$this->contentEnc = $contentEnc; |
414 |
$this->contentEnc = $contentEnc; |
415 |
} |
415 |
} |
416 |
|
416 |
|
417 |
function getContentEncoding() |
417 |
function getContentEncoding() |
418 |
{ |
418 |
{ |
419 |
global $config; |
419 |
global $config; |
420 |
|
420 |
|
421 |
if (isset($this->contentEnc)) |
421 |
if (isset($this->contentEnc)) |
422 |
return $this->contentEnc; |
422 |
return $this->contentEnc; |
423 |
|
423 |
|
424 |
return $config->getContentEncoding(); |
424 |
return $config->getContentEncoding(); |
425 |
} |
425 |
} |
426 |
|
426 |
|
427 |
// }}} |
427 |
// }}} |
428 |
|
428 |
|
429 |
// {{{ Authentication |
429 |
// {{{ Authentication |
430 |
|
430 |
|
431 |
function useAuthenticationFile($file) |
431 |
function useAuthenticationFile($file) |
432 |
{ |
432 |
{ |
433 |
if (is_readable($file)) |
433 |
if (is_readable($file)) |
434 |
$this->auth =& new Authentication($file); |
434 |
$this->auth =& new Authentication($file); |
435 |
else |
435 |
else |
436 |
die('Unable to read authentication file "'.$file.'"'); |
436 |
die('Unable to read authentication file "'.$file.'"'); |
437 |
} |
437 |
} |
438 |
|
438 |
|
439 |
function hasReadAccess($path, $checkSubFolders = false) |
439 |
function hasReadAccess($path, $checkSubFolders = false) |
440 |
{ |
440 |
{ |
441 |
global $config; |
441 |
global $config; |
442 |
|
442 |
|
443 |
$a = null; |
443 |
$a = null; |
444 |
if (isset($this->auth)) |
444 |
if (isset($this->auth)) |
445 |
$a =& $this->auth; |
445 |
$a =& $this->auth; |
446 |
else |
446 |
else |
447 |
$a =& $config->getAuth(); |
447 |
$a =& $config->getAuth(); |
448 |
|
448 |
|
449 |
if (!empty($a)) |
449 |
if (!empty($a)) |
450 |
return $a->hasReadAccess($this->svnName, $path, $checkSubFolders); |
450 |
return $a->hasReadAccess($this->svnName, $path, $checkSubFolders); |
451 |
|
451 |
|
452 |
// No auth file - free access... |
452 |
// No auth file - free access... |
453 |
return true; |
453 |
return true; |
454 |
} |
454 |
} |
455 |
|
455 |
|
456 |
function hasUnrestrictedReadAccess($path) |
456 |
function hasUnrestrictedReadAccess($path) |
457 |
{ |
457 |
{ |
458 |
global $config; |
458 |
global $config; |
459 |
|
459 |
|
460 |
$a = null; |
460 |
$a = null; |
461 |
if (isset($this->auth)) |
461 |
if (isset($this->auth)) |
462 |
$a =& $this->auth; |
462 |
$a =& $this->auth; |
463 |
else |
463 |
else |
464 |
$a =& $config->getAuth(); |
464 |
$a =& $config->getAuth(); |
465 |
|
465 |
|
466 |
if (!empty($a)) |
466 |
if (!empty($a)) |
467 |
return $a->hasUnrestrictedReadAccess($this->svnName, $path); |
467 |
return $a->hasUnrestrictedReadAccess($this->svnName, $path); |
468 |
|
468 |
|
469 |
// No auth file - free access... |
469 |
// No auth file - free access... |
470 |
return true; |
470 |
return true; |
471 |
} |
471 |
} |
472 |
|
472 |
|
473 |
// }}} |
473 |
// }}} |
474 |
|
474 |
|
475 |
} |
475 |
} |
476 |
|
476 |
|
477 |
// The general configuration class |
477 |
// The general configuration class |
478 |
|
478 |
|
479 |
Class Config |
479 |
Class Config |
480 |
{ |
480 |
{ |
481 |
// {{{ Properties |
481 |
// {{{ Properties |
482 |
|
482 |
|
483 |
// Tool path locations |
483 |
// Tool path locations |
484 |
|
484 |
|
485 |
var $svnlook = "svnlook"; |
485 |
var $svnlook = "svnlook"; |
486 |
var $svn = "svn --non-interactive --config-dir /tmp"; |
486 |
var $svn = "svn --non-interactive --config-dir /tmp"; |
487 |
var $svn_noparams = "svn --config-dir /tmp"; |
487 |
var $svn_noparams = "svn --config-dir /tmp"; |
488 |
var $diff = "diff"; |
488 |
var $diff = "diff"; |
489 |
var $enscript ="enscript"; |
489 |
var $enscript ="enscript"; |
490 |
var $sed = "sed"; |
490 |
var $sed = "sed"; |
491 |
var $gzip = "gzip"; |
491 |
var $gzip = "gzip"; |
492 |
var $tar = "tar"; |
492 |
var $tar = "tar"; |
493 |
|
493 |
|
494 |
// Other configuration items |
494 |
// Other configuration items |
495 |
|
495 |
|
496 |
var $treeView = true; |
496 |
var $treeView = true; |
497 |
var $flatIndex = true; |
497 |
var $flatIndex = true; |
498 |
var $openTree = false; |
498 |
var $openTree = false; |
499 |
var $serverIsWindows = false; |
499 |
var $serverIsWindows = false; |
500 |
var $cacheResults = false; |
500 |
var $phpCompatEnabled = false; |
501 |
var $multiViews = false; |
501 |
var $cacheResults = false; |
502 |
var $useEnscript = false; |
502 |
var $multiViews = false; |
503 |
var $allowDownload = false; |
503 |
var $useEnscript = false; |
504 |
var $minDownloadLevel = 0; |
504 |
var $allowDownload = false; |
505 |
var $allowedExceptions = array(); |
505 |
var $minDownloadLevel = 0; |
506 |
var $disallowedExceptions = array(); |
506 |
var $allowedExceptions = array(); |
507 |
var $rss = true; |
507 |
var $disallowedExceptions = array(); |
508 |
var $spaces = 8; |
508 |
var $rss = true; |
509 |
var $bugtraq = false; |
509 |
var $spaces = 8; |
510 |
var $auth = ""; |
510 |
var $bugtraq = false; |
511 |
|
511 |
var $auth = ""; |
512 |
var $templatePath = "./templates/Standard/"; |
512 |
|
513 |
var $phpCompatPath = './include/PHP/Compat.php'; |
513 |
var $templatePath = "./templates/Standard/"; |
514 |
|
514 |
var $phpCompatPath = './include/PHP/Compat.php'; |
515 |
var $ignoreSvnMimeTypes = false; |
515 |
|
516 |
var $ignoreWebSVNContentTypes = false; |
516 |
var $ignoreSvnMimeTypes = false; |
517 |
|
517 |
var $ignoreWebSVNContentTypes = false; |
518 |
var $subversionMajorVersion = ""; |
518 |
|
519 |
var $subversionMinorVersion = ""; |
519 |
var $subversionMajorVersion = ""; |
520 |
|
520 |
var $subversionMinorVersion = ""; |
521 |
// Default character encodings |
521 |
|
522 |
var $inputEnc = ""; // Encoding of output returned from command line |
522 |
// Default character encodings |
523 |
var $contentEnc = ""; // Encoding of repository content |
523 |
var $inputEnc = ""; // Encoding of output returned from command line |
524 |
var $outputEnc = "UTF-8"; // Encoding of web page. Now forced to UTF-8 |
524 |
var $contentEnc = ""; // Encoding of repository content |
525 |
|
525 |
var $outputEnc = "UTF-8"; // Encoding of web page. Now forced to UTF-8 |
526 |
var $quote = "'"; |
526 |
|
527 |
|
527 |
var $quote = "'"; |
528 |
var $_repositories; |
528 |
var $pathSeparator = ":"; |
529 |
|
529 |
|
530 |
// }}} |
530 |
var $_repositories; |
531 |
|
531 |
|
532 |
// {{{ __construct() |
532 |
// }}} |
533 |
|
533 |
|
534 |
function Config() |
534 |
// {{{ __construct() |
535 |
{ |
535 |
|
536 |
} |
536 |
function Config() |
537 |
|
537 |
{ |
538 |
// }}} |
538 |
} |
539 |
|
539 |
|
540 |
// {{{ Repository configuration |
540 |
// }}} |
541 |
|
541 |
|
542 |
function addRepository($name, $url, $group = NULL, $username = NULL, $password = NULL) |
542 |
// {{{ Repository configuration |
543 |
{ |
543 |
|
544 |
$url = str_replace(DIRECTORY_SEPARATOR, "/", $url); |
544 |
function addRepository($name, $url, $group = NULL, $username = NULL, $password = NULL) |
545 |
|
545 |
{ |
546 |
if ($url{strlen($url) - 1} == "/") |
546 |
$url = str_replace(DIRECTORY_SEPARATOR, "/", $url); |
547 |
$url = substr($url, 0, -1); |
547 |
|
548 |
|
548 |
if ($url{strlen($url) - 1} == "/") |
549 |
$svnName = substr($url, strrpos($url, "/") + 1); |
549 |
$url = substr($url, 0, -1); |
550 |
$this->_repositories[] = new Repository($name, $svnName, $url, $group, $username, $password); |
550 |
|
551 |
} |
551 |
$svnName = substr($url, strrpos($url, "/") + 1); |
552 |
|
552 |
$this->_repositories[] = new Repository($name, $svnName, $url, $group, $username, $password); |
553 |
function getRepositories() |
553 |
} |
554 |
{ |
554 |
|
555 |
return $this->_repositories; |
555 |
function getRepositories() |
556 |
} |
556 |
{ |
557 |
|
557 |
return $this->_repositories; |
558 |
function &findRepository($name) |
558 |
} |
559 |
{ |
559 |
|
560 |
foreach ($this->_repositories as $index => $rep) |
560 |
function &findRepository($name) |
561 |
{ |
561 |
{ |
562 |
if (strcmp($rep->getDisplayName(), $name) == 0) |
562 |
foreach ($this->_repositories as $index => $rep) |
563 |
{ |
563 |
{ |
564 |
$repref =& $this->_repositories[$index]; |
564 |
if (strcmp($rep->getDisplayName(), $name) == 0) |
565 |
return $repref; |
565 |
{ |
566 |
} |
566 |
$repref =& $this->_repositories[$index]; |
567 |
} |
567 |
return $repref; |
568 |
|
568 |
} |
569 |
print "ERROR: Unable to find repository '$name'"; |
569 |
} |
570 |
exit; |
570 |
|
571 |
} |
571 |
print "ERROR: Unable to find repository '$name'"; |
572 |
|
572 |
exit; |
573 |
// }}} |
573 |
} |
574 |
|
574 |
|
575 |
// {{{ setServerIsWindows |
575 |
// }}} |
576 |
// |
576 |
|
577 |
// The server is running on Windows |
577 |
// {{{ setServerIsWindows |
578 |
|
578 |
// |
579 |
function setServerIsWindows() |
579 |
// The server is running on Windows |
580 |
{ |
580 |
|
581 |
$this->serverIsWindows = true; |
581 |
function setServerIsWindows() |
582 |
|
582 |
{ |
583 |
// Try to set the input encoding intelligently |
583 |
$this->serverIsWindows = true; |
584 |
|
584 |
|
585 |
$cp = 0; |
585 |
// Try to set the input encoding intelligently |
586 |
if ($cp = @shell_exec("CHCP")) |
586 |
|
587 |
{ |
587 |
$cp = 0; |
588 |
$cp = trim(substr($cp, strpos($cp, ":") + 1)); |
588 |
if ($cp = @shell_exec("CHCP")) |
589 |
settype($cp, "integer"); |
589 |
{ |
590 |
} |
590 |
$cp = trim(substr($cp, strpos($cp, ":") + 1)); |
591 |
|
591 |
settype($cp, "integer"); |
592 |
// Use the most sensible default value if that failed |
592 |
} |
593 |
if ($cp == 0) $cp = 850; |
593 |
|
594 |
|
594 |
// Use the most sensible default value if that failed |
595 |
// We assume, as a default, that the encoding of the repository contents is |
595 |
if ($cp == 0) $cp = 850; |
596 |
// in iso-8859-1, to be compatible with compilers and the like. |
596 |
|
597 |
$this->setInputEncoding("CP$cp", "iso-8859-1"); |
597 |
// We assume, as a default, that the encoding of the repository contents is |
598 |
|
598 |
// in iso-8859-1, to be compatible with compilers and the like. |
599 |
// On Windows machines, use double quotes around command line parameters |
599 |
$this->setInputEncoding("CP$cp", "iso-8859-1"); |
600 |
|
600 |
|
601 |
$this->quote = '"'; |
601 |
// On Windows machines, use double quotes around command line parameters |
602 |
} |
602 |
$this->quote = '"'; |
603 |
|
603 |
|
604 |
// }}} |
604 |
// On Windows, semicolon separates path entries in a list rather than colon. |
605 |
|
605 |
$this->pathSeparator = ";"; |
606 |
// {{{ Caching |
606 |
} |
607 |
|
607 |
|
608 |
// setCachingOn |
608 |
// }}} |
609 |
// |
609 |
|
610 |
// Set result caching on |
610 |
// {{{ setPHPCompatEnabled |
611 |
|
611 |
// |
612 |
function setCachingOn() |
612 |
// Used for PHP4 |
613 |
{ |
613 |
|
614 |
$this->cacheResults = true; |
614 |
function setPHPCompatEnabled() { |
615 |
} |
615 |
$this->phpCompatEnabled = true; |
616 |
|
616 |
} |
617 |
function isCachingOn() |
617 |
|
618 |
{ |
618 |
function isPHPCompatEnabled() { |
619 |
return $this->cacheResults; |
619 |
return $this->phpCompatEnabled; |
620 |
} |
620 |
} |
621 |
|
621 |
|
622 |
// }}} |
622 |
// }}} |
623 |
|
623 |
|
624 |
// {{{ MultiViews |
624 |
// {{{ Caching |
625 |
|
625 |
|
626 |
// useMultiViews |
626 |
// setCachingOn |
627 |
// |
627 |
// |
628 |
// Use MultiViews to access the repository |
628 |
// Set result caching on |
629 |
|
629 |
|
630 |
function useMultiViews() |
630 |
function setCachingOn() |
631 |
{ |
631 |
{ |
632 |
$this->multiViews = true; |
632 |
$this->cacheResults = true; |
633 |
} |
633 |
} |
634 |
|
634 |
|
635 |
function getUseMultiViews() |
635 |
function isCachingOn() |
636 |
{ |
636 |
{ |
637 |
return $this->multiViews; |
637 |
return $this->cacheResults; |
638 |
} |
638 |
} |
639 |
|
639 |
|
640 |
// }}} |
640 |
// }}} |
641 |
|
641 |
|
642 |
// {{{ Enscript |
642 |
// {{{ MultiViews |
643 |
|
643 |
|
644 |
// useEnscript |
644 |
// useMultiViews |
645 |
// |
645 |
// |
646 |
// Use Enscript to colourise listings |
646 |
// Use MultiViews to access the repository |
647 |
|
647 |
|
648 |
function useEnscript() |
648 |
function useMultiViews() |
649 |
{ |
649 |
{ |
650 |
$this->useEnscript = true; |
650 |
$this->multiViews = true; |
651 |
} |
651 |
} |
652 |
|
652 |
|
653 |
function getUseEnscript() |
653 |
function getUseMultiViews() |
654 |
{ |
654 |
{ |
655 |
return $this->useEnscript; |
655 |
return $this->multiViews; |
656 |
} |
656 |
} |
657 |
|
657 |
|
658 |
// }}} |
658 |
// }}} |
659 |
|
659 |
|
660 |
// {{{ RSS |
660 |
// {{{ Enscript |
661 |
|
661 |
|
662 |
// offerRSS |
662 |
// useEnscript |
663 |
// |
663 |
// |
664 |
// Use Enscript to colourise listings |
664 |
// Use Enscript to colourise listings |
665 |
|
665 |
|
666 |
function hideRSS($myrep = 0) |
666 |
function useEnscript() |
667 |
{ |
667 |
{ |
668 |
if (empty($myrep)) |
668 |
$this->useEnscript = true; |
669 |
$this->rss = false; |
669 |
} |
670 |
else |
670 |
|
671 |
{ |
671 |
function getUseEnscript() |
672 |
$repo =& $this->findRepository($myrep); |
672 |
{ |
673 |
$repo->hideRSS(); |
673 |
return $this->useEnscript; |
674 |
} |
674 |
} |
675 |
} |
675 |
|
676 |
|
676 |
// }}} |
677 |
function getHideRSS() |
677 |
|
678 |
{ |
678 |
// {{{ RSS |
679 |
return $this->rss; |
679 |
|
680 |
} |
680 |
// offerRSS |
681 |
|
681 |
// |
682 |
// }}} |
682 |
// Use Enscript to colourise listings |
683 |
|
683 |
|
684 |
// {{{ Downloads |
684 |
function hideRSS($myrep = 0) |
685 |
|
685 |
{ |
686 |
// allowDownload |
686 |
if (empty($myrep)) |
687 |
// |
687 |
$this->rss = false; |
688 |
// Allow download of tarballs |
688 |
else |
689 |
|
689 |
{ |
690 |
function allowDownload($myrep = 0) |
690 |
$repo =& $this->findRepository($myrep); |
691 |
{ |
691 |
$repo->hideRSS(); |
692 |
if (empty($myrep)) |
692 |
} |
693 |
$this->allowDownload = true; |
693 |
} |
694 |
else |
694 |
|
695 |
{ |
695 |
function getHideRSS() |
696 |
$repo =& $this->findRepository($myrep); |
696 |
{ |
697 |
$repo->allowDownload(); |
697 |
return $this->rss; |
698 |
} |
698 |
} |
699 |
} |
699 |
|
700 |
|
700 |
// }}} |
701 |
function disallowDownload($myrep = 0) |
701 |
|
702 |
{ |
702 |
// {{{ Downloads |
703 |
if (empty($myrep)) |
703 |
|
704 |
$this->allowDownload = false; |
704 |
// allowDownload |
705 |
else |
705 |
// |
706 |
{ |
706 |
// Allow download of tarballs |
707 |
$repo =& $this->findRepository($myrep); |
707 |
|
708 |
$repo->disallowDownload(); |
708 |
function allowDownload($myrep = 0) |
709 |
} |
709 |
{ |
710 |
} |
710 |
if (empty($myrep)) |
711 |
|
711 |
$this->allowDownload = true; |
712 |
function getAllowDownload() |
712 |
else |
713 |
{ |
713 |
{ |
714 |
return $this->allowDownload; |
714 |
$repo =& $this->findRepository($myrep); |
715 |
} |
715 |
$repo->allowDownload(); |
716 |
|
716 |
} |
717 |
function setMinDownloadLevel($level, $myrep = 0) |
717 |
} |
718 |
{ |
718 |
|
719 |
if (empty($myrep)) |
719 |
function disallowDownload($myrep = 0) |
720 |
$this->minDownloadLevel = $level; |
720 |
{ |
721 |
else |
721 |
if (empty($myrep)) |
722 |
{ |
722 |
$this->allowDownload = false; |
723 |
$repo =& $this->findRepository($myrep); |
723 |
else |
724 |
$repo->setMinDownloadLevel($level); |
724 |
{ |
725 |
} |
725 |
$repo =& $this->findRepository($myrep); |
726 |
} |
726 |
$repo->disallowDownload(); |
727 |
|
727 |
} |
728 |
function getMinDownloadLevel() |
728 |
} |
729 |
{ |
729 |
|
730 |
return $this->minDownloadLevel; |
730 |
function getAllowDownload() |
731 |
} |
731 |
{ |
732 |
|
732 |
return $this->allowDownload; |
733 |
function addAllowedDownloadException($path, $myrep = 0) |
733 |
} |
734 |
{ |
734 |
|
735 |
if ($path{strlen($path) - 1} != "/") |
735 |
function setMinDownloadLevel($level, $myrep = 0) |
736 |
$path .= "/"; |
736 |
{ |
737 |
|
737 |
if (empty($myrep)) |
738 |
if (empty($myrep)) |
738 |
$this->minDownloadLevel = $level; |
739 |
$this->allowedExceptions[] = $path; |
739 |
else |
740 |
else |
740 |
{ |
741 |
{ |
741 |
$repo =& $this->findRepository($myrep); |
742 |
$repo =& $this->findRepository($myrep); |
742 |
$repo->setMinDownloadLevel($level); |
743 |
$repo->addAllowedDownloadException($path); |
743 |
} |
744 |
} |
744 |
} |
745 |
} |
745 |
|
746 |
|
746 |
function getMinDownloadLevel() |
747 |
function addDisallowedDownloadException($path, $myrep = 0) |
747 |
{ |
748 |
{ |
748 |
return $this->minDownloadLevel; |
749 |
if ($path{strlen($path) - 1} != "/") |
749 |
} |
750 |
$path .= "/"; |
750 |
|
751 |
|
751 |
function addAllowedDownloadException($path, $myrep = 0) |
752 |
if (empty($myrep)) |
752 |
{ |
753 |
$this->disallowedExceptions[] = $path; |
753 |
if ($path{strlen($path) - 1} != "/") |
754 |
else |
754 |
$path .= "/"; |
755 |
{ |
755 |
|
756 |
$repo =& $this->findRepository($myrep); |
756 |
if (empty($myrep)) |
757 |
$repo->addDisallowedDownloadException($path); |
757 |
$this->allowedExceptions[] = $path; |
758 |
} |
758 |
else |
759 |
} |
759 |
{ |
760 |
|
760 |
$repo =& $this->findRepository($myrep); |
761 |
function findException($path, $exceptions) |
761 |
$repo->addAllowedDownloadException($path); |
762 |
{ |
762 |
} |
763 |
foreach ($exceptions As $key => $exc) |
763 |
} |
764 |
{ |
764 |
|
765 |
if (strncmp($exc, $path, strlen($exc)) == 0) |
765 |
function addDisallowedDownloadException($path, $myrep = 0) |
766 |
return true; |
766 |
{ |
767 |
} |
767 |
if ($path{strlen($path) - 1} != "/") |
768 |
|
768 |
$path .= "/"; |
769 |
return false; |
769 |
|
770 |
} |
770 |
if (empty($myrep)) |
771 |
|
771 |
$this->disallowedExceptions[] = $path; |
772 |
// }}} |
772 |
else |
773 |
|
773 |
{ |
774 |
// {{{ getURL |
774 |
$repo =& $this->findRepository($myrep); |
775 |
// |
775 |
$repo->addDisallowedDownloadException($path); |
776 |
// Get the URL to a path name based on the current config |
776 |
} |
777 |
|
777 |
} |
778 |
function getURL($rep, $path, $op) |
778 |
|
779 |
{ |
779 |
function findException($path, $exceptions) |
780 |
$base = $_SERVER["SCRIPT_NAME"]; |
780 |
{ |
781 |
|
781 |
foreach ($exceptions As $key => $exc) |
782 |
if ($this->multiViews) |
782 |
{ |
783 |
{ |
783 |
if (strncmp($exc, $path, strlen($exc)) == 0) |
784 |
// Remove the .php |
784 |
return true; |
785 |
if (eregi(".php$", $base)) |
785 |
} |
786 |
{ |
786 |
|
787 |
// Remove the .php |
787 |
return false; |
788 |
$base = substr($base, 0, -4); |
788 |
} |
789 |
} |
789 |
|
790 |
|
790 |
// }}} |
791 |
if ($path && $path{0} != "/") $path = "/".$path; |
791 |
|
792 |
|
792 |
// {{{ getURL |
793 |
$url = $base; |
793 |
// |
794 |
|
794 |
// Get the URL to a path name based on the current config |
795 |
if (is_object($rep)) |
795 |
|
796 |
{ |
796 |
function getURL($rep, $path, $op) |
797 |
$url .= "/".$rep->getDisplayName().str_replace('%2F', '/', urlencode($path)); |
797 |
{ |
798 |
|
798 |
$base = $_SERVER["SCRIPT_NAME"]; |
799 |
if ($op != "dir" && $op != "file") |
799 |
|
800 |
$url .= "?op=$op&"; |
800 |
if ($this->multiViews) |
801 |
else |
801 |
{ |
802 |
$url .= "?"; |
802 |
// Remove the .php |
803 |
} |
803 |
if (eregi(".php$", $base)) |
804 |
|
804 |
{ |
805 |
return $url; |
805 |
// Remove the .php |
806 |
} |
806 |
$base = substr($base, 0, -4); |
807 |
else |
807 |
} |
808 |
{ |
808 |
|
809 |
switch ($op) |
809 |
if ($path && $path{0} != "/") $path = "/".$path; |
810 |
{ |
810 |
|
811 |
case "dir": |
811 |
$url = $base; |
812 |
$fname = "listing.php"; |
812 |
|
813 |
break; |
813 |
if (is_object($rep)) |
814 |
|
814 |
{ |
815 |
case "file": |
815 |
$url .= "/".$rep->getDisplayName().str_replace('%2F', '/', urlencode($path)); |
816 |
$fname = "filedetails.php"; |
816 |
|
817 |
break; |
817 |
if ($op != "dir" && $op != "file") |
818 |
|
818 |
$url .= "?op=$op&"; |
819 |
case "log": |
819 |
else |
820 |
$fname = "log.php"; |
820 |
$url .= "?"; |
821 |
break; |
821 |
} |
822 |
|
822 |
|
823 |
case "diff": |
823 |
return $url; |
824 |
$fname = "diff.php"; |
824 |
} |
825 |
break; |
825 |
else |
826 |
|
826 |
{ |
827 |
case "blame": |
827 |
switch ($op) |
828 |
$fname = "blame.php"; |
828 |
{ |
829 |
break; |
829 |
case "dir": |
830 |
|
830 |
$fname = "listing.php"; |
831 |
case "form": |
831 |
break; |
832 |
$fname = "form.php"; |
832 |
|
833 |
break; |
833 |
case "file": |
834 |
|
834 |
$fname = "filedetails.php"; |
835 |
case "rss": |
835 |
break; |
836 |
$fname = "rss.php"; |
836 |
|
837 |
break; |
837 |
case "log": |
838 |
|
838 |
$fname = "log.php"; |
839 |
case "dl": |
839 |
break; |
840 |
$fname = "dl.php"; |
840 |
|
841 |
break; |
841 |
case "diff": |
842 |
|
842 |
$fname = "diff.php"; |
843 |
case "comp": |
843 |
break; |
844 |
$fname = "comp.php"; |
844 |
|
845 |
break; |
845 |
case "blame": |
846 |
} |
846 |
$fname = "blame.php"; |
847 |
|
847 |
break; |
848 |
if ($rep == -1) |
848 |
|
849 |
return $fname."?path=".urlencode($path)."&"; |
849 |
case "form": |
850 |
else |
850 |
$fname = "form.php"; |
851 |
return $fname."?repname=".urlencode($rep->getDisplayName())."&path=".urlencode($path)."&"; |
851 |
break; |
852 |
} |
852 |
|
853 |
} |
853 |
case "rss": |
854 |
|
854 |
$fname = "rss.php"; |
855 |
// }}} |
855 |
break; |
856 |
|
856 |
|
857 |
// {{{ Paths and Commands |
857 |
case "dl": |
858 |
|
858 |
$fname = "dl.php"; |
859 |
// setPath |
859 |
break; |
860 |
// |
860 |
|
861 |
// Set the location of the given path |
861 |
case "comp": |
862 |
|
862 |
$fname = "comp.php"; |
863 |
function setPath(&$var, $path, $name, $params = "") |
863 |
break; |
864 |
{ |
864 |
} |
865 |
$lastchar = substr($path, -1, 1); |
865 |
|
866 |
$isDir = ($lastchar == DIRECTORY_SEPARATOR || |
866 |
if ($rep == -1) |
867 |
$lastchar == "/" || |
867 |
return $fname."?path=".urlencode($path)."&"; |
868 |
$lastchar == "\\"); |
868 |
else |
869 |
|
869 |
return $fname."?repname=".urlencode($rep->getDisplayName())."&path=".urlencode($path)."&"; |
870 |
if (!$isDir) |
870 |
} |
871 |
{ |
871 |
} |
872 |
$path .= DIRECTORY_SEPARATOR; |
872 |
|
873 |
} |
873 |
// }}} |
874 |
|
874 |
|
875 |
// On a windows machine we need to put spaces around the entire command |
875 |
// {{{ Paths and Commands |
876 |
// to allow for spaces in the path |
876 |
|
877 |
if ($this->serverIsWindows) |
877 |
// setPath |
878 |
$var = "\"$path$name\""; |
878 |
// |
879 |
else |
879 |
// Set the location of the given path |
880 |
$var = "$path$name"; |
880 |
|
881 |
|
881 |
function setPath(&$var, $path, $name, $params = "") |
882 |
$var .= " ".$params; |
882 |
{ |
883 |
} |
883 |
$lastchar = substr($path, -1, 1); |
884 |
|
884 |
$isDir = ($lastchar == DIRECTORY_SEPARATOR || |
885 |
// setSVNCommandPath |
885 |
$lastchar == "/" || |
886 |
// |
886 |
$lastchar == "\\"); |
887 |
// Define the location of the svn and svnlook commands |
887 |
|
888 |
|
888 |
if (!$isDir) |
889 |
function setSVNCommandPath($path) |
889 |
{ |
890 |
{ |
890 |
$path .= DIRECTORY_SEPARATOR; |
891 |
$this->setPath($this->svn, $path, "svn", "--non-interactive --config-dir /tmp"); |
891 |
} |
892 |
$this->setPath($this->svn_noparams, $path, "svn", " --config-dir /tmp"); |
892 |
|
893 |
$this->setPath($this->svnlook, $path, "svnlook"); |
893 |
// On a windows machine we need to put spaces around the entire command |
894 |
} |
894 |
// to allow for spaces in the path |
895 |
|
895 |
if ($this->serverIsWindows) |
896 |
function getSvnCommand() |
896 |
$var = "\"$path$name\""; |
897 |
{ |
897 |
else |
898 |
return $this->svn; |
898 |
$var = "$path$name"; |
899 |
} |
899 |
|
900 |
|
900 |
$var .= " ".$params; |
901 |
function getCleanSvnCommand() |
901 |
} |
902 |
{ |
902 |
|
903 |
return $this->svn_noparams; |
903 |
// setSVNCommandPath |
904 |
} |
904 |
// |
905 |
|
905 |
// Define the location of the svn and svnlook commands |
906 |
function getSvnlookCommand() |
906 |
|
907 |
{ |
907 |
function setSVNCommandPath($path) |
908 |
return $this->svnlook; |
908 |
{ |
909 |
} |
909 |
$this->setPath($this->svn, $path, "svn", "--non-interactive --config-dir /tmp"); |
910 |
|
910 |
$this->setPath($this->svn_noparams, $path, "svn", " --config-dir /tmp"); |
911 |
// setDiffPath |
911 |
$this->setPath($this->svnlook, $path, "svnlook"); |
912 |
// |
912 |
} |
913 |
// Define the location of the diff command |
913 |
|
914 |
|
914 |
function getSvnCommand() |
915 |
function setDiffPath($path) |
915 |
{ |
916 |
{ |
916 |
return $this->svn; |
917 |
$this->setPath($this->diff, $path, "diff"); |
917 |
} |
918 |
} |
918 |
|
919 |
|
919 |
function getCleanSvnCommand() |
920 |
function getDiffCommand() |
920 |
{ |
921 |
{ |
921 |
return $this->svn_noparams; |
922 |
return $this->diff; |
922 |
} |
923 |
} |
923 |
|
924 |
|
924 |
function getSvnlookCommand() |
925 |
// setEnscriptPath |
925 |
{ |
926 |
// |
926 |
return $this->svnlook; |
927 |
// Define the location of the enscript command |
927 |
} |
928 |
|
928 |
|
929 |
function setEnscriptPath($path) |
929 |
// setDiffPath |
930 |
{ |
930 |
// |
931 |
$this->setPath($this->enscript, $path, "enscript"); |
931 |
// Define the location of the diff command |
932 |
} |
932 |
|
933 |
|
933 |
function setDiffPath($path) |
934 |
function getEnscriptCommand() |
934 |
{ |
935 |
{ |
935 |
$this->setPath($this->diff, $path, "diff"); |
936 |
return $this->enscript; |
936 |
} |
937 |
} |
937 |
|
938 |
|
938 |
function getDiffCommand() |
939 |
// setSedPath |
939 |
{ |
940 |
// |
940 |
return $this->diff; |
941 |
// Define the location of the sed command |
941 |
} |
942 |
|
942 |
|
943 |
function setSedPath($path) |
943 |
// setEnscriptPath |
944 |
{ |
944 |
// |
945 |
$this->setPath($this->sed, $path, "sed"); |
945 |
// Define the location of the enscript command |
946 |
} |
946 |
|
947 |
|
947 |
function setEnscriptPath($path) |
948 |
function getSedCommand() |
948 |
{ |
949 |
{ |
949 |
$this->setPath($this->enscript, $path, "enscript"); |
950 |
return $this->sed; |
950 |
} |
951 |
} |
951 |
|
952 |
|
952 |
function getEnscriptCommand() |
953 |
// setTarPath |
953 |
{ |
954 |
// |
954 |
return $this->enscript; |
955 |
// Define the location of the tar command |
955 |
} |
956 |
|
956 |
|
957 |
function setTarPath($path) |
957 |
// setSedPath |
958 |
{ |
958 |
// |
959 |
$this->setPath($this->tar, $path, "tar"); |
959 |
// Define the location of the sed command |
960 |
} |
960 |
|
961 |
|
961 |
function setSedPath($path) |
962 |
function getTarCommand() |
962 |
{ |
963 |
{ |
963 |
$this->setPath($this->sed, $path, "sed"); |
964 |
return $this->tar; |
964 |
} |
965 |
} |
965 |
|
966 |
|
966 |
function getSedCommand() |
967 |
// setGzipPath |
967 |
{ |
968 |
// |
968 |
return $this->sed; |
969 |
// Define the location of the GZip command |
969 |
} |
970 |
|
970 |
|
971 |
function setGzipPath($path) |
971 |
// setTarPath |
972 |
{ |
972 |
// |
973 |
$this->setPath($this->gzip, $path, "gzip"); |
973 |
// Define the location of the tar command |
974 |
} |
974 |
|
975 |
|
975 |
function setTarPath($path) |
976 |
function getGzipCommand() |
976 |
{ |
977 |
{ |
977 |
$this->setPath($this->tar, $path, "tar"); |
978 |
return $this->gzip; |
978 |
} |
979 |
} |
979 |
|
980 |
|
980 |
function getTarCommand() |
981 |
// Templates |
981 |
{ |
982 |
|
982 |
return $this->tar; |
983 |
function setTemplatePath($path, $myrep = 0) |
983 |
} |
984 |
{ |
984 |
|
985 |
if (empty($myrep)) |
985 |
// setGzipPath |
986 |
{ |
986 |
// |
987 |
$lastchar = substr($path, -1, 1); |
987 |
// Define the location of the GZip command |
988 |
if (!($lastchar == DIRECTORY_SEPARATOR || |
988 |
|
989 |
$lastchar == '/' || |
989 |
function setGzipPath($path) |
990 |
$lastchar == '\\')) |
990 |
{ |
991 |
$path .= DIRECTORY_SEPARATOR; |
991 |
$this->setPath($this->gzip, $path, "gzip"); |
992 |
|
992 |
} |
993 |
$this->templatePath = $path; |
993 |
|
994 |
} |
994 |
function getGzipCommand() |
995 |
else |
995 |
{ |
996 |
{ |
996 |
return $this->gzip; |
997 |
$repo =& $this->findRepository($myrep); |
997 |
} |
998 |
$repo->setTemplatePath($path); |
998 |
|
999 |
} |
999 |
// Templates |
1000 |
} |
1000 |
|
1001 |
|
1001 |
function setTemplatePath($path, $myrep = 0) |
1002 |
function getTemplatePath() |
1002 |
{ |
1003 |
{ |
1003 |
if (empty($myrep)) |
1004 |
return $this->templatePath; |
1004 |
{ |
1005 |
} |
1005 |
$lastchar = substr($path, -1, 1); |
1006 |
|
1006 |
if (!($lastchar == DIRECTORY_SEPARATOR || |
1007 |
// PHP Compat file (from PEAR) |
1007 |
$lastchar == '/' || |
1008 |
|
1008 |
$lastchar == '\\')) |
1009 |
function setPHPCompatPath($path) |
1009 |
$path .= DIRECTORY_SEPARATOR; |
1010 |
{ |
1010 |
|
1011 |
$this->setPath($this->phpCompatPath, $path, 'Compat.php'); |
1011 |
$this->templatePath = $path; |
1012 |
} |
1012 |
} |
1013 |
|
1013 |
else |
1014 |
function getPHPCompatFile() |
1014 |
{ |
1015 |
{ |
1015 |
$repo =& $this->findRepository($myrep); |
1016 |
return trim($this->phpCompatPath); |
1016 |
$repo->setTemplatePath($path); |
1017 |
} |
1017 |
} |
1018 |
|
1018 |
} |
1019 |
// }}} |
1019 |
|
1020 |
|
1020 |
function getTemplatePath() |
1021 |
// {{{ parentPath |
1021 |
{ |
1022 |
// |
1022 |
return $this->templatePath; |
1023 |
// Automatically set up the repositories based on a parent path |
1023 |
} |
1024 |
|
1024 |
|
1025 |
function parentPath($path, $group = NULL) |
1025 |
// PHP Compat file (from PEAR) |
1026 |
{ |
1026 |
|
1027 |
if ($handle = @opendir($path)) |
1027 |
function setPHPCompatPath($path) |
1028 |
{ |
1028 |
{ |
1029 |
// For each file... |
1029 |
$this->setPath($this->phpCompatPath, $path, 'Compat.php'); |
1030 |
while (false !== ($file = readdir($handle))) |
1030 |
} |
1031 |
{ |
1031 |
|
1032 |
// That's also a non hidden directory |
1032 |
function getPHPCompatFile() |
1033 |
if (is_dir($path.DIRECTORY_SEPARATOR.$file) && $file{0} != ".") |
1033 |
{ |
1034 |
{ |
1034 |
return trim($this->phpCompatPath); |
1035 |
// And that contains a db directory (in an attempt to not include |
1035 |
} |
1036 |
// non svn repositories. |
1036 |
|
1037 |
|
1037 |
// }}} |
1038 |
if (is_dir($path.DIRECTORY_SEPARATOR.$file.DIRECTORY_SEPARATOR."db")) |
1038 |
|
1039 |
{ |
1039 |
// {{{ parentPath |
1040 |
// We add the repository to the list |
1040 |
// |
1041 |
$this->addRepository($file, "file:///".$path.DIRECTORY_SEPARATOR.$file, $group); |
1041 |
// Automatically set up the repositories based on a parent path |
1042 |
} |
1042 |
|
1043 |
} |
1043 |
function parentPath($path, $group = NULL) |
1044 |
} |
1044 |
{ |
1045 |
closedir($handle); |
1045 |
if ($handle = @opendir($path)) |
1046 |
} |
1046 |
{ |
1047 |
|
1047 |
// For each file... |
1048 |
// Sort the repositories into alphabetical order |
1048 |
while (false !== ($file = readdir($handle))) |
1049 |
|
1049 |
{ |
1050 |
if (!empty($this->_repositories)) |
1050 |
// That's also a non hidden directory |
1051 |
usort($this->_repositories, "cmpReps"); |
1051 |
if (is_dir($path.DIRECTORY_SEPARATOR.$file) && $file{0} != ".") |
1052 |
} |
1052 |
{ |
1053 |
|
1053 |
// And that contains a db directory (in an attempt to not include |
1054 |
// }}} |
1054 |
// non svn repositories. |
1055 |
|
1055 |
|
1056 |
// {{{ Encoding functions |
1056 |
if (is_dir($path.DIRECTORY_SEPARATOR.$file.DIRECTORY_SEPARATOR."db")) |
1057 |
|
1057 |
{ |
1058 |
function setInputEncoding($systemEnc) |
1058 |
// We add the repository to the list |
1059 |
{ |
1059 |
$this->addRepository($file, "file:///".$path.DIRECTORY_SEPARATOR.$file, $group); |
1060 |
$this->inputEnc = $systemEnc; |
1060 |
} |
1061 |
|
1061 |
} |
1062 |
if (!isset($this->contentEnc)) |
1062 |
} |
1063 |
$this->contentEnc = $systemEnc; |
1063 |
closedir($handle); |
1064 |
} |
1064 |
} |
1065 |
|
1065 |
|
1066 |
function getInputEncoding() |
1066 |
// Sort the repositories into alphabetical order |
1067 |
{ |
1067 |
|
1068 |
return $this->inputEnc; |
1068 |
if (!empty($this->_repositories)) |
1069 |
} |
1069 |
usort($this->_repositories, "cmpReps"); |
1070 |
|
1070 |
} |
1071 |
function setContentEncoding($contentEnc, $myrep = 0) |
1071 |
|
1072 |
{ |
1072 |
// }}} |
1073 |
if (empty($myrep)) |
1073 |
|
1074 |
$this->contentEnc = $contentEnc; |
1074 |
// {{{ Encoding functions |
1075 |
else |
1075 |
|
1076 |
{ |
1076 |
function setInputEncoding($systemEnc) |
1077 |
$repo =& $this->findRepository($myrep); |
1077 |
{ |
1078 |
$repo->setContentEncoding($contentEnc); |
1078 |
$this->inputEnc = $systemEnc; |
1079 |
} |
1079 |
|
1080 |
} |
1080 |
if (!isset($this->contentEnc)) |
1081 |
|
1081 |
$this->contentEnc = $systemEnc; |
1082 |
function getContentEncoding() |
1082 |
} |
1083 |
{ |
1083 |
|
1084 |
return $this->contentEnc; |
1084 |
function getInputEncoding() |
1085 |
} |
1085 |
{ |
1086 |
|
1086 |
return $this->inputEnc; |
1087 |
// }}} |
1087 |
} |
1088 |
|
1088 |
|
1089 |
// {{{ Tab expansion functions |
1089 |
function setContentEncoding($contentEnc, $myrep = 0) |
1090 |
|
1090 |
{ |
1091 |
function expandTabsBy($sp, $myrep = 0) |
1091 |
if (empty($myrep)) |
1092 |
{ |
1092 |
$this->contentEnc = $contentEnc; |
1093 |
if (empty($myrep)) |
1093 |
else |
1094 |
$this->spaces = $sp; |
1094 |
{ |
1095 |
else |
1095 |
$repo =& $this->findRepository($myrep); |
1096 |
{ |
1096 |
$repo->setContentEncoding($contentEnc); |
1097 |
$repo =& $this->findRepository($myrep); |
1097 |
} |
1098 |
$repo->expandTabsBy($sp); |
1098 |
} |
1099 |
} |
1099 |
|
1100 |
} |
1100 |
function getContentEncoding() |
1101 |
|
1101 |
{ |
1102 |
function getExpandTabsBy() |
1102 |
return $this->contentEnc; |
1103 |
{ |
1103 |
} |
1104 |
return $this->spaces; |
1104 |
|
1105 |
} |
1105 |
// }}} |
1106 |
|
1106 |
|
1107 |
// }}} |
1107 |
// {{{ Tab expansion functions |
1108 |
|
1108 |
|
1109 |
// {{{ Misc settings |
1109 |
function expandTabsBy($sp, $myrep = 0) |
1110 |
|
1110 |
{ |
1111 |
function ignoreSvnMimeTypes() |
1111 |
if (empty($myrep)) |
1112 |
{ |
1112 |
$this->spaces = $sp; |
1113 |
$this->ignoreSvnMimeTypes = true; |
1113 |
else |
1114 |
} |
1114 |
{ |
1115 |
|
1115 |
$repo =& $this->findRepository($myrep); |
1116 |
function getIgnoreSvnMimeTypes() |
1116 |
$repo->expandTabsBy($sp); |
1117 |
{ |
1117 |
} |
1118 |
return $this->ignoreSvnMimeTypes; |
1118 |
} |
1119 |
} |
1119 |
|
1120 |
|
1120 |
function getExpandTabsBy() |
1121 |
function ignoreWebSVNContentTypes() |
1121 |
{ |
1122 |
{ |
1122 |
return $this->spaces; |
1123 |
$this->ignoreWebSVNContentTypes = true; |
1123 |
} |
1124 |
} |
1124 |
|
1125 |
|
1125 |
// }}} |
1126 |
function getIgnoreWebSVNContentTypes() |
1126 |
|
1127 |
{ |
1127 |
// {{{ Misc settings |
1128 |
return $this->ignoreWebSVNContentTypes; |
1128 |
|
1129 |
} |
1129 |
function ignoreSvnMimeTypes() |
1130 |
|
1130 |
{ |
1131 |
function useBugtraqProperties($myrep = 0) |
1131 |
$this->ignoreSvnMimeTypes = true; |
1132 |
{ |
1132 |
} |
1133 |
if (empty($myrep)) |
1133 |
|
1134 |
$this->bugtraq = true; |
1134 |
function getIgnoreSvnMimeTypes() |
1135 |
else |
1135 |
{ |
1136 |
{ |
1136 |
return $this->ignoreSvnMimeTypes; |
1137 |
$repo =& $this->findRepository($myrep); |
1137 |
} |
1138 |
$repo->useBugtraqProperties(); |
1138 |
|
1139 |
} |
1139 |
function ignoreWebSVNContentTypes() |
1140 |
} |
1140 |
{ |
1141 |
|
1141 |
$this->ignoreWebSVNContentTypes = true; |
1142 |
function getBugtraq() |
1142 |
} |
1143 |
{ |
1143 |
|
1144 |
return $this->bugtraq; |
1144 |
function getIgnoreWebSVNContentTypes() |
1145 |
} |
1145 |
{ |
1146 |
|
1146 |
return $this->ignoreWebSVNContentTypes; |
1147 |
function useAuthenticationFile($file, $myrep = 0) |
1147 |
} |
1148 |
{ |
1148 |
|
1149 |
if (empty($myrep)) |
1149 |
function useBugtraqProperties($myrep = 0) |
1150 |
{ |
1150 |
{ |
1151 |
if (is_readable($file)) |
1151 |
if (empty($myrep)) |
1152 |
$this->auth = new Authentication($file); |
1152 |
$this->bugtraq = true; |
1153 |
else |
1153 |
else |
1154 |
{ |
1154 |
{ |
1155 |
echo "Unable to read authentication file '$file'"; |
1155 |
$repo =& $this->findRepository($myrep); |
1156 |
exit; |
1156 |
$repo->useBugtraqProperties(); |
1157 |
} |
1157 |
} |
1158 |
} |
1158 |
} |
1159 |
else |
1159 |
|
1160 |
{ |
1160 |
function getBugtraq() |
1161 |
$repo =& $this->findRepository($myrep); |
1161 |
{ |
1162 |
$repo->useAuthenticationFile($file); |
1162 |
return $this->bugtraq; |
1163 |
} |
1163 |
} |
1164 |
} |
1164 |
|
1165 |
|
1165 |
function useAuthenticationFile($file, $myrep = 0) |
1166 |
function &getAuth() |
1166 |
{ |
1167 |
{ |
1167 |
if (empty($myrep)) |
1168 |
return $this->auth; |
1168 |
{ |
1169 |
} |
1169 |
if (is_readable($file)) |
1170 |
|
1170 |
$this->auth = new Authentication($file); |
1171 |
function useTreeView() |
1171 |
else |
1172 |
{ |
1172 |
{ |
1173 |
$this->treeView = true; |
1173 |
echo "Unable to read authentication file '$file'"; |
1174 |
} |
1174 |
exit; |
1175 |
|
1175 |
} |
1176 |
function getUseTreeView() |
1176 |
} |
1177 |
{ |
1177 |
else |
1178 |
return $this->treeView; |
1178 |
{ |
1179 |
} |
1179 |
$repo =& $this->findRepository($myrep); |
1180 |
|
1180 |
$repo->useAuthenticationFile($file); |
1181 |
function useFlatView() |
1181 |
} |
1182 |
{ |
1182 |
} |
1183 |
$this->treeView = false; |
1183 |
|
1184 |
} |
1184 |
function &getAuth() |
1185 |
|
1185 |
{ |
1186 |
function useTreeIndex($open) |
1186 |
return $this->auth; |
1187 |
{ |
1187 |
} |
1188 |
$this->flatIndex = false; |
1188 |
|
1189 |
$this->openTree = $open; |
1189 |
function useTreeView() |
1190 |
} |
1190 |
{ |
1191 |
|
1191 |
$this->treeView = true; |
1192 |
function getUseFlatIndex() |
1192 |
} |
1193 |
{ |
1193 |
|
1194 |
return $this->flatIndex; |
1194 |
function getUseTreeView() |
1195 |
} |
1195 |
{ |
1196 |
|
1196 |
return $this->treeView; |
1197 |
function getOpenTree() |
1197 |
} |
1198 |
{ |
1198 |
|
1199 |
return $this->openTree; |
1199 |
function useFlatView() |
1200 |
} |
1200 |
{ |
1201 |
|
1201 |
$this->treeView = false; |
1202 |
// setSubversionMajorVersion |
1202 |
} |
1203 |
// |
1203 |
|
1204 |
// Set subversion major version |
1204 |
function useTreeIndex($open) |
1205 |
|
1205 |
{ |
1206 |
function setSubversionMajorVersion($subversionMajorVersion) |
1206 |
$this->flatIndex = false; |
1207 |
{ |
1207 |
$this->openTree = $open; |
1208 |
$this->subversionMajorVersion = $subversionMajorVersion; |
1208 |
} |
1209 |
} |
1209 |
|
1210 |
|
1210 |
function getUseFlatIndex() |
1211 |
function getSubversionMajorVersion() |
1211 |
{ |
1212 |
{ |
1212 |
return $this->flatIndex; |
1213 |
return $this->subversionMajorVersion; |
1213 |
} |
1214 |
} |
1214 |
|
1215 |
|
1215 |
function getOpenTree() |
1216 |
// setSubversionMinorVersion |
1216 |
{ |
1217 |
// |
1217 |
return $this->openTree; |
1218 |
// Set subversion minor version |
1218 |
} |
1219 |
|
1219 |
|
1220 |
function setSubversionMinorVersion($subversionMinorVersion) |
1220 |
// setSubversionMajorVersion |
1221 |
{ |
1221 |
// |
1222 |
$this->subversionMinorVersion = $subversionMinorVersion; |
1222 |
// Set subversion major version |
1223 |
} |
1223 |
|
1224 |
|
1224 |
function setSubversionMajorVersion($subversionMajorVersion) |
1225 |
function getSubversionMinorVersion() |
1225 |
{ |
1226 |
{ |
1226 |
$this->subversionMajorVersion = $subversionMajorVersion; |
1227 |
return $this->subversionMinorVersion; |
1227 |
} |
1228 |
} |
1228 |
|
1229 |
|
1229 |
function getSubversionMajorVersion() |
1230 |
// }}} |
1230 |
{ |
1231 |
|
1231 |
return $this->subversionMajorVersion; |
1232 |
// {{{ Sort the repostories |
1232 |
} |
1233 |
// |
1233 |
|
1234 |
// This function sorts the repositories by group name. The contents of the |
1234 |
// setSubversionMinorVersion |
1235 |
// group are left in there original order, which will either be sorted if the |
1235 |
// |
1236 |
// group was added using the parentPath function, or defined for the order in |
1236 |
// Set subversion minor version |
1237 |
// which the repositories were included in the user's config file. |
1237 |
|
1238 |
// |
1238 |
function setSubversionMinorVersion($subversionMinorVersion) |
1239 |
// Note that as of PHP 4.0.6 the usort command no longer preserves the order |
1239 |
{ |
1240 |
// of items that are considered equal (in our case, part of the same group). |
1240 |
$this->subversionMinorVersion = $subversionMinorVersion; |
1241 |
// The mergesort function preserves this order. |
1241 |
} |
1242 |
|
1242 |
|
1243 |
function sortByGroup() |
1243 |
function getSubversionMinorVersion() |
1244 |
{ |
1244 |
{ |
1245 |
if (!empty($this->_repositories)) |
1245 |
return $this->subversionMinorVersion; |
1246 |
mergesort($this->_repositories, "cmpGroups"); |
1246 |
} |
1247 |
} |
1247 |
|
1248 |
|
1248 |
// }}} |
1249 |
// }}} |
1249 |
|
1250 |
} |
1250 |
// {{{ Sort the repostories |
1251 |
?> |
1251 |
// |
- |
|
1252 |
// This function sorts the repositories by group name. The contents of the |
- |
|
1253 |
// group are left in there original order, which will either be sorted if the |
- |
|
1254 |
// group was added using the parentPath function, or defined for the order in |
- |
|
1255 |
// which the repositories were included in the user's config file. |
- |
|
1256 |
// |
- |
|
1257 |
// Note that as of PHP 4.0.6 the usort command no longer preserves the order |
- |
|
1258 |
// of items that are considered equal (in our case, part of the same group). |
- |
|
1259 |
// The mergesort function preserves this order. |
- |
|
1260 |
|
- |
|
1261 |
function sortByGroup() |
- |
|
1262 |
{ |
- |
|
1263 |
if (!empty($this->_repositories)) |
- |
|
1264 |
mergesort($this->_repositories, "cmpGroups"); |
- |
|
1265 |
} |
- |
|
1266 |
|
- |
|
1267 |
// }}} |
- |
|
1268 |
} |
- |
|
1269 |
?> |