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