File: 1.02.4b/server/web/node.edit.php (View as Code)

1: 2: /* ------------------------------------------------------------- 3: This file is part of FreeNATS 4: 5: FreeNATS is (C) Copyright 2008 PurplePixie Systems 6: 7: FreeNATS is free software: you can redistribute it and/or modify 8: it under the terms of the GNU General Public License as published by 9: the Free Software Foundation, either version 3 of the License, or 10: (at your option) any later version. 11: 12: FreeNATS is distributed in the hope that it will be useful, 13: but WITHOUT ANY WARRANTY; without even the implied warranty of 14: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 15: GNU General Public License for more details. 16: 17: You should have received a copy of the GNU General Public License 18: along with FreeNATS. If not, see www.gnu.org/licenses 19: 20: For more information see www.purplepixie.org/freenats 21: -------------------------------------------------------------- */ 22: 23: ob_start(); 24: require("include.php"); 25: $NATS->Start(); 26: if (!$NATS_Session->Check($NATS->DB)) 27: { 28: header("Location: ./?login_msg=Invalid+Or+Expired+Session"); 29: exit(); 30: } 31: if ($NATS_Session->userlevel<5) UL_Error("Edit Node"); 32: ob_end_flush(); 33: Screen_Header("Node Editor",1,1,"","main","nodes"); 34: echo "\n\n\n"; 54: ?> 55:
56: 57: if (isset($_REQUEST['action'])) 58: { 59: if ($_REQUEST['action']=="save_edit") 60: { 61: $_REQUEST['showoptions']=1; 62: if (isset($_REQUEST['nodeenabled'])) $nodeenabled=1; 63: else $nodeenabled=0; 64: if (isset($_REQUEST['pingtest'])) $pingtest=1; 65: else $pingtest=0; 66: if (isset($_REQUEST['pingfatal'])) $pingfatal=1; 67: else $pingfatal=0; 68: if (isset($_REQUEST['nodealert'])) $nodealert=1; 69: else $nodealert=0; 70: if (isset($_REQUEST['testinterval'])) $interval=$_REQUEST['testinterval']; 71: else $interval=0; 72: if (!is_numeric($interval)) $interval=0; 73: 74: if (isset($_REQUEST['nsenabled'])) $nsenabled=1; 75: else $nsenabled=0; 76: 77: $q="UPDATE fnnode SET "; 78: $q.="nodename=\"".ss($_REQUEST['nodename'])."\","; 79: $q.="nodedesc=\"".ss($_REQUEST['nodedesc'])."\","; 80: $q.="testinterval=".ss($interval).","; 81: if (isset($_REQUEST['scheduleid'])) $q.="scheduleid=".ss($_REQUEST['scheduleid']).","; 82: $q.="nodeicon=\"".ss($_REQUEST['nodeicon'])."\","; 83: $q.="nodealert=".ss($nodealert).","; 84: $q.="nodeenabled=".ss($nodeenabled).",pingtest=".ss($pingtest).",pingfatal=".ss($pingfatal).","; 85: $q.="nsenabled=".ss($nsenabled).","; 86: 87: if (isset($_REQUEST['nsurl'])) $q.="nsurl=\"".ss($_REQUEST['nsurl'])."\","; 88: if (isset($_REQUEST['nskey'])) $q.="nskey=\"".ss($_REQUEST['nskey'])."\","; 89: if (isset($_REQUEST['nspuship'])) $q.="nspuship=\"".ss($_REQUEST['nspuship'])."\","; 90: if (isset($_REQUEST['nsinterval'])) 91: { 92: $q.="nsinterval=".ss($_REQUEST['nsinterval']).","; 93: // Also use this text field as the indication that ns data is provided at all 94: if (isset($_REQUEST['nspullenabled'])) $set=1; 95: else $set=0; 96: $q.="nspullenabled=".$set.","; 97: if (isset($_REQUEST['nspushenabled'])) $set=1; 98: else $set=0; 99: $q.="nspushenabled=".$set.","; 100: } 101: 102: $q.="hostname=\"".ss($_REQUEST['hostname'])."\""; 103: 104: $q.=" WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\""; 105: //echo $q; 106: $NATS->DB->Query($q); 107: 108: if ($NATS->DB->Affected_Rows()<=0) 109: { 110: echo "Failed to Save Changes or Nothing Changed
";
111: $poplist[]="Failed to Save or Nothing Changed"; 112: } 113: else 114: { 115: echo "Saved Changes
";
116: $poplist[]="Saved Changes"; 117: } 118: 119: // Update Interval If Changed 120: if ( isset($_REQUEST['testinterval']) && isset($_REQUEST['original_testinterval']) && 121: ( $_REQUEST['testinterval'] != $_REQUEST['original_testinterval'] ) ) 122: $NATS->InvalidateNode($_REQUEST['nodeid']); 123: 124: // Update Nodeside if Newly Enabled and empty... 125: if ( isset($_REQUEST['original_nsenabled']) && ($_REQUEST['original_nsenabled']==0) && ($nsenabled==1) ) 126: { 127: $q="SELECT nskey FROM fnnode WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\""; 128: $r=$NATS->DB->Query($q); 129: if ($row=$NATS->DB->Fetch_Array($r)) 130: { 131: if ($row['nskey']=="") // generate one 132: { 133: $allow="abcdef0123456789"; 134: $len=64; 135: $alen=strlen($allow); 136: mt_srand(microtime()*1000000); 137: $key=""; 138: for ($a=0; $a<$len; $a++) 139: $key.=$allow[mt_rand(0,$alen-1)]; 140: $uq="UPDATE fnnode SET nskey=\"".$key."\" WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\""; 141: $NATS->DB->Query($uq); 142: } 143: $NATS->DB->Free($r); 144: } 145: } 146: 147: } 148: else if ($_REQUEST['action']=="invalidate") 149: { 150: $_REQUEST['showoptions']=1; 151: $NATS->InvalidateNode($_REQUEST['nodeid'],true); 152: } 153: else if ($_REQUEST['action']=="nodesiderefresh") 154: { 155: $_REQUEST['showoptions']=1; 156: $res=$NATS->NodeSide_Pull($_REQUEST['nodeid']); 157: if ($res===false) 158: { 159: $poplist[]="Error Fetching Nodeside Data"; 160: echo "Error Fetching Nodeside Data

";
161: } 162: else 163: { 164: $poplist[]="Nodeside Data Refreshed"; 165: echo "Refreshed Nodeside Data

";
166: } 167: } 168: else if ($_REQUEST['action']=="save_actions") 169: { 170: // build the two lists... 171: $cur=array(); 172: $cc=0; 173: $nl=array(); 174: $nc=0; 175: 176: if (isset($_REQUEST['links'])) 177: { 178: foreach($_REQUEST['links'] as $link) 179: { 180: $nl[$link]['proc']=false; // not processed or existing i.e. outstanding 181: $nl[$link]['aaid']=$link; 182: $nc++; 183: } 184: } 185: 186: $q="SELECT nalid,aaid FROM fnnalink WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\""; 187: $r=$NATS->DB->Query($q); 188: while ($row=$NATS->DB->Fetch_Array($r)) 189: { 190: //echo $row['aaid'].":"; 191: $cur[$row['aaid']]['proc']=false; 192: $cur[$row['aaid']]['nalid']=$row['nalid']; 193: $cur[$row['aaid']]['aaid']=$row['aaid']; 194: $cc++; 195: } 196: 197: // now we have the two lists lets process them 198: foreach($nl as $newone) 199: { 200: if (isset($cur[$newone['aaid']])) // exists - do nothing to both 201: { 202: //echo "
".$newone['aaid'].":";
203: $cur[$newone['aaid']]['proc']=true; 204: $nl[$newone['aaid']]['proc']=true; 205: } 206: // otherwise news are left false to insert and curs false to delete 207: } 208: 209: // so lets do that 210: foreach($nl as $newone) 211: { 212: if ($newone['proc']==false) 213: { 214: //echo $q; 215: $q="INSERT INTO fnnalink(aaid,nodeid) VALUES(".ss($newone['aaid']).",\"".ss($_REQUEST['nodeid'])."\")"; 216: $NATS->DB->Query($q); 217: } 218: } 219: foreach($cur as $curone) 220: { 221: if ($curone['proc']==false) 222: { 223: $q="DELETE FROM fnnalink WHERE nalid=".$curone['nalid']; 224: $NATS->DB->Query($q); 225: //echo $q; 226: } 227: } 228: 229: echo "Saved Alert List Preferences
";
230: $poplist[]="Saved Alert List Preferences"; 231: 232: 233: } 234: 235: } 236: 237: 238: 239: echo "Editing Node: ".$_REQUEST['nodeid']."

