2 $MENU_ITEMS["15_Zones"]["link"] = "$BASE_URL/zones";
3 $MENU_ITEMS["15_Zones"]["name"] = "Zones";
4 $MENU_ITEMS["20_Objects"]["link"] = "$BASE_URL/objects";
5 $MENU_ITEMS["20_Objects"]["name"] = "Objects";
6 $MENU_ITEMS["30_Rules"]["link"] = "$BASE_URL/rules";
7 $MENU_ITEMS["30_Rules"]["name"] = "Rules";
8 $MENU_ITEMS["10_Interfaces"]["link"] = "$BASE_URL/interfaces";
9 $MENU_ITEMS["10_Interfaces"]["name"] = "Interfaces";
10 $MENU_ITEMS["05_Admin"]["link"] = "$BASE_URL/admin";
11 $MENU_ITEMS["05_Admin"]["name"] = "Admin";
13 // if i believed in name spacing in php, i'd use it.
14 error_log("cbfwweb loaded");
18 function __construct()
30 $conf->loadConfig($comms->getConfig(0));
31 $rconfig = $conf->getConfig();
33 if($rconfig["status"] != "conf") {
34 if($rconfig["status"] == "nodir") {
38 cbfw_startinstaller();
43 if(isset($_REQUEST["q"])) {
44 $url = $_REQUEST["q"];
46 // ok, now we try and find the basics
47 $url_s = explode("/", $url);
52 CBFWZonesPage($url_s);
55 CBFWInterfacesPage($url_s);
58 $bodyFunction = "CBFWObjectsPage";
61 $bodyFunction = "CBFWRulesPage";
64 $bodyFunction = "CBFWAdminPage";
67 $bodyFunction = findUrl($url_s);
70 $bodyFunction = "CBFBuildHomePage";
72 if($bodyFunction != null) CBFWpageBuilder(null, $bodyFunction);
77 function CBFWAdminPage($urls)
79 echo "im an admin page";
82 function CBFBuildHomePage($urls)
84 echo "Must remember this, gotta rules could apply to multiple zones not just one<br>";
85 echo "i.e.: add rule reject from object/host/hostname to address6/2003::123 in zones Zone/zonename/rulenum Zone/zonename/rulenum";
90 print_r($conf->getConfig());
92 print_r($conf->getBootConfig());
97 function CBFWMenuBuilder()
99 global $BASE_URL, $MENU_ITEMS;
103 <table border="1"><tr><th>Menu</th><td>
104 <a href="<?php echo $BASE_URL ?>">Home</a></td>
106 foreach($MENU_ITEMS as $key => $val) {
107 $link = $val["link"];
108 $name = $val["name"];
109 echo "<td><a href=$link>$name</a></td>";
115 // just a short one to call the long one
116 function gcam($m, $s)
119 CBFWAddMessage($m, $s);
122 function CBFWAddMessage($messagelev, $message)
127 function CBFWMessageBuilder()
132 function CBFWpageBuilder($bodyClass, $bodyFunction, $bodycontent=null, $title="CBFW", $bodyfunctiondata=null)
134 global $WEB_ROOT_FS, $BASE_URL;
138 echo "<html><head><title>$title</title>";
141 if(file_exists("$WEB_ROOT_FS/css")) {
142 $dh = opendir("$WEB_ROOT_FS/css");
144 while(($file = readdir($dh))!==false) {
145 $mt = preg_match("/.*.css$/", $file);
147 error_log("loading css $file");
148 echo "<link rel=\"stylesheet\" type=\"text/css\" href=\"$BASE_URL/css/$file\">";
149 //echo "required $basedir/$file\n";
156 if(file_exists("$WEB_ROOT_FS/js")) {
157 $dh = opendir("$WEB_ROOT_FS/js");
159 while(($file = readdir($dh))!==false) {
160 $mt = preg_match("/.*.js$/", $file);
162 error_log("loading js $file");
163 echo "<script type=\"text/javascript\" src=\"$BASE_URL/js/$file\"></script>";
164 //echo "required $basedir/$file\n";
172 echo "</head><body>";
175 echo "<h1>CBFW</h1><br>";
176 echo "<table><tr><td>";
177 CBFWMessageBuilder();
178 echo "<td></tr><tr><td>";
181 echo "<table><tr><td>";
183 echo "</td></tr><tr><td>";
186 if(isset($_REQUEST["q"])) {
187 $url = $_REQUEST["q"];
190 if($bodyClass != null) {
191 $bodyClass->$bodyFunction($bodyfunctiondata);
192 } else if( $bodyFunction != null) {
193 $bodyFunction($bodyfunctiondata);
194 } else echo $bodycontent;
195 echo "</td></tr></table>";
198 // close the big wrap-around table
199 echo "</td></tr></table>";
202 echo "<br><font size=\"-1\">Copyright 2011, PJR</font><br></body></html>";
206 function cbfw_getLastSeen($ip, $data)
210 if(!$data) return $last;
214 foreach($data as $key=>$val) {
215 $last = $val["name"];
216 error_log("got $last for $ip");
219 if($last == "never") return $last;
221 $last = cbfw_tdiffToAgo(time()-$last);
223 error_log("last for $ip set to $last");
229 function cbfw_tdiffToAgo($time_in_sec)
231 $tdiff = $time_in_sec;
232 $tdiff_min = (int)($tdiff/60);
233 $tdiff_hour = (int)($tdiff/3600);
234 $tdiff_days = (int)($tdiff/86400);
236 if($tdiff < 60) $last = "Less then a minute";
237 if($tdiff >= 60 && $tdiff < 7200) $last = "$tdiff_min minutes ago";
238 if($tdiff >= 7200 && $tdiff < 86400) $last = "$tdiff_hour hours ago";
239 if($tdiff >= 86400) $last = "$tdiff_days days ago";
244 function cbfw_startInstaller()
246 global $WEB_ROOT_FS, $BASE_URL;
248 $uid = posix_geteuid();
249 $gid = posix_getegid();
250 $uid_a = posix_getpwuid($uid);
251 $uid = $uid_a["name"];
253 $gid_a = posix_getgrgid($gid);
254 $gid = $gid_a["name"];
255 error_log("user id is $uid, group id is $gid");
257 if(isset($_REQUEST["installdir"])) {
258 $c = new CBFWConfig();
259 touch($_REQUEST["installdir"]."/webconfig");
260 $c->loadConfig($_REQUEST["installdir"]."/webconfig");
261 header("Location: index.php");
265 $underroot = realpath($WEB_ROOT_FS."/../");
269 <h1>Welcome to CBFW</h1>
270 Welcome to CBFW, I cant find my configuration file so im assuming you installing me for the first time<br>
271 If this is not correct then we have a big problem that needs to be solved, i hope you have a backup of the old
272 config, cause that will make life easier.<br><br>
273 However, if this is the first time you have run this app, then all is good with the world. All I need right
274 now is a place where i can store my config. I search the following directories for the location of my
275 configuration (webconfig)<br>
278 <li> <?php echo $underroot?>/var/glcas/
281 As root, you must now create one of these directories and change the ownership of the directory to the web owner.
282 (chown <?php echo $uid?>:<?php echo $gid ?> the_path_you_choose).<br>
284 Now, tell me where you want me to create the webconfig file:<br>
286 <select name="installdir">
287 <option value="/var/run/glcas">/var/run/glcas</option>
288 <option value="/var/lib/glcas">/var/lib/glcas</option>
289 <option value="<?php echo $underroot?>/var/glcas/"><?php echo $underroot?>/var/glcas/</option>
291 <input type="submit" name="Go" value="Go">
300 function cbfw_startnodir()
305 There is no config and no directory where i can store one. Login to the server and either create /var/run/cbfwr or <?php echo $LIB_ROOT_FS?>/var