Хранилища Subversion ant

Редакция

Редакция 212 | Редакция 215 | К новейшей редакции | Содержимое файла | Сравнить с предыдущей | Последнее изменение | Открыть журнал | RSS

Редакция Автор № строки Строка
2 alex-w 1
<?php
2
 
198 alex-w 3
/**
4
 * Project:     Ant: sources.list generator
5
 * File:        admin.php
6
 *
7
 * This application is free software; you can redistribute it and/or
8
 * modify it under the terms of the GNU Lesser General Public
9
 * License as published by the Free Software Foundation; either
10
 * version 2.1 of the License, or (at your option) any later version.
11
 *
12
 * This application 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 GNU
15
 * Lesser General Public License for more details.
16
 *
17
 * You should have received a copy of the GNU Lesser General Public
18
 * License along with this library; if not, write to the Free Software
19
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
20
 *
21
 */
22
 
23
 
101 alex-w 24
require_once dirname(__FILE__)."/sign-valid.php";
2 alex-w 25
 
209 alex-w 26
$mode = $secure->wrapInt($_GET["mode"]);
27
$act  = $secure->wrapInt($_GET["action"]);
28
$uid  = $secure->wrapInt($_GET["uid"]);
29
$err  = $secure->wrapInt($_GET["error"]);
2 alex-w 30
 
104 alex-w 31
// Admin file/interface
103 alex-w 32
$admin = "./admin.php";
33
 
17 alex-w 34
switch ($err) {
35
    case '1':
36
            $error = "Ошибка ввода пароля: старый пароль неверен!";
37
            break;
38
    case '2':
39
            $error = "Ошибка ввода пароля: новые пароли не совпадают!";
40
            break;
41
}
11 alex-w 42
 
165 sivan 43
$header = "<div id='head'><div class='title'>".$core->getSetting('codename',$db)." Admin Panel</div><div class='smalltitle'>version: ".$core->getSetting('version',$db)."</div></div>";
161 diffor 44
 
181 diffor 45
$login = "<div id='login'>Вы вошли как: admin <a  class='dashed' href='./signout.php' style='color:red;'>[выход]</a></div>";
161 diffor 46
 
187 diffor 47
 
48
$menu_title = array ( "Управление", "Справочники", "Настройки" );
49
$menu_item = array (
188 diffor 50
1 => array ( "title" => $menu_title[1], "item" => "Дистрибутивы" ),
187 diffor 51
2 => array ( "title" => $menu_title[1], "item" => "Версии" ),
52
3 => array ( "title" => $menu_title[1], "item" => "Источники" ),
53
4 => array ( "title" => $menu_title[0], "item" => "Репозитории" ),
54
5 => array ( "title" => $menu_title[1], "item" => "Секции" ),
55
6 => array ( "title" => $menu_title[1], "item" => "Схемы" ),
56
7 => array ( "title" => $menu_title[1], "item" => "Типы" ),
57
20 => array ( "title" => $menu_title[2], "item" => "Опции" ),
58
21 => array ( "title" => $menu_title[2], "item" => "Интерфейсы" ),
59
22 => array ( "title" => $menu_title[2], "item" => "Пароль" ),
60
);
61
 
161 diffor 62
$menu = "
63
<div id='cont'>
64
<div id='menu'>
187 diffor 65
    <div class='menutitle'>".$menu_title[0].":</div>
66
	<div class='menuitem'><a class='dashed' href='".$admin."?mode=4'>".$menu_item[4]["item"]."</a></div>
67
    <div class='menutitle'>".$menu_title[1].":</div>
68
	<div class='menuitem'><a class='dashed' href='".$admin."?mode=1'>".$menu_item[1]["item"]."</a></div>
69
	<div class='menuitem'><a class='dashed' href='".$admin."?mode=2'>".$menu_item[2]["item"]."</a></div>
70
	<div class='menuitem'><a class='dashed' href='".$admin."?mode=3'>".$menu_item[3]["item"]."</a></div>
71
	<div class='menuitem'><a class='dashed' href='".$admin."?mode=5'>".$menu_item[5]["item"]."</a></div>
72
	<div class='menuitem'><a class='dashed' href='".$admin."?mode=6'>".$menu_item[6]["item"]."</a></div>
73
	<div class='menuitem'><a class='dashed' href='".$admin."?mode=7'>".$menu_item[7]["item"]."</a></div>
74
	<div class='menuitem'><a class='dashed' href='".$admin."?mode=8'>".$menu_item[8]["item"]."</a></div>
75
    <div class='menutitle'>".$menu_title[2].":</div>
76
	<div class='menuitem'><a class='dashed' href='".$admin."?mode=20'>".$menu_item[20]["item"]."</a></div>
77
	<div class='menuitem'><a class='dashed' href='".$admin."?mode=21'>".$menu_item[21]["item"]."</a></div>
78
	<div class='menuitem'><a class='dashed' href='".$admin."?mode=22'>".$menu_item[22]["item"]."</a></div>
161 diffor 79
</div>
80
<div id='main'>
81
";
82
 
2 alex-w 83
switch ($mode) {
84
    case '1':
85
	    // Работа с дистрибутивами
86
	    switch ($act) {
87
		case '0':
88
			// Список дистрибутивов
89
			$dist =& $db->query("SELECT * FROM distribution");
90
			if ($dist->numRows()>0) {
187 diffor 91
				$display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>";
182 diffor 92
				$display .= "<table><tr><th>Дистрибутив</th><th>Действие</th><th>Версии</th></tr>";
2 alex-w 93
				while ($dist->fetchInto($info, DB_FETCHMODE_ASSOC)) {
182 diffor 94
				    $verlist = "";
95
				    $sreq =& $db->query("SELECT * FROM version WHERE dist_id='".$info["dist_id"]."'");
96
				    while ($sreq->fetchInto($sinfo, DB_FETCHMODE_ASSOC)) {
209 alex-w 97
				    $verlist .= "<em>".$secure->stripStr($sinfo["vname"])."</em>, ";
182 diffor 98
				    }
99
				    $verlist = substr($verlist, 0, -2);
209 alex-w 100
				    $display .= "<tr><td>".$secure->stripStr($info['distname'])."</td>";
176 diffor 101
				    $display .= "<td><a href=".$admin."?mode=".$mode."&action=2&uid=".$info["dist_id"]."><img title='Редактировать' src='img/edt.png' width='16' height='16'></a>";
182 diffor 102
				    $display .= "<a href=".$admin."?mode=".$mode."&action=3&uid=".$info["dist_id"]."><img title='Удалить' src='img/del.png' width='16' height='16'></a></td>";
103
				    $display .= "<td>".$verlist."</td></tr>";
2 alex-w 104
				}
176 diffor 105
				$display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='img/add.png' width='16' height='16'>Добавить новый дистрибутив</a></p>";
2 alex-w 106
			}
107
			break;
108
		case '1':
109
			// Добавление нового дистрибутива
110
			$dtype =& $db->query("SELECT * FROM dtype");
111
			$type = "<select name='distType'>";
112
			while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) {
209 alex-w 113
			    $type .= "<option value='".$dtinfo["type_id"]."'>".$secure->stripStr($dtinfo["type"])."</option>";
2 alex-w 114
			}
115
			$type .= "</select>\n";
165 sivan 116
			$display  = "<div class='modulename'><a href='admin.php?mode=1'>Дистрибутивы</a> :: Добавление нового apt-дистрибутива</div>";
81 alex-w 117
			$display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n";
167 diffor 118
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
119
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
2 alex-w 120
			$display .= "Название дистрибутива: <input type='text' name='distName'><br>\n";
61 alex-w 121
			$display .= "Представление в строке User-Agent'а: <input type='text' name='distUA'><br>\n";
2 alex-w 122
			$display .= "Тип дистрибутива: ".$type."<br>";
83 alex-w 123
			$display .= "Логотип дистрибутива (Прозрачный PNG): <input type='file' name='distLOGO'><br>";
2 alex-w 124
			$display .= "<input type='submit' value='Создать'></form>\n";
125
			break;
126
		case '2':
127
			// Правка существующего дистрибутива
128
			$dist =& $db->query("SELECT * FROM distribution WHERE dist_id='$uid'");
129
			$dist->fetchInto($info, DB_FETCHMODE_ASSOC);
130
			$dtype =& $db->query("SELECT * FROM dtype");
131
			$type = "<select name='distType'>";
132
			while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) {
133
			    if ($info["disttype"]==$dtinfo["type_id"]) {
209 alex-w 134
				$type .= "<option value='".$dtinfo["type_id"]."' selected>".$secure->stripStr($dtinfo["type"])."</option>";
2 alex-w 135
			    } else {
209 alex-w 136
				$type .= "<option value='".$dtinfo["type_id"]."'>".$secure->stripStr($dtinfo["type"])."</option>";
2 alex-w 137
			    }
138
			}
