moved admin to repo admin
[glcas.git] / plugins / admin.php
index 13121c3..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/");
        }
        
        
@@ -162,19 +186,22 @@ class GLCASAdmin {
                        $version = $glt["versions"];
                        $archs = $glt["arch"];
                        
-                       echo "<pre>";
-                       print_r($glt);
-                       echo "</pre>";
+                       //echo "<pre>";
+                       //print_r($glt);
+                       //echo "</pre>";
                        
+                       echo "The joy of apt is that there could be a million distro's under the root of an apt mirror";
+                       echo "if it doesn't list here, but you know its there, its still usable for glcas";
                        echo "<form method=\"post\" action=\"?action=addrepoapt\">";
                        echo "<input type=\"hidden\" name=\"repourl\" value=\"$repourl\">";
                        echo "<input type=\"hidden\" name=\"distro\" value=\"$distros\">";
+                       echo "<input type=\"hidden\" name=\"provides\" value=\"Multiple\">";
                        echo "<input type=\"hidden\" name=\"arch\" value=\"$archs\">";
                        echo "<table>";
                        echo "<tr><td>Description</td><td><input type=\"text\" name=\"desc\" value=\"APT Repo$extratext\"></td>";
-                       // TODO change this "provides" bit with a bit that allows us to choose which versions
-                       // of ubuntu will be made available from the ones we found
-                       echo "<tr><td>Provides (tick those you wish to BLOCK)</td><td>";
+                       
+                       // TODO: deal with block bit
+                       echo "<tr><td>Provides (tick those you wish to BLOCK - not implemented)</td><td>";
                        foreach($glt["knownrepo"] as $key => $val) {
                                $reponame = $kos["apt"][$val["name"]];
                                $a = "";
@@ -183,7 +210,7 @@ class GLCASAdmin {
                                if($glt["knownrepo"][$key]["amd64"]) $b = "x86_64";
                                if($a != "" && $b != "") $archs = "$a/$b";
                                else $archs = "$a$b"; 
-                               echo "<input type=\"checkbox\" name=\"$val\"> $reponame ($archs)<br>";
+                               echo "<input type=\"checkbox\" name=\"blocked-".$val["name"]."\"> $reponame ($archs)<br>";
                        }
                        
                        echo "</td></tr>";
@@ -236,12 +263,29 @@ class GLCASAdmin {
                $init = false;
                if(isset($_REQUEST["initial"])) $init = true;
                
+               $blocklist = null;
+               $bn = 0;
+               foreach($_REQUEST as $key => $val) {
+                       if(preg_match("/^blocked-*/", $key)) {
+                               $blocked = preg_replace("/^blocked-/", "", $key);
+                               //echo "<br>got block for $blocked<br>";
+                               $blocklist[$bn] = "dists\/$blocked.*";
+                               $bn++;
+                       }
+               }
+               
+               //echo "<pre>";
+               //print_r($_REQUEST);
+               //echo "</pre>";
+               
+               //exit(0);
                
+               $repo->addRepo($desc, $OS, $version, $arch, "-", $shorturl, $prefix, $repurl, "APT", $init, $expiretime, $blocklist);
                
-               $repo->addRepo($desc, $OS, $version, $arch, "-", $shorturl, $prefix, $repurl, "APT", $init, $expiretime);
+               // 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)
@@ -265,18 +309,20 @@ 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)
        {
                $rkey = $_REQUEST["repo"];
+
+               error_log("would update for repo");
                
                $repo = new GLCASRepo($this->config);
                
                $repo->updateRepo($rkey);
                global $WEB_ROOT_FS, $URL_HANDLERS, $BASE_URL;
-               header("Location: $BASE_URL/admin/");
+               header("Location: $BASE_URL/repoadmin/");
        }
        
        function mainBody($url)
@@ -301,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";
@@ -318,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
@@ -338,13 +393,12 @@ class GLCASAdmin {
                //echo "</pre>";
                
                // wrap all this in a table
-               echo "<table><tr><td valign=\"top\">";
+               echo "<table border=\"1\"><tr><td valign=\"top\">";
                // now, add a repo
                echo "<h3>Add A Repo</h3>";
                echo "<form method=\"post\" action=\"?action=reponext\">";
                echo "Type <select name=\"repotype\">";
                        echo "<option value=\"yumbase\">YUM (Base URL)</option>";
-                       echo "<option value=\"yummirrorlist\">YUM (Mirror List) - not implemented</option>";
                        echo "<option value=\"apt\">APT</option>";
                        echo "</select><br>";
                echo "URL <input type=\"text\" name=\"repourl\"><br>";
@@ -359,21 +413,52 @@ class GLCASAdmin {
                echo "Hint <select name=\"repohint\">";
                        echo "<option value=\"fedora\">Fedora</option>";
                        echo "<option value=\"centos\">Centos</option>";
-                       echo "<option value=\"ubuntu\">Ubuntu</option>";
                        echo "</select><br>";
                echo "URL <input type=\"text\" name=\"repourl\"><br>";
                echo "<input type=\"submit\" name=\"Scan\" value=\"Scan\"><br>";
                echo "</form>";
                
-               echo "</td></tr></table><hr>";
+               echo "</td><td valign=\"top\">";
+               
+               // now for mirror lists
+               echo "<h3>Via Mirrolist - not implemented</h3>";
+               echo "<form method=\"post\" action=\"?action=mirrorlist\">";
+               echo "Distro <select name=\"mirrordistro\">";
+                       echo "<option value=\"fedora\">Fedora</option>";
+                       echo "<option value=\"centos\">Centos</option>";
+                       echo "</select><br>";
+               echo "Architecture <select name=\"arch\">";
+                       echo "<option value=\"x86_64\">64 bit</option>";
+                       echo "<option value=\"i386\">32 bit</option>";
+                       echo "</select><br>";
+               echo "Version <input type=\"text\" name=\"version\"><br>";
+               echo "Get updates too <input type=\"checkbox\" name=\"getupdates\"><br>";
+               echo "<input type=\"submit\" name=\"Scan\" value=\"Scan\"><br>";
+               echo "</form>";
+               
+               
+               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 type=\"text\" name=\"storageloc\" value=\"$storloc\" size=\"100\">";
+               $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;