print-dhcpd-netsh.pl 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. #!/usr/bin/perl
  2. #
  3. # Copyright (C) Roman Dmitriev, 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. use eyelib::common;
  17. my $time_shift=$ARGV[0];
  18. my $time_filter='';
  19. if ($time_shift) {
  20. my ($sec,$min,$hour,$day,$month,$year,$zone) = localtime(time()-$time_shift*3600);
  21. $month += 1;
  22. $year += 1900;
  23. my $filter_str="$year-$month-$day $hour-$min-$sec";
  24. my $filter_date=$dbh->quote($filter_str);
  25. # $time_filter=' and dhcp_time>='.$filter_date;
  26. $time_filter=' and timestamp>='.$filter_date;
  27. }
  28. my %nets;
  29. foreach my $net (@office_network_list) {
  30. my $scope_name=$net;
  31. $scope_name =~s/\/\d+$//g;
  32. $nets{$scope_name}= new Net::Patricia;
  33. $nets{$scope_name}->add_string($net);
  34. }
  35. #get userid list
  36. 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" );
  37. if ( !defined $user_auth_list ) { die "Cannot prepare statement: $DBI::errstr\n"; }
  38. $user_auth_list->execute;
  39. # user auth list
  40. my $authlist_ref = $user_auth_list->fetchall_arrayref();
  41. $user_auth_list->finish();
  42. $dbh->disconnect;
  43. foreach my $row (@$authlist_ref) {
  44. next if (!$row);
  45. my $ip=trim($row->[1]);
  46. my $ip_int=trim($row->[2]);
  47. my $mac=trim($row->[3]);
  48. my $dns_name=trim($row->[4]);
  49. next if (!$ip_int);
  50. next if (!$mac);
  51. next if (!$ip);
  52. $mac=mac_simplify($mac);
  53. my $scope_name;
  54. foreach my $scope (keys %nets) {
  55. if ($nets{$scope}->match_string($ip)) { $scope_name=$scope; }
  56. }
  57. next if (!$scope_name);
  58. my $default_name;
  59. if ($dns_name) { $default_name=$dns_name; } else {
  60. $default_name = $ip;
  61. $default_name =~s/192.168.//g;
  62. }
  63. $default_name =~s/_/-/g;
  64. $default_name =~s/[.]/-/g;
  65. $default_name =~s/ /-/g;
  66. print 'Dhcp Server \\\\127.0.0.1 Scope '.$scope_name.' Add reservedip '.$ip.' '.$mac.' "'.$default_name.'" "" "DHCP"'."\n";
  67. }
  68. exit 0;