print-dhcpd-netsh.pl 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. #!/usr/bin/perl
  2. #
  3. # Copyright (C) Roman Dmitiriev, rnd@rajven.ru
  4. #
  5. use FindBin '$Bin';
  6. use lib "/opt/Eye/scripts";
  7. use strict;
  8. use DBI;
  9. use Time::Local;
  10. use Net::Patricia;
  11. use Data::Dumper;
  12. use eyelib::config;
  13. use eyelib::main;
  14. use eyelib::net_utils;
  15. use eyelib::database;
  16. my $time_shift=$ARGV[0];
  17. my $time_filter='';
  18. if ($time_shift) {
  19. my ($sec,$min,$hour,$day,$month,$year,$zone) = localtime(time()-$time_shift*3600);
  20. $month += 1;
  21. $year += 1900;
  22. my $filter_str="$year-$month-$day $hour-$min-$sec";
  23. my $filter_date=$dbh->quote($filter_str);
  24. # $time_filter=' and dhcp_time>='.$filter_date;
  25. $time_filter=' and timestamp>='.$filter_date;
  26. }
  27. my %nets;
  28. foreach my $net (@office_network_list) {
  29. my $scope_name=$net;
  30. $scope_name =~s/\/\d+$//g;
  31. $nets{$scope_name}= new Net::Patricia;
  32. $nets{$scope_name}->add_string($net);
  33. }
  34. #get userid list
  35. my $user_auth_list = $dbh->prepare( "SELECT id,ip,ip_int,mac,dns_name FROM User_auth where deleted=0 $time_filter ORDER by ip_int" );
  36. if ( !defined $user_auth_list ) { die "Cannot prepare statement: $DBI::errstr\n"; }
  37. $user_auth_list->execute;
  38. # user auth list
  39. my $authlist_ref = $user_auth_list->fetchall_arrayref();
  40. $user_auth_list->finish();
  41. $dbh->disconnect;
  42. foreach my $row (@$authlist_ref) {
  43. next if (!$row);
  44. my $ip=trim($row->[1]);
  45. my $ip_int=trim($row->[2]);
  46. my $mac=trim($row->[3]);
  47. my $dns_name=trim($row->[4]);
  48. next if (!$ip_int);
  49. next if (!$mac);
  50. next if (!$ip);
  51. $mac=mac_simplify($mac);
  52. my $scope_name;
  53. foreach my $scope (keys %nets) {
  54. if ($nets{$scope}->match_string($ip)) { $scope_name=$scope; }
  55. }
  56. next if (!$scope_name);
  57. my $default_name;
  58. if ($dns_name) { $default_name=$dns_name; } else {
  59. $default_name = $ip;
  60. $default_name =~s/192.168.//g;
  61. }
  62. $default_name =~s/_/-/g;
  63. $default_name =~s/[.]/-/g;
  64. $default_name =~s/ /-/g;
  65. print 'Dhcp Server \\\\127.0.0.1 Scope '.$scope_name.' Add reservedip '.$ip.' '.$mac.' "'.$default_name.'" "" "DHCP"'."\n";
  66. }
  67. exit 0;