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