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