139
			$type .= "</select>\n";
209 alex-w 140
			$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Дистрибутивы</a> :: Правка apt-дистрибутива <em class='".$secure->stripStr($info["distua"])."-em'>".$secure->stripStr($info["distname"])."</em></div>";
81 alex-w 141
			$display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n";
167 diffor 142
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
143
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
144
			$display .= "<input type='hidden' name='distID' value='$uid'>\n";
209 alex-w 145
			$display .= "Название дистрибутива: <input type='text' name='distName' value='".$secure->stripStr($info["distname"])."'><br>\n";
146
			$display .= "Представление в строке User-Agent'a: <input type='text' name='distUA' value='".$secure->stripStr($info["distua"])."'><br>\n";
2 alex-w 147
			$display .= "Тип дистрибутива: ".$type."<br>";
83 alex-w 148
			$display .= "Логотип дистрибутива (Прозрачный PNG): <input type='file' name='distLOGO'><br>";
2 alex-w 149
			$display .= "<input type='submit' value='Править'></form>\n";
150
			break;
151
		case '3':
152
			// Удаление существующего дистрибутива
153
			$dist =& $db->query("SELECT * FROM distribution WHERE dist_id='$uid'");
154
			$dist->fetchInto($info, DB_FETCHMODE_ASSOC);
209 alex-w 155
			$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Дистрибутивы</a> :: Удаление apt-дистрибутива <em class='".$secure->stripStr($info["distua"])."-em'>".$secure->stripStr($info["distname"])."</em></div>";
2 alex-w 156
			$display .= "<form action='./process.php' method='POST'>\n";
167 diffor 157
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
158
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
159
			$display .= "<input type='hidden' name='distID' value='$uid'>\n";
209 alex-w 160
			$display .= "<input type='hidden' name='distUA' value='".$secure->stripStr($info["distua"])."'>\n";
2 alex-w 161
			$display .= "<input type='submit' value='Удалить'></form>\n";
162
			break;
163
	    }
164
	    break;
165
	case '2':
166
	    // Работа с версиями дистрибутивов
167
	    switch ($act) {
168
		case '0':
169
			// Все версии имеющихся дистрибутивов
170
			$dist =& $db->query("SELECT * FROM distribution d JOIN version v ON d.dist_id=v.dist_id ORDER BY d.dist_id,v.version ASC");
187 diffor 171
			$display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>";
176 diffor 172
			$display .= "<table><tr><th>Версия</th><th>Действие</th></tr>\n";
2 alex-w 173
			while ($dist->fetchInto($info, DB_FETCHMODE_ASSOC)) {
209 alex-w 174
			    $display .= "<tr><td>".$secure->stripStr($info["distname"])." ".$secure->stripStr($info["version"])." &#8220;".$secure->stripStr($info["vname"])."&#8221;</td>\n";
176 diffor 175
			    $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$info["version_id"]."' class='edit'><img title='Редактировать' src='img/edt.png' width='16' height='16'></a>";
176
			    $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$info["version_id"]."' class='delete'><img title='Удалить' src='img/del.png' width='16' height='16'></a></td></tr>\n";
2 alex-w 177
			}
176 diffor 178
			$display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='img/add.png' width='16' height='16'>Добавить новую версию дистрибутива</a></p>\n";
2 alex-w 179
			break;
180
		case '1':
181
			// Добавление новой версии дистрибутива
182
			$dtype =& $db->query("SELECT * FROM distribution");
183
			$type = "<select name='distName'>";
184
			while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) {
209 alex-w 185
			    $type .= "<option value='".$dtinfo["dist_id"]."'>".$secure->stripStr($dtinfo["distname"])."</option>";
2 alex-w 186
			}
187
			$type .= "</select>\n";
167 diffor 188
			$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Версии</a> :: Добавление новой версии apt-дистрибутива</div>";
2 alex-w 189
			$display .= "<form action='./process.php' method='POST'>\n";
167 diffor 190
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
191
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
2 alex-w 192
			$display .= "Номер версии: <input type='text' name='versNum'><br>\n";
167 diffor 193
			$display .= "Название версии: <input type='text' name='versNam'><br>\n";
2 alex-w 194
			$display .= "Кодовое имя версии: <input type='text' name='versCN'><br>\n";
195
			$display .= "Дистрибутив: ".$type."<br>";
196
			$display .= "<input type='submit' value='Создать'></form>\n";
197
			break;
198
		case '2':
199
			// Правка имеющейся версии дистрибутива
200
			$vers =& $db->query("SELECT * FROM version v JOIN distribution d ON d.dist_id=v.dist_id WHERE version_id='$uid'");
201
			$vers->fetchInto($info, DB_FETCHMODE_ASSOC);
209 alex-w 202
			$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Версии</a> :: Правка имеющейся версии <em>".$secure->stripStr($info["distname"])."</em></div>";
2 alex-w 203
			$display .= "<form action='./process.php' method='POST'>\n";
167 diffor 204
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
205
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
206
			$display .= "<input type='hidden' name='versID' value='$uid'>\n";
209 alex-w 207
			$display .= "Номер версии: <input type='text' name='versNum' value='".$secure->stripStr($info["version"])."'><br>\n";
208
			$display .= "Название версии: <input type='text' name='versNam' value='".$secure->stripStr($info["vname"])."'><br>\n";
