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