1
0

dhcp.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. <?php
  2. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/auth.php");
  3. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/languages/" . HTML_LANG . ".php");
  4. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/header.php");
  5. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/datetimefilter.php");
  6. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/cidrfilter.php");
  7. if (isset($_POST['dhcp_show'])) { $f_dhcp = $_POST['dhcp_show']; }
  8. else {
  9. if (isset($_SESSION[$page_url]['f_dhcp'])) { $f_dhcp=$_SESSION[$page_url]['f_dhcp']; } else { $f_dhcp = 'all'; }
  10. }
  11. if (isset($_POST['ip'])) { $f_ip = $_POST['ip']; }
  12. if (!isset($f_ip) and isset($_SESSION[$page_url]['ip'])) { $f_ip=$_SESSION[$page_url]['ip']; }
  13. if (!isset($f_ip)) { $f_ip=''; }
  14. $_SESSION[$page_url]['f_dhcp']=$f_dhcp;
  15. $_SESSION[$page_url]['ip']=$f_ip;
  16. $dhcp_where = '';
  17. $params=[ $date1, $date2 ];
  18. if ($f_dhcp != 'all') { $dhcp_where = " and action=?"; $params[]=$f_dhcp; }
  19. if (empty($rcidr)) { $cidr_filter = ''; } else {
  20. $cidr_range = cidrToRange($rcidr);
  21. if (!empty($cidr_range)) { $cidr_filter = " and (ip_int>=? and ip_int<=?)"; }
  22. $params[]=ip2long($cidr_range[0]);
  23. $params[]=ip2long($cidr_range[1]);
  24. }
  25. if (!empty($f_ip)) {
  26. if (checkValidIp($f_ip)) {
  27. $dhcp_where = " and ip_int=?";
  28. $params[]=ip2long($f_ip);
  29. } else {
  30. if (checkValidMac($f_ip)) {
  31. $dhcp_where = " and mac=?";
  32. $params[]= mac_dotted($f_ip);
  33. } else {
  34. $dhcp_where = " and dhcp_hostname like ?";
  35. $params[]=$f_ip.'%';
  36. }
  37. }
  38. }
  39. $dhcp_where .= $cidr_filter;
  40. print_log_submenu($page_url);
  41. ?>
  42. <div id="cont">
  43. <br>
  44. <form action="<?=$_SERVER['PHP_SELF']?>" method="post">
  45. <?php print_date_fields($date1,$date2,$date_shift); ?>
  46. <?php print WEB_rows_at_page."&nbsp"; print_row_at_pages('rows',$displayed); ?>
  47. <div><br>
  48. <?php echo WEB_network_subnet; ?>:&nbsp<?php print_subnet_select_office_splitted($db_link, 'cidr', $rcidr); ?>
  49. <?php echo WEB_log_event_type; ?>:&nbsp<?php print_dhcp_select('dhcp_show', $f_dhcp); ?>
  50. <input type="submit" value="<?php echo WEB_btn_show; ?>">
  51. <div><br>
  52. <?php echo WEB_log_select_ip_mac; ?>:&nbsp<input type="text" name="ip" value="<?php echo $f_ip; ?>" />
  53. </form>
  54. <?php
  55. $countSQL="SELECT Count(*) FROM dhcp_log WHERE ts>=? AND ts<? $dhcp_where";
  56. $count_records = get_single_field($db_link,$countSQL, $params);
  57. $total=ceil($count_records/$displayed);
  58. if ($page>$total) { $page=$total; }
  59. if ($page<1) { $page=1; }
  60. $start = ($page * $displayed) - $displayed;
  61. print_navigation($page_url,$page,$displayed,$count_records,$total);
  62. ?>
  63. <br>
  64. <table class="data" width="900">
  65. <tr align="center">
  66. <td class="data" width=150><b><?php echo WEB_log_time; ?></b></td>
  67. <td class="data"><b><?php echo WEB_cell_type; ?></b></td>
  68. <td class="data"><b><?php echo WEB_cell_mac; ?></b></td>
  69. <td class="data"><b><?php echo WEB_cell_ip; ?></b></td>
  70. <td class="data"><b><?php echo WEB_cell_dhcp_hostname; ?></b></td>
  71. </tr>
  72. <?php
  73. #speedup dhcp log paging
  74. $sSQL = "SELECT * FROM dhcp_log as D JOIN (SELECT id FROM dhcp_log WHERE ts>=? and ts<? $dhcp_where ORDER BY id DESC LIMIT ? OFFSET ?) AS I ON D.id = I.id";
  75. $params[]=$displayed;
  76. $params[]=$start;
  77. $userlog = get_records_sql($db_link, $sSQL, $params);
  78. foreach ($userlog as $row) {
  79. if ($row['action'] == "old") { $row['action'] = WEB_log_dhcp_old.": "; }
  80. if ($row['action'] == "add") { $row['action'] = WEB_log_dhcp_add.": "; }
  81. if ($row['action'] == "del") { $row['action'] = WEB_log_dhcp_del.": "; }
  82. $l_msg = $row['action'] . " " . $row['mac'] . " " . $row['ip'];
  83. print "<tr align=center class=\"tr1\" onmouseover=\"className='tr2'\" onmouseout=\"className='tr1'\">\n";
  84. print "<td class=\"data\">" . $row['ts'] . "</td>\n";
  85. print "<td class=\"data\">" . $row['action'] . "</td>\n";
  86. print "<td class=\"data\">" . $row['mac'] . "</td>\n";
  87. if (isset($row['auth_id']) and $row['auth_id'] > 0) {
  88. print "<td class=\"data\"><a href=/admin/users/editauth.php?id=".$row['auth_id'].">" . $row['ip'] . "</a></td>\n";
  89. } else {
  90. print "<td class=\"data\">" . $row['ip'] . "</td>\n";
  91. }
  92. print "<td class=\"data\">" . $row['dhcp_hostname'] . "</td>\n";
  93. print "</tr>\n";
  94. }
  95. print "</table>\n";
  96. print_navigation($page_url,$page,$displayed,$count_records,$total);
  97. require_once ($_SERVER['DOCUMENT_ROOT']."/inc/footer.php");
  98. ?>