209
			$display .= "Кодовое имя версии: <input type='text' name='versCN' value='".$secure->stripStr($info["vcodename"])."'><br>\n";
2 alex-w 210
			$display .= "<input type='submit' value='Править'></form>\n";
211
			break;
212
		case '3':
213
			// Удаление существующей версии дистрибутива
214
			$dist =& $db->query("SELECT * FROM version v JOIN distribution d ON v.dist_id=d.dist_id WHERE v.version_id='$uid'");
215
			$dist->fetchInto($info, DB_FETCHMODE_ASSOC);
209 alex-w 216
			$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Версии</a> :: Удаление версии ".$secure->stripStr($info["version"])." (&#8220;".$secure->stripStr($info["vname"])."&#8221;) <em>".$secure->stripStr($info["distname"])."</em></div>";
2 alex-w 217
			$display .= "<form action='./process.php' method='POST'>\n";
167 diffor 218
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
219
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
220
			$display .= "<input type='hidden' name='versID' value='$uid'>\n";
2 alex-w 221
			$display .= "<input type='submit' value='Удалить'></form>\n";
222
			break;
223
	    }
224
	    break;
167 diffor 225
	case '3':
226
	    // Работа с источниками репозиториев
227
	    switch ($act) {
228
		case '0':
229
			// Список источников
230
			$orig =& $db->query("SELECT * FROM origin");
231
			if ($orig->numRows()>0) {
187 diffor 232
				$display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>";
188 diffor 233
				$display .= "<table><tr><th>Источник</th><th>Действие</th></tr>\n";
167 diffor 234
				while ($orig->fetchInto($info, DB_FETCHMODE_ASSOC)) {
183 diffor 235
				    $distlist = substr($distlist, 0, -2);
209 alex-w 236
				    $display .= "<tr><td>".$secure->stripStr($info["origin"])."</td>\n";
183 diffor 237
				    $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$info["orig_id"]."' class='nodec'><img src='img/edt.png' width='16' height='16' title='Редактировать'></a>";
238
				    $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$info["orig_id"]."'><img title='Удалить' src='img/del.png' width='16' height='16'></a></td>\n";
188 diffor 239
				    $display .= "</tr>";
167 diffor 240
				}
241
			}
176 diffor 242
			$display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='img/add.png' width='16' height='16'>Добавить источник репозиториев</a></p>\n";
167 diffor 243
			break;
244
		case '1':
245
			// Добавление нового источника
186 diffor 246
			$display = "<div class='modulename'>Справочники :: <a href='admin.php?mode=".$mode."'>Источники</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>";
167 diffor 247
			$display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n";
248
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
249
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
250
			$display .= "Название источника: <input type='text' name='origin'><br>\n";
251
			$display .= "<input type='submit' value='Добавить'></form>\n";
252
			break;
253
		case '2':
254
			// Правка существующего источника
183 diffor 255
			$orig =& $db->query("SELECT * FROM origin WHERE orig_id='$uid'");
167 diffor 256
			$orig->fetchInto($info, DB_FETCHMODE_ASSOC);
257
			$type .= "</select>\n";
209 alex-w 258
			$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Источники</a> :: Правка источника репозиториев <em>'".$secure->stripStr($info["origin"])."'</em></div>";
167 diffor 259
			$display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n";
260
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
261
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
262
			$display .= "<input type='hidden' name='originID' value='$uid'>\n";
209 alex-w 263
			$display .= "Название источника: <input type='text' name='origin' value='".$secure->stripStr($info["origin"])."'><br>\n";
167 diffor 264
			$display .= "<input type='submit' value='Править'></form>\n";
265
			break;
266
		case '3':
267
			// Удаление существующего источника
183 diffor 268
			$orig =& $db->query("SELECT * FROM origin WHERE orig_id='$uid'");
167 diffor 269
			$orig->fetchInto($info, DB_FETCHMODE_ASSOC);
209 alex-w 270
			$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Источники</a> :: Удаление источника репозиториев <em>'".$secure->stripStr($info["origin"])."'</em></div>";
167 diffor 271
			$display .= "<form action='./process.php' method='POST'>\n";
272
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
273
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
274
			$display .= "<input type='hidden' name='originID' value='$uid'>\n";
275
			$display .= "<input type='submit' value='Удалить'></form>\n";
276
			break;
277
	    }
278
	    break;
279
        case '4':
2 alex-w 280
            // Работа с репозиториями
281
            switch ($act) {
282
                case '0':
283
                        // Выбор дистрибутива
185 diffor 284
			$dist =& $db->query("SELECT * FROM `repository` LEFT JOIN origin ON repository.orig_id=origin.orig_id LEFT JOIN root ON repository.root_id=root.root_id");
187 diffor 285
			$display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>";
185 diffor 286
			$display .= "<table><tr><th>Репозиторий</th><th>Действие</th><th>Корень</th><th>Источник</th></tr>\n";
2 alex-w 287
			while ($dist->fetchInto($info, DB_FETCHMODE_ASSOC)) {
185 diffor 288
			    $display .= "<tr><td>".$info["repname"]."</td>";
289
			    $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$info["rep_id"]."' class='nodec'><img src='img/edt.png' width='16' height='16' title='Редактировать'></a>";
290
			    $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$info["rep_id"]."'><img title='Удалить' src='img/del.png' width='16' height='16'></a></td>\n";
291
			    $display .= "<td>".$info["root_folder"]."</td>";
292
			    $display .= "<td>".$info["origin"]."</td></tr>";
2 alex-w 293
			}
186 diffor 294
                        $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1&uid=".$uid."'><img src='img/add.png' width='16' height='16'>Добавить новый репозиторий</a></p>";
2 alex-w 295
                        break;
296
                case '1':
297
                        // Новый репозиторий
298
                        $rep =& $db->query("SELECT * FROM distribution d JOIN version v ON v.dist_id=d.dist_id WHERE v.version_id='$uid'");
299
                        $rep->fetchInto($dist, DB_FETCHMODE_ASSOC);
300
                        $dist_id = $dist["dist_id"];
209 alex-w 301
                        $dist_vname = $secure->stripStr($dist["distname"])." ".$secure->stripStr($dist["version"])." &#8220;".$secure->stripStr($dist["vname"])."&#8221;";
8 alex-w 302
			$dtype =& $db->query("SELECT * FROM scheme");
11 alex-w 303
			$rscheme = "<select name='scheme'>";
2 alex-w 304
			while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) {
209 alex-w 305
			    $rscheme .= "<option value='".$dtinfo["scheme_id"]."'>".$secure->stripStr($dtinfo["scheme"])."</option>";
2 alex-w 306
			}
11 alex-w 307
			$rscheme .= "</select>";
185 diffor 308
			$origin_q =& $db->query("SELECT * FROM origin");
309
			$origin = "<select name='origin'>";
310
			while ($origin_q->fetchInto($origin_info, DB_FETCHMODE_ASSOC)) {
209 alex-w 311
			    $origin .= "<option value='".$origin_info["orig_id"]."'>".$secure->stripStr($origin_info["origin"])."</option>";
11 alex-w 312
			}
