Редакция 288 | Только различия | Учитывать пробелы | Содержимое файла | Авторство | Последнее изменение | Открыть журнал | RSS
Редакция 288 | Редакция 458 | ||
---|---|---|---|
1 | <?php
|
1 | <?php
|
2 | 2 | ||
3 | /**
|
3 | /**
|
4 | * Project: Ant: sources.list generator
|
4 | * Project: Ant: sources.list generator
|
5 | * File: admin.php
|
5 | * File: admin.php
|
6 | *
|
6 | *
|
7 | * This application is free software; you can redistribute it and/or
|
7 | * This application is free software; you can redistribute it and/or
|
8 | * modify it under the terms of the GNU Lesser General Public
|
8 | * modify it under the terms of the GNU Lesser General Public
|
9 | * License as published by the Free Software Foundation; either
|
9 | * License as published by the Free Software Foundation; either
|
10 | * version 2.1 of the License, or (at your option) any later version.
|
10 | * version 2.1 of the License, or (at your option) any later version.
|
11 | *
|
11 | *
|
12 | * This application is distributed in the hope that it will be useful,
|
12 | * This application is distributed in the hope that it will be useful,
|
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
15 | * Lesser General Public License for more details.
|
15 | * Lesser General Public License for more details.
|
16 | *
|
16 | *
|
17 | * You should have received a copy of the GNU Lesser General Public
|
17 | * You should have received a copy of the GNU Lesser General Public
|
18 | * License along with this library; if not, write to the Free Software
|
18 | * License along with this library; if not, write to the Free Software
|
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
20 | *
|
20 | *
|
21 | */
|
21 | */
|
22 | 22 | ||
23 | 23 | ||
24 | require_once dirname(__FILE__)."/sign-valid.php"; |
24 | require_once dirname(__FILE__)."/sign-valid.php"; |
25 | 25 | ||
26 | $mode = $secure->wrapInt($_GET["mode"]); |
26 | $mode = $secure->wrapInt($_GET["mode"]); |
27 | $act = $secure->wrapInt($_GET["action"]); |
27 | $act = $secure->wrapInt($_GET["action"]); |
28 | $uid = $secure->wrapInt($_GET["uid"]); |
28 | $uid = $secure->wrapInt($_GET["uid"]); |
29 | $err = $secure->wrapInt($_GET["error"]); |
29 | $err = $secure->wrapInt($_GET["error"]); |
30 | 30 | ||
31 | // Admin file/interface
|
31 | // Admin file/interface
|
32 | $admin = "./admin.php"; |
32 | $admin = "./admin.php"; |
33 | $imgdir = "./themes/icons/".$theme->getIconSetName($core,$db); |
33 | $imgdir = "./themes/icons/".$theme->getIconSetName($core,$db); |
34 | 34 | ||
35 | switch ($err) { |
35 | switch ($err) { |
36 | case '1': |
36 | case '1': |
37 | $error = _("Password error: the password is incorrect!"); |
37 | $error = _("Password error: the password is incorrect!"); |
38 | break; |
38 | break; |
39 | case '2': |
39 | case '2': |
40 | $error = _("Password error: new passwords do not match!"); |
40 | $error = _("Password error: new passwords do not match!"); |
41 | break; |
41 | break; |
42 | }
|
42 | }
|
43 | 43 | ||
44 | $header = "<div id='head'><div class='title'>".$core->getSetting('codename',$db)." Admin Panel</div><div class='smalltitle'>version: ".$core->getSetting('version',$db)."</div></div>"; |
44 | $header = "<div id='head'><div class='title'>".$core->getSetting('codename',$db)." Admin Panel</div><div class='smalltitle'>version: ".$core->getSetting('version',$db)."</div></div>"; |
45 | 45 | ||
46 | $login = "<div id='login'>"._("You are logged as").": <b>".$login."</b> <a class='dashed' href='./signout.php' style='color:red;'>["._("exit")."]</a></div>"; |
46 | $login = "<div id='login'>"._("You are logged as").": <b>".$login."</b> <a class='dashed' href='./signout.php' style='color:red;'>["._("exit")."]</a></div>"; |
47 | 47 | ||
48 | 48 | ||
49 | $menu_title = array ( _("Management"), _("References"), _("Preferences") ); |
49 | $menu_title = array ( _("Management"), _("References"), _("Preferences") ); |
50 | $menu_item = array ( |
50 | $menu_item = array ( |
51 | 1 => array ( "title" => $menu_title[1], "item" => _("Distributives") ), |
51 | 1 => array ( "title" => $menu_title[1], "item" => _("Distributives") ), |
52 | 2 => array ( "title" => $menu_title[1], "item" => _("Versions") ), |
52 | 2 => array ( "title" => $menu_title[1], "item" => _("Versions") ), |
53 | 3 => array ( "title" => $menu_title[1], "item" => _("Sources") ), |
53 | 3 => array ( "title" => $menu_title[1], "item" => _("Sources") ), |
54 | 4 => array ( "title" => $menu_title[0], "item" => _("Repositories") ), |
54 | 4 => array ( "title" => $menu_title[0], "item" => _("Repositories") ), |
55 | 5 => array ( "title" => $menu_title[1], "item" => _("Sections") ), |
55 | 5 => array ( "title" => $menu_title[1], "item" => _("Sections") ), |
56 | 6 => array ( "title" => $menu_title[1], "item" => _("Schemes") ), |
56 | 6 => array ( "title" => $menu_title[1], "item" => _("Schemes") ), |
57 | 7 => array ( "title" => $menu_title[1], "item" => _("Types") ), |
57 | 7 => array ( "title" => $menu_title[1], "item" => _("Types") ), |
58 | 9 => array ( "title" => $menu_title[1], "item" => _("Mirrors") ), |
58 | 9 => array ( "title" => $menu_title[1], "item" => _("Mirrors") ), |
59 | 20 => array ( "title" => $menu_title[2], "item" => _("Options") ), |
59 | 20 => array ( "title" => $menu_title[2], "item" => _("Options") ), |
60 | 21 => array ( "title" => $menu_title[2], "item" => _("Interfaces") ), |
60 | 21 => array ( "title" => $menu_title[2], "item" => _("Interfaces") ), |
61 | 22 => array ( "title" => $menu_title[2], "item" => _("Password") ), |
61 | 22 => array ( "title" => $menu_title[2], "item" => _("Password") ), |
62 | 23 => array ( "title" => $menu_title[2], "item" => _("Theme") ), |
62 | 23 => array ( "title" => $menu_title[2], "item" => _("Theme") ), |
63 | ); |
63 | ); |
64 | 64 | ||
65 | $menu = " |
65 | $menu = " |
66 | <div id='cont'>
|
66 | <div id='cont'>
|
67 | <div id='menu'>
|
67 | <div id='menu'>
|
68 | <div class='menutitle'>".$menu_title[0].":</div> |
68 | <div class='menutitle'>".$menu_title[0].":</div> |
69 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=4'>".$menu_item[4]["item"]."</a></div> |
69 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=4'>".$menu_item[4]["item"]."</a></div> |
70 | <div class='menutitle'>".$menu_title[1].":</div> |
70 | <div class='menutitle'>".$menu_title[1].":</div> |
71 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=9'>".$menu_item[9]["item"]."</a></div> |
71 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=9'>".$menu_item[9]["item"]."</a></div> |
72 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=1'>".$menu_item[1]["item"]."</a></div> |
72 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=1'>".$menu_item[1]["item"]."</a></div> |
73 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=2'>".$menu_item[2]["item"]."</a></div> |
73 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=2'>".$menu_item[2]["item"]."</a></div> |
74 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=3'>".$menu_item[3]["item"]."</a></div> |
74 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=3'>".$menu_item[3]["item"]."</a></div> |
75 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=5'>".$menu_item[5]["item"]."</a></div> |
75 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=5'>".$menu_item[5]["item"]."</a></div> |
76 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=6'>".$menu_item[6]["item"]."</a></div> |
76 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=6'>".$menu_item[6]["item"]."</a></div> |
77 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=7'>".$menu_item[7]["item"]."</a></div> |
77 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=7'>".$menu_item[7]["item"]."</a></div> |
78 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=8'>".$menu_item[8]["item"]."</a></div> |
78 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=8'>".$menu_item[8]["item"]."</a></div> |
79 | <div class='menutitle'>".$menu_title[2].":</div> |
79 | <div class='menutitle'>".$menu_title[2].":</div> |
80 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=20'>".$menu_item[20]["item"]."</a></div> |
80 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=20'>".$menu_item[20]["item"]."</a></div> |
81 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=21'>".$menu_item[21]["item"]."</a></div> |
81 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=21'>".$menu_item[21]["item"]."</a></div> |
82 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=22'>".$menu_item[22]["item"]."</a></div> |
82 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=22'>".$menu_item[22]["item"]."</a></div> |
83 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=23'>".$menu_item[23]["item"]."</a></div> |
83 | <div class='menuitem'><a class='dashed' href='".$admin."?mode=23'>".$menu_item[23]["item"]."</a></div> |
84 | </div>
|
84 | </div>
|
85 | <div id='main'>
|
85 | <div id='main'>
|
86 | "; |
86 | "; |
87 | 87 | ||
88 | switch ($mode) { |
88 | switch ($mode) { |
89 | case '1': |
89 | case '1': |
90 | // Работа с дистрибутивами
|
90 | // Работа с дистрибутивами
|
91 | switch ($act) { |
91 | switch ($act) { |
92 | case '0': |
92 | case '0': |
93 | // Список дистрибутивов
|
93 | // Список дистрибутивов
|
94 | $dist =& $db->query("SELECT * FROM distribution"); |
94 | $dist =& $db->query("SELECT * FROM distribution"); |
95 | if ($dist->numRows()>0) { |
95 | if ($dist->numRows()>0) { |
96 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
96 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
97 | $display .= "<table><tr><th>"._("Distributive")."</th><th>"._("Action")."</th><th>"._("Versions")."</th></tr>"; |
97 | $display .= "<table><tr><th>"._("Distributive")."</th><th>"._("Action")."</th><th>"._("Versions")."</th></tr>"; |
98 | while ($dist->fetchInto($info, DB_FETCHMODE_ASSOC)) { |
98 | while ($dist->fetchInto($info, DB_FETCHMODE_ASSOC)) { |
99 | $verlist = ""; |
99 | $verlist = ""; |
100 | $sreq =& $db->query("SELECT * FROM version WHERE dist_id='".$info["dist_id"]."'"); |
100 | $sreq =& $db->query("SELECT * FROM version WHERE dist_id='".$info["dist_id"]."'"); |
101 | while ($sreq->fetchInto($sinfo, DB_FETCHMODE_ASSOC)) { |
101 | while ($sreq->fetchInto($sinfo, DB_FETCHMODE_ASSOC)) { |
102 | $verlist .= "<em>".$secure->stripStr($sinfo["vname"])."</em>, "; |
102 | $verlist .= "<em>".$secure->stripStr($sinfo["vname"])."</em>, "; |
103 | }
|
103 | }
|
104 | $verlist = substr($verlist, 0, -2); |
104 | $verlist = substr($verlist, 0, -2); |
105 | $display .= "<tr><td>".$secure->stripStr($info['distname'])."</td>"; |
105 | $display .= "<tr><td>".$secure->stripStr($info['distname'])."</td>"; |
106 | $display .= "<td><a href=".$admin."?mode=".$mode."&action=2&uid=".$info["dist_id"]."><img title='"._("Edit")."' src='$imgdir/edit.png' width='16' height='16'></a>"; |
106 | $display .= "<td><a href=".$admin."?mode=".$mode."&action=2&uid=".$info["dist_id"]."><img title='"._("Edit")."' src='$imgdir/edit.png' width='16' height='16'></a>"; |
107 | $display .= "<a href=".$admin."?mode=".$mode."&action=3&uid=".$info["dist_id"]."><img title='"._("Remove")."' src='$imgdir/delete.png' width='16' height='16'></a></td>"; |
107 | $display .= "<a href=".$admin."?mode=".$mode."&action=3&uid=".$info["dist_id"]."><img title='"._("Remove")."' src='$imgdir/delete.png' width='16' height='16'></a></td>"; |
108 | $display .= "<td>".$verlist."</td></tr>"; |
108 | $display .= "<td>".$verlist."</td></tr>"; |
109 | }
|
109 | }
|
110 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>"._("Add a new distro")."</a></p>"; |
110 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>"._("Add a new distro")."</a></p>"; |
111 | }
|
111 | }
|
112 | break; |
112 | break; |
113 | case '1': |
113 | case '1': |
114 | // Добавление нового дистрибутива
|
114 | // Добавление нового дистрибутива
|
115 | $dtype =& $db->query("SELECT * FROM dtype"); |
115 | $dtype =& $db->query("SELECT * FROM dtype"); |
116 | $type = "<select name='distType'>"; |
116 | $type = "<select name='distType'>"; |
117 | while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) { |
117 | while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) { |
118 | $type .= "<option value='".$dtinfo["type_id"]."'>".$secure->stripStr($dtinfo["type"])."</option>"; |
118 | $type .= "<option value='".$dtinfo["type_id"]."'>".$secure->stripStr($dtinfo["type"])."</option>"; |
119 | }
|
119 | }
|
120 | $type .= "</select>\n"; |
120 | $type .= "</select>\n"; |
121 | $display = "<div class='modulename'><a href='admin.php?mode=1'>"._("Distributives")."</a> :: "._("Adding a new apt-distribution")."</div>"; |
121 | $display = "<div class='modulename'><a href='admin.php?mode=1'>"._("Distributives")."</a> :: "._("Adding a new apt-distribution")."</div>"; |
122 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
122 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
123 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
123 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
124 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
124 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
125 | $display .= _("Name of distro").": <input type='text' name='distName'><br>\n"; |
125 | $display .= _("Name of distro").": <input type='text' name='distName'><br>\n"; |
126 | $display .= _("User-Agent's string").": <input type='text' name='distUA'><br>\n"; |
126 | $display .= _("User-Agent's string").": <input type='text' name='distUA'><br>\n"; |
127 | $display .= _("Type of distro").": ".$type."<br>"; |
127 | $display .= _("Type of distro").": ".$type."<br>"; |
128 | $display .= _("Logo of distro (Transparent PNG)").": <input type='file' name='distLOGO'><br>"; |
128 | $display .= _("Logo of distro (Transparent PNG)").": <input type='file' name='distLOGO'><br>"; |
129 | $display .= "<input type='submit' value='"._("Create")."'></form>\n"; |
129 | $display .= "<input type='submit' value='"._("Create")."'></form>\n"; |
130 | break; |
130 | break; |
131 | case '2': |
131 | case '2': |
132 | // Правка существующего дистрибутива
|
132 | // Правка существующего дистрибутива
|
133 | $dist =& $db->query("SELECT * FROM distribution WHERE dist_id='$uid'"); |
133 | $dist =& $db->query("SELECT * FROM distribution WHERE dist_id='$uid'"); |
134 | $dist->fetchInto($info, DB_FETCHMODE_ASSOC); |
134 | $dist->fetchInto($info, DB_FETCHMODE_ASSOC); |
135 | $dtype =& $db->query("SELECT * FROM dtype"); |
135 | $dtype =& $db->query("SELECT * FROM dtype"); |
136 | $type = "<select name='distType'>"; |
136 | $type = "<select name='distType'>"; |
137 | while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) { |
137 | while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) { |
138 | if ($info["disttype"]==$dtinfo["type_id"]) { |
138 | if ($info["disttype"]==$dtinfo["type_id"]) { |
139 | $type .= "<option value='".$dtinfo["type_id"]."' selected>".$secure->stripStr($dtinfo["type"])."</option>"; |
139 | $type .= "<option value='".$dtinfo["type_id"]."' selected>".$secure->stripStr($dtinfo["type"])."</option>"; |
140 | } else { |
140 | } else { |
141 | $type .= "<option value='".$dtinfo["type_id"]."'>".$secure->stripStr($dtinfo["type"])."</option>"; |
141 | $type .= "<option value='".$dtinfo["type_id"]."'>".$secure->stripStr($dtinfo["type"])."</option>"; |
142 | }
|
142 | }
|
143 | }
|
143 | }
|
144 | $type .= "</select>\n"; |
144 | $type .= "</select>\n"; |
145 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>"._("Distributives")."</a> :: "._("Editing apt-distribution")." <em class='".$secure->stripStr($info["distua"])."-em'>".$secure->stripStr($info["distname"])."</em></div>"; |
145 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>"._("Distributives")."</a> :: "._("Editing apt-distribution")." <em class='".$secure->stripStr($info["distua"])."-em'>".$secure->stripStr($info["distname"])."</em></div>"; |
146 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
146 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
147 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
147 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
148 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
148 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
149 | $display .= "<input type='hidden' name='distID' value='$uid'>\n"; |
149 | $display .= "<input type='hidden' name='distID' value='$uid'>\n"; |
150 | $display .= _("Name of distro").": <input type='text' name='distName' value='".$secure->stripStr($info["distname"])."'><br>\n"; |
150 | $display .= _("Name of distro").": <input type='text' name='distName' value='".$secure->stripStr($info["distname"])."'><br>\n"; |
151 | $display .= _("User-Agent's string").": <input type='text' name='distUA' value='".$secure->stripStr($info["distua"])."'><br>\n"; |
151 | $display .= _("User-Agent's string").": <input type='text' name='distUA' value='".$secure->stripStr($info["distua"])."'><br>\n"; |
152 | $display .= _("Type of distro").": ".$type."<br>"; |
152 | $display .= _("Type of distro").": ".$type."<br>"; |
153 | $display .= _("Logo of distro (Transparent PNG)").": <input type='file' name='distLOGO'><br>"; |
153 | $display .= _("Logo of distro (Transparent PNG)").": <input type='file' name='distLOGO'><br>"; |
154 | $display .= "<input type='submit' value='"._("Edit")."'></form>\n"; |
154 | $display .= "<input type='submit' value='"._("Edit")."'></form>\n"; |
155 | break; |
155 | break; |
156 | case '3': |
156 | case '3': |
157 | // Удаление существующего дистрибутива
|
157 | // Удаление существующего дистрибутива
|
158 | $dist =& $db->query("SELECT * FROM distribution WHERE dist_id='$uid'"); |
158 | $dist =& $db->query("SELECT * FROM distribution WHERE dist_id='$uid'"); |
159 | $dist->fetchInto($info, DB_FETCHMODE_ASSOC); |
159 | $dist->fetchInto($info, DB_FETCHMODE_ASSOC); |
160 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>"._("Distributives")."</a> :: "._("Removal of apt-distribution")." <em class='".$secure->stripStr($info["distua"])."-em'>".$secure->stripStr($info["distname"])."</em></div>"; |
160 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>"._("Distributives")."</a> :: "._("Removal of apt-distribution")." <em class='".$secure->stripStr($info["distua"])."-em'>".$secure->stripStr($info["distname"])."</em></div>"; |
161 | $display .= "<form action='./process.php' method='POST'>\n"; |
161 | $display .= "<form action='./process.php' method='POST'>\n"; |
162 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
162 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
163 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
163 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
164 | $display .= "<input type='hidden' name='distID' value='$uid'>\n"; |
164 | $display .= "<input type='hidden' name='distID' value='$uid'>\n"; |
165 | $display .= "<input type='hidden' name='distUA' value='".$secure->stripStr($info["distua"])."'>\n"; |
165 | $display .= "<input type='hidden' name='distUA' value='".$secure->stripStr($info["distua"])."'>\n"; |
166 | $display .= "<input type='submit' value='"._("Remove")."'></form>\n"; |
166 | $display .= "<input type='submit' value='"._("Remove")."'></form>\n"; |
167 | break; |
167 | break; |
168 | }
|
168 | }
|
169 | break; |
169 | break; |
170 | case '2': |
170 | case '2': |
171 | // Работа с версиями дистрибутивов
|
171 | // Работа с версиями дистрибутивов
|
172 | switch ($act) { |
172 | switch ($act) { |
173 | case '0': |
173 | case '0': |
174 | // Все версии имеющихся дистрибутивов
|
174 | // Все версии имеющихся дистрибутивов
|
175 | $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"); |
175 | $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"); |
176 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
176 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
177 | $display .= "<table><tr><th>".("Version")."</th><th>"._("Action")."</th></tr>\n"; |
177 | $display .= "<table><tr><th>".("Version")."</th><th>"._("Action")."</th></tr>\n"; |
178 | while ($dist->fetchInto($info, DB_FETCHMODE_ASSOC)) { |
178 | while ($dist->fetchInto($info, DB_FETCHMODE_ASSOC)) { |
179 | $display .= "<tr><td>".$secure->stripStr($info["distname"])." ".$secure->stripStr($info["version"])." “".$secure->stripStr($info["vname"])."”</td>\n"; |
179 | $display .= "<tr><td>".$secure->stripStr($info["distname"])." ".$secure->stripStr($info["version"])." “".$secure->stripStr($info["vname"])."”</td>\n"; |
180 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$info["version_id"]."' class='edit'><img title='"._("Edit")."' src='$imgdir/edit.png' width='16' height='16'></a>"; |
180 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$info["version_id"]."' class='edit'><img title='"._("Edit")."' src='$imgdir/edit.png' width='16' height='16'></a>"; |
181 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$info["version_id"]."' class='delete'><img title='"._("Remove")."' src='$imgdir/delete.png' width='16' height='16'></a></td></tr>\n"; |
181 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$info["version_id"]."' class='delete'><img title='"._("Remove")."' src='$imgdir/delete.png' width='16' height='16'></a></td></tr>\n"; |
182 | }
|
182 | }
|
183 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>"._("Add a new version of distro")."</a></p>\n"; |
183 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>"._("Add a new version of distro")."</a></p>\n"; |
184 | break; |
184 | break; |
185 | case '1': |
185 | case '1': |
186 | // Добавление новой версии дистрибутива
|
186 | // Добавление новой версии дистрибутива
|
187 | $dtype =& $db->query("SELECT * FROM distribution"); |
187 | $dtype =& $db->query("SELECT * FROM distribution"); |
188 | $type = "<select name='distName'>"; |
188 | $type = "<select name='distName'>"; |
189 | while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) { |
189 | while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) { |
190 | $type .= "<option value='".$dtinfo["dist_id"]."'>".$secure->stripStr($dtinfo["distname"])."</option>"; |
190 | $type .= "<option value='".$dtinfo["dist_id"]."'>".$secure->stripStr($dtinfo["distname"])."</option>"; |
191 | }
|
191 | }
|
192 | $type .= "</select>\n"; |
192 | $type .= "</select>\n"; |
193 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>"._("Versions")."</a> :: "._("Editiong version of distribution")."</div>"; |
193 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>"._("Versions")."</a> :: "._("Editiong version of distribution")."</div>"; |
194 | $display .= "<form action='./process.php' method='POST'>\n"; |
194 | $display .= "<form action='./process.php' method='POST'>\n"; |
195 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
195 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
196 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
196 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
197 | $display .= _("Version number").": <input type='text' name='versNum'><br>\n"; |
197 | $display .= _("Version number").": <input type='text' name='versNum'><br>\n"; |
198 | $display .= _("Version name").": <input type='text' name='versNam'><br>\n"; |
198 | $display .= _("Version name").": <input type='text' name='versNam'><br>\n"; |
199 | $display .= _("Version codename").": <input type='text' name='versCN'><br>\n"; |
199 | $display .= _("Version codename").": <input type='text' name='versCN'><br>\n"; |
200 | $display .= _("Distribution").": ".$type."<br>"; |
200 | $display .= _("Distribution").": ".$type."<br>"; |
201 | $display .= "<input type='submit' value='"._("Create")."'></form>\n"; |
201 | $display .= "<input type='submit' value='"._("Create")."'></form>\n"; |
202 | break; |
202 | break; |
203 | case '2': |
203 | case '2': |
204 | // Правка имеющейся версии дистрибутива
|
204 | // Правка имеющейся версии дистрибутива
|
205 | $vers =& $db->query("SELECT * FROM version v JOIN distribution d ON d.dist_id=v.dist_id WHERE version_id='$uid'"); |
205 | $vers =& $db->query("SELECT * FROM version v JOIN distribution d ON d.dist_id=v.dist_id WHERE version_id='$uid'"); |
206 | $vers->fetchInto($info, DB_FETCHMODE_ASSOC); |
206 | $vers->fetchInto($info, DB_FETCHMODE_ASSOC); |
207 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>"._("Versions")."</a> :: "._("Adding a new version of distribution")." <em>".$secure->stripStr($info["distname"])."</em></div>"; |
207 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>"._("Versions")."</a> :: "._("Adding a new version of distribution")." <em>".$secure->stripStr($info["distname"])."</em></div>"; |
208 | $display .= "<form action='./process.php' method='POST'>\n"; |
208 | $display .= "<form action='./process.php' method='POST'>\n"; |
209 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
209 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
210 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
210 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
211 | $display .= "<input type='hidden' name='versID' value='$uid'>\n"; |
211 | $display .= "<input type='hidden' name='versID' value='$uid'>\n"; |
212 | $display .= _("Version number").": <input type='text' name='versNum' value='".$secure->stripStr($info["version"])."'><br>\n"; |
212 | $display .= _("Version number").": <input type='text' name='versNum' value='".$secure->stripStr($info["version"])."'><br>\n"; |
213 | $display .= _("Version name").": <input type='text' name='versNam' value='".$secure->stripStr($info["vname"])."'><br>\n"; |
213 | $display .= _("Version name").": <input type='text' name='versNam' value='".$secure->stripStr($info["vname"])."'><br>\n"; |
214 | $display .= _("Version codename").": <input type='text' name='versCN' value='".$secure->stripStr($info["vcodename"])."'><br>\n"; |
214 | $display .= _("Version codename").": <input type='text' name='versCN' value='".$secure->stripStr($info["vcodename"])."'><br>\n"; |
215 | $display .= "<input type='submit' value='"._("Edit")."'></form>\n"; |
215 | $display .= "<input type='submit' value='"._("Edit")."'></form>\n"; |
216 | break; |
216 | break; |
217 | case '3': |
217 | case '3': |
218 | // Удаление существующей версии дистрибутива
|
218 | // Удаление существующей версии дистрибутива
|
219 | $dist =& $db->query("SELECT * FROM version v JOIN distribution d ON v.dist_id=d.dist_id WHERE v.version_id='$uid'"); |
219 | $dist =& $db->query("SELECT * FROM version v JOIN distribution d ON v.dist_id=d.dist_id WHERE v.version_id='$uid'"); |
220 | $dist->fetchInto($info, DB_FETCHMODE_ASSOC); |
220 | $dist->fetchInto($info, DB_FETCHMODE_ASSOC); |
221 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>"._("Versions")."</a> :: "._("Removal version of distribution")." ".$secure->stripStr($info["version"])." (“".$secure->stripStr($info["vname"])."”) <em>".$secure->stripStr($info["distname"])."</em></div>"; |
221 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>"._("Versions")."</a> :: "._("Removal version of distribution")." ".$secure->stripStr($info["version"])." (“".$secure->stripStr($info["vname"])."”) <em>".$secure->stripStr($info["distname"])."</em></div>"; |
222 | $display .= "<form action='./process.php' method='POST'>\n"; |
222 | $display .= "<form action='./process.php' method='POST'>\n"; |
223 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
223 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
224 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
224 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
225 | $display .= "<input type='hidden' name='versID' value='$uid'>\n"; |
225 | $display .= "<input type='hidden' name='versID' value='$uid'>\n"; |
226 | $display .= "<input type='submit' value='"._("Remove")."'></form>\n"; |
226 | $display .= "<input type='submit' value='"._("Remove")."'></form>\n"; |
227 | break; |
227 | break; |
228 | }
|
228 | }
|
229 | break; |
229 | break; |
230 | case '3': |
230 | case '3': |
231 | // Работа с источниками репозиториев
|
231 | // Работа с источниками репозиториев
|
232 | switch ($act) { |
232 | switch ($act) { |
233 | case '0': |
233 | case '0': |
234 | // Список источников
|
234 | // Список источников
|
235 | $orig =& $db->query("SELECT * FROM origin"); |
235 | $orig =& $db->query("SELECT * FROM origin"); |
236 | if ($orig->numRows()>0) { |
236 | if ($orig->numRows()>0) { |
237 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
237 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
238 | $display .= "<table><tr><th>Источник</th><th>Действие</th></tr>\n"; |
238 | $display .= "<table><tr><th>Источник</th><th>Действие</th></tr>\n"; |
239 | while ($orig->fetchInto($info, DB_FETCHMODE_ASSOC)) { |
239 | while ($orig->fetchInto($info, DB_FETCHMODE_ASSOC)) { |
240 | $distlist = substr($distlist, 0, -2); |
240 | $distlist = substr($distlist, 0, -2); |
241 | $display .= "<tr><td>".$secure->stripStr($info["origin"])."</td>\n"; |
241 | $display .= "<tr><td>".$secure->stripStr($info["origin"])."</td>\n"; |
242 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$info["orig_id"]."' class='nodec'><img src='$imgdir/edit.png' width='16' height='16' title='Редактировать'></a>"; |
242 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$info["orig_id"]."' class='nodec'><img src='$imgdir/edit.png' width='16' height='16' title='Редактировать'></a>"; |
243 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$info["orig_id"]."'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td>\n"; |
243 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$info["orig_id"]."'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td>\n"; |
244 | $display .= "</tr>"; |
244 | $display .= "</tr>"; |
245 | }
|
245 | }
|
246 | }
|
246 | }
|
247 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить источник репозиториев</a></p>\n"; |
247 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить источник репозиториев</a></p>\n"; |
248 | break; |
248 | break; |
249 | case '1': |
249 | case '1': |
250 | // Добавление нового источника
|
250 | // Добавление нового источника
|
251 | $display = "<div class='modulename'>Справочники :: <a href='admin.php?mode=".$mode."'>Источники</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
251 | $display = "<div class='modulename'>Справочники :: <a href='admin.php?mode=".$mode."'>Источники</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
252 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
252 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
253 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
253 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
254 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
254 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
255 | $display .= "Название источника: <input type='text' name='origin'><br>\n"; |
255 | $display .= "Название источника: <input type='text' name='origin'><br>\n"; |
256 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
256 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
257 | break; |
257 | break; |
258 | case '2': |
258 | case '2': |
259 | // Правка существующего источника
|
259 | // Правка существующего источника
|
260 | $orig =& $db->query("SELECT * FROM origin WHERE orig_id='$uid'"); |
260 | $orig =& $db->query("SELECT * FROM origin WHERE orig_id='$uid'"); |
261 | $orig->fetchInto($info, DB_FETCHMODE_ASSOC); |
261 | $orig->fetchInto($info, DB_FETCHMODE_ASSOC); |
262 | $type .= "</select>\n"; |
262 | $type .= "</select>\n"; |
263 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Источники</a> :: Правка источника репозиториев <em>'".$secure->stripStr($info["origin"])."'</em></div>"; |
263 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Источники</a> :: Правка источника репозиториев <em>'".$secure->stripStr($info["origin"])."'</em></div>"; |
264 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
264 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
265 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
265 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
266 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
266 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
267 | $display .= "<input type='hidden' name='originID' value='$uid'>\n"; |
267 | $display .= "<input type='hidden' name='originID' value='$uid'>\n"; |
268 | $display .= "Название источника: <input type='text' name='origin' value='".$secure->stripStr($info["origin"])."'><br>\n"; |
268 | $display .= "Название источника: <input type='text' name='origin' value='".$secure->stripStr($info["origin"])."'><br>\n"; |
269 | $display .= "<input type='submit' value='Править'></form>\n"; |
269 | $display .= "<input type='submit' value='Править'></form>\n"; |
270 | break; |
270 | break; |
271 | case '3': |
271 | case '3': |
272 | // Удаление существующего источника
|
272 | // Удаление существующего источника
|
273 | $orig =& $db->query("SELECT * FROM origin WHERE orig_id='$uid'"); |
273 | $orig =& $db->query("SELECT * FROM origin WHERE orig_id='$uid'"); |
274 | $orig->fetchInto($info, DB_FETCHMODE_ASSOC); |
274 | $orig->fetchInto($info, DB_FETCHMODE_ASSOC); |
275 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Источники</a> :: Удаление источника репозиториев <em>'".$secure->stripStr($info["origin"])."'</em></div>"; |
275 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Источники</a> :: Удаление источника репозиториев <em>'".$secure->stripStr($info["origin"])."'</em></div>"; |
276 | $display .= "<form action='./process.php' method='POST'>\n"; |
276 | $display .= "<form action='./process.php' method='POST'>\n"; |
277 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
277 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
278 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
278 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
279 | $display .= "<input type='hidden' name='originID' value='$uid'>\n"; |
279 | $display .= "<input type='hidden' name='originID' value='$uid'>\n"; |
280 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
280 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
281 | break; |
281 | break; |
282 | }
|
282 | }
|
283 | break; |
283 | break; |
284 | case '4': |
284 | case '4': |
285 | // Работа с репозиториями
|
285 | // Работа с репозиториями
|
286 | switch ($act) { |
286 | switch ($act) { |
287 | case '0': |
287 | case '0': |
288 | // Выбор дистрибутива
|
288 | // Выбор дистрибутива
|
289 | $dist =& $db->query("SELECT * FROM `repository` LEFT JOIN origin ON repository.orig_id=origin.orig_id LEFT JOIN root ON repository.root_id=root.root_id"); |
289 | $dist =& $db->query("SELECT * FROM `repository` LEFT JOIN origin ON repository.orig_id=origin.orig_id LEFT JOIN root ON repository.root_id=root.root_id"); |
290 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
290 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
291 | $display .= "<table><tr><th>Репозиторий</th><th>Действие</th><th>Корень</th><th>Источник</th></tr>\n"; |
291 | $display .= "<table><tr><th>Репозиторий</th><th>Действие</th><th>Корень</th><th>Источник</th></tr>\n"; |
292 | while ($dist->fetchInto($info, DB_FETCHMODE_ASSOC)) { |
292 | while ($dist->fetchInto($info, DB_FETCHMODE_ASSOC)) { |
293 | $display .= "<tr><td>".$info["repname"]."</td>"; |
293 | $display .= "<tr><td>".$info["repname"]."</td>"; |
294 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$info["rep_id"]."' class='nodec'><img src='$imgdir/edit.png' width='16' height='16' title='Редактировать'></a>"; |
294 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$info["rep_id"]."' class='nodec'><img src='$imgdir/edit.png' width='16' height='16' title='Редактировать'></a>"; |
295 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$info["rep_id"]."'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td>\n"; |
295 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$info["rep_id"]."'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td>\n"; |
296 | $display .= "<td>".$info["root_folder"]."</td>"; |
296 | $display .= "<td>".$info["root_folder"]."</td>"; |
297 | $display .= "<td>".$info["origin"]."</td></tr>"; |
297 | $display .= "<td>".$info["origin"]."</td></tr>"; |
298 | }
|
298 | }
|
299 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1&uid=".$uid."'><img src='$imgdir/add.png' width='16' height='16'>Добавить новый репозиторий</a></p>"; |
299 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1&uid=".$uid."'><img src='$imgdir/add.png' width='16' height='16'>Добавить новый репозиторий</a></p>"; |
300 | break; |
300 | break; |
301 | case '1': |
301 | case '1': |
302 | // Новый репозиторий
|
302 | // Новый репозиторий
|
303 | $mirr =& $db->query("SELECT * FROM mirror"); |
303 | $mirr =& $db->query("SELECT * FROM mirror"); |
304 | $mirror = ""; |
304 | $mirror = ""; |
305 | while($mirr->fetchInto($gm, DB_FETCHMODE_ASSOC)) { |
305 | while($mirr->fetchInto($gm, DB_FETCHMODE_ASSOC)) { |
306 | $mirror .= "<input type='checkbox' name='repMirror' value='".$gm["mirror_id"]."'> ".$secure->stripStr($gm["mname"])." "; |
306 | $mirror .= "<input type='checkbox' name='repMirror' value='".$gm["mirror_id"]."'> ".$secure->stripStr($gm["mname"])." "; |
307 | }
|
307 | }
|
308 | $rep =& $db->query("SELECT * FROM distribution d JOIN version v ON v.dist_id=d.dist_id WHERE v.version_id='$uid'"); |
308 | $rep =& $db->query("SELECT * FROM distribution d JOIN version v ON v.dist_id=d.dist_id WHERE v.version_id='$uid'"); |
309 | $rep->fetchInto($dist, DB_FETCHMODE_ASSOC); |
309 | $rep->fetchInto($dist, DB_FETCHMODE_ASSOC); |
310 | $dist_id = $dist["dist_id"]; |
310 | $dist_id = $dist["dist_id"]; |
311 | $dist_vname = $secure->stripStr($dist["distname"])." ".$secure->stripStr($dist["version"])." “".$secure->stripStr($dist["vname"])."”"; |
311 | $dist_vname = $secure->stripStr($dist["distname"])." ".$secure->stripStr($dist["version"])." “".$secure->stripStr($dist["vname"])."”"; |
312 | $dtype =& $db->query("SELECT * FROM scheme"); |
312 | $dtype =& $db->query("SELECT * FROM scheme"); |
313 | $rscheme = "<select name='scheme'>"; |
313 | $rscheme = "<select name='scheme'>"; |
314 | while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) { |
314 | while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) { |
315 | $rscheme .= "<option value='".$dtinfo["scheme_id"]."'>".$secure->stripStr($dtinfo["scheme"])."</option>"; |
315 | $rscheme .= "<option value='".$dtinfo["scheme_id"]."'>".$secure->stripStr($dtinfo["scheme"])."</option>"; |
316 | }
|
316 | }
|
317 | $rscheme .= "</select>"; |
317 | $rscheme .= "</select>"; |
318 | $origin_q =& $db->query("SELECT * FROM origin"); |
318 | $origin_q =& $db->query("SELECT * FROM origin"); |
319 | $origin = "<select name='origin'>"; |
319 | $origin = "<select name='origin'>"; |
320 | while ($origin_q->fetchInto($origin_info, DB_FETCHMODE_ASSOC)) { |
320 | while ($origin_q->fetchInto($origin_info, DB_FETCHMODE_ASSOC)) { |
321 | $origin .= "<option value='".$origin_info["orig_id"]."'>".$secure->stripStr($origin_info["origin"])."</option>"; |
321 | $origin .= "<option value='".$origin_info["orig_id"]."'>".$secure->stripStr($origin_info["origin"])."</option>"; |
322 | }
|
322 | }
|
323 | $origin .= "</select>\n"; |
323 | $origin .= "</select>\n"; |
324 | $sect =& $db->query("SELECT * FROM section s JOIN sect2dist d ON d.sect_id=s.sect_id WHERE d.dist_id='$dist_id'"); |
324 | $sect =& $db->query("SELECT * FROM section s JOIN sect2dist d ON d.sect_id=s.sect_id WHERE d.dist_id='$dist_id'"); |
325 | $list = ""; |
325 | $list = ""; |
326 | while ($sect->fetchInto($slist, DB_FETCHMODE_ASSOC)) { |
326 | while ($sect->fetchInto($slist, DB_FETCHMODE_ASSOC)) { |
327 | $list .= "<input type='checkbox' name='sect[]' value='".$slist["sect_id"]."'> <span title='".$secure->stripStr($slist["sectinfo"])."'>".$secure->stripStr($slist["sectname"])."</span> "; |
327 | $list .= "<input type='checkbox' name='sect[]' value='".$slist["sect_id"]."'> <span title='".$secure->stripStr($slist["sectinfo"])."'>".$secure->stripStr($slist["sectname"])."</span> "; |
328 | }
|
328 | }
|
329 | $type .= "</select>\n"; |
329 | $type .= "</select>\n"; |
330 | $rootfolder = "<select name='rootFolder'>\n"; |
330 | $rootfolder = "<select name='rootFolder'>\n"; |
331 | $root =& $db->query("SELECT * FROM root"); |
331 | $root =& $db->query("SELECT * FROM root"); |
332 | while ($root->fetchInto($rfi, DB_FETCHMODE_ASSOC)) { |
332 | while ($root->fetchInto($rfi, DB_FETCHMODE_ASSOC)) { |
333 | $rootfolder .= "<option value='".$rfi["root_id"]."'>".$secure->stripStr($rfi["root_folder"])."</option>"; |
333 | $rootfolder .= "<option value='".$rfi["root_id"]."'>".$secure->stripStr($rfi["root_folder"])."</option>"; |
334 | }
|
334 | }
|
335 | $rootfolder .= "</select>"; |
335 | $rootfolder .= "</select>"; |
336 | $display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
336 | $display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
337 | $display .= "<form action='./process.php' method='POST'>\n"; |
337 | $display .= "<form action='./process.php' method='POST'>\n"; |
338 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
338 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
339 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
339 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
340 | $display .= "<input type='hidden' name='vers' value='$uid'>\n"; |
340 | $display .= "<input type='hidden' name='vers' value='$uid'>\n"; |
341 | $display .= "Название репозитория (codename): <input type='text' name='repName'><br>\n"; |
341 | $display .= "Название репозитория (codename): <input type='text' name='repName'><br>\n"; |
342 | $display .= "Описание репозитория:<br> <textarea name='repInfo'></textarea><br>\n"; |
342 | $display .= "Описание репозитория:<br> <textarea name='repInfo'></textarea><br>\n"; |
343 | $display .= "Схема репозитория: ".$rscheme."<br>"; |
343 | $display .= "Схема репозитория: ".$rscheme."<br>"; |
344 | $display .= _("Mirrors").": ".$mirror."<br>"; |
344 | $display .= _("Mirrors").": ".$mirror."<br>"; |
345 | $display .= "Источник репозитория: ".$origin."<br>"; |
345 | $display .= "Источник репозитория: ".$origin."<br>"; |
346 | $display .= "Корневая папка репозитория: ".$rootfolder."<br>"; |
346 | $display .= "Корневая папка репозитория: ".$rootfolder."<br>"; |
347 | $display .= "Секции: ".$list."<br>"; |
347 | $display .= "Секции: ".$list."<br>"; |
348 | $display .= "По умолчанию: <input type='checkbox' name='default' value='1'>"; |
348 | $display .= "По умолчанию: <input type='checkbox' name='default' value='1'>"; |
349 | $display .= "<br><input type='submit' value='Создать'></form>\n"; |
349 | $display .= "<br><input type='submit' value='Создать'></form>\n"; |
350 | break; |
350 | break; |
351 | case '2': |
351 | case '2': |
352 | // Редактирование репозитория
|
352 | // Редактирование репозитория
|
353 | $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'"); |
353 | $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'"); |
354 | $rep->fetchInto($info, DB_FETCHMODE_ASSOC); |
354 | $rep->fetchInto($info, DB_FETCHMODE_ASSOC); |
355 | $dist_vname = $secure->stripStr($info["distname"])." ".$secure->stripStr($info["version"])." “".$secure->stripStr($info["vname"])."”"; |
355 | $dist_vname = $secure->stripStr($info["distname"])." ".$secure->stripStr($info["version"])." “".$secure->stripStr($info["vname"])."”"; |
356 | $tlist = "<select name='scheme'>"; |
356 | $tlist = "<select name='scheme'>"; |
357 | $sq =& $db->query("SELECT * FROM scheme"); |
357 | $sq =& $db->query("SELECT * FROM scheme"); |
358 | while ($sq->fetchInto($type, DB_FETCHMODE_ASSOC)) { |
358 | while ($sq->fetchInto($type, DB_FETCHMODE_ASSOC)) { |
359 | if ($type["scheme_id"]==$info["scheme_id"]) { |
359 | if ($type["scheme_id"]==$info["scheme_id"]) { |
360 | $tlist .= "<option value='".$type["scheme_id"]."' selected>".$secure->stripStr($type["scheme"])."</option>"; |
360 | $tlist .= "<option value='".$type["scheme_id"]."' selected>".$secure->stripStr($type["scheme"])."</option>"; |
361 | } else { |
361 | } else { |
362 | $tlist .= "<option value='".$type["scheme_id"]."'>".$secure->stripStr($type["scheme"])."</option>"; |
362 | $tlist .= "<option value='".$type["scheme_id"]."'>".$secure->stripStr($type["scheme"])."</option>"; |
363 | }
|
363 | }
|
364 | }
|
364 | }
|
365 | $tlist .= "</select>"; |
365 | $tlist .= "</select>"; |
366 | $mlist = ""; |
366 | $mlist = ""; |
367 | $mq =& $db->query("SELECT * FROM mirror m JOIN mirr2rep r ON m.mirror_id=r.mirror_id WHERE r.rep_id='$uid'"); |
367 | $mq =& $db->query("SELECT * FROM mirror m JOIN mirr2rep r ON m.mirror_id=r.mirror_id WHERE r.rep_id='$uid'"); |
368 | if ($mq->numRows()>0) { |
368 | if ($mq->numRows()>0) { |
369 | while ($mq->fetchInto($mget, DB_FETCHMODE_ASSOC)) { |
369 | while ($mq->fetchInto($mget, DB_FETCHMODE_ASSOC)) { |
370 | $mlist .= "<input type='checkbox' name='repMirror' value='".$mget["mirror_id"]."' checked> ".$secure->stripStr($mget["mname"])." "; |
370 | $mlist .= "<input type='checkbox' name='repMirror' value='".$mget["mirror_id"]."' checked> ".$secure->stripStr($mget["mname"])." "; |
371 | }
|
371 | }
|
372 | }
|
372 | }
|
373 | $mq =& $db->query("SELECT m.* FROM mirror m WHERE m.mirror_id NOT IN (SELECT mirror_id FROM mirr2rep WHERE rep_id='$uid')"); |
373 | $mq =& $db->query("SELECT m.* FROM mirror m WHERE m.mirror_id NOT IN (SELECT mirror_id FROM mirr2rep WHERE rep_id='$uid')"); |
374 | if ($mq->numRows()>0) { |
374 | if ($mq->numRows()>0) { |
375 | while ($mq->fetchInto($mget, DB_FETCHMODE_ASSOC)) { |
375 | while ($mq->fetchInto($mget, DB_FETCHMODE_ASSOC)) { |
376 | $mlist .= "<input type='checkbox' name='repMirror' value='".$mget["mirror_id"]."'> ".$secure->stripStr($mget["mname"])." "; |
376 | $mlist .= "<input type='checkbox' name='repMirror' value='".$mget["mirror_id"]."'> ".$secure->stripStr($mget["mname"])." "; |
377 | }
|
377 | }
|
378 | }
|
378 | }
|
379 | 379 | ||
380 | $tlist2 = "<select name='origin'>"; |
380 | $tlist2 = "<select name='origin'>"; |
381 | $sq =& $db->query("SELECT * FROM origin"); |
381 | $sq =& $db->query("SELECT * FROM origin"); |
382 | while ($sq->fetchInto($type, DB_FETCHMODE_ASSOC)) { |
382 | while ($sq->fetchInto($type, DB_FETCHMODE_ASSOC)) { |
383 | if ($type["orig_id"]==$info["orig_id"]) { |
383 | if ($type["orig_id"]==$info["orig_id"]) { |
384 | $tlist2 .= "<option value='".$type["orig_id"]."' selected>".$secure->stripStr($type["origin"])."</option>"; |
384 | $tlist2 .= "<option value='".$type["orig_id"]."' selected>".$secure->stripStr($type["origin"])."</option>"; |
385 | } else { |
385 | } else { |
386 | $tlist2 .= "<option value='".$type["orig_id"]."'>".$secure->stripStr($type["origin"])."</option>"; |
386 | $tlist2 .= "<option value='".$type["orig_id"]."'>".$secure->stripStr($type["origin"])."</option>"; |
387 | }
|
387 | }
|
388 | }
|
388 | }
|
389 | $tlist2 .= "</select>"; |
389 | $tlist2 .= "</select>"; |
390 | $list = ""; |
390 | $list = ""; |
391 | $req =& $db->query("SELECT * FROM section s JOIN sect2rep r ON s.sect_id=r.sect_id WHERE r.rep_id='$uid'"); |
391 | $req =& $db->query("SELECT * FROM section s JOIN sect2rep r ON s.sect_id=r.sect_id WHERE r.rep_id='$uid'"); |
392 | if ($req->numRows()>0) { |
392 | if ($req->numRows()>0) { |
393 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
393 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
394 | $list .= "<input type='checkbox' name='sect[]' value='".$sect["sect_id"]."' checked><span title='".$secure->stripStr($sect["sectinfo"])."'>".$secure->stripStr($sect["sectname"])."</span> "; |
394 | $list .= "<input type='checkbox' name='sect[]' value='".$sect["sect_id"]."' checked><span title='".$secure->stripStr($sect["sectinfo"])."'>".$secure->stripStr($sect["sectname"])."</span> "; |
395 | }
|
395 | }
|
396 | }
|
396 | }
|
397 | $req =& $db->query("SELECT s.* FROM section s WHERE s.sect_id NOT IN (SELECT sect_id FROM sect2rep WHERE rep_id='$uid')"); |
397 | $req =& $db->query("SELECT s.* FROM section s WHERE s.sect_id NOT IN (SELECT sect_id FROM sect2rep WHERE rep_id='$uid')"); |
398 | if ($req->numRows()>0) { |
398 | if ($req->numRows()>0) { |
399 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
399 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
400 | $list .= "<input type='checkbox' name='sect[]' value='".$sect["sect_id"]."'><span title='".$secure->stripStr($sect["sectinfo"])."'>".$secure->stripStr($sect["sectname"])."</span> "; |
400 | $list .= "<input type='checkbox' name='sect[]' value='".$sect["sect_id"]."'><span title='".$secure->stripStr($sect["sectinfo"])."'>".$secure->stripStr($sect["sectname"])."</span> "; |
401 | }
|
401 | }
|
402 | }
|
402 | }
|
403 | $rootfolder = "<select name='rootFolder'>\n"; |
403 | $rootfolder = "<select name='rootFolder'>\n"; |
404 | $req =& $db->query("SELECT * FROM root"); |
404 | $req =& $db->query("SELECT * FROM root"); |
405 | if ($req->numRows()>0) { |
405 | if ($req->numRows()>0) { |
406 | while ($req->fetchInto($rfi, DB_FETCHMODE_ASSOC)) { |
406 | while ($req->fetchInto($rfi, DB_FETCHMODE_ASSOC)) { |
407 | if ($rfi["root_id"]==$info["root_id"]) { |
407 | if ($rfi["root_id"]==$info["root_id"]) { |
408 | $rootfolder .= "<option value='".$rfi["root_id"]."' selected>".$secure->stripStr($rfi["root_folder"])."</option>"; |
408 | $rootfolder .= "<option value='".$rfi["root_id"]."' selected>".$secure->stripStr($rfi["root_folder"])."</option>"; |
409 | } else { |
409 | } else { |
410 | $rootfolder .= "<option value='".$rfi["root_id"]."'>".$secure->stripStr($rfi["root_folder"])."</option>"; |
410 | $rootfolder .= "<option value='".$rfi["root_id"]."'>".$secure->stripStr($rfi["root_folder"])."</option>"; |
411 | }
|
411 | }
|
412 | }
|
412 | }
|
413 | }
|
413 | }
|
414 | $rootfolder .= "</select>"; |
414 | $rootfolder .= "</select>"; |
415 | 415 | ||
416 | if ($info["defaultrep"]==1){$ch="checked";} else{$ch="";} |
416 | if ($info["defaultrep"]==1){$ch="checked";} else{$ch="";} |
417 | 417 | ||
418 | $display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка : ".$info["repname"]."</a></div>"; |
418 | $display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка : ".$info["repname"]."</a></div>"; |
419 | $display .= "<form action='./process.php' method='POST'>\n"; |
419 | $display .= "<form action='./process.php' method='POST'>\n"; |
420 | $display .= "<input type='hidden' name='mode' value=".$mode.">\n"; |
420 | $display .= "<input type='hidden' name='mode' value=".$mode.">\n"; |
421 | $display .= "<input type='hidden' name='act' value=".$act.">\n"; |
421 | $display .= "<input type='hidden' name='act' value=".$act.">\n"; |
422 | $display .= "<input type='hidden' name='rep' value='$uid'>\n"; |
422 | $display .= "<input type='hidden' name='rep' value='$uid'>\n"; |
423 | $display .= "Название репозитория (codename): <input type='text' name='repName' value='".$secure->stripStr($info["repname"])."'><br>\n"; |
423 | $display .= "Название репозитория (codename): <input type='text' name='repName' value='".$secure->stripStr($info["repname"])."'><br>\n"; |
424 | $display .= "Описание репозитория:<br> <textarea name='repInfo'>".$secure->stripStr($info["repdescribe"])."</textarea><br>\n"; |
424 | $display .= "Описание репозитория:<br> <textarea name='repInfo'>".$secure->stripStr($info["repdescribe"])."</textarea><br>\n"; |
425 | $display .= "Схема репозитория: ".$tlist."<br>"; |
425 | $display .= "Схема репозитория: ".$tlist."<br>"; |
426 | $display .= "Источник репозитория: ".$tlist2."<br>"; |
426 | $display .= "Источник репозитория: ".$tlist2."<br>"; |
427 | $display .= _("Mirrors").": ".$mlist."<br>"; |
427 | $display .= _("Mirrors").": ".$mlist."<br>"; |
428 | $display .= "Корневая папка репозитория: ".$rootfolder."<br>"; |
428 | $display .= "Корневая папка репозитория: ".$rootfolder."<br>"; |
429 | $display .= "Секции: ".$list."<br>"; |
429 | $display .= "Секции: ".$list."<br>"; |
430 | $display .= "По умолчанию: <input type='checkbox' name='default' value='1' ".$ch.">"; |
430 | $display .= "По умолчанию: <input type='checkbox' name='default' value='1' ".$ch.">"; |
431 | $display .= "<br><input type='submit' value='Править'></form>\n"; |
431 | $display .= "<br><input type='submit' value='Править'></form>\n"; |
432 | break; |
432 | break; |
433 | case '3': |
433 | case '3': |
434 | // Удаление репозитория
|
434 | // Удаление репозитория
|
435 | $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'"); |
435 | $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'"); |
436 | $rep->fetchInto($info, DB_FETCHMODE_ASSOC); |
436 | $rep->fetchInto($info, DB_FETCHMODE_ASSOC); |
437 | $dist_vname = $secure->stripStr($info["distname"])." ".$secure->stripStr($info["version"])." “".$secure->stripStr($info["vname"])."”"; |
437 | $dist_vname = $secure->stripStr($info["distname"])." ".$secure->stripStr($info["version"])." “".$secure->stripStr($info["vname"])."”"; |
438 | $display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление : ".$info["repname"]."</a></div>"; |
438 | $display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление : ".$info["repname"]."</a></div>"; |
439 | $display .= "<form action='./process.php' method='POST'>\n"; |
439 | $display .= "<form action='./process.php' method='POST'>\n"; |
440 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
440 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
441 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
441 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
442 | $display .= "<input type='hidden' name='rep' value='$uid'>\n"; |
442 | $display .= "<input type='hidden' name='rep' value='$uid'>\n"; |
443 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
443 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
444 | break; |
444 | break; |
445 | }
|
445 | }
|
446 | break; |
446 | break; |
447 | case '5': |
447 | case '5': |
448 | // Управление разделами
|
448 | // Управление разделами
|
449 | switch ($act) { |
449 | switch ($act) { |
450 | case '0': |
450 | case '0': |
451 | // Список секций
|
451 | // Список секций
|
452 | $req =& $db->query("SELECT * FROM section"); |
452 | $req =& $db->query("SELECT * FROM section"); |
453 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
453 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
454 | $display .= "<table><tr><th>Раздел</th><th>Действие</th><th>Используется в</th></tr>\n"; |
454 | $display .= "<table><tr><th>Раздел</th><th>Действие</th><th>Используется в</th></tr>\n"; |
455 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
455 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
456 | $replist = ""; |
456 | $replist = ""; |
457 | $sreq =& $db->query("SELECT * FROM distribution d JOIN sect2dist s ON s.dist_id=d.dist_id WHERE s.sect_id='".$sect["sect_id"]."'"); |
457 | $sreq =& $db->query("SELECT * FROM distribution d JOIN sect2dist s ON s.dist_id=d.dist_id WHERE s.sect_id='".$sect["sect_id"]."'"); |
458 | while ($sreq->fetchInto($rep, DB_FETCHMODE_ASSOC)) { |
458 | while ($sreq->fetchInto($rep, DB_FETCHMODE_ASSOC)) { |
459 | $replist .= "<em>".$secure->stripStr($rep["distname"])."</em>, "; |
459 | $replist .= "<em>".$secure->stripStr($rep["distname"])."</em>, "; |
460 | }
|
460 | }
|
461 | $replist = substr($replist, 0, -2); |
461 | $replist = substr($replist, 0, -2); |
462 | $display .= "<tr><td>".$secure->stripStr($sect["sectname"])."</td>"; |
462 | $display .= "<tr><td>".$secure->stripStr($sect["sectname"])."</td>"; |
463 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$sect["sect_id"]."' class='edit'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
463 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$sect["sect_id"]."' class='edit'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
464 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$sect["sect_id"]."' class='delete'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td>"; |
464 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$sect["sect_id"]."' class='delete'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td>"; |
465 | $display .= "<td>".$replist."</td></tr>"; |
465 | $display .= "<td>".$replist."</td></tr>"; |
466 | }
|
466 | }
|
467 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить секцию</a></p>"; |
467 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить секцию</a></p>"; |
468 | break; |
468 | break; |
469 | case '1': |
469 | case '1': |
470 | $req =& $db->query("SELECT * FROM distribution"); |
470 | $req =& $db->query("SELECT * FROM distribution"); |
471 | while ($req->fetchInto($dist, DB_FETCHMODE_ASSOC)) { |
471 | while ($req->fetchInto($dist, DB_FETCHMODE_ASSOC)) { |
472 | $list .= "<br><input type='checkbox' name='dist' value='".$dist["dist_id"]."'>".$secure->stripStr($dist["distname"])." "; |
472 | $list .= "<br><input type='checkbox' name='dist' value='".$dist["dist_id"]."'>".$secure->stripStr($dist["distname"])." "; |
473 | }
|
473 | }
|
474 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Создание секции репозитория</div>"; |
474 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Создание секции репозитория</div>"; |
475 | $display .= "<form action='./process.php' method='POST'>\n"; |
475 | $display .= "<form action='./process.php' method='POST'>\n"; |
476 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
476 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
477 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
477 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
478 | $display .= "Название секции (codename): <input type='text' name='sectName'><br>\n"; |
478 | $display .= "Название секции (codename): <input type='text' name='sectName'><br>\n"; |
479 | $display .= "Описание секции:<br> <textarea name='sectInfo'></textarea><br>\n"; |
479 | $display .= "Описание секции:<br> <textarea name='sectInfo'></textarea><br>\n"; |
480 | $display .= "Используется в дистрибутивах: ".$list; |
480 | $display .= "Используется в дистрибутивах: ".$list; |
481 | $display .= "<br><input type='submit' value='Добавить'></form>\n"; |
481 | $display .= "<br><input type='submit' value='Добавить'></form>\n"; |
482 | break; |
482 | break; |
483 | case '2': |
483 | case '2': |
484 | $req =& $db->query("SELECT * FROM distribution d JOIN sect2dist s ON s.dist_id=d.dist_id WHERE s.sect_id='$uid'"); |
484 | $req =& $db->query("SELECT * FROM distribution d JOIN sect2dist s ON s.dist_id=d.dist_id WHERE s.sect_id='$uid'"); |
485 | if ($req->numRows()>0) { |
485 | if ($req->numRows()>0) { |
486 | while ($req->fetchInto($dist, DB_FETCHMODE_ASSOC)) { |
486 | while ($req->fetchInto($dist, DB_FETCHMODE_ASSOC)) { |
487 | $list .= "<br><input type='checkbox' name='dist[]' value='".$dist["dist_id"]."' checked>".$secure->stripStr($dist["distname"])." "; |
487 | $list .= "<br><input type='checkbox' name='dist[]' value='".$dist["dist_id"]."' checked>".$secure->stripStr($dist["distname"])." "; |
488 | }
|
488 | }
|
489 | }
|
489 | }
|
490 | $req =& $db->query("SELECT d.* FROM distribution d WHERE dist_id NOT IN (SELECT dist_id FROM sect2dist WHERE sect_id='$uid')"); |
490 | $req =& $db->query("SELECT d.* FROM distribution d WHERE dist_id NOT IN (SELECT dist_id FROM sect2dist WHERE sect_id='$uid')"); |
491 | if ($req->numRows()>0) { |
491 | if ($req->numRows()>0) { |
492 | while ($req->fetchInto($dist, DB_FETCHMODE_ASSOC)) { |
492 | while ($req->fetchInto($dist, DB_FETCHMODE_ASSOC)) { |
493 | $list .= "<br><input type='checkbox' name='dist[]' value='".$dist["dist_id"]."'>".$secure->stripStr($dist["distname"])." "; |
493 | $list .= "<br><input type='checkbox' name='dist[]' value='".$dist["dist_id"]."'>".$secure->stripStr($dist["distname"])." "; |
494 | }
|
494 | }
|
495 | }
|
495 | }
|
496 | $req =& $db->query("SELECT * FROM section WHERE sect_id='$uid'"); |
496 | $req =& $db->query("SELECT * FROM section WHERE sect_id='$uid'"); |
497 | $req->fetchInto($sect, DB_FETCHMODE_ASSOC); |
497 | $req->fetchInto($sect, DB_FETCHMODE_ASSOC); |
498 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Правка секции репозитория</div>"; |
498 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Правка секции репозитория</div>"; |
499 | $display .= "<form action='./process.php' method='POST'>\n"; |
499 | $display .= "<form action='./process.php' method='POST'>\n"; |
500 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
500 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
501 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
501 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
502 | $display .= "<input type='hidden' name='sectID' value='$uid'>\n"; |
502 | $display .= "<input type='hidden' name='sectID' value='$uid'>\n"; |
503 | $display .= "Название секции (codename): <input type='text' name='sectName' value='".$secure->stripStr($sect["sectname"])."'><br>\n"; |
503 | $display .= "Название секции (codename): <input type='text' name='sectName' value='".$secure->stripStr($sect["sectname"])."'><br>\n"; |
504 | $display .= "Описание секции:<br> <textarea name='sectInfo'>".$secure->stripStr($sect["sectinfo"])."</textarea><br>\n"; |
504 | $display .= "Описание секции:<br> <textarea name='sectInfo'>".$secure->stripStr($sect["sectinfo"])."</textarea><br>\n"; |
505 | $display .= "Используется в дистрибутивах: ".$list; |
505 | $display .= "Используется в дистрибутивах: ".$list; |
506 | $display .= "<br><input type='submit' value='Править'></form>\n"; |
506 | $display .= "<br><input type='submit' value='Править'></form>\n"; |
507 | break; |
507 | break; |
508 | case '3': |
508 | case '3': |
509 | $req =& $db->query("SELECT * FROM section WHERE sect_id='$uid'"); |
509 | $req =& $db->query("SELECT * FROM section WHERE sect_id='$uid'"); |
510 | $req->fetchInto($sect, DB_FETCHMODE_ASSOC); |
510 | $req->fetchInto($sect, DB_FETCHMODE_ASSOC); |
511 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Удаление секции <em>".$secure->stripStr($sect["sectname"])."</em></div>"; |
511 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Удаление секции <em>".$secure->stripStr($sect["sectname"])."</em></div>"; |
512 | $display .= "<form action='./process.php' method='POST'>\n"; |
512 | $display .= "<form action='./process.php' method='POST'>\n"; |
513 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
513 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
514 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
514 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
515 | $display .= "<input type='hidden' name='sectID' value='$uid'>\n"; |
515 | $display .= "<input type='hidden' name='sectID' value='$uid'>\n"; |
516 | $display .= "<br><input type='submit' value='Удалить'></form>\n"; |
516 | $display .= "<br><input type='submit' value='Удалить'></form>\n"; |
517 | break; |
517 | break; |
518 | }
|
518 | }
|
519 | break; |
519 | break; |
520 | case '6': |
520 | case '6': |
521 | // Управление схемами репозиториев
|
521 | // Управление схемами репозиториев
|
522 | switch ($act) { |
522 | switch ($act) { |
523 | case '0': |
523 | case '0': |
524 | // Список схем
|
524 | // Список схем
|
525 | $req =& $db->query("SELECT * FROM scheme"); |
525 | $req =& $db->query("SELECT * FROM scheme"); |
526 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
526 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
527 | $display .= "<table><th>Схема</th><th>Действие</th></tr>"; |
527 | $display .= "<table><th>Схема</th><th>Действие</th></tr>"; |
528 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
528 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
529 | $display .= "<tr><td>".$secure->stripStr($sect["scheme"])."</td>"; |
529 | $display .= "<tr><td>".$secure->stripStr($sect["scheme"])."</td>"; |
530 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$sect["scheme_id"]."' class='edit'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
530 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$sect["scheme_id"]."' class='edit'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
531 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$sect["scheme_id"]."' class='delete'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td></tr>"; |
531 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$sect["scheme_id"]."' class='delete'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td></tr>"; |
532 | }
|
532 | }
|
533 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новую схему</a></p>"; |
533 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новую схему</a></p>"; |
534 | break; |
534 | break; |
535 | case '1': |
535 | case '1': |
536 | // Добавление новой схемы
|
536 | // Добавление новой схемы
|
537 | $display = "<div class='modulename'><a href='admin.php?mode=5'>Схемы</a> :: Создание схемы репозитория</div>"; |
537 | $display = "<div class='modulename'><a href='admin.php?mode=5'>Схемы</a> :: Создание схемы репозитория</div>"; |
538 | $display .= "<form action='./process.php' method='POST'>\n"; |
538 | $display .= "<form action='./process.php' method='POST'>\n"; |
539 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
539 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
540 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
540 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
541 | $display .= "Схема репозитория: <input type='text' name='scheme'><br>\n"; |
541 | $display .= "Схема репозитория: <input type='text' name='scheme'><br>\n"; |
542 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
542 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
543 | break; |
543 | break; |
544 | case '2': |
544 | case '2': |
545 | // Правка существующей схемы
|
545 | // Правка существующей схемы
|
546 | $req =& $db->query("SELECT * FROM scheme WHERE scheme_id='$uid'"); |
546 | $req =& $db->query("SELECT * FROM scheme WHERE scheme_id='$uid'"); |
547 | if ($req->numRows()>0) { |
547 | if ($req->numRows()>0) { |
548 | $req->fetchInto($scheme, DB_FETCHMODE_ASSOC); |
548 | $req->fetchInto($scheme, DB_FETCHMODE_ASSOC); |
549 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Схемы</a> :: Правка схемы репозитория</div>"; |
549 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Схемы</a> :: Правка схемы репозитория</div>"; |
550 | $display .= "<form action='./process.php' method='POST'>\n"; |
550 | $display .= "<form action='./process.php' method='POST'>\n"; |
551 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
551 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
552 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
552 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
553 | $display .= "<input type='hidden' name='schemeID' value='".$secure->stripStr($scheme["scheme_id"])."'><br>\n"; |
553 | $display .= "<input type='hidden' name='schemeID' value='".$secure->stripStr($scheme["scheme_id"])."'><br>\n"; |
554 | $display .= "Схема репозитория: <input type='text' name='scheme' value='".$secure->stripStr($scheme["scheme"])."'><br>\n"; |
554 | $display .= "Схема репозитория: <input type='text' name='scheme' value='".$secure->stripStr($scheme["scheme"])."'><br>\n"; |
555 | $display .= "<input type='submit' value='Править'></form>\n"; |
555 | $display .= "<input type='submit' value='Править'></form>\n"; |
556 | } else { |
556 | } else { |
557 | $display = "Такой схемы репозитория не существует"; |
557 | $display = "Такой схемы репозитория не существует"; |
558 | }
|
558 | }
|
559 | break; |
559 | break; |
560 | case '3': |
560 | case '3': |
561 | // Удаление существующей схемы
|
561 | // Удаление существующей схемы
|
562 | $req =& $db->query("SELECT * FROM scheme WHERE scheme_id='$uid'"); |
562 | $req =& $db->query("SELECT * FROM scheme WHERE scheme_id='$uid'"); |
563 | if ($req->numRows()>0) { |
563 | if ($req->numRows()>0) { |
564 | $req->fetchInto($scheme, DB_FETCHMODE_ASSOC); |
564 | $req->fetchInto($scheme, DB_FETCHMODE_ASSOC); |
565 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Схемы</a> :: Удаление схемы репозитория</div>"; |
565 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Схемы</a> :: Удаление схемы репозитория</div>"; |
566 | $display .= "Удаляемая схема: ".$secure->stripStr($scheme["scheme"])."<br>"; |
566 | $display .= "Удаляемая схема: ".$secure->stripStr($scheme["scheme"])."<br>"; |
567 | $display .= "<form action='./process.php' method='POST'>\n"; |
567 | $display .= "<form action='./process.php' method='POST'>\n"; |
568 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
568 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
569 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
569 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
570 | $display .= "<input type='hidden' name='schemeID' value='".$scheme["scheme_id"]."'><br>\n"; |
570 | $display .= "<input type='hidden' name='schemeID' value='".$scheme["scheme_id"]."'><br>\n"; |
571 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
571 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
572 | } else { |
572 | } else { |
573 | $display = "Такой схемы репозитория не существует"; |
573 | $display = "Такой схемы репозитория не существует"; |
574 | }
|
574 | }
|
575 | break; |
575 | break; |
576 | }
|
576 | }
|
577 | break; |
577 | break; |
578 | case '7': |
578 | case '7': |
579 | // Управление типами репозиториев
|
579 | // Управление типами репозиториев
|
580 | switch ($act) { |
580 | switch ($act) { |
581 | case '0': |
581 | case '0': |
582 | // Список типов репозиториев
|
582 | // Список типов репозиториев
|
583 | $req =& $db->query("SELECT * FROM rtype"); |
583 | $req =& $db->query("SELECT * FROM rtype"); |
584 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
584 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
585 | $display .= "<table><tr><th>Тип</th><th>Действие</th></tr>"; |
585 | $display .= "<table><tr><th>Тип</th><th>Действие</th></tr>"; |
586 | if ($req->numRows()>0) { |
586 | if ($req->numRows()>0) { |
587 | while ($req->fetchInto($setting, DB_FETCHMODE_ASSOC)) { |
587 | while ($req->fetchInto($setting, DB_FETCHMODE_ASSOC)) { |
588 | $display .= "<tr><td>".$secure->stripStr($setting["rtype"])."</td>"; |
588 | $display .= "<tr><td>".$secure->stripStr($setting["rtype"])."</td>"; |
589 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$setting["rtype_id"]."' class='edit'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
589 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$setting["rtype_id"]."' class='edit'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
590 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$setting["rtype_id"]."' class='delete'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td></tr>"; |
590 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$setting["rtype_id"]."' class='delete'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td></tr>"; |
591 | }
|
591 | }
|
592 | }
|
592 | }
|
593 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новый тип репозитория</a></p>"; |
593 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новый тип репозитория</a></p>"; |
594 | break; |
594 | break; |
595 | case '1': |
595 | case '1': |
596 | // Добавление нового типа репозитория
|
596 | // Добавление нового типа репозитория
|
597 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Создание нового типа репозитория</div>"; |
597 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Создание нового типа репозитория</div>"; |
598 | $display .= "<form action='./process.php' method='POST'>\n"; |
598 | $display .= "<form action='./process.php' method='POST'>\n"; |
599 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
599 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
600 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
600 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
601 | $display .= "Тип: <input type='text' name='rtype'><br>\n"; |
601 | $display .= "Тип: <input type='text' name='rtype'><br>\n"; |
602 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
602 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
603 | break; |
603 | break; |
604 | case '2': |
604 | case '2': |
605 | // Правка существующего типа репозитория
|
605 | // Правка существующего типа репозитория
|
606 | $req =& $db->query("SELECT * FROM rtype WHERE rtype_id='$uid'"); |
606 | $req =& $db->query("SELECT * FROM rtype WHERE rtype_id='$uid'"); |
607 | if ($req->numRows()>0) { |
607 | if ($req->numRows()>0) { |
608 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
608 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
609 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Правка типа репозитория</div>"; |
609 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Правка типа репозитория</div>"; |
610 | $display .= "<form action='./process.php' method='POST'>\n"; |
610 | $display .= "<form action='./process.php' method='POST'>\n"; |
611 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
611 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
612 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
612 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
613 | $display .= "<input type='hidden' name='rtypeID' value='".$secure->stripStr($setting["rtype_id"])."'><br>\n"; |
613 | $display .= "<input type='hidden' name='rtypeID' value='".$secure->stripStr($setting["rtype_id"])."'><br>\n"; |
614 | $display .= "Тип: <input type='text' name='rtype' value='".$secure->stripStr($setting["rtype"])."'><br>\n"; |
614 | $display .= "Тип: <input type='text' name='rtype' value='".$secure->stripStr($setting["rtype"])."'><br>\n"; |
615 | $display .= "<input type='submit' value='Править'></form>\n"; |
615 | $display .= "<input type='submit' value='Править'></form>\n"; |
616 | } else { |
616 | } else { |
617 | $display = "Такого типа репозитория не существует"; |
617 | $display = "Такого типа репозитория не существует"; |
618 | }
|
618 | }
|
619 | break; |
619 | break; |
620 | case '3': |
620 | case '3': |
621 | // Удаление существующего типа репозитория
|
621 | // Удаление существующего типа репозитория
|
622 | $req =& $db->query("SELECT * FROM rtype WHERE rtype_id='$uid'"); |
622 | $req =& $db->query("SELECT * FROM rtype WHERE rtype_id='$uid'"); |
623 | if ($req->numRows()>0) { |
623 | if ($req->numRows()>0) { |
624 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
624 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
625 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Удаление существующего типа репозитория</div>"; |
625 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Удаление существующего типа репозитория</div>"; |
626 | $display .= "Удаляемый тип <em>".$secure->stripStr($setting["rtype"])."</em><br>"; |
626 | $display .= "Удаляемый тип <em>".$secure->stripStr($setting["rtype"])."</em><br>"; |
627 | $display .= "<form action='./process.php' method='POST'>\n"; |
627 | $display .= "<form action='./process.php' method='POST'>\n"; |
628 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
628 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
629 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
629 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
630 | $display .= "<input type='hidden' name='rtypeID' value='".$setting["rtype_id"]."'><br>\n"; |
630 | $display .= "<input type='hidden' name='rtypeID' value='".$setting["rtype_id"]."'><br>\n"; |
631 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
631 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
632 | } else { |
632 | } else { |
633 | $display = "Такого типа репозитория не существует"; |
633 | $display = "Такого типа репозитория не существует"; |
634 | }
|
634 | }
|
635 | break; |
635 | break; |
636 | }
|
636 | }
|
637 | break; |
637 | break; |
638 | case '8': |
638 | case '8': |
639 | // Управление корневыми папками репозиториев
|
639 | // Управление корневыми папками репозиториев
|
640 | switch ($act) { |
640 | switch ($act) { |
641 | case '0': |
641 | case '0': |
642 | // Список корневых папок репозиториев
|
642 | // Список корневых папок репозиториев
|
643 | $req =& $db->query("SELECT * FROM root"); |
643 | $req =& $db->query("SELECT * FROM root"); |
644 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
644 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
645 | $display .= "<table><tr><th>Путь</th><th>Действие</th></tr>\n"; |
645 | $display .= "<table><tr><th>Путь</th><th>Действие</th></tr>\n"; |
646 | if ($req->numRows()>0) { |
646 | if ($req->numRows()>0) { |
647 | $display .= "<ul>\n"; |
647 | $display .= "<ul>\n"; |
648 | while ($req->fetchInto($root, DB_FETCHMODE_ASSOC)) { |
648 | while ($req->fetchInto($root, DB_FETCHMODE_ASSOC)) { |
649 | $display .= "<tr><td>".$secure->stripStr($root["root_folder"])."</td>"; |
649 | $display .= "<tr><td>".$secure->stripStr($root["root_folder"])."</td>"; |
650 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$root["root_id"]."' class='edit'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
650 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$root["root_id"]."' class='edit'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
651 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$root["root_id"]."' class='delete'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td></tr>"; |
651 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$root["root_id"]."' class='delete'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td></tr>"; |
652 | }
|
652 | }
|
653 | $display .= "</table>\n"; |
653 | $display .= "</table>\n"; |
654 | } else { |
654 | } else { |
655 | $display .= "<p>Ни одной корневой папки не найдено.</p>"; |
655 | $display .= "<p>Ни одной корневой папки не найдено.</p>"; |
656 | }
|
656 | }
|
657 | $display .= "<p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новую корневую папку репозиториев</a></p>"; |
657 | $display .= "<p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новую корневую папку репозиториев</a></p>"; |
658 | break; |
658 | break; |
659 | case '1': |
659 | case '1': |
660 | // Добавление новой корневой папки репозиториев
|
660 | // Добавление новой корневой папки репозиториев
|
661 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Добавление корневой папки</div>"; |
661 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Добавление корневой папки</div>"; |
662 | $display .= "<form action='./process.php' method='post'>\n"; |
662 | $display .= "<form action='./process.php' method='post'>\n"; |
663 | $display .= "<input type='hidden' name='mode' value='".$mode."'>"; |
663 | $display .= "<input type='hidden' name='mode' value='".$mode."'>"; |
664 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
664 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
665 | $display .= "Корневая папка: <input type='text' name='rootFolder'><br>\n"; |
665 | $display .= "Корневая папка: <input type='text' name='rootFolder'><br>\n"; |
666 | $display .= "<input type='submit' value='Создать'>\n</form>\n"; |
666 | $display .= "<input type='submit' value='Создать'>\n</form>\n"; |
667 | break; |
667 | break; |
668 | case '2': |
668 | case '2': |
669 | // Редактирование корневой папки репозиториев
|
669 | // Редактирование корневой папки репозиториев
|
670 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Редактирование корневой папки</div>"; |
670 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Редактирование корневой папки</div>"; |
671 | $req =& $db->query("SELECT * FROM root WHERE root_id='$uid'"); |
671 | $req =& $db->query("SELECT * FROM root WHERE root_id='$uid'"); |
672 | if ($req->numRows()>0) { |
672 | if ($req->numRows()>0) { |
673 | $req->fetchInto($root, DB_FETCHMODE_ASSOC); |
673 | $req->fetchInto($root, DB_FETCHMODE_ASSOC); |
674 | $display .= "<form action='./process.php' method='post'>\n"; |
674 | $display .= "<form action='./process.php' method='post'>\n"; |
675 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
675 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
676 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
676 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
677 | $display .= "<input type='hidden' name='rootID' value='$uid'>\n"; |
677 | $display .= "<input type='hidden' name='rootID' value='$uid'>\n"; |
678 | $display .= "Корневая папка репозитория: <input type='text' name='rootFolder' value='".$secure->stripStr($root["root_folder"])."'><br>\n"; |
678 | $display .= "Корневая папка репозитория: <input type='text' name='rootFolder' value='".$secure->stripStr($root["root_folder"])."'><br>\n"; |
679 | $display .= "<input type='submit' value='Редактировать'>\n</form>\n"; |
679 | $display .= "<input type='submit' value='Редактировать'>\n</form>\n"; |
680 | } else { |
680 | } else { |
681 | $display .= "<p>Такой корневой папки репозиториев не существует</p>"; |
681 | $display .= "<p>Такой корневой папки репозиториев не существует</p>"; |
682 | }
|
682 | }
|
683 | break; |
683 | break; |
684 | case '3': |
684 | case '3': |
685 | // Удаление корневой папки репозиториев
|
685 | // Удаление корневой папки репозиториев
|
686 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Удаление корневой папки</div>"; |
686 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Удаление корневой папки</div>"; |
687 | $req =& $db->query("SELECT * FROM root WHERE root_id='$uid'"); |
687 | $req =& $db->query("SELECT * FROM root WHERE root_id='$uid'"); |
688 | if ($req->numRows()>0) { |
688 | if ($req->numRows()>0) { |
689 | $req->fetchInto($root, DB_FETCHMODE_ASSOC); |
689 | $req->fetchInto($root, DB_FETCHMODE_ASSOC); |
690 | $display .= "<form action='./process.php' method='post'>\n"; |
690 | $display .= "<form action='./process.php' method='post'>\n"; |
691 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
691 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
692 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
692 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
693 | $display .= "<input type='hidden' name='rootID' value='$uid'>\n"; |
693 | $display .= "<input type='hidden' name='rootID' value='$uid'>\n"; |
694 | $display .= "Корневая папка репозитория: <input type='text' name='rootFolder' value='".$secure->stripStr($root["root_folder"])."' readonly><br>\n"; |
694 | $display .= "Корневая папка репозитория: <input type='text' name='rootFolder' value='".$secure->stripStr($root["root_folder"])."' readonly><br>\n"; |
695 | $display .= "<input type='submit' value='Удалить'>\n</form>\n"; |
695 | $display .= "<input type='submit' value='Удалить'>\n</form>\n"; |
696 | } else { |
696 | } else { |
697 | $display .= "<p>Такой корневой папки не существует</p>"; |
697 | $display .= "<p>Такой корневой папки не существует</p>"; |
698 | }
|
698 | }
|
699 | break; |
699 | break; |
700 | }
|
700 | }
|
701 | break; |
701 | break; |
702 | case '9': |
702 | case '9': |
703 | // Работа с зеркалами репозиториев
|
703 | // Работа с зеркалами репозиториев
|
704 | switch ($act) { |
704 | switch ($act) { |
705 | case '0': |
705 | case '0': |
706 | // Список зеркал
|
706 | // Список зеркал
|
707 | $mirr =& $db->query("SELECT * FROM mirror"); |
707 | $mirr =& $db->query("SELECT * FROM mirror"); |
708 | if ($mirr->numRows()>0) { |
708 | if ($mirr->numRows()>0) { |
709 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
709 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
710 | $display .= "<table><tr><th>Зеркало</th><th>Действие</th></tr>\n"; |
710 | $display .= "<table><tr><th>Зеркало</th><th>Действие</th></tr>\n"; |
711 | while ($mirr->fetchInto($info, DB_FETCHMODE_ASSOC)) { |
711 | while ($mirr->fetchInto($info, DB_FETCHMODE_ASSOC)) { |
712 | $display .= "<tr><td>".$secure->stripStr($info["mname"])."</td>\n"; |
712 | $display .= "<tr><td>".$secure->stripStr($info["mname"])."</td>\n"; |
713 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$info["mirror_id"]."' class='nodec'><img src='$imgdir/edit.png' width='16' height='16' title='Редактировать'></a>"; |
713 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$info["mirror_id"]."' class='nodec'><img src='$imgdir/edit.png' width='16' height='16' title='Редактировать'></a>"; |
714 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$info["mirror_id"]."'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td>\n"; |
714 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$info["mirror_id"]."'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td>\n"; |
715 | $display .= "</tr>"; |
715 | $display .= "</tr>"; |
716 | }
|
716 | }
|
717 | }
|
717 | }
|
718 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить зеркало репозиториев</a></p>\n"; |
718 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить зеркало репозиториев</a></p>\n"; |
719 | break; |
719 | break; |
720 | case '1': |
720 | case '1': |
721 | // Добавление нового зеркала
|
721 | // Добавление нового зеркала
|
722 | $display = "<div class='modulename'>Справочники :: <a href='admin.php?mode=".$mode."'>Зеркала</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
722 | $display = "<div class='modulename'>Справочники :: <a href='admin.php?mode=".$mode."'>Зеркала</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
723 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
723 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
724 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
724 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
725 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
725 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
726 | $display .= "Название зеркала: <input type='text' name='mname'><br>\n"; |
726 | $display .= "Название зеркала: <input type='text' name='mname'><br>\n"; |
727 | $display .= "URL зеркала: <input type='text' name='murl'><br>\n"; |
727 | $display .= "URL зеркала: <input type='text' name='murl'><br>\n"; |
728 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
728 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
729 | break; |
729 | break; |
730 | case '2': |
730 | case '2': |
731 | // Правка существующего зеркала
|
731 | // Правка существующего зеркала
|
732 | $mirr =& $db->query("SELECT * FROM mirror WHERE mirror_id='$uid'"); |
732 | $mirr =& $db->query("SELECT * FROM mirror WHERE mirror_id='$uid'"); |
733 | $mirr->fetchInto($info, DB_FETCHMODE_ASSOC); |
733 | $mirr->fetchInto($info, DB_FETCHMODE_ASSOC); |
734 | $type .= "</select>\n"; |
734 | $type .= "</select>\n"; |
735 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Зеркала</a> :: Правка зеркала репозиториев <em>'".$secure->stripStr($info["mname"])."'</em></div>"; |
735 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Зеркала</a> :: Правка зеркала репозиториев <em>'".$secure->stripStr($info["mname"])."'</em></div>"; |
736 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
736 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
737 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
737 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
738 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
738 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
739 | $display .= "<input type='hidden' name='mirrorID' value='$uid'>\n"; |
739 | $display .= "<input type='hidden' name='mirrorID' value='$uid'>\n"; |
740 | $display .= "Название источника: <input type='text' name='mname' value='".$secure->stripStr($info["mname"])."'><br>\n"; |
740 | $display .= "Название источника: <input type='text' name='mname' value='".$secure->stripStr($info["mname"])."'><br>\n"; |
741 | $display .= "URL источника: <input type='text' name='murl' value='".$secure->stripStr($info["mproto"]).$secure->stripStr($info["murl"])."'><br>\n"; |
741 | $display .= "URL источника: <input type='text' name='murl' value='".$secure->stripStr($info["mproto"]).$secure->stripStr($info["murl"])."'><br>\n"; |
742 | $display .= "<input type='submit' value='Править'></form>\n"; |
742 | $display .= "<input type='submit' value='Править'></form>\n"; |
743 | break; |
743 | break; |
744 | case '3': |
744 | case '3': |
745 | // Удаление существующего зеркала
|
745 | // Удаление существующего зеркала
|
746 | $orig =& $db->query("SELECT * FROM mirror WHERE mirror_id='$uid'"); |
746 | $orig =& $db->query("SELECT * FROM mirror WHERE mirror_id='$uid'"); |
747 | $orig->fetchInto($info, DB_FETCHMODE_ASSOC); |
747 | $orig->fetchInto($info, DB_FETCHMODE_ASSOC); |
748 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Зеркала</a> :: Удаление зеркала репозиториев <em>'".$secure->stripStr($info["mname"])."'</em></div>"; |
748 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Зеркала</a> :: Удаление зеркала репозиториев <em>'".$secure->stripStr($info["mname"])."'</em></div>"; |
749 | $display .= "<form action='./process.php' method='POST'>\n"; |
749 | $display .= "<form action='./process.php' method='POST'>\n"; |
750 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
750 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
751 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
751 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
752 | $display .= "<input type='hidden' name='mirrorID' value='$uid'>\n"; |
752 | $display .= "<input type='hidden' name='mirrorID' value='$uid'>\n"; |
753 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
753 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
754 | break; |
754 | break; |
755 | }
|
755 | }
|
756 | break; |
756 | break; |
757 | case '20': |
757 | case '20': |
758 | // Управление опциями Ant
|
758 | // Управление опциями Ant
|
759 | switch ($act) { |
759 | switch ($act) { |
760 | case '0': |
760 | case '0': |
761 | // Список опций Ant
|
761 | // Список опций Ant
|
762 | $req =& $db->query("SELECT * FROM settings"); |
762 | $req =& $db->query("SELECT * FROM settings"); |
763 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
763 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
764 | $display .= "<table><tr><th>Опция</th><th>Действие</th><th>Значение</th></tr>"; |
764 | $display .= "<table><tr><th>Опция</th><th>Действие</th><th>Значение</th></tr>"; |
765 | if ($req->numRows()>0) { |
765 | if ($req->numRows()>0) { |
766 | while ($req->fetchInto($setting, DB_FETCHMODE_ASSOC)) { |
766 | while ($req->fetchInto($setting, DB_FETCHMODE_ASSOC)) { |
767 | $display .= "<tr><td>".$secure->stripStr($setting["opt"])."</td>"; |
767 | $display .= "<tr><td>".$secure->stripStr($setting["opt"])."</td>"; |
768 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$setting["opt_id"]."'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
768 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$setting["opt_id"]."'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
769 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$setting["opt_id"]."' class='delete'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td>"; |
769 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$setting["opt_id"]."' class='delete'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td>"; |
770 | $display .= "<td>".$secure->stripStr($setting["optvalue"])."</td></tr>"; |
770 | $display .= "<td>".$secure->stripStr($setting["optvalue"])."</td></tr>"; |
771 | }
|
771 | }
|
772 | }
|
772 | }
|
773 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новую опцию</a></p>"; |
773 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новую опцию</a></p>"; |
774 | break; |
774 | break; |
775 | case '1': |
775 | case '1': |
776 | // Добавление новой опции Ant
|
776 | // Добавление новой опции Ant
|
777 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
777 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
778 | $display .= "<form action='./process.php' method='POST'>\n"; |
778 | $display .= "<form action='./process.php' method='POST'>\n"; |
779 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
779 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
780 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
780 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
781 | $display .= "Настройка (латиница, без пробелов): <input type='text' name='setoption'><br>\n"; |
781 | $display .= "Настройка (латиница, без пробелов): <input type='text' name='setoption'><br>\n"; |
782 | $display .= "Свойство (значение) настройки: <input type='text' name='setvalue'><br>\n"; |
782 | $display .= "Свойство (значение) настройки: <input type='text' name='setvalue'><br>\n"; |
783 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
783 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
784 | break; |
784 | break; |
785 | case '2': |
785 | case '2': |
786 | // Правка существующей опции Ant
|
786 | // Правка существующей опции Ant
|
787 | $req =& $db->query("SELECT * FROM settings WHERE opt_id='$uid'"); |
787 | $req =& $db->query("SELECT * FROM settings WHERE opt_id='$uid'"); |
788 | if ($req->numRows()>0) { |
788 | if ($req->numRows()>0) { |
789 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
789 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
790 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка</a></div>"; |
790 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка</a></div>"; |
791 | $display .= "<form action='./process.php' method='POST'>\n"; |
791 | $display .= "<form action='./process.php' method='POST'>\n"; |
792 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
792 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
793 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
793 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
794 | $display .= "<input type='hidden' name='optID' value='".$secure->stripStr($setting["opt_id"])."'><br>\n"; |
794 | $display .= "<input type='hidden' name='optID' value='".$secure->stripStr($setting["opt_id"])."'><br>\n"; |
795 | $display .= "Настройка: <input type='text' name='setoption' value='".$secure->stripStr($setting["opt"])."' readonly><br>\n"; |
795 | $display .= "Настройка: <input type='text' name='setoption' value='".$secure->stripStr($setting["opt"])."' readonly><br>\n"; |
796 | if ($setting["opt"]=="interface") { |
796 | if ($setting["opt"]=="interface") { |
797 | $sq =& $db->query("SELECT * FROM interfaces"); |
797 | $sq =& $db->query("SELECT * FROM interfaces"); |
798 | $setvalue = "<select name='setvalue'>"; |
798 | $setvalue = "<select name='setvalue'>"; |
799 | while ($sq->fetchInto($if, DB_FETCHMODE_ASSOC)) { |
799 | while ($sq->fetchInto($if, DB_FETCHMODE_ASSOC)) { |
800 | if ($if["interface"]==$setting["optvalue"]) { |
800 | if ($if["interface"]==$setting["optvalue"]) { |
801 | $setvalue .= "<option value='".$secure->stripStr($if["interface"])."' selected>".$secure->stripStr($if["interfaceinfo"])."</option>\n"; |
801 | $setvalue .= "<option value='".$secure->stripStr($if["interface"])."' selected>".$secure->stripStr($if["interfaceinfo"])."</option>\n"; |
802 | } else { |
802 | } else { |
803 | $setvalue .= "<option value='".$secure->stripStr($if["interface"])."'>".$secure->stripStr($if["interfaceinfo"])."</option>\n"; |
803 | $setvalue .= "<option value='".$secure->stripStr($if["interface"])."'>".$secure->stripStr($if["interfaceinfo"])."</option>\n"; |
804 | }
|
804 | }
|
805 | }
|
805 | }
|
806 | $setvalue .= "</select>"; |
806 | $setvalue .= "</select>"; |
807 | $display .= "Свойство: ".$setvalue."<br>\n"; |
807 | $display .= "Свойство: ".$setvalue."<br>\n"; |
808 | } else { |
808 | } else { |
809 | $display .= "Свойство: <input type='text' name='setvalue' value='".$secure->stripStr($setting["optvalue"])."'><br>\n"; |
809 | $display .= "Свойство: <input type='text' name='setvalue' value='".$secure->stripStr($setting["optvalue"])."'><br>\n"; |
810 | }
|
810 | }
|
811 | $display .= "<input type='submit' value='Править'></form>\n"; |
811 | $display .= "<input type='submit' value='Править'></form>\n"; |
812 | } else { |
812 | } else { |
813 | $display = "Такой опции не существует"; |
813 | $display = "Такой опции не существует"; |
814 | }
|
814 | }
|
815 | break; |
815 | break; |
816 | case '3': |
816 | case '3': |
817 | // Удаление существующей опции Ant
|
817 | // Удаление существующей опции Ant
|
818 | $req =& $db->query("SELECT * FROM settings WHERE opt_id='$uid'"); |
818 | $req =& $db->query("SELECT * FROM settings WHERE opt_id='$uid'"); |
819 | if ($req->numRows()>0) { |
819 | if ($req->numRows()>0) { |
820 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
820 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
821 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление</a></div>"; |
821 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление</a></div>"; |
822 | $display .= "Удаляемая опция <em>".$secure->stripStr($setting["opt"])."</em> с свойством <em>".$secure->stripStr($setting["optvalue"])."</em><br>"; |
822 | $display .= "Удаляемая опция <em>".$secure->stripStr($setting["opt"])."</em> с свойством <em>".$secure->stripStr($setting["optvalue"])."</em><br>"; |
823 | $display .= "<form action='./process.php' method='POST'>\n"; |
823 | $display .= "<form action='./process.php' method='POST'>\n"; |
824 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
824 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
825 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
825 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
826 | $display .= "<input type='hidden' name='optID' value='".$setting["opt_id"]."'><br>\n"; |
826 | $display .= "<input type='hidden' name='optID' value='".$setting["opt_id"]."'><br>\n"; |
827 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
827 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
828 | } else { |
828 | } else { |
829 | $display = "Такой опции не существует"; |
829 | $display = "Такой опции не существует"; |
830 | }
|
830 | }
|
831 | break; |
831 | break; |
832 | }
|
832 | }
|
833 | break; |
833 | break; |
834 | case '21': |
834 | case '21': |
835 | // Управление интерфейсами
|
835 | // Управление интерфейсами
|
836 | switch($act) { |
836 | switch($act) { |
837 | case '0': |
837 | case '0': |
838 | // Список интерфейсов
|
838 | // Список интерфейсов
|
839 | $req =& $db->query("SELECT * FROM interfaces"); |
839 | $req =& $db->query("SELECT * FROM interfaces"); |
840 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
840 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
841 | $display .= "<table><tr><th>Интерфейс</th><th>Действие</th></tr>"; |
841 | $display .= "<table><tr><th>Интерфейс</th><th>Действие</th></tr>"; |
842 | if ($req->numRows()>0) { |
842 | if ($req->numRows()>0) { |
843 | while ($req->fetchInto($if, DB_FETCHMODE_ASSOC)) { |
843 | while ($req->fetchInto($if, DB_FETCHMODE_ASSOC)) { |
844 | $display .= "<tr><td>".$secure->stripStr($if["interfaceinfo"])." (".$secure->stripStr($if["interface"]).") </td>"; |
844 | $display .= "<tr><td>".$secure->stripStr($if["interfaceinfo"])." (".$secure->stripStr($if["interface"]).") </td>"; |
845 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$if["if_id"]."' class='edit'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
845 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$if["if_id"]."' class='edit'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
846 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$if["if_id"]."' class='delete'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td></tr>"; |
846 | $display .= "<a href='".$admin."?mode=".$mode."&action=3&uid=".$if["if_id"]."' class='delete'><img title='Удалить' src='$imgdir/delete.png' width='16' height='16'></a></td></tr>"; |
847 | }
|
847 | }
|
848 | }
|
848 | }
|
849 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новый интерфейс</a></p>"; |
849 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новый интерфейс</a></p>"; |
850 | break; |
850 | break; |
851 | case '1': |
851 | case '1': |
852 | // Добавление нового интерфейса
|
852 | // Добавление нового интерфейса
|
853 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
853 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
854 | $display .= "<form action='./process.php' method='POST'>\n"; |
854 | $display .= "<form action='./process.php' method='POST'>\n"; |
855 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
855 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
856 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
856 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
857 | $display .= "Интерфейс (имя файла): <input type='text' name='ifname'><br>\n"; |
857 | $display .= "Интерфейс (имя файла): <input type='text' name='ifname'><br>\n"; |
858 | $display .= "Интерфейс (название): <input type='text' name='ifinfo'><br>\n"; |
858 | $display .= "Интерфейс (название): <input type='text' name='ifinfo'><br>\n"; |
859 | $display .= "<input type='submit' value='Добавить интерфейс'></form>\n"; |
859 | $display .= "<input type='submit' value='Добавить интерфейс'></form>\n"; |
860 | break; |
860 | break; |
861 | case '2': |
861 | case '2': |
862 | // Правка интерфейса
|
862 | // Правка интерфейса
|
863 | $req =& $db->query("SELECT * FROM interfaces WHERE if_id='$uid'"); |
863 | $req =& $db->query("SELECT * FROM interfaces WHERE if_id='$uid'"); |
864 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка</a></div>"; |
864 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка</a></div>"; |
865 | if ($req->numRows()>0) { |
865 | if ($req->numRows()>0) { |
866 | $req->fetchInto($if, DB_FETCHMODE_ASSOC); |
866 | $req->fetchInto($if, DB_FETCHMODE_ASSOC); |
867 | $display .= "<form action='./process.php' method='POST'>"; |
867 | $display .= "<form action='./process.php' method='POST'>"; |
868 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
868 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
869 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
869 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
870 | $display .= "<input type='hidden' name='if' value='$uid'>\n"; |
870 | $display .= "<input type='hidden' name='if' value='$uid'>\n"; |
871 | $display .= "Интерфейс (имя файла): <input type='text' name='ifname' value='".$secure->stripStr($if["interface"])."'><br>\n"; |
871 | $display .= "Интерфейс (имя файла): <input type='text' name='ifname' value='".$secure->stripStr($if["interface"])."'><br>\n"; |
872 | $display .= "Интерфейс (название): <input type='text' name='ifinfo' value='".$secure->stripStr($if["interfaceinfo"])."'><br>\n"; |
872 | $display .= "Интерфейс (название): <input type='text' name='ifinfo' value='".$secure->stripStr($if["interfaceinfo"])."'><br>\n"; |
873 | $display .= "<input type='submit' value='Отредактировать'></form>\n"; |
873 | $display .= "<input type='submit' value='Отредактировать'></form>\n"; |
874 | } else { |
874 | } else { |
875 | $display .= "<p>Такого интерфейса не существует</p>"; |
875 | $display .= "<p>Такого интерфейса не существует</p>"; |
876 | }
|
876 | }
|
877 | break; |
877 | break; |
878 | case '3': |
878 | case '3': |
879 | // Удаление интерфейса
|
879 | // Удаление интерфейса
|
880 | $req =& $db->query("SELECT * FROM interfaces WHERE if_id='$uid'"); |
880 | $req =& $db->query("SELECT * FROM interfaces WHERE if_id='$uid'"); |
881 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление</a></div>"; |
881 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление</a></div>"; |
882 | if ($req->numRows()>0) { |
882 | if ($req->numRows()>0) { |
883 | $req->fetchInto($if, DB_FETCHMODE_ASSOC); |
883 | $req->fetchInto($if, DB_FETCHMODE_ASSOC); |
884 | $display .= "<form action='./process.php' method='POST'>"; |
884 | $display .= "<form action='./process.php' method='POST'>"; |
885 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
885 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
886 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
886 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
887 | $display .= "<input type='hidden' name='if' value='$uid'>\n"; |
887 | $display .= "<input type='hidden' name='if' value='$uid'>\n"; |
888 | $display .= "Интерфейс (имя файла): <input type='text' name='ifname' value='".$secure->stripStr($if["interface"])."' readonly><br>\n"; |
888 | $display .= "Интерфейс (имя файла): <input type='text' name='ifname' value='".$secure->stripStr($if["interface"])."' readonly><br>\n"; |
889 | $display .= "Интерфейс (название): <input type='text' name='ifinfo' value='".$secure->stripStr($if["interfaceinfo"])."' readonly><br>\n"; |
889 | $display .= "Интерфейс (название): <input type='text' name='ifinfo' value='".$secure->stripStr($if["interfaceinfo"])."' readonly><br>\n"; |
890 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
890 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
891 | }
|
891 | }
|
892 | break; |
892 | break; |
893 | }
|
893 | }
|
894 | break; |
894 | break; |
895 | case '22': |
895 | case '22': |
896 | // Управление паролем
|
896 | // Управление паролем
|
897 | switch($act) { |
897 | switch($act) { |
898 | case '0': |
898 | case '0': |
899 | // Смена пароля входа
|
899 | // Смена пароля входа
|
900 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
900 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
901 | $display .= "<form action='./process.php' method='POST'>\n"; |
901 | $display .= "<form action='./process.php' method='POST'>\n"; |
902 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
902 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
903 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
903 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
904 | $display .= "Старый пароль: <input type='password' name='oldPW'><br>\n"; |
904 | $display .= "Старый пароль: <input type='password' name='oldPW'><br>\n"; |
905 | $display .= "Новый пароль: <input type='password' name='newPW1'><br>\n"; |
905 | $display .= "Новый пароль: <input type='password' name='newPW1'><br>\n"; |
906 | $display .= "Новый пароль (еще раз): <input type='password' name='newPW2'><br>\n"; |
906 | $display .= "Новый пароль (еще раз): <input type='password' name='newPW2'><br>\n"; |
907 | $display .= "<input type='submit' value='Сменить пароль'></form>\n"; |
907 | $display .= "<input type='submit' value='Сменить пароль'></form>\n"; |
908 | break; |
908 | break; |
909 | 909 | ||
910 | break; |
910 | break; |
911 | }
|
911 | }
|
912 | break; |
912 | break; |
913 | case '23': |
913 | case '23': |
914 | // Управление темами
|
914 | // Управление темами
|
915 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
915 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
916 | if (isset($_GET['chtheme'])){ |
916 | if (isset($_GET['chtheme'])){ |
917 | $chtheme = $secure->wrapStr($_GET["chtheme"]); |
917 | $chtheme = $secure->wrapStr($_GET["chtheme"]); |
918 | $chicon = $secure->wrapStr($_GET["chicon"]); |
918 | $chicon = $secure->wrapStr($_GET["chicon"]); |
919 | $theme->setTheme($chtheme,$chicon,$db); |
919 | $theme->setTheme($chtheme,$chicon,$db); |
920 | $display.='<p style="color:red;">Тема измененна</p>'; |
920 | $display.='<p style="color:red;">Тема измененна</p>'; |
921 | }
|
921 | }
|
922 | $themename = $theme->getThemeName($core,$db); |
922 | $themename = $theme->getThemeName($core,$db); |
923 | $iconsname = $theme->getIconSetName($core,$db); |
923 | $iconsname = $theme->getIconSetName($core,$db); |
924 | 924 | ||
925 | $display.= '<form action="admin.php" method="GET">'; |
925 | $display.= '<form action="admin.php" method="GET">'; |
926 | $display.= '<input type="hidden" name="mode" value="23">'; |
926 | $display.= '<input type="hidden" name="mode" value="23">'; |
927 | $display.='<table>'; |
927 | $display.='<table>'; |
928 | $display.='<tr><td>Текущий стиль:</td><td><b>'.$themename.'</b></td><td>'; |
928 | $display.='<tr><td>Текущий стиль:</td><td><b>'.$themename.'</b></td><td>'; |
929 | $display.= '<select id="cht" name="chtheme">'; |
929 | $display.= '<select id="cht" name="chtheme">'; |
930 | $dis=$theme->getThemesList('style'); |
930 | $dis=$theme->getThemesList('style'); |
931 | foreach ($dis as $thm){ |
931 | foreach ($dis as $thm){ |
932 | if($themename==$thm){ |
932 | if($themename==$thm){ |
933 | $display.= '<option selected>'.$thm.'</option>'; |
933 | $display.= '<option selected>'.$thm.'</option>'; |
934 | }else{ |
934 | }else{ |
935 | $display.= '<option>'.$thm.'</option>'; |
935 | $display.= '<option>'.$thm.'</option>'; |
936 | }
|
936 | }
|
937 | }
|
937 | }
|
938 | $display.= '</select></td></tr>'; |
938 | $display.= '</select></td></tr>'; |
939 | $display.='<tr><td>Текущий набор иконок:</td><td><b>'.$iconsname.'</b></td><td>'; |
939 | $display.='<tr><td>Текущий набор иконок:</td><td><b>'.$iconsname.'</b></td><td>'; |
940 | $display.= '<select id="chi" name="chicon">'; |
940 | $display.= '<select id="chi" name="chicon">'; |
941 | $dis=$theme->getThemesList('icon'); |
941 | $dis=$theme->getThemesList('icon'); |
942 | foreach ($dis as $thm){ |
942 | foreach ($dis as $thm){ |
943 | if($iconsname==$thm){ |
943 | if($iconsname==$thm){ |
944 | $display.= '<option selected>'.$thm.'</option>'; |
944 | $display.= '<option selected>'.$thm.'</option>'; |
945 | }else{ |
945 | }else{ |
946 | $display.= '<option>'.$thm.'</option>'; |
946 | $display.= '<option>'.$thm.'</option>'; |
947 | }
|
947 | }
|
948 | }
|
948 | }
|
949 | $display.= '</select></td></tr></table>'; |
949 | $display.= '</select></td></tr></table>'; |
950 | $display.= '<button type="submit">Сменить тему</button>'; |
950 | $display.= '<button type="submit">Сменить тему</button>'; |
951 | $display.= '</form>'; |
951 | $display.= '</form>'; |
952 | break; |
952 | break; |
953 | break; |
953 | break; |
954 | }
|
954 | }
|
955 | 955 | ||
956 | 956 | ||
957 | $display .= "</div></div>"; |
957 | $display .= "</div></div>"; |
958 | 958 | ||
959 | $smarty->assign('feedaddr',$_SERVER["HTTP_HOST"].dirname($_SERVER["PHP_SELF"])); |
959 | $smarty->assign('feedaddr',$_SERVER["HTTP_HOST"].dirname($_SERVER["PHP_SELF"])); |
960 | $smarty->assign('error',$error); |
960 | $smarty->assign('error',$error); |
961 | $smarty->assign('header',$header); |
961 | $smarty->assign('header',$header); |
962 | $smarty->assign('login',$login); |
962 | $smarty->assign('login',$login); |
963 | $smarty->assign('menu',$menu); |
963 | $smarty->assign('menu',$menu); |
964 | $smarty->assign('display',$display); |
964 | $smarty->assign('display',$display); |
965 | $smarty->assign('antversion',$core->getSetting('version',$db)); |
965 | $smarty->assign('antversion',$core->getSetting('version',$db)); |
966 | $smarty->assign('title',$core->getSetting('codename',$db)); |
966 | $smarty->assign('title',$core->getSetting('codename',$db)); |
967 | $smarty->assign('style',$core->getCSSList($db)); |
967 | $smarty->assign('style',$core->getCSSList($db)); |
968 | $smarty->assign('theme',$theme->getThemeName($core,$db)); |
968 | $smarty->assign('theme',$theme->getThemeName($core,$db)); |
969 | $smarty->display('admin.tpl'); |
969 | $smarty->display('admin.tpl'); |
970 | 970 | ||
971 | 971 | ||
972 | ?>
|
972 | ?>
|
973 | 973 |