Редакция 279 | Редакция 286 | К новейшей редакции | Только различия | Не учитывать пробелы | Содержимое файла | Авторство | Последнее изменение | Открыть журнал | RSS
Редакция 279 | Редакция 282 | ||
---|---|---|---|
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>admin</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 | $rep =& $db->query("SELECT * FROM distribution d JOIN version v ON v.dist_id=d.dist_id WHERE v.version_id='$uid'"); |
303 | $rep =& $db->query("SELECT * FROM distribution d JOIN version v ON v.dist_id=d.dist_id WHERE v.version_id='$uid'"); |
304 | $rep->fetchInto($dist, DB_FETCHMODE_ASSOC); |
304 | $rep->fetchInto($dist, DB_FETCHMODE_ASSOC); |
305 | $dist_id = $dist["dist_id"]; |
305 | $dist_id = $dist["dist_id"]; |
306 | $dist_vname = $secure->stripStr($dist["distname"])." ".$secure->stripStr($dist["version"])." “".$secure->stripStr($dist["vname"])."”"; |
306 | $dist_vname = $secure->stripStr($dist["distname"])." ".$secure->stripStr($dist["version"])." “".$secure->stripStr($dist["vname"])."”"; |
307 | $dtype =& $db->query("SELECT * FROM scheme"); |
307 | $dtype =& $db->query("SELECT * FROM scheme"); |
308 | $rscheme = "<select name='scheme'>"; |
308 | $rscheme = "<select name='scheme'>"; |
309 | while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) { |
309 | while ($dtype->fetchInto($dtinfo, DB_FETCHMODE_ASSOC)) { |
310 | $rscheme .= "<option value='".$dtinfo["scheme_id"]."'>".$secure->stripStr($dtinfo["scheme"])."</option>"; |
310 | $rscheme .= "<option value='".$dtinfo["scheme_id"]."'>".$secure->stripStr($dtinfo["scheme"])."</option>"; |
311 | }
|
311 | }
|
312 | $rscheme .= "</select>"; |
312 | $rscheme .= "</select>"; |
313 | $origin_q =& $db->query("SELECT * FROM origin"); |
313 | $origin_q =& $db->query("SELECT * FROM origin"); |
314 | $origin = "<select name='origin'>"; |
314 | $origin = "<select name='origin'>"; |
315 | while ($origin_q->fetchInto($origin_info, DB_FETCHMODE_ASSOC)) { |
315 | while ($origin_q->fetchInto($origin_info, DB_FETCHMODE_ASSOC)) { |
316 | $origin .= "<option value='".$origin_info["orig_id"]."'>".$secure->stripStr($origin_info["origin"])."</option>"; |
316 | $origin .= "<option value='".$origin_info["orig_id"]."'>".$secure->stripStr($origin_info["origin"])."</option>"; |
317 | }
|
317 | }
|
318 | $origin .= "</select>\n"; |
318 | $origin .= "</select>\n"; |
319 | $sect =& $db->query("SELECT * FROM section s JOIN sect2dist d ON d.sect_id=s.sect_id WHERE d.dist_id='$dist_id'"); |
319 | $sect =& $db->query("SELECT * FROM section s JOIN sect2dist d ON d.sect_id=s.sect_id WHERE d.dist_id='$dist_id'"); |
320 | $list = ""; |
320 | $list = ""; |
321 | while ($sect->fetchInto($slist, DB_FETCHMODE_ASSOC)) { |
321 | while ($sect->fetchInto($slist, DB_FETCHMODE_ASSOC)) { |
322 | $list .= "<input type='checkbox' name='sect[]' value='".$slist["sect_id"]."'> <span title='".$secure->stripStr($slist["sectinfo"])."'>".$secure->stripStr($slist["sectname"])."</span> "; |
322 | $list .= "<input type='checkbox' name='sect[]' value='".$slist["sect_id"]."'> <span title='".$secure->stripStr($slist["sectinfo"])."'>".$secure->stripStr($slist["sectname"])."</span> "; |
323 | }
|
323 | }
|
324 | $type .= "</select>\n"; |
324 | $type .= "</select>\n"; |
325 | $rootfolder = "<select name='rootFolder'>\n"; |
325 | $rootfolder = "<select name='rootFolder'>\n"; |
326 | $root =& $db->query("SELECT * FROM root"); |
326 | $root =& $db->query("SELECT * FROM root"); |
327 | while ($root->fetchInto($rfi, DB_FETCHMODE_ASSOC)) { |
327 | while ($root->fetchInto($rfi, DB_FETCHMODE_ASSOC)) { |
328 | $rootfolder .= "<option value='".$rfi["root_id"]."'>".$secure->stripStr($rfi["root_folder"])."</option>"; |
328 | $rootfolder .= "<option value='".$rfi["root_id"]."'>".$secure->stripStr($rfi["root_folder"])."</option>"; |
329 | }
|
329 | }
|
330 | $rootfolder .= "</select>"; |
330 | $rootfolder .= "</select>"; |
331 | $display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
331 | $display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
332 | $display .= "<form action='./process.php' method='POST'>\n"; |
332 | $display .= "<form action='./process.php' method='POST'>\n"; |
333 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
333 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
334 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
334 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
335 | $display .= "<input type='hidden' name='vers' value='$uid'>\n"; |
335 | $display .= "<input type='hidden' name='vers' value='$uid'>\n"; |
336 | $display .= "Название репозитория (codename): <input type='text' name='repName'><br>\n"; |
336 | $display .= "Название репозитория (codename): <input type='text' name='repName'><br>\n"; |
337 | $display .= "Описание репозитория:<br> <textarea name='repInfo'></textarea><br>\n"; |
337 | $display .= "Описание репозитория:<br> <textarea name='repInfo'></textarea><br>\n"; |
338 | $display .= "Схема репозитория: ".$rscheme."<br>"; |
338 | $display .= "Схема репозитория: ".$rscheme."<br>"; |
339 | $display .= "Источник репозитория: ".$origin."<br>"; |
339 | $display .= "Источник репозитория: ".$origin."<br>"; |
340 | $display .= "Корневая папка репозитория: ".$rootfolder."<br>"; |
340 | $display .= "Корневая папка репозитория: ".$rootfolder."<br>"; |
341 | $display .= "Секции: ".$list."<br>"; |
341 | $display .= "Секции: ".$list."<br>"; |
342 | $display .= "По умолчанию: <input type='checkbox' name='default' value='1'>"; |
342 | $display .= "По умолчанию: <input type='checkbox' name='default' value='1'>"; |
343 | $display .= "<br><input type='submit' value='Создать'></form>\n"; |
343 | $display .= "<br><input type='submit' value='Создать'></form>\n"; |
344 | break; |
344 | break; |
345 | case '2': |
345 | case '2': |
346 | // Редактирование репозитория
|
346 | // Редактирование репозитория
|
347 | $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'"); |
347 | $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'"); |
348 | $rep->fetchInto($info, DB_FETCHMODE_ASSOC); |
348 | $rep->fetchInto($info, DB_FETCHMODE_ASSOC); |
349 | $dist_vname = $secure->stripStr($info["distname"])." ".$secure->stripStr($info["version"])." “".$secure->stripStr($info["vname"])."”"; |
349 | $dist_vname = $secure->stripStr($info["distname"])." ".$secure->stripStr($info["version"])." “".$secure->stripStr($info["vname"])."”"; |
350 | $tlist = "<select name='scheme'>"; |
350 | $tlist = "<select name='scheme'>"; |
351 | $sq =& $db->query("SELECT * FROM scheme"); |
351 | $sq =& $db->query("SELECT * FROM scheme"); |
352 | while ($sq->fetchInto($type, DB_FETCHMODE_ASSOC)) { |
352 | while ($sq->fetchInto($type, DB_FETCHMODE_ASSOC)) { |
353 | if ($type["scheme_id"]==$info["scheme_id"]) { |
353 | if ($type["scheme_id"]==$info["scheme_id"]) { |
354 | $tlist .= "<option value='".$type["scheme_id"]."' selected>".$secure->stripStr($type["scheme"])."</option>"; |
354 | $tlist .= "<option value='".$type["scheme_id"]."' selected>".$secure->stripStr($type["scheme"])."</option>"; |
355 | } else { |
355 | } else { |
356 | $tlist .= "<option value='".$type["scheme_id"]."'>".$secure->stripStr($type["scheme"])."</option>"; |
356 | $tlist .= "<option value='".$type["scheme_id"]."'>".$secure->stripStr($type["scheme"])."</option>"; |
357 | }
|
357 | }
|
358 | }
|
358 | }
|
359 | $tlist .= "</select>"; |
359 | $tlist .= "</select>"; |
360 | $tlist2 = "<select name='origin'>"; |
360 | $tlist2 = "<select name='origin'>"; |
361 | $sq =& $db->query("SELECT * FROM origin"); |
361 | $sq =& $db->query("SELECT * FROM origin"); |
362 | while ($sq->fetchInto($type, DB_FETCHMODE_ASSOC)) { |
362 | while ($sq->fetchInto($type, DB_FETCHMODE_ASSOC)) { |
363 | if ($type["orig_id"]==$info["orig_id"]) { |
363 | if ($type["orig_id"]==$info["orig_id"]) { |
364 | $tlist2 .= "<option value='".$type["orig_id"]."' selected>".$secure->stripStr($type["origin"])."</option>"; |
364 | $tlist2 .= "<option value='".$type["orig_id"]."' selected>".$secure->stripStr($type["origin"])."</option>"; |
365 | } else { |
365 | } else { |
366 | $tlist2 .= "<option value='".$type["orig_id"]."'>".$secure->stripStr($type["origin"])."</option>"; |
366 | $tlist2 .= "<option value='".$type["orig_id"]."'>".$secure->stripStr($type["origin"])."</option>"; |
367 | }
|
367 | }
|
368 | }
|
368 | }
|
369 | $tlist2 .= "</select>"; |
369 | $tlist2 .= "</select>"; |
370 | $list = ""; |
370 | $list = ""; |
371 | $req =& $db->query("SELECT * FROM section s JOIN sect2rep r ON s.sect_id=r.sect_id WHERE r.rep_id='$uid'"); |
371 | $req =& $db->query("SELECT * FROM section s JOIN sect2rep r ON s.sect_id=r.sect_id WHERE r.rep_id='$uid'"); |
372 | if ($req->numRows()>0) { |
372 | if ($req->numRows()>0) { |
373 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
373 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
374 | $list .= "<input type='checkbox' name='sect[]' value='".$sect["sect_id"]."' checked><span title='".$secure->stripStr($sect["sectinfo"])."'>".$secure->stripStr($sect["sectname"])."</span> "; |
374 | $list .= "<input type='checkbox' name='sect[]' value='".$sect["sect_id"]."' checked><span title='".$secure->stripStr($sect["sectinfo"])."'>".$secure->stripStr($sect["sectname"])."</span> "; |
375 | }
|
375 | }
|
376 | }
|
376 | }
|
377 | $req =& $db->query("SELECT s.* FROM section s WHERE s.sect_id NOT IN (SELECT sect_id FROM sect2rep WHERE rep_id='$uid')"); |
377 | $req =& $db->query("SELECT s.* FROM section s WHERE s.sect_id NOT IN (SELECT sect_id FROM sect2rep WHERE rep_id='$uid')"); |
378 | if ($req->numRows()>0) { |
378 | if ($req->numRows()>0) { |
379 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
379 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
380 | $list .= "<input type='checkbox' name='sect[]' value='".$sect["sect_id"]."'><span title='".$secure->stripStr($sect["sectinfo"])."'>".$secure->stripStr($sect["sectname"])."</span> "; |
380 | $list .= "<input type='checkbox' name='sect[]' value='".$sect["sect_id"]."'><span title='".$secure->stripStr($sect["sectinfo"])."'>".$secure->stripStr($sect["sectname"])."</span> "; |
381 | }
|
381 | }
|
382 | }
|
382 | }
|
383 | $rootfolder = "<select name='rootFolder'>\n"; |
383 | $rootfolder = "<select name='rootFolder'>\n"; |
384 | $req =& $db->query("SELECT * FROM root"); |
384 | $req =& $db->query("SELECT * FROM root"); |
385 | if ($req->numRows()>0) { |
385 | if ($req->numRows()>0) { |
386 | while ($req->fetchInto($rfi, DB_FETCHMODE_ASSOC)) { |
386 | while ($req->fetchInto($rfi, DB_FETCHMODE_ASSOC)) { |
387 | if ($rfi["root_id"]==$info["root_id"]) { |
387 | if ($rfi["root_id"]==$info["root_id"]) { |
388 | $rootfolder .= "<option value='".$rfi["root_id"]."' selected>".$secure->stripStr($rfi["root_folder"])."</option>"; |
388 | $rootfolder .= "<option value='".$rfi["root_id"]."' selected>".$secure->stripStr($rfi["root_folder"])."</option>"; |
389 | } else { |
389 | } else { |
390 | $rootfolder .= "<option value='".$rfi["root_id"]."'>".$secure->stripStr($rfi["root_folder"])."</option>"; |
390 | $rootfolder .= "<option value='".$rfi["root_id"]."'>".$secure->stripStr($rfi["root_folder"])."</option>"; |
391 | }
|
391 | }
|
392 | }
|
392 | }
|
393 | }
|
393 | }
|
394 | $rootfolder .= "</select>"; |
394 | $rootfolder .= "</select>"; |
395 | 395 | ||
396 | if ($info["defaultrep"]==1){$ch="checked";} else{$ch="";} |
396 | if ($info["defaultrep"]==1){$ch="checked";} else{$ch="";} |
397 | 397 | ||
398 | $display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка : ".$info["repname"]."</a></div>"; |
398 | $display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка : ".$info["repname"]."</a></div>"; |
399 | $display .= "<form action='./process.php' method='POST'>\n"; |
399 | $display .= "<form action='./process.php' method='POST'>\n"; |
400 | $display .= "<input type='hidden' name='mode' value=".$mode.">\n"; |
400 | $display .= "<input type='hidden' name='mode' value=".$mode.">\n"; |
401 | $display .= "<input type='hidden' name='act' value=".$act.">\n"; |
401 | $display .= "<input type='hidden' name='act' value=".$act.">\n"; |
402 | $display .= "<input type='hidden' name='rep' value='$uid'>\n"; |
402 | $display .= "<input type='hidden' name='rep' value='$uid'>\n"; |
403 | $display .= "Название репозитория (codename): <input type='text' name='repName' value='".$secure->stripStr($info["repname"])."'><br>\n"; |
403 | $display .= "Название репозитория (codename): <input type='text' name='repName' value='".$secure->stripStr($info["repname"])."'><br>\n"; |
404 | $display .= "Описание репозитория:<br> <textarea name='repInfo'>".$secure->stripStr($info["repdescribe"])."</textarea><br>\n"; |
404 | $display .= "Описание репозитория:<br> <textarea name='repInfo'>".$secure->stripStr($info["repdescribe"])."</textarea><br>\n"; |
405 | $display .= "Схема репозитория: ".$tlist."<br>"; |
405 | $display .= "Схема репозитория: ".$tlist."<br>"; |
406 | $display .= "Источник репозитория: ".$tlist2."<br>"; |
406 | $display .= "Источник репозитория: ".$tlist2."<br>"; |
407 | $display .= "Корневая папка репозитория: ".$rootfolder."<br>"; |
407 | $display .= "Корневая папка репозитория: ".$rootfolder."<br>"; |
408 | $display .= "Секции: ".$list."<br>"; |
408 | $display .= "Секции: ".$list."<br>"; |
409 | $display .= "По умолчанию: <input type='checkbox' name='default' value='1' ".$ch.">"; |
409 | $display .= "По умолчанию: <input type='checkbox' name='default' value='1' ".$ch.">"; |
410 | $display .= "<br><input type='submit' value='Править'></form>\n"; |
410 | $display .= "<br><input type='submit' value='Править'></form>\n"; |
411 | break; |
411 | break; |
412 | case '3': |
412 | case '3': |
413 | // Удаление репозитория
|
413 | // Удаление репозитория
|
414 | $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'"); |
414 | $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'"); |
415 | $rep->fetchInto($info, DB_FETCHMODE_ASSOC); |
415 | $rep->fetchInto($info, DB_FETCHMODE_ASSOC); |
416 | $dist_vname = $secure->stripStr($info["distname"])." ".$secure->stripStr($info["version"])." “".$secure->stripStr($info["vname"])."”"; |
416 | $dist_vname = $secure->stripStr($info["distname"])." ".$secure->stripStr($info["version"])." “".$secure->stripStr($info["vname"])."”"; |
417 | $display = "<div class='modulename'>Управление :: <a href='admin.php?mode=".$mode."'>Репозитории</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление : ".$info["repname"]."</a></div>"; |
417 | $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 .= "<form action='./process.php' method='POST'>\n"; |
418 | $display .= "<form action='./process.php' method='POST'>\n"; |
419 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
419 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
420 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
420 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
421 | $display .= "<input type='hidden' name='rep' value='$uid'>\n"; |
421 | $display .= "<input type='hidden' name='rep' value='$uid'>\n"; |
422 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
422 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
423 | break; |
423 | break; |
424 | }
|
424 | }
|
425 | break; |
425 | break; |
426 | case '5': |
426 | case '5': |
427 | // Управление разделами
|
427 | // Управление разделами
|
428 | switch ($act) { |
428 | switch ($act) { |
429 | case '0': |
429 | case '0': |
430 | // Список секций
|
430 | // Список секций
|
431 | $req =& $db->query("SELECT * FROM section"); |
431 | $req =& $db->query("SELECT * FROM section"); |
432 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
432 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
433 | $display .= "<table><tr><th>Раздел</th><th>Действие</th><th>Используется в</th></tr>\n"; |
433 | $display .= "<table><tr><th>Раздел</th><th>Действие</th><th>Используется в</th></tr>\n"; |
434 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
434 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
435 | $replist = ""; |
435 | $replist = ""; |
436 | $sreq =& $db->query("SELECT * FROM distribution d JOIN sect2dist s ON s.dist_id=d.dist_id WHERE s.sect_id='".$sect["sect_id"]."'"); |
436 | $sreq =& $db->query("SELECT * FROM distribution d JOIN sect2dist s ON s.dist_id=d.dist_id WHERE s.sect_id='".$sect["sect_id"]."'"); |
437 | while ($sreq->fetchInto($rep, DB_FETCHMODE_ASSOC)) { |
437 | while ($sreq->fetchInto($rep, DB_FETCHMODE_ASSOC)) { |
438 | $replist .= "<em>".$secure->stripStr($rep["distname"])."</em>, "; |
438 | $replist .= "<em>".$secure->stripStr($rep["distname"])."</em>, "; |
439 | }
|
439 | }
|
440 | $replist = substr($replist, 0, -2); |
440 | $replist = substr($replist, 0, -2); |
441 | $display .= "<tr><td>".$secure->stripStr($sect["sectname"])."</td>"; |
441 | $display .= "<tr><td>".$secure->stripStr($sect["sectname"])."</td>"; |
442 | $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>"; |
442 | $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>"; |
443 | $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>"; |
443 | $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>"; |
444 | $display .= "<td>".$replist."</td></tr>"; |
444 | $display .= "<td>".$replist."</td></tr>"; |
445 | }
|
445 | }
|
446 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить секцию</a></p>"; |
446 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить секцию</a></p>"; |
447 | break; |
447 | break; |
448 | case '1': |
448 | case '1': |
449 | $req =& $db->query("SELECT * FROM distribution"); |
449 | $req =& $db->query("SELECT * FROM distribution"); |
450 | while ($req->fetchInto($dist, DB_FETCHMODE_ASSOC)) { |
450 | while ($req->fetchInto($dist, DB_FETCHMODE_ASSOC)) { |
451 | $list .= "<br><input type='checkbox' name='dist' value='".$dist["dist_id"]."'>".$secure->stripStr($dist["distname"])." "; |
451 | $list .= "<br><input type='checkbox' name='dist' value='".$dist["dist_id"]."'>".$secure->stripStr($dist["distname"])." "; |
452 | }
|
452 | }
|
453 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Создание секции репозитория</div>"; |
453 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Создание секции репозитория</div>"; |
454 | $display .= "<form action='./process.php' method='POST'>\n"; |
454 | $display .= "<form action='./process.php' method='POST'>\n"; |
455 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
455 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
456 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
456 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
457 | $display .= "Название секции (codename): <input type='text' name='sectName'><br>\n"; |
457 | $display .= "Название секции (codename): <input type='text' name='sectName'><br>\n"; |
458 | $display .= "Описание секции:<br> <textarea name='sectInfo'></textarea><br>\n"; |
458 | $display .= "Описание секции:<br> <textarea name='sectInfo'></textarea><br>\n"; |
459 | $display .= "Используется в дистрибутивах: ".$list; |
459 | $display .= "Используется в дистрибутивах: ".$list; |
460 | $display .= "<br><input type='submit' value='Добавить'></form>\n"; |
460 | $display .= "<br><input type='submit' value='Добавить'></form>\n"; |
461 | break; |
461 | break; |
462 | case '2': |
462 | case '2': |
463 | $req =& $db->query("SELECT * FROM distribution d JOIN sect2dist s ON s.dist_id=d.dist_id WHERE s.sect_id='$uid'"); |
463 | $req =& $db->query("SELECT * FROM distribution d JOIN sect2dist s ON s.dist_id=d.dist_id WHERE s.sect_id='$uid'"); |
464 | if ($req->numRows()>0) { |
464 | if ($req->numRows()>0) { |
465 | while ($req->fetchInto($dist, DB_FETCHMODE_ASSOC)) { |
465 | while ($req->fetchInto($dist, DB_FETCHMODE_ASSOC)) { |
466 | $list .= "<br><input type='checkbox' name='dist[]' value='".$dist["dist_id"]."' checked>".$secure->stripStr($dist["distname"])." "; |
466 | $list .= "<br><input type='checkbox' name='dist[]' value='".$dist["dist_id"]."' checked>".$secure->stripStr($dist["distname"])." "; |
467 | }
|
467 | }
|
468 | }
|
468 | }
|
469 | $req =& $db->query("SELECT d.* FROM distribution d WHERE dist_id NOT IN (SELECT dist_id FROM sect2dist WHERE sect_id='$uid')"); |
469 | $req =& $db->query("SELECT d.* FROM distribution d WHERE dist_id NOT IN (SELECT dist_id FROM sect2dist WHERE sect_id='$uid')"); |
470 | if ($req->numRows()>0) { |
470 | if ($req->numRows()>0) { |
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 | }
|
474 | }
|
475 | $req =& $db->query("SELECT * FROM section WHERE sect_id='$uid'"); |
475 | $req =& $db->query("SELECT * FROM section WHERE sect_id='$uid'"); |
476 | $req->fetchInto($sect, DB_FETCHMODE_ASSOC); |
476 | $req->fetchInto($sect, DB_FETCHMODE_ASSOC); |
477 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Правка секции репозитория</div>"; |
477 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Правка секции репозитория</div>"; |
478 | $display .= "<form action='./process.php' method='POST'>\n"; |
478 | $display .= "<form action='./process.php' method='POST'>\n"; |
479 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
479 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
480 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
480 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
481 | $display .= "<input type='hidden' name='sectID' value='$uid'>\n"; |
481 | $display .= "<input type='hidden' name='sectID' value='$uid'>\n"; |
482 | $display .= "Название секции (codename): <input type='text' name='sectName' value='".$secure->stripStr($sect["sectname"])."'><br>\n"; |
482 | $display .= "Название секции (codename): <input type='text' name='sectName' value='".$secure->stripStr($sect["sectname"])."'><br>\n"; |
483 | $display .= "Описание секции:<br> <textarea name='sectInfo'>".$secure->stripStr($sect["sectinfo"])."</textarea><br>\n"; |
483 | $display .= "Описание секции:<br> <textarea name='sectInfo'>".$secure->stripStr($sect["sectinfo"])."</textarea><br>\n"; |
484 | $display .= "Используется в дистрибутивах: ".$list; |
484 | $display .= "Используется в дистрибутивах: ".$list; |
485 | $display .= "<br><input type='submit' value='Править'></form>\n"; |
485 | $display .= "<br><input type='submit' value='Править'></form>\n"; |
486 | break; |
486 | break; |
487 | case '3': |
487 | case '3': |
488 | $req =& $db->query("SELECT * FROM section WHERE sect_id='$uid'"); |
488 | $req =& $db->query("SELECT * FROM section WHERE sect_id='$uid'"); |
489 | $req->fetchInto($sect, DB_FETCHMODE_ASSOC); |
489 | $req->fetchInto($sect, DB_FETCHMODE_ASSOC); |
490 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Удаление секции <em>".$secure->stripStr($sect["sectname"])."</em></div>"; |
490 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Секции</a> :: Удаление секции <em>".$secure->stripStr($sect["sectname"])."</em></div>"; |
491 | $display .= "<form action='./process.php' method='POST'>\n"; |
491 | $display .= "<form action='./process.php' method='POST'>\n"; |
492 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
492 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
493 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
493 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
494 | $display .= "<input type='hidden' name='sectID' value='$uid'>\n"; |
494 | $display .= "<input type='hidden' name='sectID' value='$uid'>\n"; |
495 | $display .= "<br><input type='submit' value='Удалить'></form>\n"; |
495 | $display .= "<br><input type='submit' value='Удалить'></form>\n"; |
496 | break; |
496 | break; |
497 | }
|
497 | }
|
498 | break; |
498 | break; |
499 | case '6': |
499 | case '6': |
500 | // Управление схемами репозиториев
|
500 | // Управление схемами репозиториев
|
501 | switch ($act) { |
501 | switch ($act) { |
502 | case '0': |
502 | case '0': |
503 | // Список схем
|
503 | // Список схем
|
504 | $req =& $db->query("SELECT * FROM scheme"); |
504 | $req =& $db->query("SELECT * FROM scheme"); |
505 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
505 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
506 | $display .= "<table><th>Схема</th><th>Действие</th></tr>"; |
506 | $display .= "<table><th>Схема</th><th>Действие</th></tr>"; |
507 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
507 | while ($req->fetchInto($sect, DB_FETCHMODE_ASSOC)) { |
508 | $display .= "<tr><td>".$secure->stripStr($sect["scheme"])."</td>"; |
508 | $display .= "<tr><td>".$secure->stripStr($sect["scheme"])."</td>"; |
509 | $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>"; |
509 | $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>"; |
510 | $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>"; |
510 | $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>"; |
511 | }
|
511 | }
|
512 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новую схему</a></p>"; |
512 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новую схему</a></p>"; |
513 | break; |
513 | break; |
514 | case '1': |
514 | case '1': |
515 | // Добавление новой схемы
|
515 | // Добавление новой схемы
|
516 | $display = "<div class='modulename'><a href='admin.php?mode=5'>Схемы</a> :: Создание схемы репозитория</div>"; |
516 | $display = "<div class='modulename'><a href='admin.php?mode=5'>Схемы</a> :: Создание схемы репозитория</div>"; |
517 | $display .= "<form action='./process.php' method='POST'>\n"; |
517 | $display .= "<form action='./process.php' method='POST'>\n"; |
518 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
518 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
519 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
519 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
520 | $display .= "Схема репозитория: <input type='text' name='scheme'><br>\n"; |
520 | $display .= "Схема репозитория: <input type='text' name='scheme'><br>\n"; |
521 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
521 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
522 | break; |
522 | break; |
523 | case '2': |
523 | case '2': |
524 | // Правка существующей схемы
|
524 | // Правка существующей схемы
|
525 | $req =& $db->query("SELECT * FROM scheme WHERE scheme_id='$uid'"); |
525 | $req =& $db->query("SELECT * FROM scheme WHERE scheme_id='$uid'"); |
526 | if ($req->numRows()>0) { |
526 | if ($req->numRows()>0) { |
527 | $req->fetchInto($scheme, DB_FETCHMODE_ASSOC); |
527 | $req->fetchInto($scheme, DB_FETCHMODE_ASSOC); |
528 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Схемы</a> :: Правка схемы репозитория</div>"; |
528 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Схемы</a> :: Правка схемы репозитория</div>"; |
529 | $display .= "<form action='./process.php' method='POST'>\n"; |
529 | $display .= "<form action='./process.php' method='POST'>\n"; |
530 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
530 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
531 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
531 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
532 | $display .= "<input type='hidden' name='schemeID' value='".$secure->stripStr($scheme["scheme_id"])."'><br>\n"; |
532 | $display .= "<input type='hidden' name='schemeID' value='".$secure->stripStr($scheme["scheme_id"])."'><br>\n"; |
533 | $display .= "Схема репозитория: <input type='text' name='scheme' value='".$secure->stripStr($scheme["scheme"])."'><br>\n"; |
533 | $display .= "Схема репозитория: <input type='text' name='scheme' value='".$secure->stripStr($scheme["scheme"])."'><br>\n"; |
534 | $display .= "<input type='submit' value='Править'></form>\n"; |
534 | $display .= "<input type='submit' value='Править'></form>\n"; |
535 | } else { |
535 | } else { |
536 | $display = "Такой схемы репозитория не существует"; |
536 | $display = "Такой схемы репозитория не существует"; |
537 | }
|
537 | }
|
538 | break; |
538 | break; |
539 | case '3': |
539 | case '3': |
540 | // Удаление существующей схемы
|
540 | // Удаление существующей схемы
|
541 | $req =& $db->query("SELECT * FROM scheme WHERE scheme_id='$uid'"); |
541 | $req =& $db->query("SELECT * FROM scheme WHERE scheme_id='$uid'"); |
542 | if ($req->numRows()>0) { |
542 | if ($req->numRows()>0) { |
543 | $req->fetchInto($scheme, DB_FETCHMODE_ASSOC); |
543 | $req->fetchInto($scheme, DB_FETCHMODE_ASSOC); |
544 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Схемы</a> :: Удаление схемы репозитория</div>"; |
544 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Схемы</a> :: Удаление схемы репозитория</div>"; |
545 | $display .= "Удаляемая схема: ".$secure->stripStr($scheme["scheme"])."<br>"; |
545 | $display .= "Удаляемая схема: ".$secure->stripStr($scheme["scheme"])."<br>"; |
546 | $display .= "<form action='./process.php' method='POST'>\n"; |
546 | $display .= "<form action='./process.php' method='POST'>\n"; |
547 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
547 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
548 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
548 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
549 | $display .= "<input type='hidden' name='schemeID' value='".$scheme["scheme_id"]."'><br>\n"; |
549 | $display .= "<input type='hidden' name='schemeID' value='".$scheme["scheme_id"]."'><br>\n"; |
550 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
550 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
551 | } else { |
551 | } else { |
552 | $display = "Такой схемы репозитория не существует"; |
552 | $display = "Такой схемы репозитория не существует"; |
553 | }
|
553 | }
|
554 | break; |
554 | break; |
555 | }
|
555 | }
|
556 | break; |
556 | break; |
557 | case '7': |
557 | case '7': |
558 | // Управление типами репозиториев
|
558 | // Управление типами репозиториев
|
559 | switch ($act) { |
559 | switch ($act) { |
560 | case '0': |
560 | case '0': |
561 | // Список типов репозиториев
|
561 | // Список типов репозиториев
|
562 | $req =& $db->query("SELECT * FROM rtype"); |
562 | $req =& $db->query("SELECT * FROM rtype"); |
563 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
563 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
564 | $display .= "<table><tr><th>Тип</th><th>Действие</th></tr>"; |
564 | $display .= "<table><tr><th>Тип</th><th>Действие</th></tr>"; |
565 | if ($req->numRows()>0) { |
565 | if ($req->numRows()>0) { |
566 | while ($req->fetchInto($setting, DB_FETCHMODE_ASSOC)) { |
566 | while ($req->fetchInto($setting, DB_FETCHMODE_ASSOC)) { |
567 | $display .= "<tr><td>".$secure->stripStr($setting["rtype"])."</td>"; |
567 | $display .= "<tr><td>".$secure->stripStr($setting["rtype"])."</td>"; |
568 | $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>"; |
568 | $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>"; |
569 | $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>"; |
569 | $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>"; |
570 | }
|
570 | }
|
571 | }
|
571 | }
|
572 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новый тип репозитория</a></p>"; |
572 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новый тип репозитория</a></p>"; |
573 | break; |
573 | break; |
574 | case '1': |
574 | case '1': |
575 | // Добавление нового типа репозитория
|
575 | // Добавление нового типа репозитория
|
576 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Создание нового типа репозитория</div>"; |
576 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Создание нового типа репозитория</div>"; |
577 | $display .= "<form action='./process.php' method='POST'>\n"; |
577 | $display .= "<form action='./process.php' method='POST'>\n"; |
578 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
578 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
579 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
579 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
580 | $display .= "Тип: <input type='text' name='rtype'><br>\n"; |
580 | $display .= "Тип: <input type='text' name='rtype'><br>\n"; |
581 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
581 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
582 | break; |
582 | break; |
583 | case '2': |
583 | case '2': |
584 | // Правка существующего типа репозитория
|
584 | // Правка существующего типа репозитория
|
585 | $req =& $db->query("SELECT * FROM rtype WHERE rtype_id='$uid'"); |
585 | $req =& $db->query("SELECT * FROM rtype WHERE rtype_id='$uid'"); |
586 | if ($req->numRows()>0) { |
586 | if ($req->numRows()>0) { |
587 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
587 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
588 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Правка типа репозитория</div>"; |
588 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Правка типа репозитория</div>"; |
589 | $display .= "<form action='./process.php' method='POST'>\n"; |
589 | $display .= "<form action='./process.php' method='POST'>\n"; |
590 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
590 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
591 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
591 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
592 | $display .= "<input type='hidden' name='rtypeID' value='".$secure->stripStr($setting["rtype_id"])."'><br>\n"; |
592 | $display .= "<input type='hidden' name='rtypeID' value='".$secure->stripStr($setting["rtype_id"])."'><br>\n"; |
593 | $display .= "Тип: <input type='text' name='rtype' value='".$secure->stripStr($setting["rtype"])."'><br>\n"; |
593 | $display .= "Тип: <input type='text' name='rtype' value='".$secure->stripStr($setting["rtype"])."'><br>\n"; |
594 | $display .= "<input type='submit' value='Править'></form>\n"; |
594 | $display .= "<input type='submit' value='Править'></form>\n"; |
595 | } else { |
595 | } else { |
596 | $display = "Такого типа репозитория не существует"; |
596 | $display = "Такого типа репозитория не существует"; |
597 | }
|
597 | }
|
598 | break; |
598 | break; |
599 | case '3': |
599 | case '3': |
600 | // Удаление существующего типа репозитория
|
600 | // Удаление существующего типа репозитория
|
601 | $req =& $db->query("SELECT * FROM rtype WHERE rtype_id='$uid'"); |
601 | $req =& $db->query("SELECT * FROM rtype WHERE rtype_id='$uid'"); |
602 | if ($req->numRows()>0) { |
602 | if ($req->numRows()>0) { |
603 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
603 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
604 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Удаление существующего типа репозитория</div>"; |
604 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Типы репозиториев</a> :: Удаление существующего типа репозитория</div>"; |
605 | $display .= "Удаляемый тип <em>".$secure->stripStr($setting["rtype"])."</em><br>"; |
605 | $display .= "Удаляемый тип <em>".$secure->stripStr($setting["rtype"])."</em><br>"; |
606 | $display .= "<form action='./process.php' method='POST'>\n"; |
606 | $display .= "<form action='./process.php' method='POST'>\n"; |
607 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
607 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
608 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
608 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
609 | $display .= "<input type='hidden' name='rtypeID' value='".$setting["rtype_id"]."'><br>\n"; |
609 | $display .= "<input type='hidden' name='rtypeID' value='".$setting["rtype_id"]."'><br>\n"; |
610 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
610 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
611 | } else { |
611 | } else { |
612 | $display = "Такого типа репозитория не существует"; |
612 | $display = "Такого типа репозитория не существует"; |
613 | }
|
613 | }
|
614 | break; |
614 | break; |
615 | }
|
615 | }
|
616 | break; |
616 | break; |
617 | case '8': |
617 | case '8': |
618 | // Управление корневыми папками репозиториев
|
618 | // Управление корневыми папками репозиториев
|
619 | switch ($act) { |
619 | switch ($act) { |
620 | case '0': |
620 | case '0': |
621 | // Список корневых папок репозиториев
|
621 | // Список корневых папок репозиториев
|
622 | $req =& $db->query("SELECT * FROM root"); |
622 | $req =& $db->query("SELECT * FROM root"); |
623 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
623 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
624 | $display .= "<table><tr><th>Путь</th><th>Действие</th></tr>\n"; |
624 | $display .= "<table><tr><th>Путь</th><th>Действие</th></tr>\n"; |
625 | if ($req->numRows()>0) { |
625 | if ($req->numRows()>0) { |
626 | $display .= "<ul>\n"; |
626 | $display .= "<ul>\n"; |
627 | while ($req->fetchInto($root, DB_FETCHMODE_ASSOC)) { |
627 | while ($req->fetchInto($root, DB_FETCHMODE_ASSOC)) { |
628 | $display .= "<tr><td>".$secure->stripStr($root["root_folder"])."</td>"; |
628 | $display .= "<tr><td>".$secure->stripStr($root["root_folder"])."</td>"; |
629 | $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>"; |
629 | $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>"; |
630 | $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>"; |
630 | $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>"; |
631 | }
|
631 | }
|
632 | $display .= "</table>\n"; |
632 | $display .= "</table>\n"; |
633 | } else { |
633 | } else { |
634 | $display .= "<p>Ни одной корневой папки не найдено.</p>"; |
634 | $display .= "<p>Ни одной корневой папки не найдено.</p>"; |
635 | }
|
635 | }
|
636 | $display .= "<p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новую корневую папку репозиториев</a></p>"; |
636 | $display .= "<p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новую корневую папку репозиториев</a></p>"; |
637 | break; |
637 | break; |
638 | case '1': |
638 | case '1': |
639 | // Добавление новой корневой папки репозиториев
|
639 | // Добавление новой корневой папки репозиториев
|
640 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Добавление корневой папки</div>"; |
640 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Добавление корневой папки</div>"; |
641 | $display .= "<form action='./process.php' method='post'>\n"; |
641 | $display .= "<form action='./process.php' method='post'>\n"; |
642 | $display .= "<input type='hidden' name='mode' value='".$mode."'>"; |
642 | $display .= "<input type='hidden' name='mode' value='".$mode."'>"; |
643 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
643 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
644 | $display .= "Корневая папка: <input type='text' name='rootFolder'><br>\n"; |
644 | $display .= "Корневая папка: <input type='text' name='rootFolder'><br>\n"; |
645 | $display .= "<input type='submit' value='Создать'>\n</form>\n"; |
645 | $display .= "<input type='submit' value='Создать'>\n</form>\n"; |
646 | break; |
646 | break; |
647 | case '2': |
647 | case '2': |
648 | // Редактирование корневой папки репозиториев
|
648 | // Редактирование корневой папки репозиториев
|
649 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Редактирование корневой папки</div>"; |
649 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Редактирование корневой папки</div>"; |
650 | $req =& $db->query("SELECT * FROM root WHERE root_id='$uid'"); |
650 | $req =& $db->query("SELECT * FROM root WHERE root_id='$uid'"); |
651 | if ($req->numRows()>0) { |
651 | if ($req->numRows()>0) { |
652 | $req->fetchInto($root, DB_FETCHMODE_ASSOC); |
652 | $req->fetchInto($root, DB_FETCHMODE_ASSOC); |
653 | $display .= "<form action='./process.php' method='post'>\n"; |
653 | $display .= "<form action='./process.php' method='post'>\n"; |
654 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
654 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
655 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
655 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
656 | $display .= "<input type='hidden' name='rootID' value='$uid'>\n"; |
656 | $display .= "<input type='hidden' name='rootID' value='$uid'>\n"; |
657 | $display .= "Корневая папка репозитория: <input type='text' name='rootFolder' value='".$secure->stripStr($root["root_folder"])."'><br>\n"; |
657 | $display .= "Корневая папка репозитория: <input type='text' name='rootFolder' value='".$secure->stripStr($root["root_folder"])."'><br>\n"; |
658 | $display .= "<input type='submit' value='Редактировать'>\n</form>\n"; |
658 | $display .= "<input type='submit' value='Редактировать'>\n</form>\n"; |
659 | } else { |
659 | } else { |
660 | $display .= "<p>Такой корневой папки репозиториев не существует</p>"; |
660 | $display .= "<p>Такой корневой папки репозиториев не существует</p>"; |
661 | }
|
661 | }
|
662 | break; |
662 | break; |
663 | case '3': |
663 | case '3': |
664 | // Удаление корневой папки репозиториев
|
664 | // Удаление корневой папки репозиториев
|
665 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Удаление корневой папки</div>"; |
665 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Корневые пути</a> :: Удаление корневой папки</div>"; |
666 | $req =& $db->query("SELECT * FROM root WHERE root_id='$uid'"); |
666 | $req =& $db->query("SELECT * FROM root WHERE root_id='$uid'"); |
667 | if ($req->numRows()>0) { |
667 | if ($req->numRows()>0) { |
668 | $req->fetchInto($root, DB_FETCHMODE_ASSOC); |
668 | $req->fetchInto($root, DB_FETCHMODE_ASSOC); |
669 | $display .= "<form action='./process.php' method='post'>\n"; |
669 | $display .= "<form action='./process.php' method='post'>\n"; |
670 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
670 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
671 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
671 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
672 | $display .= "<input type='hidden' name='rootID' value='$uid'>\n"; |
672 | $display .= "<input type='hidden' name='rootID' value='$uid'>\n"; |
673 | $display .= "Корневая папка репозитория: <input type='text' name='rootFolder' value='".$secure->stripStr($root["root_folder"])."' readonly><br>\n"; |
673 | $display .= "Корневая папка репозитория: <input type='text' name='rootFolder' value='".$secure->stripStr($root["root_folder"])."' readonly><br>\n"; |
674 | $display .= "<input type='submit' value='Удалить'>\n</form>\n"; |
674 | $display .= "<input type='submit' value='Удалить'>\n</form>\n"; |
675 | } else { |
675 | } else { |
676 | $display .= "<p>Такой корневой папки не существует</p>"; |
676 | $display .= "<p>Такой корневой папки не существует</p>"; |
677 | }
|
677 | }
|
678 | break; |
678 | break; |
679 | }
|
679 | }
|
680 | break; |
680 | break; |
681 | case '9': |
681 | case '9': |
682 | // Работа с зеркалами репозиториев
|
682 | // Работа с зеркалами репозиториев
|
683 | switch ($act) { |
683 | switch ($act) { |
684 | case '0': |
684 | case '0': |
685 | // Список зеркал
|
685 | // Список зеркал
|
686 | $mirr =& $db->query("SELECT * FROM mirror"); |
686 | $mirr =& $db->query("SELECT * FROM mirror"); |
687 | if ($mirr->numRows()>0) { |
687 | if ($mirr->numRows()>0) { |
688 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
688 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
689 | $display .= "<table><tr><th>Зеркало</th><th>Действие</th></tr>\n"; |
689 | $display .= "<table><tr><th>Зеркало</th><th>Действие</th></tr>\n"; |
690 | while ($mirr->fetchInto($info, DB_FETCHMODE_ASSOC)) { |
690 | while ($mirr->fetchInto($info, DB_FETCHMODE_ASSOC)) { |
691 | $display .= "<tr><td>".$secure->stripStr($info["mname"])."</td>\n"; |
691 | $display .= "<tr><td>".$secure->stripStr($info["mname"])."</td>\n"; |
692 | $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>"; |
692 | $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>"; |
693 | $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"; |
693 | $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"; |
694 | $display .= "</tr>"; |
694 | $display .= "</tr>"; |
695 | }
|
695 | }
|
696 | }
|
696 | }
|
697 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить зеркало репозиториев</a></p>\n"; |
697 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить зеркало репозиториев</a></p>\n"; |
698 | break; |
698 | break; |
699 | case '1': |
699 | case '1': |
700 | // Добавление нового зеркала
|
700 | // Добавление нового зеркала
|
701 | $display = "<div class='modulename'>Справочники :: <a href='admin.php?mode=".$mode."'>Зеркала</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
701 | $display = "<div class='modulename'>Справочники :: <a href='admin.php?mode=".$mode."'>Зеркала</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
702 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
702 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
703 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
703 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
704 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
704 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
705 | $display .= "Название зеркала: <input type='text' name='mname'><br>\n"; |
705 | $display .= "Название зеркала: <input type='text' name='mname'><br>\n"; |
706 | $display .= "URL зеркала: <input type='text' name='murl'><br>\n"; |
706 | $display .= "URL зеркала: <input type='text' name='murl'><br>\n"; |
707 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
707 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
708 | break; |
708 | break; |
709 | case '2': |
709 | case '2': |
710 | // Правка существующего зеркала
|
710 | // Правка существующего зеркала
|
711 | $mirr =& $db->query("SELECT * FROM mirror WHERE mirror_id='$uid'"); |
711 | $mirr =& $db->query("SELECT * FROM mirror WHERE mirror_id='$uid'"); |
712 | $mirr->fetchInto($info, DB_FETCHMODE_ASSOC); |
712 | $mirr->fetchInto($info, DB_FETCHMODE_ASSOC); |
713 | $type .= "</select>\n"; |
713 | $type .= "</select>\n"; |
714 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Зеркала</a> :: Правка зеркала репозиториев <em>'".$secure->stripStr($info["mname"])."'</em></div>"; |
714 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Зеркала</a> :: Правка зеркала репозиториев <em>'".$secure->stripStr($info["mname"])."'</em></div>"; |
715 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
715 | $display .= "<form action='./process.php' method='POST' enctype='multipart/form-data'>\n"; |
716 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
716 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
717 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
717 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
718 | $display .= "<input type='hidden' name='mirrorID' value='$uid'>\n"; |
718 | $display .= "<input type='hidden' name='mirrorID' value='$uid'>\n"; |
719 | $display .= "Название источника: <input type='text' name='mname' value='".$secure->stripStr($info["mname"])."'><br>\n"; |
719 | $display .= "Название источника: <input type='text' name='mname' value='".$secure->stripStr($info["mname"])."'><br>\n"; |
720 | $display .= "URL источника: <input type='text' name='murl' value='".$secure->stripStr($info["murl"])."'><br>\n"; |
720 | $display .= "URL источника: <input type='text' name='murl' value='".$secure->stripStr($info["murl"])."'><br>\n"; |
721 | $display .= "<input type='submit' value='Править'></form>\n"; |
721 | $display .= "<input type='submit' value='Править'></form>\n"; |
722 | break; |
722 | break; |
723 | case '3': |
723 | case '3': |
724 | // Удаление существующего зеркала
|
724 | // Удаление существующего зеркала
|
725 | $orig =& $db->query("SELECT * FROM mirror WHERE mirror_id='$uid'"); |
725 | $orig =& $db->query("SELECT * FROM mirror WHERE mirror_id='$uid'"); |
726 | $orig->fetchInto($info, DB_FETCHMODE_ASSOC); |
726 | $orig->fetchInto($info, DB_FETCHMODE_ASSOC); |
727 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Зеркала</a> :: Удаление зеркала репозиториев <em>'".$secure->stripStr($info["mname"])."'</em></div>"; |
727 | $display = "<div class='modulename'><a href='admin.php?mode=".$mode."'>Зеркала</a> :: Удаление зеркала репозиториев <em>'".$secure->stripStr($info["mname"])."'</em></div>"; |
728 | $display .= "<form action='./process.php' method='POST'>\n"; |
728 | $display .= "<form action='./process.php' method='POST'>\n"; |
729 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
729 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
730 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
730 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
731 | $display .= "<input type='hidden' name='mirrorID' value='$uid'>\n"; |
731 | $display .= "<input type='hidden' name='mirrorID' value='$uid'>\n"; |
732 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
732 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
733 | break; |
733 | break; |
734 | }
|
734 | }
|
735 | break; |
735 | break; |
736 | case '20': |
736 | case '20': |
737 | // Управление опциями Ant
|
737 | // Управление опциями Ant
|
738 | switch ($act) { |
738 | switch ($act) { |
739 | case '0': |
739 | case '0': |
740 | // Список опций Ant
|
740 | // Список опций Ant
|
741 | $req =& $db->query("SELECT * FROM settings"); |
741 | $req =& $db->query("SELECT * FROM settings"); |
742 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
742 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
743 | $display .= "<table><tr><th>Опция</th><th>Действие</th><th>Значение</th></tr>"; |
743 | $display .= "<table><tr><th>Опция</th><th>Действие</th><th>Значение</th></tr>"; |
744 | if ($req->numRows()>0) { |
744 | if ($req->numRows()>0) { |
745 | while ($req->fetchInto($setting, DB_FETCHMODE_ASSOC)) { |
745 | while ($req->fetchInto($setting, DB_FETCHMODE_ASSOC)) { |
746 | $display .= "<tr><td>".$secure->stripStr($setting["opt"])."</td>"; |
746 | $display .= "<tr><td>".$secure->stripStr($setting["opt"])."</td>"; |
747 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$setting["opt_id"]."'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
747 | $display .= "<td><a href='".$admin."?mode=".$mode."&action=2&uid=".$setting["opt_id"]."'><img title='Редактировать' src='$imgdir/edit.png' width='16' height='16'></a>"; |
748 | $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>"; |
748 | $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>"; |
749 | $display .= "<td>".$secure->stripStr($setting["optvalue"])."</td></tr>"; |
749 | $display .= "<td>".$secure->stripStr($setting["optvalue"])."</td></tr>"; |
750 | }
|
750 | }
|
751 | }
|
751 | }
|
752 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новую опцию</a></p>"; |
752 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новую опцию</a></p>"; |
753 | break; |
753 | break; |
754 | case '1': |
754 | case '1': |
755 | // Добавление новой опции Ant
|
755 | // Добавление новой опции Ant
|
756 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
756 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
757 | $display .= "<form action='./process.php' method='POST'>\n"; |
757 | $display .= "<form action='./process.php' method='POST'>\n"; |
758 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
758 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
759 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
759 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
760 | $display .= "Настройка (латиница, без пробелов): <input type='text' name='setoption'><br>\n"; |
760 | $display .= "Настройка (латиница, без пробелов): <input type='text' name='setoption'><br>\n"; |
761 | $display .= "Свойство (значение) настройки: <input type='text' name='setvalue'><br>\n"; |
761 | $display .= "Свойство (значение) настройки: <input type='text' name='setvalue'><br>\n"; |
762 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
762 | $display .= "<input type='submit' value='Добавить'></form>\n"; |
763 | break; |
763 | break; |
764 | case '2': |
764 | case '2': |
765 | // Правка существующей опции Ant
|
765 | // Правка существующей опции Ant
|
766 | $req =& $db->query("SELECT * FROM settings WHERE opt_id='$uid'"); |
766 | $req =& $db->query("SELECT * FROM settings WHERE opt_id='$uid'"); |
767 | if ($req->numRows()>0) { |
767 | if ($req->numRows()>0) { |
768 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
768 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
769 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка</a></div>"; |
769 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка</a></div>"; |
770 | $display .= "<form action='./process.php' method='POST'>\n"; |
770 | $display .= "<form action='./process.php' method='POST'>\n"; |
771 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
771 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
772 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
772 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
773 | $display .= "<input type='hidden' name='optID' value='".$secure->stripStr($setting["opt_id"])."'><br>\n"; |
773 | $display .= "<input type='hidden' name='optID' value='".$secure->stripStr($setting["opt_id"])."'><br>\n"; |
774 | $display .= "Настройка: <input type='text' name='setoption' value='".$secure->stripStr($setting["opt"])."' readonly><br>\n"; |
774 | $display .= "Настройка: <input type='text' name='setoption' value='".$secure->stripStr($setting["opt"])."' readonly><br>\n"; |
775 | if ($setting["opt"]=="interface") { |
775 | if ($setting["opt"]=="interface") { |
776 | $sq =& $db->query("SELECT * FROM interfaces"); |
776 | $sq =& $db->query("SELECT * FROM interfaces"); |
777 | $setvalue = "<select name='setvalue'>"; |
777 | $setvalue = "<select name='setvalue'>"; |
778 | while ($sq->fetchInto($if, DB_FETCHMODE_ASSOC)) { |
778 | while ($sq->fetchInto($if, DB_FETCHMODE_ASSOC)) { |
779 | if ($if["interface"]==$setting["optvalue"]) { |
779 | if ($if["interface"]==$setting["optvalue"]) { |
780 | $setvalue .= "<option value='".$secure->stripStr($if["interface"])."' selected>".$secure->stripStr($if["interfaceinfo"])."</option>\n"; |
780 | $setvalue .= "<option value='".$secure->stripStr($if["interface"])."' selected>".$secure->stripStr($if["interfaceinfo"])."</option>\n"; |
781 | } else { |
781 | } else { |
782 | $setvalue .= "<option value='".$secure->stripStr($if["interface"])."'>".$secure->stripStr($if["interfaceinfo"])."</option>\n"; |
782 | $setvalue .= "<option value='".$secure->stripStr($if["interface"])."'>".$secure->stripStr($if["interfaceinfo"])."</option>\n"; |
783 | }
|
783 | }
|
784 | }
|
784 | }
|
785 | $setvalue .= "</select>"; |
785 | $setvalue .= "</select>"; |
786 | $display .= "Свойство: ".$setvalue."<br>\n"; |
786 | $display .= "Свойство: ".$setvalue."<br>\n"; |
787 | } else { |
787 | } else { |
788 | $display .= "Свойство: <input type='text' name='setvalue' value='".$secure->stripStr($setting["optvalue"])."'><br>\n"; |
788 | $display .= "Свойство: <input type='text' name='setvalue' value='".$secure->stripStr($setting["optvalue"])."'><br>\n"; |
789 | }
|
789 | }
|
790 | $display .= "<input type='submit' value='Править'></form>\n"; |
790 | $display .= "<input type='submit' value='Править'></form>\n"; |
791 | } else { |
791 | } else { |
792 | $display = "Такой опции не существует"; |
792 | $display = "Такой опции не существует"; |
793 | }
|
793 | }
|
794 | break; |
794 | break; |
795 | case '3': |
795 | case '3': |
796 | // Удаление существующей опции Ant
|
796 | // Удаление существующей опции Ant
|
797 | $req =& $db->query("SELECT * FROM settings WHERE opt_id='$uid'"); |
797 | $req =& $db->query("SELECT * FROM settings WHERE opt_id='$uid'"); |
798 | if ($req->numRows()>0) { |
798 | if ($req->numRows()>0) { |
799 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
799 | $req->fetchInto($setting, DB_FETCHMODE_ASSOC); |
800 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление</a></div>"; |
800 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Опции</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление</a></div>"; |
801 | $display .= "Удаляемая опция <em>".$secure->stripStr($setting["opt"])."</em> с свойством <em>".$secure->stripStr($setting["optvalue"])."</em><br>"; |
801 | $display .= "Удаляемая опция <em>".$secure->stripStr($setting["opt"])."</em> с свойством <em>".$secure->stripStr($setting["optvalue"])."</em><br>"; |
802 | $display .= "<form action='./process.php' method='POST'>\n"; |
802 | $display .= "<form action='./process.php' method='POST'>\n"; |
803 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
803 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
804 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
804 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
805 | $display .= "<input type='hidden' name='optID' value='".$setting["opt_id"]."'><br>\n"; |
805 | $display .= "<input type='hidden' name='optID' value='".$setting["opt_id"]."'><br>\n"; |
806 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
806 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
807 | } else { |
807 | } else { |
808 | $display = "Такой опции не существует"; |
808 | $display = "Такой опции не существует"; |
809 | }
|
809 | }
|
810 | break; |
810 | break; |
811 | }
|
811 | }
|
812 | break; |
812 | break; |
813 | case '21': |
813 | case '21': |
814 | // Управление интерфейсами
|
814 | // Управление интерфейсами
|
815 | switch($act) { |
815 | switch($act) { |
816 | case '0': |
816 | case '0': |
817 | // Список интерфейсов
|
817 | // Список интерфейсов
|
818 | $req =& $db->query("SELECT * FROM interfaces"); |
818 | $req =& $db->query("SELECT * FROM interfaces"); |
819 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
819 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
820 | $display .= "<table><tr><th>Интерфейс</th><th>Действие</th></tr>"; |
820 | $display .= "<table><tr><th>Интерфейс</th><th>Действие</th></tr>"; |
821 | if ($req->numRows()>0) { |
821 | if ($req->numRows()>0) { |
822 | while ($req->fetchInto($if, DB_FETCHMODE_ASSOC)) { |
822 | while ($req->fetchInto($if, DB_FETCHMODE_ASSOC)) { |
823 | $display .= "<tr><td>".$secure->stripStr($if["interfaceinfo"])." (".$secure->stripStr($if["interface"]).") </td>"; |
823 | $display .= "<tr><td>".$secure->stripStr($if["interfaceinfo"])." (".$secure->stripStr($if["interface"]).") </td>"; |
824 | $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>"; |
824 | $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>"; |
825 | $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>"; |
825 | $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>"; |
826 | }
|
826 | }
|
827 | }
|
827 | }
|
828 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новый интерфейс</a></p>"; |
828 | $display .= "</table><p><a href='".$admin."?mode=".$mode."&action=1'><img src='$imgdir/add.png' width='16' height='16'>Добавить новый интерфейс</a></p>"; |
829 | break; |
829 | break; |
830 | case '1': |
830 | case '1': |
831 | // Добавление нового интерфейса
|
831 | // Добавление нового интерфейса
|
832 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
832 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Добавление</a></div>"; |
833 | $display .= "<form action='./process.php' method='POST'>\n"; |
833 | $display .= "<form action='./process.php' method='POST'>\n"; |
834 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
834 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
835 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
835 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
836 | $display .= "Интерфейс (имя файла): <input type='text' name='ifname'><br>\n"; |
836 | $display .= "Интерфейс (имя файла): <input type='text' name='ifname'><br>\n"; |
837 | $display .= "Интерфейс (название): <input type='text' name='ifinfo'><br>\n"; |
837 | $display .= "Интерфейс (название): <input type='text' name='ifinfo'><br>\n"; |
838 | $display .= "<input type='submit' value='Добавить интерфейс'></form>\n"; |
838 | $display .= "<input type='submit' value='Добавить интерфейс'></form>\n"; |
839 | break; |
839 | break; |
840 | case '2': |
840 | case '2': |
841 | // Правка интерфейса
|
841 | // Правка интерфейса
|
842 | $req =& $db->query("SELECT * FROM interfaces WHERE if_id='$uid'"); |
842 | $req =& $db->query("SELECT * FROM interfaces WHERE if_id='$uid'"); |
843 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка</a></div>"; |
843 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Правка</a></div>"; |
844 | if ($req->numRows()>0) { |
844 | if ($req->numRows()>0) { |
845 | $req->fetchInto($if, DB_FETCHMODE_ASSOC); |
845 | $req->fetchInto($if, DB_FETCHMODE_ASSOC); |
846 | $display .= "<form action='./process.php' method='POST'>"; |
846 | $display .= "<form action='./process.php' method='POST'>"; |
847 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
847 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
848 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
848 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
849 | $display .= "<input type='hidden' name='if' value='$uid'>\n"; |
849 | $display .= "<input type='hidden' name='if' value='$uid'>\n"; |
850 | $display .= "Интерфейс (имя файла): <input type='text' name='ifname' value='".$secure->stripStr($if["interface"])."'><br>\n"; |
850 | $display .= "Интерфейс (имя файла): <input type='text' name='ifname' value='".$secure->stripStr($if["interface"])."'><br>\n"; |
851 | $display .= "Интерфейс (название): <input type='text' name='ifinfo' value='".$secure->stripStr($if["interfaceinfo"])."'><br>\n"; |
851 | $display .= "Интерфейс (название): <input type='text' name='ifinfo' value='".$secure->stripStr($if["interfaceinfo"])."'><br>\n"; |
852 | $display .= "<input type='submit' value='Отредактировать'></form>\n"; |
852 | $display .= "<input type='submit' value='Отредактировать'></form>\n"; |
853 | } else { |
853 | } else { |
854 | $display .= "<p>Такого интерфейса не существует</p>"; |
854 | $display .= "<p>Такого интерфейса не существует</p>"; |
855 | }
|
855 | }
|
856 | break; |
856 | break; |
857 | case '3': |
857 | case '3': |
858 | // Удаление интерфейса
|
858 | // Удаление интерфейса
|
859 | $req =& $db->query("SELECT * FROM interfaces WHERE if_id='$uid'"); |
859 | $req =& $db->query("SELECT * FROM interfaces WHERE if_id='$uid'"); |
860 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление</a></div>"; |
860 | $display = "<div class='modulename'>Настройки :: <a href='admin.php?mode=".$mode."'>Интерфейсы</a> :: <a href='admin.php?mode=".$mode."&act=".$act."'>Удаление</a></div>"; |
861 | if ($req->numRows()>0) { |
861 | if ($req->numRows()>0) { |
862 | $req->fetchInto($if, DB_FETCHMODE_ASSOC); |
862 | $req->fetchInto($if, DB_FETCHMODE_ASSOC); |
863 | $display .= "<form action='./process.php' method='POST'>"; |
863 | $display .= "<form action='./process.php' method='POST'>"; |
864 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
864 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
865 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
865 | $display .= "<input type='hidden' name='act' value='".$act."'>\n"; |
866 | $display .= "<input type='hidden' name='if' value='$uid'>\n"; |
866 | $display .= "<input type='hidden' name='if' value='$uid'>\n"; |
867 | $display .= "Интерфейс (имя файла): <input type='text' name='ifname' value='".$secure->stripStr($if["interface"])."' readonly><br>\n"; |
867 | $display .= "Интерфейс (имя файла): <input type='text' name='ifname' value='".$secure->stripStr($if["interface"])."' readonly><br>\n"; |
868 | $display .= "Интерфейс (название): <input type='text' name='ifinfo' value='".$secure->stripStr($if["interfaceinfo"])."' readonly><br>\n"; |
868 | $display .= "Интерфейс (название): <input type='text' name='ifinfo' value='".$secure->stripStr($if["interfaceinfo"])."' readonly><br>\n"; |
869 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
869 | $display .= "<input type='submit' value='Удалить'></form>\n"; |
870 | }
|
870 | }
|
871 | break; |
871 | break; |
872 | }
|
872 | }
|
873 | break; |
873 | break; |
874 | case '22': |
874 | case '22': |
875 | // Управление паролем
|
875 | // Управление паролем
|
876 | switch($act) { |
876 | switch($act) { |
877 | case '0': |
877 | case '0': |
878 | // Смена пароля входа
|
878 | // Смена пароля входа
|
879 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
879 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
880 | $display .= "<form action='./process.php' method='POST'>\n"; |
880 | $display .= "<form action='./process.php' method='POST'>\n"; |
881 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
881 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
882 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
882 | $display .= "<input type='hidden' name='mode' value='".$mode."'>\n"; |
883 | $display .= "Старый пароль: <input type='password' name='oldPW'><br>\n"; |
883 | $display .= "Старый пароль: <input type='password' name='oldPW'><br>\n"; |
884 | $display .= "Новый пароль: <input type='password' name='newPW1'><br>\n"; |
884 | $display .= "Новый пароль: <input type='password' name='newPW1'><br>\n"; |
885 | $display .= "Новый пароль (еще раз): <input type='password' name='newPW2'><br>\n"; |
885 | $display .= "Новый пароль (еще раз): <input type='password' name='newPW2'><br>\n"; |
886 | $display .= "<input type='submit' value='Сменить пароль'></form>\n"; |
886 | $display .= "<input type='submit' value='Сменить пароль'></form>\n"; |
887 | break; |
887 | break; |
888 | 888 | ||
889 | break; |
889 | break; |
890 | }
|
890 | }
|
891 | break; |
891 | break; |
892 | case '23': |
892 | case '23': |
893 | // Управление темами
|
893 | // Управление темами
|
894 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
894 | $display = "<div class='modulename'>".$menu_item[$mode]["title"]." :: <a href='admin.php?mode=".$mode."'>".$menu_item[$mode]["item"]."</a></div>"; |
895 | if (isset($_GET['chtheme'])){ |
895 | if (isset($_GET['chtheme'])){ |
896 | $chtheme = $secure->wrapStr($_GET["chtheme"]); |
896 | $chtheme = $secure->wrapStr($_GET["chtheme"]); |
897 | $chicon = $secure->wrapStr($_GET["chicon"]); |
897 | $chicon = $secure->wrapStr($_GET["chicon"]); |
898 | $theme->SetTheme($chtheme,$db); |
898 | $theme->setTheme($chtheme,$chicon,$db); |
899 | $theme->setIcon($chicon,$db); |
- | |
900 | $display.='<p style="color:red;">Тема измененна</p>'; |
899 | $display.='<p style="color:red;">Тема измененна</p>'; |
901 | }
|
900 | }
|
902 | $themename = $theme->getThemeName($core,$db); |
901 | $themename = $theme->getThemeName($core,$db); |
903 | $iconsname = $theme->getIconSetName($core,$db); |
902 | $iconsname = $theme->getIconSetName($core,$db); |
904 | 903 | ||
905 | $display.= '<form action="admin.php" method="GET">'; |
904 | $display.= '<form action="admin.php" method="GET">'; |
906 | $display.= '<input type="hidden" name="mode" value="23">'; |
905 | $display.= '<input type="hidden" name="mode" value="23">'; |
907 | $display.='<table>'; |
906 | $display.='<table>'; |
908 | $display.='<tr><td>Текущий стиль:</td><td><b>'.$themename.'</b></td><td>'; |
907 | $display.='<tr><td>Текущий стиль:</td><td><b>'.$themename.'</b></td><td>'; |
909 | $display.= '<select id="cht" name="chtheme">'; |
908 | $display.= '<select id="cht" name="chtheme">'; |
910 | $dis=$theme->getThemesList('style'); |
909 | $dis=$theme->getThemesList('style'); |
911 | foreach ($dis as $thm){ |
910 | foreach ($dis as $thm){ |
912 | if($themename==$thm){ |
911 | if($themename==$thm){ |
913 | $display.= '<option selected>'.$thm.'</option>'; |
912 | $display.= '<option selected>'.$thm.'</option>'; |
914 | }else{ |
913 | }else{ |
915 | $display.= '<option>'.$thm.'</option>'; |
914 | $display.= '<option>'.$thm.'</option>'; |
916 | }
|
915 | }
|
917 | }
|
916 | }
|
918 | $display.= '</select></td></tr>'; |
917 | $display.= '</select></td></tr>'; |
919 | $display.='<tr><td>Текущий набор иконок:</td><td><b>'.$iconsname.'</b></td><td>'; |
918 | $display.='<tr><td>Текущий набор иконок:</td><td><b>'.$iconsname.'</b></td><td>'; |
920 | $display.= '<select id="chi" name="chicon">'; |
919 | $display.= '<select id="chi" name="chicon">'; |
921 | $dis=$theme->getThemesList('icon'); |
920 | $dis=$theme->getThemesList('icon'); |
922 | foreach ($dis as $thm){ |
921 | foreach ($dis as $thm){ |
923 | if($iconsname==$thm){ |
922 | if($iconsname==$thm){ |
924 | $display.= '<option selected>'.$thm.'</option>'; |
923 | $display.= '<option selected>'.$thm.'</option>'; |
925 | }else{ |
924 | }else{ |
926 | $display.= '<option>'.$thm.'</option>'; |
925 | $display.= '<option>'.$thm.'</option>'; |
927 | }
|
926 | }
|
928 | }
|
927 | }
|
929 | $display.= '</select></td></tr></table>'; |
928 | $display.= '</select></td></tr></table>'; |
930 | $display.= '<button type="submit">Сменить тему</button>'; |
929 | $display.= '<button type="submit">Сменить тему</button>'; |
931 | $display.= '</form>'; |
930 | $display.= '</form>'; |
932 | break; |
931 | break; |
933 | break; |
932 | break; |
934 | }
|
933 | }
|
935 | 934 | ||
936 | 935 | ||
937 | $display .= "</div></div>"; |
936 | $display .= "</div></div>"; |
938 | 937 | ||
939 | $smarty->assign('feedaddr',$_SERVER["HTTP_HOST"].dirname($_SERVER["PHP_SELF"])); |
938 | $smarty->assign('feedaddr',$_SERVER["HTTP_HOST"].dirname($_SERVER["PHP_SELF"])); |
940 | $smarty->assign('error',$error); |
939 | $smarty->assign('error',$error); |
941 | $smarty->assign('header',$header); |
940 | $smarty->assign('header',$header); |
942 | $smarty->assign('login',$login); |
941 | $smarty->assign('login',$login); |
943 | $smarty->assign('menu',$menu); |
942 | $smarty->assign('menu',$menu); |
944 | $smarty->assign('display',$display); |
943 | $smarty->assign('display',$display); |
945 | $smarty->assign('antversion',$core->getSetting('version',$db)); |
944 | $smarty->assign('antversion',$core->getSetting('version',$db)); |
946 | $smarty->assign('title',$core->getSetting('codename',$db)); |
945 | $smarty->assign('title',$core->getSetting('codename',$db)); |
947 | $smarty->assign('style',$core->getCSSList($db)); |
946 | $smarty->assign('style',$core->getCSSList($db)); |
948 | $smarty->assign('theme',$theme->getThemeName($core,$db)); |
947 | $smarty->assign('theme',$theme->getThemeName($core,$db)); |
949 | $smarty->display('admin.tpl'); |
948 | $smarty->display('admin.tpl'); |
950 | 949 | ||
951 | 950 | ||
952 | ?>
|
951 | ?>
|
953 | 952 |