185 diffor 313
			$origin .= "</select>\n";
2 alex-w 314
                        $sect =& $db->query("SELECT * FROM section s JOIN sect2dist d ON d.sect_id=s.sect_id WHERE d.dist_id='$dist_id'");
315
                        $list = "";
316
                        while ($sect->fetchInto($slist, DB_FETCHMODE_ASSOC)) {
209 alex-w 317
                            $list .= "<input type='checkbox' name='sect[]' value='".$slist["sect_id"]."'> <span title='".$secure->stripStr($slist["sectinfo"])."'>".$secure->stripStr($slist["sectname"])."</span> ";
2 alex-w 318
                        }
319
			$type .= "</select>\n";
91 alex-w 320
			$rootfolder = "<select name='rootFolder'>\n";
321
			$root =& $db->query("SELECT * FROM root");
322
			while ($root->fetchInto($rfi, DB_FETCHMODE_ASSOC)) {
209 alex-w 323
				$rootfolder .= "<option value='".$rfi["root_id"]."'>".$secure->stripStr($rfi["root_folder"])."</option>";
91 alex-w 324
			}
325
			$rootfolder .= "</select>";
186 diffor 326
			$display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>";
2 alex-w 327
			$display .= "<form action='./process.php' method='POST'>\n";
167 diffor 328
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
329
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
2 alex-w 330
			$display .= "<input type='hidden' name='vers' value='$uid'>\n";
331
			$display .= "Название репозитория (codename): <input type='text' name='repName'><br>\n";
332
			$display .= "Описание репозитория:<br> <textarea name='repInfo'></textarea><br>\n";
11 alex-w 333
                        $display .= "Схема репозитория: ".$rscheme."<br>";
185 diffor 334
			$display .= "Источник репозитория: ".$origin."<br>";
91 alex-w 335
			$display .= "Корневая папка репозитория: ".$rootfolder."<br>";
207 diffor 336
			$display .= "Секции: ".$list."<br>";
213 alex-w 337
			$display .= "По умолчанию: <input type='checkbox' name='default' value='1'>";
167 diffor 338
			$display .= "<br><input type='submit' value='Создать'></form>\n";
2 alex-w 339
                        break;
185 diffor 340
                case '2':
2 alex-w 341
            		// Редактирование репозитория
91 alex-w 342
			$rep =& $db->query("SELECT * FROM repository r JOIN ver2rep l ON l.rep_id=r.rep_id JOIN version v ON v.version_id=l.ver_id JOIN distribution d ON v.dist_id=d.dist_id JOIN root r2 ON r2.root_id=r.root_id WHERE r.rep_id='$uid'");
2 alex-w 343
            		$rep->fetchInto($info, DB_FETCHMODE_ASSOC);
209 alex-w 344
			$dist_vname = $secure->stripStr($info["distname"])." ".$secure->stripStr($info["version"])." &#8220;".$secure->stripStr($info["vname"])."&#8221;";
8 alex-w 345
            		$tlist = "<select name='scheme'>";
346
            		$sq =& $db->query("SELECT * FROM scheme");
2 alex-w 347
            		while ($sq->fetchInto($type, DB_FETCHMODE_ASSOC)) {
8 alex-w 348
            		    if ($type["scheme_id"]==$info["scheme_id"]) {
209 alex-w 349
            			$tlist .= "<option value='".$type["scheme_id"]."' selected>".$secure->stripStr($type["scheme"])."</option>";
2 alex-w 350
            		    } else {
209 alex-w 351
            			$tlist .= "<option value='".$type["scheme_id"]."'>".$secure->stripStr($type["scheme"])."</option>";
2 alex-w 352
            		    }
353
            		}
11 alex-w 354
			$tlist .= "</select>";
185 diffor 355
			$tlist2 = "<select name='origin'>";
356
			$sq =& $db->query("SELECT * FROM origin");
11 alex-w 357
            		while ($sq->fetchInto($type, DB_FETCHMODE_ASSOC)) {
185 diffor 358
            		    if ($type["orig_id"]==$info["orig_id"]) {
209 alex-w 359
            			$tlist2 .= "<option value='".$type["orig_id"]."' selected>".$secure->stripStr($type["origin"])."</option>";
11 alex-w 360
            		    } else {
209 alex-w 361
            			$tlist2 .= "<option value='".$type["orig_id"]."'>".$secure->stripStr($type["origin"])."</option>";
11 alex-w 362
            		    }
363
            		}
364
            		$tlist2 .= "</select>";
2 alex-w 365
            		$list = "";
366
            		$req =& $db->query("SELECT * FROM section s JOIN sect2rep r ON s.sect_id=r.sect_id WHERE r.rep_id='$uid'");
367
            		if ($req->numRows()>0) {
368
            		    while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) {
209 alex-w 369
            			$list .= "<input type='checkbox' name='sect[]' value='".$sect["sect_id"]."' checked><span title='".$secure->stripStr($sect["sectinfo"])."'>".$secure->stripStr($sect["sectname"])."</span> ";
2 alex-w 370
            		    }
371
            		}
372
            		$req =& $db->query("SELECT s.* FROM section s WHERE s.sect_id NOT IN (SELECT sect_id FROM sect2rep WHERE rep_id='$uid')");
373
            		if ($req->numRows()>0) {
374
            		    while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) {
209 alex-w 375
            			$list .= "<input type='checkbox' name='sect[]' value='".$sect["sect_id"]."'><span title='".$secure->stripStr($sect["sectinfo"])."'>".$secure->stripStr($sect["sectname"])."</span> ";
2 alex-w 376
            		    }
377
            		}
91 alex-w 378
			$rootfolder = "<select name='rootFolder'>\n";
379
			$req =& $db->query("SELECT * FROM root");
380
			if ($req->numRows()>0) {
381
				while ($req->fetchInto($rfi, DB_FETCHMODE_ASSOC)) {
382
					if ($rfi["root_id"]==$info["root_id"]) {
209 alex-w 383
						$rootfolder .= "<option value='".$rfi["root_id"]."' selected>".$secure->stripStr($rfi["root_folder"])."</option>";
91 alex-w 384
					} else {
209 alex-w 385
						$rootfolder .= "<option value='".$rfi["root_id"]."'>".$secure->stripStr($rfi["root_folder"])."</option>";
91 alex-w 386
					}
387
				}
388
			}
389
			$rootfolder .= "</select>";
390
 
212 alex-w 391
			if ($info[""]==true){$ch="checked";} else{$ch="";}
207 diffor 392
 
186 diffor 393
			$display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка : ".$info["repname"]."</a></div>";
2 alex-w 394
			$display .= "<form action='./process.php' method='POST'>\n";
167 diffor 395
			$display .= "<input type='hidden' name='mode' value=".$mode.">\n";
396
			$display .= "<input type='hidden' name='act' value=".$act.">\n";
2 alex-w 397
			$display .= "<input type='hidden' name='rep' value='$uid'>\n";
209 alex-w 398
			$display .= "Название репозитория (codename): <input type='text' name='repName' value='".$secure->stripStr($info["repname"])."'><br>\n";
