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