";
240: 241: 242: $q="SELECT * FROM fnnode WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\" LIMIT 0,1"; 243: $r=$NATS->DB->Query($q); 244: if (!$row=$NATS->DB->Fetch_Array($r)) 245: { 246: echo "No such node.

";
247: Screen_Footer(); 248: exit(); 249: } 250: $NATS->DB->Free($r); 251: 252: $title="Node Settings"; 253: Start_Round($title,600); 254: echo "
"; 255: echo "
"; 256: echo ""; 257: 258: echo ""; 259: echo ""; 260: 261: echo ""; 266: 267: echo ""; 272: 273: echo ""; 278: 279: echo ""; 284: 285: echo ""; 297: 298: echo ""; 301: echo ""; 302: 303: echo ""; 311: 312: echo ""; 329: 330: echo ""; 336: echo "337: 338: echo ""; 348: 349: echo ""; 357: 358: echo ""; 359: 360: echo ""; 368: 369: echo ""; 377: 378: echo ""; 379: 380: echo ""; 390: echo ""; 391: 392: if ($nodeside) 393: { 394: echo ""; 398: 399: echo ""; 400: if ($row['nspullenabled']==1) $s=" checked"; 401: else $s=""; 402: echo ""; 405: 406: echo ""; 415: 416: echo ""; 420: 421: echo ""; 422: if ($row['nspushenabled']==1) $s=" checked"; 423: else $s=""; 424: echo ""; 427: 428: echo ""; 432: 433: echo ""; 435: 436: if ($row['nspullenabled']==1) 437: { 438: echo ""; 442: } 443: 444: echo ""; 453: 454: echo ""; 458: 459: } 460: 461: echo ""; 462: 463: echo ""; 467: echo "
262: NodeID 263: :"; 264: echo $row['nodeid']; 265: echo "
268: Node Name 269: :"; 270: echo ""; 271: echo "
274: Hostname 275: :"; 276: echo ""; 277: echo "
280: Description 281: :"; 282: echo ""; 283: echo "
286: Node Icon 287: :"; 288: echo " [ Show Icons ]"; 295: echo " [ Show/Hide Icons ]"; 296: echo "
"; 299: echo "
";
300: echo "