399
			$display .= "Описание репозитория:<br> <textarea name='repInfo'>".$secure->stripStr($info["repdescribe"])."</textarea><br>\n";
8 alex-w 400
                        $display .= "Схема репозитория: ".$tlist."<br>";
185 diffor 401
			$display .= "Источник репозитория: ".$tlist2."<br>";
91 alex-w 402
			$display .= "Корневая папка репозитория: ".$rootfolder."<br>";
207 diffor 403
			$display .= "Секции: ".$list."<br>";
213 alex-w 404
			$display .= "По умолчанию: <input type='checkbox' name='default' value='1' ".$ch.">";
167 diffor 405
			$display .= "<br><input type='submit' value='Править'></form>\n";
406
		break;
185 diffor 407
            	case '3':
2 alex-w 408
            		// Удаление репозитория
38 alex-w 409
			$rep =& $db->query("SELECT * FROM repository r JOIN ver2rep l ON l.rep_id=r.rep_id JOIN version v ON v.version_id=l.ver_id JOIN distribution d ON v.dist_id=d.dist_id WHERE r.rep_id='$uid'");
2 alex-w 410
            		$rep->fetchInto($info, DB_FETCHMODE_ASSOC);
209 alex-w 411
			$dist_vname = $secure->stripStr($info["distname"])." ".$secure->stripStr($info["version"])." &#8220;".$secure->stripStr($info["vname"])."&#8221;";
186 diffor 412
			$display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление : ".$info["repname"]."</a></div>";
2 alex-w 413
			$display .= "<form action='./process.php' method='POST'>\n";
167 diffor 414
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
415
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
2 alex-w 416
			$display .= "<input type='hidden' name='rep' value='$uid'>\n";
167 diffor 417
			$display .= "<input type='submit' value='Удалить'></form>\n";
418
		break;
2 alex-w 419
            }
420
            break;
167 diffor 421
        case '5':
2 alex-w 422
            // Управление разделами
423
            switch ($act) {
424
        	case '0':
425
        		// Список секций
426
        		$req =& $db->query("SELECT * FROM section");
187 diffor 427
			$display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>";
176 diffor 428
        		$display .= "<table><tr><th>Раздел</th><th>Действие</th><th>Используется в</th></tr>\n";
2 alex-w 429
        		while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) {
176 diffor 430
        		    $replist = "";
2 alex-w 431
        		    $sreq =& $db->query("SELECT * FROM distribution d JOIN sect2dist s ON s.dist_id=d.dist_id WHERE s.sect_id='".$sect["sect_id"]."'");
432
        		    while ($sreq->fetchInto($rep, DB_FETCHMODE_ASSOC)) {
209 alex-w 433
        			$replist .= "<em>".$secure->stripStr($rep["distname"])."</em>, ";
2 alex-w 434
        		    }
435
        		    $replist = substr($replist, 0, -2);
209 alex-w 436
        		    $display .= "<tr><td>".$secure->stripStr($sect["sectname"])."</td>";
176 diffor 437
        		    $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$sect["sect_id"]."' class='edit'><img title='Редактировать' src='img/edt.png' width='16' height='16'></a>";
438
        		    $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$sect["sect_id"]."' class='delete'><img title='Удалить' src='img/del.png' width='16' height='16'></a></td>";
439
        		    $display .= "<td>".$replist."</td></tr>";
2 alex-w 440
        		}
176 diffor 441
        		$display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='img/add.png' width='16' height='16'>Добавить секцию</a></p>";
2 alex-w 442
        		break;
443
        	case '1':
444
        		$req =& $db->query("SELECT * FROM distribution");
445
        		while ($req->fetchInto($dist, DB_FETCHMODE_ASSOC)) {
209 alex-w 446
        		    $list .= "<br><input type='checkbox' name='dist' value='".$dist["dist_id"]."'>".$secure->stripStr($dist["distname"])." ";
2 alex-w 447
        		}
167 diffor 448
			$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Создание секции репозитория</div>";
2 alex-w 449
			$display .= "<form action='./process.php' method='POST'>\n";
167 diffor 450
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
451
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
2 alex-w 452
			$display .= "Название секции (codename): <input type='text' name='sectName'><br>\n";
453
			$display .= "Описание секции:<br> <textarea name='sectInfo'></textarea><br>\n";
454
                        $display .= "Используется в дистрибутивах: ".$list;
167 diffor 455
			$display .= "<br><input type='submit' value='Добавить'></form>\n";
2 alex-w 456
        		break;
457
        	case '2':
458
        		$req =& $db->query("SELECT * FROM distribution d JOIN sect2dist s ON s.dist_id=d.dist_id WHERE s.sect_id='$uid'");
459
        		if ($req->numRows()>0) {
460
            		    while ($req->fetchInto($dist, DB_FETCHMODE_ASSOC)) {
209 alex-w 461
        			$list .= "<br><input type='checkbox' name='dist[]' value='".$dist["dist_id"]."' checked>".$secure->stripStr($dist["distname"])." ";
2 alex-w 462
        		    }
463
        		}
464
        		$req =& $db->query("SELECT d.* FROM distribution d WHERE dist_id NOT IN (SELECT dist_id FROM sect2dist WHERE sect_id='$uid')");
465
        		if ($req->numRows()>0) {
466
        		    while ($req->fetchInto($dist, DB_FETCHMODE_ASSOC)) {
209 alex-w 467
        			$list .= "<br><input type='checkbox' name='dist[]' value='".$dist["dist_id"]."'>".$secure->stripStr($dist["distname"])." ";
2 alex-w 468
        		    }
469
        		}
470
        		$req =& $db->query("SELECT * FROM section WHERE sect_id='$uid'");
471
        		$req->fetchInto($sect, DB_FETCHMODE_ASSOC);
167 diffor 472
			$display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Правка секции репозитория</div>";
2 alex-w 473
			$display .= "<form action='./process.php' method='POST'>\n";
167 diffor 474
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
475
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
476
			$display .= "<input type='hidden' name='sectID' value='$uid'>\n";
209 alex-w 477
			$display .= "Название секции (codename): <input type='text' name='sectName' value='".$secure->stripStr($sect["sectname"])."'><br>\n";
478
			$display .= "Описание секции:<br> <textarea name='sectInfo'>".$secure->stripStr($sect["sectinfo"])."</textarea><br>\n";
2 alex-w 479
                        $display .= "Используется в дистрибутивах: ".$list;
167 diffor 480
			$display .= "<br><input type='submit' value='Править'></form>\n";
2 alex-w 481
        		break;
482
        	case '3':
483
        		$req =& $db->query("SELECT * FROM section WHERE sect_id='$uid'");
484
        		$req->fetchInto($sect, DB_FETCHMODE_ASSOC);
209 alex-w 485
			$display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Удаление секции <em>".$secure->stripStr($sect["sectname"])."</em></div>";
2 alex-w 486
			$display .= "<form action='./process.php' method='POST'>\n";
167 diffor 487
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
488
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
489
			$display .= "<input type='hidden' name='sectID' value='$uid'>\n";
