File: 1.14.2a/server/web/node.edit.php (View as Code)

1: 2: /* ------------------------------------------------------------- 3: This file is part of FreeNATS 4: 5: FreeNATS is (C) Copyright 2008-2011 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($NATS->Lang->Item("node.editor")); 32: ob_end_flush(); 33: Screen_Header($NATS->Lang->Item("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($NATS->StripGPC($_REQUEST['nodename']))."\","; 79: $q.="nodedesc=\"".ss($NATS->StripGPC($_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: $q.="masterid=\"".ss($_REQUEST['masterid'])."\","; 88: $q.="masterjustping=".ss($_REQUEST['masterjustping']).","; 89: 90: if (isset($_REQUEST['nsurl'])) $q.="nsurl=\"".ss($NATS->StripGPC($_REQUEST['nsurl']))."\","; 91: if (isset($_REQUEST['nskey'])) $q.="nskey=\"".ss($NATS->StripGPC($_REQUEST['nskey']))."\","; 92: if (isset($_REQUEST['nspuship'])) $q.="nspuship=\"".ss($_REQUEST['nspuship'])."\","; 93: if (isset($_REQUEST['nsinterval'])) 94: { 95: $q.="nsinterval=".ss($_REQUEST['nsinterval']).","; 96: // Also use this text field as the indication that ns data is provided at all 97: if (isset($_REQUEST['nspullenabled'])) $set=1; 98: else $set=0; 99: $q.="nspullenabled=".$set.","; 100: if (isset($_REQUEST['nspushenabled'])) $set=1; 101: else $set=0; 102: $q.="nspushenabled=".$set.","; 103: } 104: 105: $q.="hostname=\"".ss($_REQUEST['hostname'])."\""; 106: 107: //if ($NATS->Cfg->Get("dev.links",0)==1) 108: //{ 109: // Utility Links 110: for ($a=0; $a<3; $a++) 111: { 112: $ulink="ulink".$a; 113: $utitle=$ulink."_title"; 114: $uurl=$ulink."_url"; 115: if (isset($_REQUEST[$ulink])) $ulinkv=1; 116: else $ulinkv=0; 117: $q.=",".$ulink."=".$ulinkv.","; 118: $q.=$utitle."=\"".ss($_REQUEST[$utitle])."\","; 119: $q.=$uurl."=\"".ss($_REQUEST[$uurl])."\""; 120: } 121: //} 122: 123: 124: 125: $q.=" WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\""; 126: //echo $q; 127: $NATS->DB->Query($q); 128: 129: if ($NATS->DB->Affected_Rows()<=0) 130: { 131: echo "".$NATS->Lang->Item("save.failed")."
";
132: $poplist[]=$NATS->Lang->Item("save.failed"); 133: } 134: else 135: { 136: echo "".$NATS->Lang->Item("save.ok")."
";
137: $poplist[]=$NATS->Lang->Item("save.ok"); 138: } 139: 140: // Update Interval If Changed 141: if ( isset($_REQUEST['testinterval']) && isset($_REQUEST['original_testinterval']) && 142: ( $_REQUEST['testinterval'] != $_REQUEST['original_testinterval'] ) ) 143: $NATS->InvalidateNode($_REQUEST['nodeid']); 144: 145: // Update Nodeside if Newly Enabled and empty... 146: if ( isset($_REQUEST['original_nsenabled']) && ($_REQUEST['original_nsenabled']==0) && ($nsenabled==1) ) 147: { 148: $q="SELECT nskey FROM fnnode WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\""; 149: $r=$NATS->DB->Query($q); 150: if ($row=$NATS->DB->Fetch_Array($r)) 151: { 152: if ($row['nskey']=="") // generate one 153: { 154: $allow="abcdef0123456789"; 155: $len=64; 156: $alen=strlen($allow); 157: mt_srand(microtime()*1000000); 158: $key=""; 159: for ($a=0; $a<$len; $a++) 160: $key.=$allow[mt_rand(0,$alen-1)]; 161: $uq="UPDATE fnnode SET nskey=\"".$key."\" WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\""; 162: $NATS->DB->Query($uq); 163: } 164: $NATS->DB->Free($r); 165: } 166: } 167: 168: } 169: else if ($_REQUEST['action']=="invalidate") 170: { 171: $_REQUEST['showoptions']=1; 172: $NATS->InvalidateNode($_REQUEST['nodeid'],true); 173: } 174: else if ($_REQUEST['action']=="nodesiderefresh") 175: { 176: $_REQUEST['showoptions']=1; 177: $res=$NATS->NodeSide_Pull($_REQUEST['nodeid']); 178: if ($res===false) 179: { 180: $poplist[]=$NATS->Lang->Item("nodeside.fetch.error"); 181: echo "".$NATS->Lang->Item("nodeside.fetch.error")."

";
182: } 183: else 184: { 185: $poplist[]=$NATS->Lang->Item("nodeside.refreshed"); 186: echo "".$NATS->Lang->Item("nodeside.refreshed")."

";
187: } 188: } 189: else if ($_REQUEST['action']=="save_actions") 190: { 191: // build the two lists... 192: $cur=array(); 193: $cc=0; 194: $nl=array(); 195: $nc=0; 196: 197: if (isset($_REQUEST['links'])) 198: { 199: foreach($_REQUEST['links'] as $link) 200: { 201: $nl[$link]['proc']=false; // not processed or existing i.e. outstanding 202: $nl[$link]['aaid']=$link; 203: $nc++; 204: } 205: } 206: 207: $q="SELECT nalid,aaid FROM fnnalink WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\""; 208: $r=$NATS->DB->Query($q); 209: while ($row=$NATS->DB->Fetch_Array($r)) 210: { 211: //echo $row['aaid'].":"; 212: $cur[$row['aaid']]['proc']=false; 213: $cur[$row['aaid']]['nalid']=$row['nalid']; 214: $cur[$row['aaid']]['aaid']=$row['aaid']; 215: $cc++; 216: } 217: 218: // now we have the two lists lets process them 219: foreach($nl as $newone) 220: { 221: if (isset($cur[$newone['aaid']])) // exists - do nothing to both 222: { 223: //echo "
".$newone['aaid'].":";
224: $cur[$newone['aaid']]['proc']=true; 225: $nl[$newone['aaid']]['proc']=true; 226: } 227: // otherwise news are left false to insert and curs false to delete 228: } 229: 230: // so lets do that 231: foreach($nl as $newone) 232: { 233: if ($newone['proc']==false) 234: { 235: //echo $q; 236: $q="INSERT INTO fnnalink(aaid,nodeid) VALUES(".ss($newone['aaid']).",\"".ss($_REQUEST['nodeid'])."\")"; 237: $NATS->DB->Query($q); 238: } 239: } 240: foreach($cur as $curone) 241: { 242: if ($curone['proc']==false) 243: { 244: $q="DELETE FROM fnnalink WHERE nalid=".$curone['nalid']; 245: $NATS->DB->Query($q); 246: //echo $q; 247: } 248: } 249: 250: echo $NATS->Lang->Item("save.ok")."

";
251: $poplist[]=$NATS->Lang->Item("save.ok"); 252: 253: 254: } 255: 256: } 257: 258: 259: 260: echo "".$NATS->Lang->Item("editing")." ".$NATS->Lang->Item("node").": "; 261: echo "".$_REQUEST['nodeid']."

";
262: 263: 264: $q="SELECT * FROM fnnode WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\" LIMIT 0,1"; 265: $r=$NATS->DB->Query($q); 266: if (!$row=$NATS->DB->Fetch_Array($r)) 267: { 268: echo $NATS->Lang->Item("no.such.node")."

";
269: Screen_Footer(); 270: exit(); 271: } 272: $NATS->DB->Free($r); 273: 274: $title="".$NATS->Lang->Item("node.settings").""; 275: Start_Round($title,600); 276: echo "
"; 277: echo "
"; 278: echo ""; 279: 280: echo ""; 281: echo ""; 282: 283: echo ""; 288: 289: echo ""; 294: 295: echo ""; 300: 301: echo ""; 306: 307: echo ""; 319: 320: echo ""; 323: 324: echo ""; 353: 354: echo ""; 369: echo ""; 370: 371: echo ""; 379: 380: echo ""; 397: 398: echo ""; 404: echo "405: 406: echo ""; 416: 417: echo ""; 425: 426: echo ""; 427: 428: echo ""; 436: 437: echo ""; 445: 446: echo ""; 447: 448: echo ""; 458: echo ""; 459: 460: if ($nodeside) 461: { 462: echo ""; 466: 467: echo ""; 468: if ($row['nspullenabled']==1) $s=" checked"; 469: else $s=""; 470: echo ""; 473: 474: echo ""; 483: 484: echo ""; 488: 489: echo ""; 490: if ($row['nspushenabled']==1) $s=" checked"; 491: else $s=""; 492: echo ""; 495: 496: echo ""; 500: 501: echo ""; 503: 504: if ($row['nspullenabled']==1) 505: { 506: echo ""; 510: } 511: 512: echo ""; 521: 522: echo ""; 526: 527: } 528: 529: echo ""; 530: 531: // New Utility Links 532: //if ($NATS->Cfg->Get("dev.links",0)==1) // ABOVE AS WELL!! 533: //{ 534: echo ""; 554: 555: 556: echo ""; 557: //} 558: 559: 560: echo ""; 564: echo "
"; 284: echo $NATS->Lang->Item("node.id"); 285: echo " :"; 286: echo $row['nodeid']; 287: echo "
"; 290: echo $NATS->Lang->Item("node.name"); 291: echo " :"; 292: echo ""; 293: echo "
"; 296: echo $NATS->Lang->Item("hostname"); 297: echo " :"; 298: echo ""; 299: echo "
"; 302: echo $NATS->Lang->Item("description"); 303: echo " :"; 304: echo ""; 305: echo "
"; 308: echo $NATS->Lang->Item("node.icon"); 309: echo " :"; 310: echo " [ Show Icons ]"; 317: echo " [ ".$NATS->Lang->Item("show.hide.icons")." ]"; 318: echo "
"; 321: echo "
";
322: echo "
"; 325: echo $NATS->Lang->Item("master.node"); 326: echo " :"; 327: echo " ".hlink("Node:Master")."\n"; 352: echo "
"; 355: echo $NATS->Lang->Item("master.skip"); 356: echo " :"; 357: echo " ".hlink("MasterNode:Ping")."\n"; 368: echo "

"; 372: echo $NATS->Lang->Item("node.enabled"); 373: echo " :"; 374: if ($row['nodeenabled']==1) $s=" checked"; 375: else $s=""; 376: echo ""; 377: echo " ".hlink("Node:Enabled"); 378: echo "
"; 381: echo $NATS->Lang->Item("test.schedule"); 382: echo " :"; 383: echo ""; 394: $NATS->DB->Free($sr); 395: echo " ".hlink("Schedule"); 396: echo "
"; 399: echo $NATS->Lang->Item("test.interval"); 400: echo " :"; 401: echo " "; 402: echo $NATS->Lang->Item("minutes")." ".hlink("Node:TestInterval"); 403: echo "
"; 407: echo $NATS->Lang->Item("test.due"); 408: echo " :"; 409: if ($row['nextrunx']>0) echo nicedt($row['nextrunx']); 410: else echo $NATS->Lang->Item("now"); 411: echo "
";
412: echo nicenextx($row['nextrunx']); 413: echo " ".$NATS->Lang->Item("check.asap")." "; 414: echo hlink("Node:CheckASAP",12); 415: echo "
"; 418: echo $NATS->Lang->Item("alerts.active"); 419: echo " :"; 420: if ($row['nodealert']==1) $s=" checked"; 421: else $s=""; 422: echo ""; 423: echo " ".hlink("Node:AlertActive"); 424: echo "

"; 429: echo $NATS->Lang->Item("ping.test"); 430: echo " :"; 431: if ($row['pingtest']==1) $s=" checked"; 432: else $s=""; 433: echo ""; 434: echo " ".hlink("Node:PingTest"); 435: echo "
"; 438: echo $NATS->Lang->Item("require.ping"); 439: echo " :"; 440: if ($row['pingfatal']==1) $s=" checked"; 441: else $s=""; 442: echo ""; 443: echo " ".hlink("Node:RequirePing"); 444: echo "

"; 449: echo $NATS->Lang->Item("nodeside.testing"); 450: echo " :"; 451: if ($row['nsenabled']==1) $nodeside=true; 452: else $nodeside=false; 453: if ($nodeside) $s=" checked"; 454: else $s=""; 455: echo ""; 456: echo " ".hlink("Nodeside"); 457: echo "
".$NATS->Lang->Item("node.key")." :"; 463: echo ""; 464: echo " ".hlink("Nodeside:Key"); 465: echo "
".$NATS->Lang->Item("pull.enabled")." : "; 471: echo hlink("Nodeside:PullEnabled"); 472: echo "
".$NATS->Lang->Item("pull.url")." :"; 475: echo ""; 476: if ($row['nsurl']!="") 477: { 478: $uri=$row['nsurl']."?nodekey=".$row['nskey']."&noupdates=1"; 479: echo " ".$NATS->Lang->Item("debug.raw").""; 480: } 481: echo " ".hlink("Nodeside:URL"); 482: echo "
".$NATS->Lang->Item("pull.interval")." :"; 485: echo ""; 486: echo " ".$NATS->Lang->Item("minutes")." ".hlink("Nodeside:Interval"); 487: echo "
".$NATS->Lang->Item("push.enabled")." : "; 493: echo hlink("Nodeside:PushEnabled"); 494: echo "
".$NATS->Lang->Item("push.ip")." :"; 497: echo ""; 498: echo " ".hlink("Nodeside:PushIP"); 499: echo "
".$NATS->Lang->Item("last.data")." :"; 502: echo nicedt($row['nslastx'])." - ".dtago($row['nslastx'])."
".$NATS->Lang->Item("next.pull.due")." :"; 507: if ($row['nsnextx']>0) echo nicedt($row['nsnextx'])." - ".nicenextx($row['nsnextx']); 508: else echo $NATS->Lang->Item("now"); 509: echo "
".$NATS->Lang->Item("catalogue")." :"; 513: $nsq="SELECT COUNT(nstestid) FROM fnnstest WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\""; 514: $nsr=$NATS->DB->Query($nsq); 515: if ($nsrow=$NATS->DB->Fetch_Array($nsr)) 516: { 517: echo $nsrow['COUNT(nstestid)']." ".$NATS->Lang->Item("nodeside.monitors"); 518: } 519: $NATS->DB->Free($nsr); 520: echo "
".$NATS->Lang->Item("refresh.now").":"; 523: if ($row['nspullenabled']==1) echo "".$NATS->Lang->Item("nodeside.pull.now").""; 524: else echo "".$NATS->Lang->Item("nodeside.pull.disabled").""; 525: echo "

".$NATS->Lang->Item("utility.links")." ".hlink("UtilLinks",12)." :"; 535: echo ""; 536: echo ""; 537: for ($a=0; $a<3; $a++) // auto loop through them 538: { 539: $ulink="ulink".$a; 540: $utitle=$ulink."_title"; 541: $uurl=$ulink."_url"; 542: echo "\n"; 551: } 552: echo "
 ".$NATS->Lang->Item("title")."".$NATS->Lang->Item("url")."
"; 543: if ($row[$ulink]) $s=" checked"; 544: else $s=""; 545: echo ""; 546: echo ""; 547: echo ""; 548: echo ""; 549: echo ""; 550: echo "
";
553: echo "

"; 561: echo "Lang->Item("save.settings")."\"> ".$NATS->Lang->Item("cancel").""; 562: echo "

";
563: echo "
";
565: echo "
";
566: echo "".$NATS->Lang->Item("show.hide.options").""; 567: echo "\n"; 570: End_Round(); 571: 572: if (isset($_REQUEST['show_icons'])) 573: { 574: echo "

";
575: ShowIcons(); 576: echo "

";
577: } 578: 579: //echo "
";
580: 581: echo "

";
582: $title="".$NATS->Lang->Item("node.tests").""; 583: Start_Round($title,600); 584: echo ""; 585: $q="SELECT * FROM fnlocaltest WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\" AND testtype!=\"ICMP\" ORDER BY localtestid ASC"; 586: $r=$NATS->DB->Query($q); 587: while ($row=$NATS->DB->Fetch_Array($r)) 588: { 589: echo ""; 598: 599: echo ""; 606: } 607: 608: if ($nodeside) 609: { 610: $q="SELECT * FROM fnnstest WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\" AND testenabled=1 ORDER BY testtype"; 611: $r=$NATS->DB->Query($q); 612: while ($row=$NATS->DB->Fetch_Array($r)) 613: { 614: echo ""; 621: 622: echo ""; 629: } 630: $NATS->DB->Free($r); 631: } 632: 633: echo "
";
634: echo "\n"; 635: echo ""; 636: echo ""; 637: echo ""; 659: 660: if ($nodeside) 661: { 662: echo "
";
663: echo ""; 664: echo ""; 665: echo ""; 677: } 678: 679: echo "
"; 590: 591: echo ""; 592: if (strlen($row['testparam'])>10) $tp=substr($row['testparam'],0,8).".."; 593: else $tp=$row['testparam']; 594: if ($row['testname']=="") echo lText($row['testtype'])." (".$tp.")"; 595: else echo $row['testname']; 596: echo ""; 597: echo " "; 600: echo "Lang->Item("edit.options")."\"> "; 601: echo ""; 602: echo "Lang->Item("delete")."\">"; 603: 604: echo "  ".$NATS->Lang->Item("last.tested").": ".dtago($row['lastrunx']).""; 605: echo "
"; 615: 616: echo ""; 617: if ($row['testname']=="") echo $row['testdesc']; 618: else echo $row['testname']; 619: echo ""; 620: echo " "; 623: echo "Lang->Item("edit.options")."\"> "; 624: echo ""; 625: echo "Lang->Item("delete")."\">"; 626: 627: echo "  ".$NATS->Lang->Item("last.tested").": ".dtago($row['lastrunx']).""; 628: echo "
 
".$NATS->Lang->Item("add.test")." : "; 651: 652: // one day will do fancy JS option here but for now moved to the edit 653: //echo " "; 654: echo ""; 655: echo ""; 656: 657: echo "Lang->Item("create.test")."\">"; 658: echo "
".$NATS->Lang->Item("add.nodeside")." :"; 675: echo " Lang->Item("add")."\">"; 676: echo "
";
680: End_Round(); 681: echo "

";
682: 683: $title="".$NATS->Lang->Item("alert.actions")." ".hlink("AlertAction",12); 684: Start_Round($title,600); 685: echo ""; 686: echo ""; 687: echo ""; 688: $q="SELECT aaid,aname FROM fnalertaction"; 689: $r=$NATS->DB->Query($q); 690: $c=0; 691: while ($row=$NATS->DB->Fetch_Array($r)) 692: { 693: // has link? 694: $lq="SELECT nalid FROM fnnalink WHERE nodeid=\"".ss($_REQUEST['nodeid'])."\" AND aaid=".ss($row['aaid'])." LIMIT 0,1"; 695: $lr=$NATS->DB->Query($lq); 696: if ($NATS->DB->Num_Rows($lr)>0) $s=" checked"; 697: else $s=""; 698: $NATS->DB->Free($lr); 699: echo ""; 701: } 702: $NATS->DB->Free($r); 703: echo ""; 704: echo "
"; 700: echo "".$row['aaid']." - ".$row['aname']."
Lang->Item("update.alert.actions")."\">
";
705: End_Round(); 706: ?> 707:

708: 709: 710: Screen_Footer(); 711: ?> 712: