switchstatus.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. <?php
  2. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/auth.php");
  3. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/languages/" . $language . ".php");
  4. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/idfilter.php");
  5. $switch=get_record($db_link,'devices',"id=".$id);
  6. if (isset($_POST["regensnmp"])) {
  7. $snmp_index = $_POST["f_snmp_start"] * 1;
  8. $sSQL = "SELECT id,port from device_ports WHERE device_ports.device_id=$id order by id";
  9. $flist = mysqli_query($db_link, $sSQL);
  10. LOG_DEBUG($db_link, "Recalc snmp_index for device id: $id with start $snmp_index");
  11. while (list ($port_id, $port) = mysqli_fetch_array($flist)) {
  12. $snmp = $port + $snmp_index - 1;
  13. $new['snmp_index'] = $snmp;
  14. update_record($db_link, "device_ports", "id='$port_id'", $new);
  15. }
  16. header("Location: " . $_SERVER["REQUEST_URI"]);
  17. }
  18. if (isset($_POST['poe_on']) and $switch['snmp_version']>0) {
  19. $len = is_array($_POST['poe_on']) ? count($_POST['poe_on']) : 0;
  20. for ($i = 0; $i < $len; $i ++) {
  21. $port_index = intval($_POST['poe_on'][$i]);
  22. LOG_DEBUG($db_link, "Device id: $id enable poe at port snmp index $port_index");
  23. set_port_poe_state($switch['vendor_id'], $port_index, $switch['ip'], $switch['rw_community'], $switch['snmp_version'], 1);
  24. }
  25. header("Location: " . $_SERVER["REQUEST_URI"]);
  26. }
  27. if (isset($_POST['poe_off']) and $switch['snmp_version']>0) {
  28. $len = is_array($_POST['poe_off']) ? count($_POST['poe_off']) : 0;
  29. for ($i = 0; $i < $len; $i ++) {
  30. $port_index = intval($_POST['poe_off'][$i]);
  31. LOG_DEBUG($db_link, "Device id: $id disable poe at port snmp index $port_index");
  32. set_port_poe_state($switch['vendor_id'], $port_index, $switch['ip'], $switch['rw_community'], $switch['snmp_version'], 0);
  33. }
  34. header("Location: " . $_SERVER["REQUEST_URI"]);
  35. }
  36. if (isset($_POST['port_on']) and $switch['snmp_version']>0) {
  37. $len = is_array($_POST['port_on']) ? count($_POST['port_on']) : 0;
  38. for ($i = 0; $i < $len; $i ++) {
  39. $port_index = intval($_POST['port_on'][$i]);
  40. LOG_DEBUG($db_link, "Device id: $id enable port with snmp index $port_index");
  41. set_port_state($switch['vendor_id'], $port_index, $switch['ip'], $switch['rw_community'], $switch['snmp_version'], 1);
  42. }
  43. header("Location: " . $_SERVER["REQUEST_URI"]);
  44. }
  45. if (isset($_POST['port_off']) and $switch['snmp_version']>0) {
  46. $len = is_array($_POST['port_off']) ? count($_POST['port_off']) : 0;
  47. for ($i = 0; $i < $len; $i ++) {
  48. $port_index = intval($_POST['port_off'][$i]);
  49. LOG_DEBUG($db_link, "Device id: $id disable port with snmp index $port_index");
  50. set_port_state($switch['vendor_id'], $port_index, $switch['ip'], $switch['rw_community'], $switch['snmp_version'], 0);
  51. }
  52. header("Location: " . $_SERVER["REQUEST_URI"]);
  53. }
  54. unset($_POST);
  55. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/header.php");
  56. print_editdevice_submenu($page_url,$id);
  57. ?>
  58. <div id="cont">
  59. <form name="def" action="switchstatus.php?id=<? echo $id; ?>" method="post">
  60. <?php
  61. print "<br>\n";
  62. print "<b>Состояние портов ".$switch['device_name']." - ".$switch['ip']."</b><br>\n";
  63. if ($switch['snmp_version']>0) {
  64. $snmp_ok = check_snmp_access($switch['ip'], $switch['community'], $switch['snmp_version']);
  65. if ($snmp_ok) {
  66. global $cisco_modules;
  67. if ($switch['snmp_version'] == 2) {
  68. $modules_oids = snmp2_real_walk($switch['ip'], $switch['community'], $cisco_modules);
  69. }
  70. if ($switch['snmp_version'] == 1) {
  71. $modules_oids = snmprealwalk($switch['ip'], $switch['community'], $cisco_modules);
  72. }
  73. }
  74. } else { $snmp_ok = 0; }
  75. print "<table class=\"data\" cellspacing=\"1\" cellpadding=\"4\">\n";
  76. print "<tr>\n";
  77. print "<td>id</td>\n";
  78. print "<td>N</td>\n";
  79. print "<td>Порт</td>\n";
  80. print "<td>snmp</td>\n";
  81. print "<td>Юзер|Device</td>\n";
  82. print "<td>Комментарий</td>\n";
  83. print "<td>Uplink</td>\n";
  84. print "<td>Nagios</td>\n";
  85. print "<td>Skip</td>\n";
  86. print "<td>Vlan</td>\n";
  87. print "<td>IfName</td>\n";
  88. print "<td>Speed</td>\n";
  89. print "<td>Errors</td>\n";
  90. print "<td>Mac count</td>\n";
  91. print "<td>Additional</td>\n";
  92. print "<td>POE Control</td>\n";
  93. print "<td>Port Control</td>\n";
  94. print "</tr>\n";
  95. $sSQL = "SELECT * FROM device_ports WHERE device_ports.device_id=$id ORDER BY port";
  96. $ports=get_records_sql($db_link,$sSQL);
  97. foreach ($ports as $row) {
  98. print "<tr align=center>\n";
  99. $cl = "down";
  100. $new_info = NULL;
  101. //fix empty port names
  102. if (!isset($row['port_name'])) { $row['port_name']=$row['port']; $new_info['port_name']=$row['port']; }
  103. if (isset($switch['ip']) and ($switch['ip'] != '') and $snmp_ok) {
  104. $port_state_detail = get_port_state_detail($row['snmp_index'], $switch['ip'], $switch['community'], $switch['snmp_version'], $switch['fdb_snmp_index']);
  105. list ($poper, $padmin, $pspeed, $perrors) = explode(';', $port_state_detail);
  106. if (preg_match('/up/i', $poper)) { $cl = "up"; }
  107. if (preg_match('/down/i', $poper)) {
  108. if (preg_match('/down/i', $padmin)) { $cl = "shutdown"; } else { $cl = "down"; }
  109. }
  110. }
  111. print "<td class=\"$cl\" style='padding:0'><input type=checkbox name=d_port_index[] value=".$row['snmp_index']." ></td>\n";
  112. print "<td class=\"$cl\"><a href=\"editport.php?id=".$row['id']."\">" . $row['port'] . "</a></td>\n";
  113. print "<td class=\"$cl\" >" . $row['port_name'] . "</td>\n";
  114. print "<td class=\"$cl\" >" . $row['snmp_index'] . "</td>\n";
  115. print "<td class=\"$cl\">";
  116. if (isset($row['target_port_id']) and $row['target_port_id'] > 0) {
  117. print_device_port($db_link, $row['target_port_id']);
  118. } else {
  119. print_auth_port($db_link, $row['id']);
  120. }
  121. print "</td>\n";
  122. print "<td class=\"$cl\">" . $row['comment'] . "</td>\n";
  123. print "<td class=\"$cl\" >" . get_qa($row['uplink']) . "</td>\n";
  124. print "<td class=\"$cl\" >" . get_qa($row['nagios']) . "</td>\n";
  125. print "<td class=\"$cl\" >" . get_qa($row['skip']) . "</td>\n";
  126. $poe_info="POE:None";
  127. $vlan = $row['vlan'];
  128. $ifname= $row['ifName'];
  129. if ($snmp_ok) {
  130. $vlan = get_port_vlan($row['port'], $row['snmp_index'], $switch['ip'], $switch['community'], $switch['snmp_version'], $switch['fdb_snmp_index']);
  131. $ifname = get_snmp_ifname($switch['ip'], $switch['community'], $switch['snmp_version'], $row['snmp_index']);
  132. $sfp_status = get_sfp_status($switch['vendor_id'], $row['snmp_index'], $switch['ip'], $switch['community'], $switch['snmp_version'], $modules_oids);
  133. $poe_status = get_port_poe_state($switch['vendor_id'], $row['snmp_index'], $switch['ip'], $switch['community'], $switch['snmp_version']);
  134. if (isset($poe_status)) {
  135. if ($poe_status == 1) {
  136. $port_poe_detail = get_port_poe_detail($switch['vendor_id'], $row['snmp_index'], $switch['ip'], $switch['community'], $switch['snmp_version']);
  137. $poe_info="POE:On " . $port_poe_detail;
  138. }
  139. if ($poe_status == 2) { $poe_info="POE:Off"; }
  140. }
  141. if (!isset($vlan)) { $vlan = $row['vlan']; } else {
  142. if ($row['vlan']!==$vlan) { $new_info['vlan']=$vlan; }
  143. }
  144. if (!isset($row['ifName']) or $row['ifName'] !== $ifname) { $new_info['ifName']=$ifname; }
  145. }
  146. //fix port information
  147. if (!empty($new_info)) { update_record($db_link, "device_ports", "id=".$row['id'], $new_info); }
  148. $ifname=compact_port_name($ifname);
  149. global $torrus_url;
  150. $f_cacti_url = get_cacti_graph($switch['ip'], $row['snmp_index']);
  151. if (! isset($torrus_url) and (! isset($f_cacti_url))) { $snmp_url=$ifname; }
  152. else {
  153. if (isset($f_cacti_url)) { $snmp_url = "<a href=\"$f_cacti_url\">" . $ifname . "</a>"; }
  154. if (isset($torrus_url)) {
  155. $normed_ifname = str_replace("/", "_", $ifname);
  156. $normed_ifname = str_replace(".", "_", $normed_ifname);
  157. $normed_ifname = trim(str_replace(" ", "_", $normed_ifname));
  158. $t_url = str_replace("HOST_IP", $switch['ip'], $torrus_url);
  159. $t_url = str_replace("IF_NAME", $normed_ifname, $t_url);
  160. $snmp_url = "<a href=\"$t_url\">" . $ifname . "</a>";
  161. }
  162. }
  163. print "<td class=\"$cl\">" . $vlan . "</td>\n";
  164. print "<td class=\"$cl\">" . $snmp_url . "</td>\n";
  165. $speed = "0";
  166. $cl_speed = $cl;
  167. if ($pspeed == 0) { $speed = ""; }
  168. if ($pspeed == 10000000) { $speed = "10M"; $cl_speed = "speed10M"; }
  169. if ($pspeed == 100000000) { $speed = "100M"; $cl_speed = "speed100M"; }
  170. if ($pspeed == 1000000000) { $speed = "1G"; $cl_speed = "speed1G"; }
  171. if ($pspeed == 10000000000) { $speed = "10G"; $cl_speed = "speed10G"; }
  172. if ($pspeed == 4294967295) { $speed = "10G"; $cl_speed = "speed10G"; }
  173. if ($pspeed == 10) { $speed = "10G"; $cl_speed = "speed10G"; }
  174. print "<td class=\"$cl_speed\">" . $speed . "</td>\n";
  175. $cl_error = $cl;
  176. if ($perrors > 0) { $cl_error = "crc"; }
  177. print "<td class=\"$cl_error\">" . $perrors . "</td>\n";
  178. print "<td class=\"$cl\" ><button name=\"write\" class=\"j-submit-report\" onclick=\"window.open('portmactable.php?id=" . $row['id'] . "')\">" . $row['last_mac_count'] . "</button></td>\n";
  179. print "<td class=\"$cl\">" . $sfp_status. " ". $poe_info."</td>\n";
  180. if (isset($poe_status) and ! $row['skip'] and ! $switch['is_router']) {
  181. print "<td class=\"data\">";
  182. if ($switch['vendor_id'] != 9) {
  183. if ($poe_status == 2) {
  184. print "<button name='poe_on[]' value='{$row['snmp_index']}'>POE On</button>";
  185. }
  186. if ($poe_status == 1) {
  187. print "<button name='poe_off[]' value='{$row['snmp_index']}'>POE Off</button>";
  188. }
  189. } else {
  190. print "Not supported";
  191. }
  192. print "</td>\n";
  193. } else {
  194. print "<td>Not supported</td>\n";
  195. }
  196. if (isset($padmin) and ! $row['uplink'] and ! $row['skip'] and ! $switch['is_router']) {
  197. print "<td class=\"data\">";
  198. if ($switch['vendor_id'] != 9) {
  199. if (preg_match('/down/i', $padmin)) {
  200. print "<button name='port_on[]' value='{$row['snmp_index']}'>Enable port</button>";
  201. }
  202. if (preg_match('/up/i', $padmin)) {
  203. print "<button name='port_off[]' value='{$row['snmp_index']}'>Shutdown port</button>";
  204. }
  205. } else {
  206. print "Not supported";
  207. }
  208. print "</td>\n";
  209. }
  210. print "</tr>";
  211. }
  212. print "<tr>\n";
  213. print "<td colspan=10>snmp start &nbsp<input type=\"text\" name='f_snmp_start' value=1></td>\n";
  214. print "<td><input type=\"submit\" name=\"regensnmp\" value=\"Обновить snmp\"></td>\n";
  215. print "</tr>\n";
  216. print "</table>\n";
  217. print "<table class=\"data\" cellspacing=\"1\" cellpadding=\"4\">\n";
  218. print "<tr><td>Port status</td></tr>\n";
  219. print "<tr><td class=\"down\">Oper down</td><td class=\"up\">Oper up</td><td class=\"shutdown\">Admin shutdown</td><tr>\n";
  220. print "</table>\n";
  221. print "<table class=\"data\" cellspacing=\"1\" cellpadding=\"4\">\n";
  222. print "<tr><td>Port speed</td></tr>\n";
  223. print "<tr><td class=\"speed10M\">10M</td><td class=\"speed100M\">100M</td><td class=\"speed1G\">1G</td><td class=\"speed10G\">10G</td><tr>\n";
  224. print "</table>\n";
  225. print "</form>";
  226. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/footer.small.php");
  227. ?>