490
			$display .= "<br><input type='submit' value='Удалить'></form>\n";
2 alex-w 491
        		break;
492
            }
493
            break;
167 diffor 494
	case '6':
4 alex-w 495
	    // Управление схемами репозиториев
496
	    switch ($act) {
497
		case '0':
498
			// Список схем
499
			$req =& $db->query("SELECT * FROM scheme");
187 diffor 500
			$display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>";
176 diffor 501
        		$display .= "<table><th>Схема</th><th>Действие</th></tr>";
4 alex-w 502
        		while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) {
209 alex-w 503
        			$display .= "<tr><td>".$secure->stripStr($sect["scheme"])."</td>";
176 diffor 504
        			$display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$sect["scheme_id"]."' class='edit'><img title='Редактировать' src='img/edt.png' width='16' height='16'></a>";
505
        			$display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$sect["scheme_id"]."' class='delete'><img title='Удалить' src='img/del.png' width='16' height='16'></a></td></tr>";
4 alex-w 506
        		}
176 diffor 507
        		$display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='img/add.png' width='16' height='16'>Добавить новую схему</a></p>";
4 alex-w 508
			break;
5 alex-w 509
		case '1':
510
			// Добавление новой схемы
165 sivan 511
			$display  = "<div class='modulename'><a href='admin.php?mode=5'>Схемы</a> :: Создание схемы репозитория</div>";
5 alex-w 512
			$display .= "<form action='./process.php' method='POST'>\n";
167 diffor 513
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
514
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
5 alex-w 515
			$display .= "Схема репозитория: <input type='text' name='scheme'><br>\n";
516
			$display .= "<input type='submit' value='Добавить'></form>\n";
517
			break;
518
		case '2':
519
			// Правка существующей схемы
520
			$req =& $db->query("SELECT * FROM scheme WHERE scheme_id='$uid'");
521
			if ($req->numRows()>0) {
176 diffor 522
				$req->fetchInto($scheme, DB_FETCHMODE_ASSOC);
167 diffor 523
				$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Схемы</a> :: Правка схемы репозитория</div>";
5 alex-w 524
				$display .= "<form action='./process.php' method='POST'>\n";
167 diffor 525
				$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
526
				$display .= "<input type='hidden' name='act' value='".$act."'>\n";
209 alex-w 527
				$display .= "<input type='hidden' name='schemeID' value='".$secure->stripStr($scheme["scheme_id"])."'><br>\n";
528
				$display .= "Схема репозитория: <input type='text' name='scheme' value='".$secure->stripStr($scheme["scheme"])."'><br>\n";
5 alex-w 529
				$display .= "<input type='submit' value='Править'></form>\n";
530
			} else {
531
				$display = "Такой схемы репозитория не существует";
532
			}
533
			break;
534
		case '3':
535
			// Удаление существующей схемы
536
			$req =& $db->query("SELECT * FROM scheme WHERE scheme_id='$uid'");
537
			if ($req->numRows()>0) {
538
				$req->fetchInto($scheme, DB_FETCHMODE_ASSOC);
167 diffor 539
				$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Схемы</a> :: Удаление схемы репозитория</div>";
209 alex-w 540
				$display .= "Удаляемая схема: ".$secure->stripStr($scheme["scheme"])."<br>";
5 alex-w 541
				$display .= "<form action='./process.php' method='POST'>\n";
167 diffor 542
				$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
543
				$display .= "<input type='hidden' name='act' value='".$act."'>\n";
544
				$display .= "<input type='hidden' name='schemeID' value='".$scheme["scheme_id"]."'><br>\n";
5 alex-w 545
				$display .= "<input type='submit' value='Удалить'></form>\n";
546
			} else {
547
				$display = "Такой схемы репозитория не существует";
548
			}
549
			break;
4 alex-w 550
	    }
551
	    break;
167 diffor 552
	case '7':
553
	    // Управление типами репозиториев
554
	    switch ($act) {
555
		case '0':
556
			// Список типов репозиториев
557
			$req =& $db->query("SELECT * FROM rtype");
187 diffor 558
			$display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>";
176 diffor 559
			$display .= "<table><tr><th>Тип</th><th>Действие</th></tr>";
167 diffor 560
			if ($req->numRows()>0) {
561
				while ($req->fetchInto($setting, DB_FETCHMODE_ASSOC)) {
209 alex-w 562
					$display .= "<tr><td>".$secure->stripStr($setting["rtype"])."</td>";
176 diffor 563
					$display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$setting["rtype_id"]."' class='edit'><img title='Редактировать' src='img/edt.png' width='16' height='16'></a>";
564
					$display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$setting["rtype_id"]."' class='delete'><img title='Удалить' src='img/del.png' width='16' height='16'></a></td></tr>";
167 diffor 565
				}
566
			}
176 diffor 567
        		$display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='img/add.png' width='16' height='16'>Добавить новый тип репозитория</a></p>";
167 diffor 568
			break;
569
		case '1':
570
			// Добавление нового типа репозитория
571
			$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Создание нового типа репозитория</div>";
572
			$display .= "<form action='./process.php' method='POST'>\n";
573
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
574
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
176 diffor 575
			$display .= "Тип: <input type='text' name='rtype'><br>\n";
167 diffor 576
			$display .= "<input type='submit' value='Добавить'></form>\n";
577
			break;
578
		case '2':
579
			// Правка существующего типа репозитория
580
			$req =& $db->query("SELECT * FROM rtype WHERE rtype_id='$uid'");
581
			if ($req->numRows()>0) {
176 diffor 582
				$req->fetchInto($setting, DB_FETCHMODE_ASSOC);
167 diffor 583
				$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Правка типа репозитория</div>";
584
				$display .= "<form action='./process.php' method='POST'>\n";
585
				$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
586
				$display .= "<input type='hidden' name='act' value='".$act."'>\n";
209 alex-w 587
				$display .= "<input type='hidden' name='rtypeID' value='".$secure->stripStr($setting["rtype_id"])."'><br>\n";
588
				$display .= "Тип: <input type='text' name='rtype' value='".$secure->stripStr($setting["rtype"])."'><br>\n";
167 diffor 589
				$display .= "<input type='submit' value='Править'></form>\n";
590
			} else {
591
				$display = "Такого типа репозитория не существует";
592
			}
593
			break;
594
		case '3':
595
			// Удаление существующего типа репозитория
596
			$req =& $db->query("SELECT * FROM rtype WHERE rtype_id='$uid'");
597
			if ($req->numRows()>0) {
598
				$req->fetchInto($setting, DB_FETCHMODE_ASSOC);
599
				$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Удаление существующего типа репозитория</div>";
209 alex-w 600
				$display .= "Удаляемый тип <em>".$secure->stripStr($setting["rtype"])."</em><br>";
167 diffor 601
				$display .= "<form action='./process.php' method='POST'>\n";
602
				$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
603
				$display .= "<input type='hidden' name='act' value='".$act."'>\n";
604
				$display .= "<input type='hidden' name='rtypeID' value='".$setting["rtype_id"]."'><br>\n";
605
				$display .= "<input type='submit' value='Удалить'></form>\n";
606
			} else {
607
				$display = "Такого типа репозитория не существует";
608
			}
609
			break;
610
	    }
