nagios.php 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. <?php
  2. $default_displayed=500;
  3. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/auth.php");
  4. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/languages/" . HTML_LANG . ".php");
  5. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/header.php");
  6. $default_sort='ip_int';
  7. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/oufilter.php");
  8. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/subnetfilter.php");
  9. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/sortfilter.php");
  10. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/gatefilter.php");
  11. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/enabledfilter.php");
  12. $sort_table = 'user_auth';
  13. if ($sort_field == 'login') { $sort_table = 'user_list'; }
  14. if ($sort_field == 'description') { $sort_table = 'user_list'; }
  15. $sort_url = "<a href=nagios.php?ou=" . $rou;
  16. $params=[];
  17. if ($rou == 0) { $ou_filter = ''; } else { $ou_filter = " and user_list.ou_id=?"; $params[]=$rou; }
  18. if ($rsubnet == 0) { $subnet_filter = ''; } else {
  19. $subnet_range = get_subnet_range($db_link,$rsubnet);
  20. if (!empty($subnet_range)) { $subnet_filter = " and user_auth.ip_int>=? and user_auth.ip_int<=?"; }
  21. $params[]=$subnet_range['start'];
  22. $params[]=$subnet_range['stop'];
  23. }
  24. $enabled_filter='';
  25. if ($enabled>0) {
  26. if ($enabled===2) { $enabled_filter = ' and user_auth.nagios=1'; }
  27. if ($enabled===1) { $enabled_filter = ' and user_auth.nagios=0'; }
  28. }
  29. $ip_list_filter = $ou_filter.$subnet_filter.$enabled_filter;
  30. print_ip_submenu($page_url);
  31. ?>
  32. <div id="cont">
  33. <form name="filter" action="nagios.php" method="post">
  34. <table class="data">
  35. <tr>
  36. <td>
  37. <b><?php print WEB_cell_ou; ?> :</b><?php print_ou_select($db_link, 'ou', $rou); ?>
  38. <b><?php print WEB_network_subnet; ?> - </b><?php print_subnet_select_office($db_link, 'subnet', $rsubnet); ?>
  39. <b><?php print WEB_nagios; ?> :</b><?php print_enabled_select('enabled', $enabled); ?>
  40. <?php print WEB_rows_at_page."&nbsp"; print_row_at_pages('rows',$displayed); ?>
  41. <input id="btn_filter" name="btn_filter" type="submit" value="<?php print WEB_btn_show; ?>">
  42. </td>
  43. </tr>
  44. </table>
  45. </form>
  46. <a class="mainButton" href="#modal"><?php print WEB_btn_apply_selected; ?></a>
  47. <div class="remodal" data-remodal-options="closeOnConfirm: true" data-remodal-id="modal" role="dialog" aria-labelledby="modal1Title" aria-describedby="modal1Desc">
  48. <div class="remodalBorder">
  49. <button data-remodal-action="close" class="remodal-close" aria-label="Close"></button>
  50. <form id="formAuthApply">
  51. <h2 id="modal1Title"><?php print WEB_selection_title; ?></h2>
  52. <input type="hidden" name="ApplyForAll" value="MassChange">
  53. <table class="data" align=center>
  54. <tr><td><input type=checkbox class="putField" name="e_nag_enabled" value='1'></td><td>Nagios&nbsp<?php print_qa_select('n_enabled', 1); ?></td></tr>
  55. <tr><td><input type=checkbox class="putField" name="e_nag_link" value='1'></td><td>Link&nbsp<?php print_qa_select('n_link', 0); ?></td></tr>
  56. <tr><td><input type=checkbox class="putField" name="e_nag_handler" value='1'></td><td>Event-handler&nbsp<?php print_nagios_handler_select($db_link,'n_handler', ''); ?></td></tr>
  57. </table>
  58. <input type="submit" name="submit" class="btn" value="<?php echo WEB_btn_apply; ?>">
  59. </form>
  60. </div>
  61. </div>
  62. <?php
  63. $countSQL="SELECT Count(*) FROM user_auth, user_list WHERE user_auth.user_id = user_list.id AND user_auth.deleted =0 $ip_list_filter";
  64. $count_records = get_single_field($db_link,$countSQL, $params);
  65. $total=ceil($count_records/$displayed);
  66. if ($page>$total) { $page=$total; }
  67. if ($page<1) { $page=1; }
  68. $start = ($page * $displayed) - $displayed;
  69. print_navigation($page_url,$page,$displayed,$count_records,$total);
  70. ?>
  71. <br>
  72. <form id="def" name="def">
  73. <table class="data">
  74. <tr>
  75. <td align=Center><input type="checkbox" onClick="checkAll(this.checked);"></td>
  76. <td align=Center><?php print $sort_url . "&sort=login&order=$new_order>" . WEB_cell_login . "</a>"; ?></td>
  77. <td align=Center><?php print $sort_url . "&sort=ip_int&order=$new_order>" . WEB_cell_ip . "</a>"; ?></td>
  78. <td align=Center><?php print $sort_url . "&sort=mac&order=$new_order>" . WEB_cell_mac . "</a>"; ?></td>
  79. <td align=Center><?php print WEB_cell_description; ?></td>
  80. <td align=Center><?php print WEB_cell_wikiname; ?></td>
  81. <td align=Center><?php print $sort_url . "&sort=nagios&order=$new_order>" . WEB_cell_nagios; ?></td>
  82. <td align=Center><?php print $sort_url . "&sort=link_check&order=$new_order>" . WEB_cell_link; ?></td>
  83. <td align=Center><?php print WEB_cell_nagios_handler; ?></td>
  84. <td align=Center><?php print $sort_url . "&sort=last_found&order=$new_order>Last</a>"; ?></td>
  85. <td align=Center><?php print WEB_cell_connection; ?></td>
  86. </tr>
  87. <?php
  88. $sSQL = "SELECT user_auth.*, user_list.login FROM user_auth, user_list
  89. WHERE user_auth.user_id = user_list.id AND user_auth.deleted =0 $ip_list_filter
  90. ORDER BY $sort_table.$sort_field $order LIMIT ? OFFSET ?";
  91. $params[]=$displayed;
  92. $params[]=$start;
  93. $users = get_records_sql($db_link,$sSQL, $params);
  94. foreach ($users as $user) {
  95. if ($user['dhcp_time'] == '0000-00-00 00:00:00') {
  96. $dhcp_str = '';
  97. } else {
  98. $dhcp_str = $user['dhcp_time'] . " (" . $user['dhcp_action'] . ")";
  99. }
  100. if ($user['last_found'] == '0000-00-00 00:00:00') { $user['last_found'] = ''; }
  101. print "<tr align=center>\n";
  102. $cl = "data";
  103. if ($user['nagios_status'] == "UP") { $cl = "up"; }
  104. if ($user['nagios_status'] == "DOWN") { $cl = "down"; }
  105. if (!$user['nagios']) { $cl = "data"; }
  106. print "<td class=\"$cl\" style='padding:0'><input type=checkbox name=fid[] value=".$user['id']."></td>\n";
  107. print "<td class=\"$cl\" ><a href=/admin/users/edituser.php?id=".$user['user_id'].">" . $user['login'] . "</a></td>\n";
  108. print "<td class=\"$cl\" ><a href=/admin/users/editauth.php?id=".$user['id'].">" . $user['ip'] . "</a></td>\n";
  109. print "<td class=\"$cl\" >" . expand_mac($db_link,$user['mac']) . "</td>\n";
  110. if (isset($user['dhcp_hostname']) and strlen($user['dhcp_hostname']) > 0) {
  111. print "<td class=\"$cl\" width=200>".$user['description']." [" . $user['dhcp_hostname'] . "]</td>\n";
  112. } else {
  113. print "<td class=\"$cl\" width=200>".$user['description']."</td>\n";
  114. }
  115. if (!empty($user['wikiname'])) {
  116. $wiki_url = rtrim(get_option($db_link, 60),'/');
  117. if (preg_match('/127.0.0.1/', $wiki_url)) { print "<td class=\"$cl\" ></td>\n"; } else {
  118. $wiki_web = rtrim(get_option($db_link, 63),'/');
  119. $wiki_web = ltrim($wiki_web,'/');
  120. $wiki_link = $wiki_url.'/'.$wiki_web.'/'.$user['wikiname'];
  121. print "<td class=\"$cl\" >"; print_url($user['wikiname'],$wiki_link); print "</td>\n";
  122. }
  123. } else {
  124. print "<td class=\"$cl\" ></td>\n";
  125. }
  126. if (!empty($user['nagios']) and $user['nagios']) {
  127. if (preg_match('/127.0.0.1/', get_const('nagios_url'))) { print "<td class=\"$cl\" >". get_qa($user['nagios']) ."</td>\n"; } else {
  128. $nagios_link = get_const('nagios_url').'status.cgi?host='.get_nagios_name($user);
  129. print "<td class=\"$cl\" >"; print_url(get_qa($user['nagios']),$nagios_link); print "</td>\n";
  130. }
  131. } else {
  132. print_td_qa($user['nagios'],FALSE,$cl);
  133. }
  134. print_td_qa($user['link_check'],FALSE,$cl);
  135. print "<td class=\"$cl\" >".$user['nagios_handler']."</td>\n";
  136. print "<td class=\"$cl\" >".$user['last_found']."</td>\n";
  137. print "<td class=\"$cl\" >" . get_connection($db_link, $user['id']) . "</td>\n";
  138. print "</tr>\n";
  139. }
  140. print "</table>\n";
  141. print_navigation($page_url,$page,$displayed,$count_records,$total);
  142. ?>
  143. <br>
  144. <table class="data">
  145. <tr><td><?php echo WEB_color_description; ?></td></tr>
  146. <tr>
  147. <td class="up"><?php echo WEB_nagios_host_up; ?></td>
  148. <td class="down"><?php echo WEB_nagios_host_down; ?></td>
  149. <td class="data"><?php echo WEB_nagios_host_unknown; ?></td>
  150. </table>
  151. <script src="/js/remodal/remodal.min.js"></script>
  152. <script src="/js/remodal-auth.js"></script>
  153. <script>
  154. document.getElementById('ou').addEventListener('change', function(event) {
  155. const buttonApply = document.getElementById('btn_filter');
  156. buttonApply.click();
  157. });
  158. document.getElementById('subnet').addEventListener('change', function(event) {
  159. const buttonApply = document.getElementById('btn_filter');
  160. buttonApply.click();
  161. });
  162. document.getElementById('enabled').addEventListener('change', function(event) {
  163. const buttonApply = document.getElementById('btn_filter');
  164. buttonApply.click();
  165. });
  166. document.getElementById('rows').addEventListener('change', function(event) {
  167. const buttonApply = document.getElementById('btn_filter');
  168. buttonApply.click();
  169. });
  170. </script>
  171. <?php
  172. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/footer.php");
  173. ?>