304: Node Enabled 305: :"; 306: if ($row['nodeenabled']==1) $s=" checked"; 307: else $s=""; 308: echo ""; 309: echo " ".hlink("Node:Enabled"); 310: echo "
313: Test Schedule 314: :"; 315: echo ""; 326: $NATS->DB->Free($sr); 327: echo " ".hlink("Schedule"); 328: echo "
331: Test Interval 332: :"; 333: echo " "; 334: echo "Minutes ".hlink("Node:TestInterval"); 335: echo "
339: Test Due 340: :"; 341: if ($row['nextrunx']>0) echo nicedt($row['nextrunx']); 342: else echo "Now"; 343: echo "
";
344: echo nicenextx($row['nextrunx']); 345: echo " Check ASAP "; 346: echo hlink("Node:CheckASAP",12); 347: echo "
350: Alerts Active 351: :"; 352: if ($row['nodealert']==1) $s=" checked"; 353: else $s=""; 354: echo ""; 355: echo " ".hlink("Node:AlertActive"); 356: echo "

361: Ping Test 362: :"; 363: if ($row['pingtest']==1) $s=" checked"; 364: else $s=""; 365: echo ""; 366: echo " ".hlink("Node:PingTest"); 367: echo "
370: Require Ping 371: :"; 372: if ($row['pingfatal']==1) $s=" checked"; 373: else $s=""; 374: echo ""; 375: echo " ".hlink("Node:RequirePing"); 376: echo "

381: Node-Side Testing 382: :"; 383: if ($row['nsenabled']==1) $nodeside=true; 384: else $nodeside=false; 385: if ($nodeside) $s=" checked"; 386: else $s=""; 387: echo ""; 388: echo " ".hlink("Nodeside"); 389: echo "
Node Key :"; 395: echo ""; 396: echo " ".hlink("Nodeside:Key"); 397: echo "
Pull Enabled : "; 403: echo hlink("Nodeside:PullEnabled"); 404: echo "
Pull URL :"; 407: echo ""; 408: if ($row['nsurl']!="") 409: { 410: $uri=$row['nsurl']."?nodekey=".$row['nskey']."&noupdates=1"; 411: echo " Debug Raw Output"; 412: } 413: echo " ".hlink("Nodeside:URL"); 414: echo "
Pull Interval :"; 417: echo ""; 418: echo " Minutes ".hlink("Nodeside:Interval"); 419: echo "
Push Enabled : "; 425: echo hlink("Nodeside:PushEnabled"); 426: echo "
Push IP :"; 429: echo ""; 430: echo " ".hlink("Nodeside:URL"); 431: echo "
Last Data :"; 434: echo nicedt($row['nslastx'])." - ".dtago($row['nslastx'])."
Next Pull Due :"; 439: if ($row['nsnextx']>0) echo nicedt($row['nsnextx'])." - ".nicenextx($row['nsnextx']); 440: else echo "Now"; 441: echo "
Catalogue :"; 445: $nsq="SELECT COUNT(nstestid) FROM fnnstest WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\""; 446: $nsr=$NATS->DB->Query($nsq); 447: if ($nsrow=$NATS->DB->Fetch_Array($nsr)) 448: { 449: echo $nsrow['COUNT(nstestid)']." Node-Side Monitors"; 450: } 451: $NATS->DB->Free($nsr); 452: echo "
Refresh Now :"; 455: if ($row['nspullenabled']==1) echo "Refresh (Pull) Now"; 456: else echo "Pull Method Disabled"; 457: echo "

