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