moved admin to repo admin
[glcas.git] / plugins / admin.php
index 492ed29..e3dc5ce 100644 (file)
@@ -2,16 +2,20 @@
 
 error_log("admin loaded");
 
+global $BASE_URL, $MENU_ITEMS;
+$MENU_ITEMS["30admin"]["name"] = "Repo Admin";
+$MENU_ITEMS["30admin"]["link"] = "$BASE_URL/repoadmin";
+
 global $URL_HANDLERS;
-$URL_HANDLERS["admin.*"] = "GLCASAdmin";
+$URL_HANDLERS["repoadmin.*"] = "GLCASRepoAdmin";
 global $CRON_CLASSES;
-$CRON_CLASSES["GLCASAdmin"] = "GLCASAdmin";
+$CRON_CLASSES["GLCASAdmin"] = "GLCASRepoAdmin";
 
-class GLCASAdmin {
+class GLCASRepoAdmin {
        function __construct($config)
        {
                $this->config = $config;
-               error_log("constructor for GLCASAdmin");
+               error_log("constructor for GLCASRepoAdmin");
                
        }
        
@@ -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;
                        }
@@ -53,14 +61,14 @@ class GLCASAdmin {
        
        function cron()
        {
-               echo "ADMIN CRON: nothing to see here<br>";
+               echo "REPOADMIN CRON: nothing to see here<br>";
                // TODO: touch cronstamp file here
                
                // make a backup of the config.. but.. errr. how to tell if theres an old backup?
                // backups will occur... weekly and be called $configpath.DDMMYYYY
                $configpath = glcas_getWebConfigPath();
                $basepath = dirname($configpath);
-               echo "ADMIN CRON: backing up config, $configpath, $basepath<br>";
+               echo "REPOADMIN CRON: backing up config, $configpath, $basepath<br>";
                $nowtime = time();
                $oneday = 3600 * 24; // 1 hour in seconds, by 24 hours
                for($i = 0; $i < 7; $i ++) {
@@ -76,7 +84,7 @@ class GLCASAdmin {
                $nowdatestr = strftime("%d-%h-%Y");
                $backupfile = "$configpath.$nowdatestr";
                copy($configpath, $backupfile);
-               echo "ADMIN CRON: createing backup of config as $backupfile<br>";
+               echo "REPOADMIN CRON: createing backup of config as $backupfile<br>";
        }
        
        function body($url)
@@ -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/repoadmin/");
+               
+       }
+       
        function doRemoveRepo($url)
        {
                $repo = $_REQUEST["repo"];
@@ -103,7 +127,7 @@ class GLCASAdmin {
                $myRep->deleteRepo($repo);
                
                global $WEB_ROOT_FS, $URL_HANDLERS, $BASE_URL;
-               header("Location: $BASE_URL/admin/");
+               header("Location: $BASE_URL/repoadmin/");
        }
        
        
@@ -261,7 +285,7 @@ class GLCASAdmin {
                // next we need to deal with that "blocked" bit
                
                global $WEB_ROOT_FS, $URL_HANDLERS, $BASE_URL;
-               header("Location: $BASE_URL/admin/");
+               header("Location: $BASE_URL/repoadmin/");
        }
        
        function doAddRepoYum($url)
@@ -285,7 +309,7 @@ class GLCASAdmin {
                $repo->addRepo($desc, $OS, $version, $arch, $other, $shorturl, $prefix, $repurl, "YUM", $init, $expiretime);
                
                global $WEB_ROOT_FS, $URL_HANDLERS, $BASE_URL;
-               header("Location: $BASE_URL/admin/");
+               header("Location: $BASE_URL/repoadmin/");
        }
        
        function doUpdateRepo($url)
@@ -298,7 +322,7 @@ class GLCASAdmin {
                
                $repo->updateRepo($rkey);
                global $WEB_ROOT_FS, $URL_HANDLERS, $BASE_URL;
-               header("Location: $BASE_URL/admin/");
+               header("Location: $BASE_URL/repoadmin/");
        }
        
        function mainBody($url)
@@ -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");
+               $storloc = $this->config->getConfig("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->getConfig("proxyaddress");
+               $proxylogin = $this->config->getConfig("proxylogin");
+               $proxypass = $this->config->getConfig("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;