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