X-Git-Url: http://git.pjr.cc/?p=CBFWR.git;a=blobdiff_plain;f=libcbfwr%2Ffwui.php;h=adc95416a886aa96ab5a9c21287fe547ba1c89eb;hp=fb9ef70262b34f57bb47ecb0438f0dda88894dad;hb=13e5ebe14a18fb0d217fdc6fc4fc786a678889da;hpb=60673f4f00bab805471fcbb85c8816aebb3a9582
diff --git a/libcbfwr/fwui.php b/libcbfwr/fwui.php
index fb9ef70..adc9541 100644
--- a/libcbfwr/fwui.php
+++ b/libcbfwr/fwui.php
@@ -16,12 +16,14 @@ function CBFWZonesPage($urls)
$newname = $_REQUEST["zonename"];
$renewname = null;
+ error_log("comparing \"$oldname\" to \"$newname\"");
if($oldname != $newname) {
$renewname = " rename $newname";
}
- $oldconf = $comms->getConfig(0);
+ $oldconf = getWebUserConfig();
$olddesc = $oldconf["zone"][$oldname]["description"];
+ error_log("Comparing \"$olddesc\" and \"$desc\"");
if($desc != $olddesc) {
$newdesc = " # $desc";
} else $newdesc = null;
@@ -31,6 +33,7 @@ function CBFWZonesPage($urls)
if($renewname == null && $newdesc == null) {
header("Location: $BASE_URL/zones");
+ error_log("no changes?");
return;
}
@@ -55,15 +58,8 @@ function CBFWZonesPage($urls)
case "delete":
$zonetodelete = $urls[2];
-
- $conf = $comms->getConfig(3);
- $changes = $conf["status"];
- if($changes == "nochange") $conf["status"] = 1;
- else $conf["status"] = $changes + 1;
- $cnum = $conf["status"];
-
- $conf[$cnum]["delete"] = "zone $zonetodelete";
- $comms->putConfig($conf, 3);
+
+ addWebUserChange("delete zone name $zonetodelete");
header("Location: $BASE_URL/zones");
break;
@@ -71,21 +67,16 @@ function CBFWZonesPage($urls)
case "add":
// UGLY
- $cnum = 0;
$nametoadd = $_REQUEST["toadd"];
$desc = $_REQUEST["desc"];
+
$descbit = "";
if($desc != "") $descbit = " # $desc";
if($nametoadd == "" || $nametoadd == null) {
return;
}
- $conf = $comms->getConfig(3);
- $changes = $conf["status"];
- if($changes == "nochange") $conf["status"] = 1;
- else $conf["status"] = $changes + 1;
- $cnum = $conf["status"];
- $conf[$cnum]["add"] = "zone $nametoadd$descbit";
- $comms->putConfig($conf, 3);
+
+ addWebUserChange("zone name $nametoadd $descbit");
header("Location: $BASE_URL/zones");
break;
@@ -104,12 +95,7 @@ function CBFWZonesEditPage($urls)
$zone = $urls[2];
- $comms = new Comms();
- $myconf = new Config();
-
- $config = $comms->getConfig();
- $conf2 = $comms->getConfig(3);
- $config = $myconf->mergeConfig($config, $conf2);
+ $config = getWebUserConfig();
echo "
Edit Zone $zone
";
@@ -124,16 +110,67 @@ function CBFWZonesEditPage($urls)
echo "";
}
-function CBFWZonesPageDisplay()
+function addWebUserChange($change)
{
- global $BASE_URL, $MENU_ITEMS;
+ $comms = new Comms();
+ $myconf = new Config();
+
+ $conf = $comms->getConfig(3);
+
+ if(!isset($conf["status"])) {
+ $conf["status"] = "nochange";
+ }
+
+ $changes = $conf["status"];
+ if($changes == "nochange") $conf["status"] = 1;
+ else $conf["status"] = $changes + 1;
+ $cnum = $conf["status"];
+ $conf["changes"][$cnum] = "$change";
+ $comms->putConfig($conf, 3);
+
+}
+
+// TODO: we need to really sit and think about this one
+function getWebUserConfig()
+{
$comms = new Comms();
$myconf = new Config();
- $config = $comms->getConfig();
+
+ // check to see if pre-cache config matches change level of config change buffer
+ $config = $comms->getConfig(5);
$conf2 = $comms->getConfig(3);
- $config = $myconf->mergeConfig($config, $conf2);
+ if(isset($config["status"])) {
+ if($config["status"] == $conf2["status"]) {
+ // it did, return the pre-cache
+ error_log("got pre-cache config");
+ return $config;
+ }
+ }
+
+ // it did not, do a new merge and cache
+ // TODO: need to do this part
+ $config = $comms->getConfig();
+ $reconfig = $config;
+ $myconf->setConfig($config);
+ if(isset($conf2["changes"])) foreach($conf2["changes"] as $key => $var) {
+ error_log("Adding config line $key, $var");
+ $myconf->addConfigLine($var);
+ }
+ $reconfig = $myconf->getConfig();
+ $reconfig["status"] = $conf2["status"];
+ error_log("put pre-cache config");
+ $comms->putConfig($reconfig, 5);
+
+ return $reconfig;
+}
+
+function CBFWZonesPageDisplay()
+{
+ global $BASE_URL, $MENU_ITEMS;
+
+ $config = getWebUserConfig();
echo "Zones
";
echo "Zone | Interfaces | Description | Edit |
";
@@ -155,6 +192,31 @@ function CBFWZonesPageDisplay()
}
+function CBFWRoutingPage($urls)
+{
+ if(isset($urls[1])) {
+ switch($urls[1]) {
+ case "edit":
+ CBFWpageBuilder(null, "CBFWRoutingPageEdit", null, null, $urls[2]);
+ break;
+ case "change":
+ CBFWRoutingChange();
+ break;
+ default:
+ CBFWpageBuilder(null, "CBFWRoutingPageDisplay");
+ }
+ } else {
+ error_log("main interface page");
+ CBFWpageBuilder(null, "CBFWRoutingPageDisplay");
+ }
+
+}
+
+function CBFWRoutingPageDisplay()
+{
+ echo "Routing
";
+}
+
function CBFWInterfacesPage($urls)
{
if(isset($urls[1])) {
@@ -179,7 +241,6 @@ function CBFWInterfacesChange()
global $BASE_URL, $MENU_ITEMS;
$comms = new Comms();
- $comms->sendMessage("interface eth0 changename poof");
header("Location: $BASE_URL/interfaces");
}
@@ -188,16 +249,51 @@ function CBFWInterfacesPageEdit($urls)
global $BASE_URL, $MENU_ITEMS;
$interface = $urls;
+ $comms = new Comms();
+
+ $config = getWebUserConfig();
+ $boot_config = $comms->getConfig(1);
+
+ if(isset($config["interface"]["dev"]["$interface"]["name"])) $name = $config["interface"]["dev"]["$interface"]["name"];
+ else $name = "";
+
+ $extra2 = "";
+ if(file_exists("/sys/class/net/$interface/address")) {
+ $extra2 = trim(file_get_contents("/sys/class/net/$interface/address"));
+ }
+
+ $extra = "";
+ if(isset($boot_config["hardware"]["netdev"]["$interface"]["hwaddress"])) {
+ $hwaddr = $boot_config["hardware"]["netdev"]["$interface"]["hwaddress"];
+ $extra = " Original address: $hwaddr";
+ if($hwaddr != $extra2 && $extra2 != "") {
+ $extra .= " Current Address: $hwaddr";
+ }
+ }
+ if(isset($config["interface"]["dev"]["$interface"]["hwaddress"])) $hwaddr = $config["interface"]["dev"]["$interface"]["hwaddress"];
+
+ if(isset($config["interface"]["dev"]["$interface"]["zone"])) $zone = $config["interface"]["dev"]["$interface"]["zone"];
+
+ if(isset($config["interface"]["dev"]["$interface"]["address4"])) $ip4 = $config["interface"]["dev"]["$interface"]["address4"];
+
+ if(isset($config["interface"]["dev"]["$interface"]["address6"])) $ip6 = $config["interface"]["dev"]["$interface"]["address6"];
+
+ if(isset($boot_config["hardware"]["netdev"]["$interface"]["speed"])) $speed = $boot_config["hardware"]["netdev"]["$interface"]["speed"];
+ if(isset($boot_config["hardware"]["netdev"]["$interface"]["duplex"])) $duplex = $boot_config["hardware"]["netdev"]["$interface"]["duplex"];
+ if(isset($config["interface"]["dev"]["$interface"]["speed"])) $speed = $config["interface"]["dev"]["$interface"]["speed"];
+ if(isset($config["interface"]["dev"]["$interface"]["duplex"])) $duplex = $config["interface"]["dev"]["$interface"]["duplex"];
+
echo "Edit Interface $interface
";
echo "