611
	    break;
612
	case '8':
613
	    // Управление корневыми папками репозиториев
614
	    switch ($act) {
615
		case '0':
616
			// Список корневых папок репозиториев
617
			$req =& $db->query("SELECT * FROM root");
187 diffor 618
			$display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>";
176 diffor 619
			$display .= "<table><tr><th>Путь</th><th>Действие</th></tr>\n";
167 diffor 620
			if ($req->numRows()>0) {
176 diffor 621
			    $display .= "<ul>\n";
622
			    while ($req->fetchInto($root, DB_FETCHMODE_ASSOC)) {
209 alex-w 623
				$display .= "<tr><td>".$secure->stripStr($root["root_folder"])."</td>";
176 diffor 624
				$display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$root["root_id"]."' class='edit'><img title='Редактировать' src='img/edt.png' width='16' height='16'></a>";
625
				$display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$root["root_id"]."' class='delete'><img title='Удалить' src='img/del.png' width='16' height='16'></a></td></tr>";
626
			    }
627
				$display .= "</table>\n";
167 diffor 628
			} else {
629
				$display .= "<p>Ни одной корневой папки не найдено.</p>";
630
			}
176 diffor 631
			$display .= "<p><a href='".$admin."?mode=".$mode."&action=1'><img src='img/add.png' width='16' height='16'>Добавить новую корневую папку репозиториев</a></p>";
167 diffor 632
			break;
633
		case '1':
634
			// Добавление новой корневой папки репозиториев
635
			$display  = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Добавление корневой папки</div>";
636
			$display .= "<form action='./process.php' method='post'>\n";
637
			$display .= "<input type='hidden' name='mode' value='".$mode."'>";
638
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
639
			$display .= "Корневая папка: <input type='text' name='rootFolder'><br>\n";
640
			$display .= "<input type='submit' value='Создать'>\n</form>\n";
641
			break;
642
		case '2':
643
			// Редактирование корневой папки репозиториев
644
			$display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Редактирование корневой папки</div>";
645
			$req =& $db->query("SELECT * FROM root WHERE root_id='$uid'");
646
			if ($req->numRows()>0) {
647
				$req->fetchInto($root, DB_FETCHMODE_ASSOC);
648
				$display .= "<form action='./process.php' method='post'>\n";
649
				$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
650
				$display .= "<input type='hidden' name='act' value='".$act."'>\n";
651
				$display .= "<input type='hidden' name='rootID' value='$uid'>\n";
209 alex-w 652
				$display .= "Корневая папка репозитория: <input type='text' name='rootFolder' value='".$secure->stripStr($root["root_folder"])."'><br>\n";
167 diffor 653
				$display .= "<input type='submit' value='Редактировать'>\n</form>\n";
654
			} else {
655
				$display .= "<p>Такой корневой папки репозиториев не существует</p>";
656
			}
657
			break;
658
		case '3':
659
			// Удаление корневой папки репозиториев
660
			$display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Удаление корневой папки</div>";
661
			$req =& $db->query("SELECT * FROM root WHERE root_id='$uid'");
662
			if ($req->numRows()>0) {
663
				$req->fetchInto($root, DB_FETCHMODE_ASSOC);
664
				$display .= "<form action='./process.php' method='post'>\n";
665
				$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
666
				$display .= "<input type='hidden' name='act' value='".$act."'>\n";
667
				$display .= "<input type='hidden' name='rootID' value='$uid'>\n";
209 alex-w 668
				$display .= "Корневая папка репозитория: <input type='text' name='rootFolder' value='".$secure->stripStr($root["root_folder"])."' readonly><br>\n";
167 diffor 669
				$display .= "<input type='submit' value='Удалить'>\n</form>\n";
670
			} else {
671
				$display .= "<p>Такой корневой папки не существует</p>";
672
			}
673
			break;
674
	    }
177 diffor 675
	break;
178 diffor 676
	case '20':
677
	    // Управление опциями Ant
678
	    switch ($act) {
679
		case '0':
680
			// Список опций Ant
681
			$req =& $db->query("SELECT * FROM settings");
187 diffor 682
			$display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>";
178 diffor 683
			$display .= "<table><tr><th>Опция</th><th>Действие</th><th>Значение</th></tr>";
684
			if ($req->numRows()>0) {
685
				while ($req->fetchInto($setting, DB_FETCHMODE_ASSOC)) {
209 alex-w 686
					$display .= "<tr><td>".$secure->stripStr($setting["opt"])."</td>";
178 diffor 687
					$display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$setting["opt_id"]."'><img title='Редактировать' src='img/edt.png' width='16' height='16'></a>";
688
					$display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$setting["opt_id"]."' class='delete'><img title='Удалить' src='img/del.png' width='16' height='16'></a></td>";
209 alex-w 689
					$display .= "<td>".$secure->stripStr($setting["optvalue"])."</td></tr>";
178 diffor 690
				}
691
			}
692
        		$display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='img/add.png' width='16' height='16'>Добавить новую опцию</a></p>";
693
			break;
694
		case '1':
695
			// Добавление новой опции Ant
179 diffor 696
			$display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>";
178 diffor 697
			$display .= "<form action='./process.php' method='POST'>\n";
698
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
699
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
700
			$display .= "Настройка (латиница, без пробелов): <input type='text' name='setoption'><br>\n";
701
			$display .= "Свойство (значение) настройки: <input type='text' name='setvalue'><br>\n";
702
			$display .= "<input type='submit' value='Добавить'></form>\n";
703
			break;
704
		case '2':
705
			// Правка существующей опции Ant
706
			$req =& $db->query("SELECT * FROM settings WHERE opt_id='$uid'");
707
			if ($req->numRows()>0) {
708
				$req->fetchInto($setting, DB_FETCHMODE_ASSOC);
179 diffor 709
				$display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка</a></div>";
178 diffor 710
				$display .= "<form action='./process.php' method='POST'>\n";
711
				$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
712
				$display .= "<input type='hidden' name='act' value='".$act."'>\n";
209 alex-w 713
				$display .= "<input type='hidden' name='optID' value='".$secure->stripStr($setting["opt_id"])."'><br>\n";
714
				$display .= "Настройка: <input type='text' name='setoption' value='".$secure->stripStr($setting["opt"])."' readonly><br>\n";
178 diffor 715
				if ($setting["opt"]=="interface") {
716
					$sq =& $db->query("SELECT * FROM interfaces");
717
					$setvalue = "<select name='setvalue'>";
718
					while ($sq->fetchInto($if, DB_FETCHMODE_ASSOC)) {
719
						if ($if["interface"]==$setting["optvalue"]) {
209 alex-w 720
							$setvalue .= "<option value='".$secure->stripStr($if["interface"])."' selected>".$secure->stripStr($if["interfaceinfo"])."</option>\n";
178 diffor 721
						} else {
209 alex-w 722
							$setvalue .= "<option value='".$secure->stripStr($if["interface"])."'>".$secure->stripStr($if["interfaceinfo"])."</option>\n";
178 diffor 723
						}
724
					}
725
					$setvalue .= "</select>";
726
					$display .= "Свойство: ".$setvalue."<br>\n";
727
				} else {
209 alex-w 728
					$display .= "Свойство: <input type='text' name='setvalue' value='".$secure->stripStr($setting["optvalue"])."'><br>\n";
178 diffor 729
				}
730
				$display .= "<input type='submit' value='Править'></form>\n";
731
			} else {
732
				$display = "Такой опции не существует";
733
			}
734
			break;
735
		case '3':
736
			// Удаление существующей опции Ant
737
			$req =& $db->query("SELECT * FROM settings WHERE opt_id='$uid'");
738
			if ($req->numRows()>0) {
739
				$req->fetchInto($setting, DB_FETCHMODE_ASSOC);
179 diffor 740
				$display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление</a></div>";
209 alex-w 741
				$display .= "Удаляемая опция <em>".$secure->stripStr($setting["opt"])."</em> с свойством <em>".$secure->stripStr($setting["optvalue"])."</em><br>";
178 diffor 742
				$display .= "<form action='./process.php' method='POST'>\n";
743
				$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
744
				$display .= "<input type='hidden' name='act' value='".$act."'>\n";
745
				$display .= "<input type='hidden' name='optID' value='".$setting["opt_id"]."'><br>\n";
746
				$display .= "<input type='submit' value='Удалить'></form>\n";
747
			} else {
748
				$display = "Такой опции не существует";
749
			}
750
			break;
751
		}
