Хранилища Subversion ant

Редакция

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

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