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