"; 464: echo " Cancel Changes"; 465: echo "

";
466: echo "
";
468: echo "
";
469: echo "Show / Hide Node Options"; 470: echo "\n"; 473: End_Round(); 474: 475: if (isset($_REQUEST['show_icons'])) 476: { 477: echo "

";
478: ShowIcons(); 479: echo "

";
480: } 481: 482: //echo "
";
483: 484: echo "

";
485: $title="Node Tests"; 486: Start_Round($title,600); 487: echo ""; 488: $q="SELECT * FROM fnlocaltest WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\" AND testtype!=\"ICMP\" ORDER BY localtestid ASC"; 489: $r=$NATS->DB->Query($q); 490: while ($row=$NATS->DB->Fetch_Array($r)) 491: { 492: echo ""; 501: 502: echo ""; 509: } 510: 511: if ($nodeside) 512: { 513: $q="SELECT * FROM fnnstest WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\" AND testenabled=1"; 514: $r=$NATS->DB->Query($q); 515: while ($row=$NATS->DB->Fetch_Array($r)) 516: { 517: echo ""; 524: 525: echo ""; 532: } 533: $NATS->DB->Free($r); 534: } 535: 536: echo "
";
537: echo "\n"; 538: echo ""; 539: echo ""; 540: echo ""; 563: 564: if ($nodeside) 565: { 566: echo "
";
567: echo ""; 568: echo ""; 569: echo ""; 581: } 582: 583: echo "
"; 493: 494: echo ""; 495: if (strlen($row['testparam'])>10) $tp=substr($row['testparam'],0,8).".."; 496: else $tp=$row['testparam']; 497: if ($row['testname']=="") echo lText($row['testtype'])." (".$tp.")"; 498: else echo $row['testname']; 499: echo ""; 500: echo " "; 503: echo " "; 504: echo ""; 505: echo ""; 506: 507: echo "  Last Tested: ".dtago($row['lastrunx']).""; 508: echo "
"; 518: 519: echo ""; 520: if ($row['testname']=="") echo $row['testdesc']; 521: else echo $row['testname']; 522: echo ""; 523: echo " "; 526: echo " "; 527: echo ""; 528: echo ""; 529: 530: echo "  Last Tested: ".dtago($row['lastrunx']).""; 531: echo "
 
Add Test : "; 555: 556: // one day will do fancy JS option here but for now moved to the edit 557: //echo " "; 558: echo ""; 559: echo ""; 560: 561: echo ""; 562: echo "
Add Node-side Monitor :"; 579: echo " "; 580: echo "
";
584: End_Round(); 585: echo "

";
586: 587: $title="Alert Actions ".hlink("AlertAction",12); 588: Start_Round($title,600); 589: echo ""; 590: echo ""; 591: echo ""; 592: $q="SELECT aaid,aname FROM fnalertaction"; 593: $r=$NATS->DB->Query($q); 594: $c=0; 595: while ($row=$NATS->DB->Fetch_Array($r)) 596: { 597: // has link? 598: $lq="SELECT nalid FROM fnnalink WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\" AND aaid=".ss($row['aaid'])." LIMIT 0,1"; 599: $lr=$NATS->DB->Query($lq); 600: if ($NATS->DB->Num_Rows($lr)>0) $s=" checked"; 601: else $s=""; 602: $NATS->DB->Free($lr); 603: echo ""; 605: } 606: $NATS->DB->Free($r); 607: echo ""; 608: echo "
"; 604: echo "".$row['aaid']." - ".$row['aname']."
";
609: End_Round(); 610: ?> 611:

612: 613: 614: Screen_Footer(); 615: ?> 616: