X-Git-Url: http://git.pjr.cc/?p=CBFWR.git;a=blobdiff_plain;f=libcbfwr%2Ffwui.php;h=fb9ef70262b34f57bb47ecb0438f0dda88894dad;hp=cf8056b079fac867a12b9e70da4f073e7076f050;hb=60673f4f00bab805471fcbb85c8816aebb3a9582;hpb=175dadf56670772f8d889276df67471354a36f21
diff --git a/libcbfwr/fwui.php b/libcbfwr/fwui.php
index cf8056b..fb9ef70 100644
--- a/libcbfwr/fwui.php
+++ b/libcbfwr/fwui.php
@@ -1,17 +1,317 @@
getConfig(0);
+ $olddesc = $oldconf["zone"][$oldname]["description"];
+ if($desc != $olddesc) {
+ $newdesc = " # $desc";
+ } else $newdesc = null;
+
+ //echo "confs: \"$olddesc\", \"$newdesc\", $oldname, $newname
";
+ //exit(0);
+
+ if($renewname == null && $newdesc == null) {
+ header("Location: $BASE_URL/zones");
+ return;
+ }
+
+
+ $conf = $comms->getConfig(3);
+ $changes = $conf["status"];
+ if($changes == "nochange") $conf["status"] = 1;
+ else $conf["status"] = $changes + 1;
+ $cnum = $conf["status"];
+
+ $conf[$cnum]["modify"] = "zone $oldname$renewname$newdesc";
+ $comms->putConfig($conf, 3);
+ header("Location: $BASE_URL/zones");
+
+ break;
+
+
+ case "edit":
+ CBFWpageBuilder(null, "CBFWZonesEditPage", null, null, $urls);
+ break;
+
+
+ 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);
+ header("Location: $BASE_URL/zones");
+ break;
+
+
+ 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);
+ header("Location: $BASE_URL/zones");
+ break;
+
+
+ default:
+ CBFWpageBuilder(null, "CBFWZonesPageDisplay");
+ }
+ } else {
+ CBFWpageBuilder(null, "CBFWZonesPageDisplay");
+ }
+}
+
+function CBFWZonesEditPage($urls)
+{
+ global $BASE_URL, $MENU_ITEMS;
+
+ $zone = $urls[2];
+
+ $comms = new Comms();
+ $myconf = new Config();
+
$config = $comms->getConfig();
+ $conf2 = $comms->getConfig(3);
+ $config = $myconf->mergeConfig($config, $conf2);
+
+
+ echo "
Edit Zone $zone
";
+ echo "";
}
-function CBFWInterfacesPage()
+function CBFWZonesPageDisplay()
{
+ global $BASE_URL, $MENU_ITEMS;
+
$comms = new Comms();
+ $myconf = new Config();
$config = $comms->getConfig();
+ $conf2 = $comms->getConfig(3);
+ $config = $myconf->mergeConfig($config, $conf2);
+
+ echo "Zones
";
+ echo "Zone | Interfaces | Description | Edit |
";
+ foreach($config["zone"] as $key => $var) {
+ $name = $key;
+ $url = "Edit";
+ $url2 = "Delete";
+ $desc = $var["description"];
+ echo "$name | ... | $desc | $url $url2 |
";
+ }
+
+ echo "
";
+ echo "";
+
+}
+
+function CBFWInterfacesPage($urls)
+{
+ if(isset($urls[1])) {
+ switch($urls[1]) {
+ case "edit":
+ CBFWpageBuilder(null, "CBFWInterfacesPageEdit", null, null, $urls[2]);
+ break;
+ case "change":
+ CBFWInterfacesChange();
+ break;
+ default:
+ CBFWpageBuilder(null, "CBFWInterfacesPageDisplay");
+ }
+ } else {
+ error_log("main interface page");
+ CBFWpageBuilder(null, "CBFWInterfacesPageDisplay");
+ }
+}
+
+function CBFWInterfacesChange()
+{
+ global $BASE_URL, $MENU_ITEMS;
+ $comms = new Comms();
+
+ $comms->sendMessage("interface eth0 changename poof");
+ header("Location: $BASE_URL/interfaces");
+}
+
+function CBFWInterfacesPageEdit($urls)
+{
+ global $BASE_URL, $MENU_ITEMS;
+ $interface = $urls;
+
+ echo "Edit Interface $interface
";
+ echo "";
+}
+
+function CBFWInterfacesPageDisplay()
+{
+ global $BASE_URL, $MENU_ITEMS;
+ $comms = new Comms();
+
+ $config = $comms->getConfig(0);
+ $boot_config = $comms->getConfig(1);
+
+ // now build an interface table
+ $table = array();
+ foreach($boot_config["hardware"]["netdev"] as $key=>$val) {
+ $ename = $key;
+ $table[$key]["realname"] = $val["name"];
+ $table[$key]["name"] = $val["name"];
+
+
+ // driver
+ if(isset($val["driver"])) $table[$key]["type"] = $val["driver"];
+ else $table[$key]["type"] = "Unknown";
+
+ // hw address
+ if(isset($val["hwaddress"])) $table[$key]["hwaddress"] = $val["hwaddress"];
+
+ // current mtu
+ if(isset($val["mtu"])) $table[$key]["mtu"] = $val["mtu"];
+ }
+
+ foreach($config["hardware"]["netdev"] as $key=>$val) {
+ $ename = $key;
+ if(isset($config["interface"]["$key"]["name"])) $table[$key]["name"] = $config["interface"]["$key"]["name"];
+ $table[$key]["address4"] = null;
+ $table[$key]["address6"] = null;
+
+ if(isset($config["interface"][$table[$key]["name"]]["address4"])) {
+ $table[$key]["address4"] = $config["interface"][$table[$key]["name"]]["address4"];
+ }
+
+ if(isset($config["interface"][$table[$key]["name"]]["address6"])) {
+ $table[$key]["address6"] = $config["interface"][$table[$key]["name"]]["address6"];
+ }
+
+ if(isset($config["interface"][$table[$key]["name"]]["mtu"])) {
+ $table[$key]["mtu"] = $config["interface"][$table[$key]["name"]]["mtu"];
+ } else {
+ $table[$key]["mtu"] = "1500"; // TODO: this needs to actually come from somewhere
+ }
+
+ if(isset($config["interface"][$table[$key]["name"]]["speed"])) {
+ $table[$key]["speed"] = $config["interface"][$table[$key]["name"]]["speed"];
+ } else {
+ $table[$key]["speed"] = null;
+ }
+
+ if(isset($config["interface"][$table[$key]["name"]]["duplex"])) {
+ $table[$key]["duplex"] = $config["interface"][$table[$key]["name"]]["duplex"];
+ } else {
+ $table[$key]["duplex"] = null;
+ }
+
+ if(isset($config["interface"][$table[$key]["name"]]["zone"])) {
+ $table[$key]["zone"] = $config["interface"][$table[$key]["name"]]["zone"];
+ } else {
+ $table[$key]["zone"] = null;
+ }
+ }
+
+
+ echo "Device | Zone | Type | MAC Address | Address | MTU | Speed/Duplex | Control | ";
+ foreach($table as $key =>$val) {
+ if($val["realname"] == $val["name"]) $name = $val["name"];
+ else $name = $val["name"]." (".$val["realname"].")";
+
+ // zone
+ if($val["zone"] == null) $zone = "-";
+ else $zone = $val["zone"];
+
+ // mtu
+ $mtu = $val["mtu"];
+
+ // driver type
+ $type = $val["type"];
+
+ // hardware address
+ $mac = $val["hwaddress"];
+
+ // speed and duplex
+ if($val["duplex"] == null) $dup = "default";
+ else $dup = $val["duplex"];
+
+ if($val["speed"] == null) $spd = "default";
+ else $spd = $val["speed"];
+
+ $spanddu = "$spd/$dup";
+
+ // network address
+ if($val["address4"]!=null && $val["address6"]!=null) {
+ $address = $val["address4"]."
".$val["address6"];
+ } else if($val["address4"] != null) {
+ $address = $val["address4"];
+ } else if($val["address6"] != null) {
+ $address = $val["address6"];
+ } else {
+ $address = "-";
+ }
+
+ echo "$name | $zone | $type | $mac | $address | $mtu | $spanddu | Edit |
";
+ }
+ echo "
";
}
function CBFWObjectsPage()