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