Added a hosts bit
[glcas.git] / plugins / admin.php
index 492ed29..c10ce86 100644 (file)
@@ -2,6 +2,10 @@
 
 error_log("admin loaded");
 
+global $BASE_URL, $MENU_ITEMS;
+$MENU_ITEMS["10admin"]["name"] = "Admin";
+$MENU_ITEMS["10admin"]["link"] = "$BASE_URL/admin";
+
 global $URL_HANDLERS;
 $URL_HANDLERS["admin.*"] = "GLCASAdmin";
 global $CRON_CLASSES;
@@ -44,6 +48,10 @@ class GLCASAdmin {
                                        error_log("call setstorage");
                                        GLCASpageBuilder($this, "setStorage");
                                        return;
+                               case "freezerepo":
+                                       error_log("call freezerepo");
+                                       GLCASpageBuilder($this, "freezeRepo");
+                                       return;
                                case "scanrepo":
                                        break;
                        }
@@ -93,6 +101,22 @@ class GLCASAdmin {
                $this->mainBody($url);
        }
        
+       function freezeRepo($url)
+       {
+               $repo = $_REQUEST["repo"];
+               
+               
+               $myRep = new GLCASRepo($this->config);
+               
+               
+               error_log("called freeze repo on $repo");
+               $myRep->freezeRepo($repo);
+               
+               global $WEB_ROOT_FS, $URL_HANDLERS, $BASE_URL;
+               header("Location: $BASE_URL/admin/");
+               
+       }
+       
        function doRemoveRepo($url)
        {
                $repo = $_REQUEST["repo"];
@@ -323,9 +347,18 @@ class GLCASAdmin {
                        $repotype = $rval["repotype"];
                        $prefix = $rval["prefix"];
                        $shorturl = $rval["shorturl"];
+                       if(isset($rval["frozen"])) $frozen = $rval["frozen"];
+                       else $frozen = false;
                        if($prefix == "") $prefix = "-";
                        if($shorturl == "") $shorturl = "-";
-                       echo "<tr><td>$desc</td><td>$repotype</td><td>$os</td><td>$version</td><td>$arch</td><td>$other</td><td>$prefix</td><td>$shorturl</td>";
+                       if($frozen) {
+                               $bgcol = "bgcolor=\"#bbbbff\"";
+                               $frotext = "Unfreeze";
+                       } else {
+                               $frotext = "Freeze";
+                               $bgcol = "";
+                       }
+                       echo "<tr $bgcol><td>$desc</td><td>$repotype</td><td>$os</td><td>$version</td><td>$arch</td><td>$other</td><td>$prefix</td><td>$shorturl</td>";
                        
                        // get url
                        $browseurl = "$BASE_URL/repo/$rkey";
@@ -340,9 +373,9 @@ class GLCASAdmin {
                        // Edit
                        echo "<a href=\"?action=editrepo&repo=$rkey\">Edit</a> ";
                        // update
-                       echo "<a href=\"?action=updaterepo&repo=$rkey\">Update</a> ";
+                       if(!$frozen) echo "<a href=\"?action=updaterepo&repo=$rkey\">Update</a> ";
                        // freeze
-                       echo "<a href=\"?action=freezerepo&repo=$rkey\">Freeze</a> ";
+                       echo "<a href=\"?action=freezerepo&repo=$rkey\">$frotext</a> ";
                        // deactivate
                        echo "<a href=\"?action=disablerepo&repo=$rkey\">Disable</a> ";
                        // clean
@@ -407,12 +440,25 @@ class GLCASAdmin {
                echo "</td></tr></table>";
                
                // repo storage location
-               echo "<h3>Storage<h3><br>";
+               echo "<h3>Storage</h3><br>";
                echo "<form method=\"post\" action=\"?action=setstorage\">";
                $storloc = $this->config->getConfigVar("storagelocation");
                echo "<input class=\"storage\" type=\"text\" name=\"storageloc\" value=\"$storloc\" size=\"100\">";
                echo "<input type=\"submit\" name=\"Set\" value=\"Set\">";
                echo "</form>";
+               
+               echo "<hr>";
+               echo "<h3>Proxy Config</h3><br>";
+               echo "<form method=\"post\" action=\"?action=setproxy\">";
+               $proxyaddress = $this->config->getConfigVar("proxyaddress");
+               $proxylogin = $this->config->getConfigVar("proxylogin");
+               $proxypass = $this->config->getConfigVar("proxypass");
+               echo "Proxy Address <input type=\"text\" name=\"proxyaddress\" value=\"$proxyaddress\" size=\"100\"><br>";
+               echo "Proxy Login <input type=\"text\" name=\"proxylogin\" value=\"$proxylogin\" size=\"100\"><br>";
+               echo "Proxy Password <input type=\"text\" name=\"proxypassword\" value=\"$proxypass\" size=\"100\"><br>";
+               echo "<input type=\"submit\" name=\"Set\" value=\"Set\">";
+               echo "</form>";
+               
        }
 
        private $config;