752
	    break;
177 diffor 753
	case '21':
754
	    // Управление интерфейсами
755
	    switch($act) {
756
		case '0':
757
			// Список интерфейсов
758
			$req =& $db->query("SELECT * FROM interfaces");
187 diffor 759
			$display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>";
177 diffor 760
			$display .= "<table><tr><th>Интерфейс</th><th>Действие</th></tr>";
761
			if ($req->numRows()>0) {
762
			    while ($req->fetchInto($if, DB_FETCHMODE_ASSOC)) {
209 alex-w 763
				$display .= "<tr><td>".$secure->stripStr($if["interfaceinfo"])." (".$secure->stripStr($if["interface"]).") </td>";
177 diffor 764
				$display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$if["if_id"]."' class='edit'><img title='Редактировать' src='img/edt.png' width='16' height='16'></a>";
765
				$display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$if["if_id"]."' class='delete'><img title='Удалить' src='img/del.png' width='16' height='16'></a></td></tr>";
766
			    }
767
			}
768
			$display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='img/add.png' width='16' height='16'>Добавить новый интерфейс</a></p>";
769
			break;
770
		case '1':
771
			// Добавление нового интерфейса
179 diffor 772
			$display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>";
177 diffor 773
			$display .= "<form action='./process.php' method='POST'>\n";
774
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
775
			$display .= "<input type='hidden' name='act' value='".$act."'>\n";
776
			$display .= "Интерфейс (имя файла): <input type='text' name='ifname'><br>\n";
777
			$display .= "Интерфейс (название): <input type='text' name='ifinfo'><br>\n";
778
			$display .= "<input type='submit' value='Добавить интерфейс'></form>\n";
779
			break;
780
		case '2':
781
			// Правка интерфейса
782
			$req =& $db->query("SELECT * FROM interfaces WHERE if_id='$uid'");
179 diffor 783
			$display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка</a></div>";
177 diffor 784
			if ($req->numRows()>0) {
785
				$req->fetchInto($if, DB_FETCHMODE_ASSOC);
786
				$display .= "<form action='./process.php' method='POST'>";
787
				$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
788
				$display .= "<input type='hidden' name='act' value='".$act."'>\n";
789
				$display .= "<input type='hidden' name='if' value='$uid'>\n";
209 alex-w 790
				$display .= "Интерфейс (имя файла): <input type='text' name='ifname' value='".$secure->stripStr($if["interface"])."'><br>\n";
791
				$display .= "Интерфейс (название): <input type='text' name='ifinfo' value='".$secure->stripStr($if["interfaceinfo"])."'><br>\n";
177 diffor 792
				$display .= "<input type='submit' value='Отредактировать'></form>\n";
793
			} else {
794
				$display .= "<p>Такого интерфейса не существует</p>";
795
			}
796
			break;
797
		case '3':
798
			// Удаление интерфейса
799
			$req =& $db->query("SELECT * FROM interfaces WHERE if_id='$uid'");
179 diffor 800
			$display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление</a></div>";
177 diffor 801
			if ($req->numRows()>0) {
802
				$req->fetchInto($if, DB_FETCHMODE_ASSOC);
803
				$display .= "<form action='./process.php' method='POST'>";
804
				$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
805
				$display .= "<input type='hidden' name='act' value='".$act."'>\n";
806
				$display .= "<input type='hidden' name='if' value='$uid'>\n";
209 alex-w 807
				$display .= "Интерфейс (имя файла): <input type='text' name='ifname' value='".$secure->stripStr($if["interface"])."' readonly><br>\n";
808
				$display .= "Интерфейс (название): <input type='text' name='ifinfo' value='".$secure->stripStr($if["interfaceinfo"])."' readonly><br>\n";
177 diffor 809
				$display .= "<input type='submit' value='Удалить'></form>\n";
810
			}
811
			break;
812
	    }
813
	break;
179 diffor 814
	case '22':
815
	    // Управление паролем
816
	    switch($act) {
817
		case '0':
16 alex-w 818
			// Смена пароля входа
187 diffor 819
			$display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>";
16 alex-w 820
			$display .= "<form action='./process.php' method='POST'>\n";
179 diffor 821
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
822
			$display .= "<input type='hidden' name='mode' value='".$mode."'>\n";
16 alex-w 823
			$display .= "Старый пароль: <input type='password' name='oldPW'><br>\n";
179 diffor 824
			$display .= "Новый пароль: <input type='password' name='newPW1'><br>\n";
825
			$display .= "Новый пароль (еще раз): <input type='password' name='newPW2'><br>\n";
16 alex-w 826
			$display .= "<input type='submit' value='Сменить пароль'></form>\n";
827
			break;
167 diffor 828
 
7 alex-w 829
	    break;
179 diffor 830
	    }
831
	break;
2 alex-w 832
}
833
 
39 alex-w 834
 
161 diffor 835
$display .= "</div></div>";
836
 
131 alex-w 837
$smarty->assign('feedaddr',$_SERVER["HTTP_HOST"].dirname($_SERVER["PHP_SELF"]));
17 alex-w 838
$smarty->assign('error',$error);
161 diffor 839
$smarty->assign('header',$header);
840
$smarty->assign('login',$login);
841
$smarty->assign('menu',$menu);
2 alex-w 842
$smarty->assign('display',$display);
132 alex-w 843
$smarty->assign('antversion',$core->getSetting('version',$db));
844
$smarty->assign('title',$core->getSetting('codename',$db));
80 alex-w 845
$smarty->assign('style',$core->getCSSList($db));
2 alex-w 846
$smarty->display('admin.tpl');
847
 
848
?>