#!/usr/bin/perl # # Copyright (C) Roman Dmitiriev, rnd@rajven.ru # use FindBin '$Bin'; use lib "$Bin/"; use strict; use Time::Local; use FileHandle; use Data::Dumper; use Rstat::config; use Rstat::main; use Rstat::net_utils; use Rstat::mysql; use Rstat::snmp; use Rstat::cmd; use Net::SNMP qw(:snmp); use Fcntl qw(:flock); open(SELF,"<",$0) or die "Cannot open $0 - $!"; flock(SELF, LOCK_EX|LOCK_NB) or exit 1; my @auth_list = get_records_sql($dbh,"SELECT A.id,A.ip,A.mac,A.dns_name,A.comments,A.dhcp_hostname,A.WikiName,K.login,K.ou_id FROM User_auth as A, User_list as K WHERE K.id=A.user_id AND A.deleted=0 ORDER BY A.id"); my %auth_ref; foreach my $auth (@auth_list) { $auth_ref{$auth->{id}}{id}=$auth->{id}; $auth_ref{$auth->{id}}{ou_id}=$auth->{ou_id}; $auth_ref{$auth->{id}}{ip}=$auth->{ip}; $auth_ref{$auth->{id}}{mac}=$auth->{mac}; $auth_ref{$auth->{id}}{dns_name}=$auth->{dns_name}; $auth_ref{$auth->{id}}{comments}=$auth->{comments}; $auth_ref{$auth->{id}}{dhcp_hostname}=$auth->{dhcp_hostname}; $auth_ref{$auth->{id}}{WikiName}=$auth->{WikiName}; $auth_ref{$auth->{id}}{login}=$auth->{login}; if ($auth->{dns_name}) { $auth_ref{$auth->{id}}{description} = $auth->{dns_name}; } if (!$auth_ref{$auth->{id}}{description} and $auth->{WikiName}) { $auth_ref{$auth->{id}}{description} = $auth->{WikiName}; } if (!$auth_ref{$auth->{id}}{description} and $auth->{comments}) { $auth_ref{$auth->{id}}{description} = translit($auth->{comments}); } if (!$auth_ref{$auth->{id}}{description} and $auth->{dhcp_hostname}) { $auth_ref{$auth->{id}}{description} = $auth->{dhcp_hostname}; } if (!$auth_ref{$auth->{id}}{description}) { $auth_ref{$auth->{id}}{description} = translit($auth->{login})."_".$auth->{ip}; } $auth_ref{$auth->{id}}{description}=~s/\./-/g; $auth_ref{$auth->{id}}{description}=~s/\(/_/g; $auth_ref{$auth->{id}}{description}=~s/\)/_/g; } my %port_info; my $d_sql="SELECT DP.id, D.ip, D.device_name, D.device_model_id, DP.port, DP.snmp_index, DP.comment, D.community, D.snmp_version, DP.target_port_id, D.vendor_id, D.device_type FROM devices AS D, device_ports AS DP WHERE D.snmp_version>0 and D.id = DP.device_id AND D.community IS NOT NULL AND (D.device_type = 1 OR D.device_type=2) AND D.deleted=0 ORDER BY D.device_name,DP.port"; my @port_list = get_records_sql($dbh,$d_sql); foreach my $port (@port_list) { $port_info{$port->{id}}{id}=$port->{id}; $port_info{$port->{id}}{device_name}=$port->{device_name}; $port_info{$port->{id}}{ip}=$port->{ip}; $port_info{$port->{id}}{device_model_id}=$port->{device_model_id}; $port_info{$port->{id}}{port}=$port->{port}; $port_info{$port->{id}}{snmp_index}=$port->{snmp_index}; $port_info{$port->{id}}{community}=$port->{community}; $port_info{$port->{id}}{comment}=$port->{comment}; $port_info{$port->{id}}{snmp_version}=$port->{snmp_version}; $port_info{$port->{id}}{target_port_id}=$port->{target_port_id}; $port_info{$port->{id}}{vendor_id}=$port->{vendor_id}; $port_info{$port->{id}}{device_type}=$port->{device_type}; } my %conn_info; $d_sql="SELECT C.id, C.port_id, C.auth_id FROM connections AS C, User_auth as A WHERE A.id=C.auth_id AND A.deleted=0 ORDER BY C.id"; my @conn_list = get_records_sql($dbh,$d_sql); foreach my $conn (@conn_list) { $conn_info{$conn->{id}}{id}=$conn->{id}; $conn_info{$conn->{id}}{port_id}=$conn->{port_id}; if ($conn->{auth_id}) { $conn_info{$conn->{id}}{auth_id}=$conn->{auth_id}; $conn_info{$conn->{id}}{description}=$auth_ref{$conn->{auth_id}}->{description}."==ID:".$conn->{auth_id}; $conn_info{$conn->{id}}{ou_id}=$auth_ref{$conn->{auth_id}}->{ou_id}; } } foreach my $conn_id (keys %conn_info) { if (exists $port_info{$conn_info{$conn_id}{port_id}}{count}) { $port_info{$conn_info{$conn_id}{port_id}}{count}++; if ($conn_info{$conn_id}{ou_id}~~[7,10,12,28] and $conn_info{$conn_id}{description}) { $port_info{$conn_info{$conn_id}{port_id}}{description} = $conn_info{$conn_id}{description}; } next; } else { $port_info{$conn_info{$conn_id}{port_id}}{count}=1; } if (!exists $port_info{$conn_info{$conn_id}{port_id}}{description} and $conn_info{$conn_id}{description}) { $port_info{$conn_info{$conn_id}{port_id}}{description} = $conn_info{$conn_id}{description}; } } my %devices; foreach my $port_id (keys %port_info) { if ($port_info{$port_id}{target_port_id}) { $port_info{$port_id}{description}=$port_info{$port_info{$port_id}{target_port_id}}{device_name}."-port-".$port_info{$port_info{$port_id}{target_port_id}}{port}; } if (!$port_info{$port_id}{description} and $port_info{$port_id}{comment}) { $port_info{$port_id}{description}=translit($port_info{$port_id}{comment}); } $devices{$port_info{$port_id}{device_name}}{ports}{$port_info{$port_id}{port}}{description}=$port_info{$port_id}{description}; $devices{$port_info{$port_id}{device_name}}{ports}{$port_info{$port_id}{port}}{snmp_index}=$port_info{$port_id}{snmp_index}; $devices{$port_info{$port_id}{device_name}}{device_name}=$port_info{$port_id}{device_name}; $devices{$port_info{$port_id}{device_name}}{ip}=$port_info{$port_id}{ip}; $devices{$port_info{$port_id}{device_name}}{device_model_id}=$port_info{$port_id}{device_model_id}; $devices{$port_info{$port_id}{device_name}}{vendor_id}=$port_info{$port_id}{vendor_id}; $devices{$port_info{$port_id}{device_name}}{device_type}=$port_info{$port_id}{device_type}; $devices{$port_info{$port_id}{device_name}}{community}=$port_info{$port_id}{community}; $devices{$port_info{$port_id}{device_name}}{snmp_version}=$port_info{$port_id}{snmp_version}; } foreach my $device_name (keys %devices) { my $device = $devices{$device_name}; #skip unknown vendor next if (!$switch_auth{$device->{vendor_id}}); #next if ($device->{ip} ne "192.168.32.11"); my $ip = $device->{ip}; my $community = $device->{community}; my $snmp_version = $device->{snmp_version}; print "Device: $device_name IP: $ip community: $community version: $snmp_version\n"; #get interface names my $int = get_interfaces($ip,$community,$snmp_version,0); $device = netdev_set_auth($device); my $session = netdev_login($device); if ($session) { netdev_set_hostname($session,$device); foreach my $port (sort { $a <=> $b } keys %{$device->{ports}}) { my $descr = $device->{ports}{$port}{description}; my $index = $device->{ports}{$port}{snmp_index}; print "Port: $port index: $index Descr: $descr\n"; netdev_set_port_descr($session,$device,$int->{$index}->{name},$port,$descr); } netdev_wr_mem($session,$device); } } exit;