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