summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorivan <ivan>2011-03-01 18:37:16 +0000
committerivan <ivan>2011-03-01 18:37:16 +0000
commit3f17118ce8dbb578ae735ab1f20548f4a4addaea (patch)
treec93d3c96c13176c85bf5881ec80c57b01fccff55
parent499fc3a18a561c085b0848b331916ead06ba59cb (diff)
get serviceids from torrus config + our torrus_srvderive table, not from srvexport
-rw-r--r--FS/FS/NetworkMonitoringSystem/Torrus_Internal.pm133
1 files changed, 86 insertions, 47 deletions
diff --git a/FS/FS/NetworkMonitoringSystem/Torrus_Internal.pm b/FS/FS/NetworkMonitoringSystem/Torrus_Internal.pm
index f2194f811..8f00312fb 100644
--- a/FS/FS/NetworkMonitoringSystem/Torrus_Internal.pm
+++ b/FS/FS/NetworkMonitoringSystem/Torrus_Internal.pm
@@ -9,6 +9,7 @@ use Date::Format;
use XML::Simple;
use FS::Record qw(qsearch qsearchs dbh);
use FS::svc_port;
+use FS::torrus_srvderive;
use FS::torrus_srvderive_component;
use Torrus::ConfigTree;
@@ -30,43 +31,74 @@ sub ddx2hash {
my $self = shift;
my $ddx_xml = slurp($ddxfile);
my $xs = new XML::Simple(RootName=> undef, SuppressEmpty => '',
- ForceArray => 1, );
+ ForceArray => 1, );
return $xs->XMLin($ddx_xml);
}
sub get_router_serviceids {
- my $self = shift;
- my $router = shift;
- my $find_serviceid = shift;
- my $found_serviceid = 0;
- my $ddx_hash = $self->ddx2hash;
- if($ddx_hash->{host}){
- my @hosts = @{$ddx_hash->{host}};
- foreach my $host ( @hosts ) {
- my $param = $host->{param};
- if($param && $param->{'snmp-host'}
- && (!$router || $param->{'snmp-host'}->{'value'} eq $router)
- && $param->{'RFC2863_IF_MIB::external-serviceid'}) {
- my $serviceids = $param->{'RFC2863_IF_MIB::external-serviceid'}->{'content'};
- my %hash = ();
- if($serviceids) {
- my @serviceids = split(',',$serviceids);
- foreach my $serviceid ( @serviceids ) {
- $serviceid =~ s/^\s+|\s+$//g;
- my @s = split(':',$serviceid);
- next unless scalar(@s) == 4;
- $hash{$s[1]} = $s[0] if $router;
- if ($find_serviceid && $find_serviceid eq $s[0]) {
- $hash{$param->{'snmp-host'}->{'value'}} = $s[1];
- $found_serviceid = 1;
- }
- }
- }
- return \%hash if ($router || $found_serviceid);
- }
- }
+ my $self = shift;
+ my $router = shift;
+ my $find_serviceid = shift;
+ my $found_serviceid = 0;
+ my $ddx_hash = $self->ddx2hash;
+ return '' unless $ddx_hash->{'host'};
+
+ my @hosts = @{$ddx_hash->{host}};
+ foreach my $host ( @hosts ) {
+ my $param = $host->{param};
+ if($param && $param->{'snmp-host'}
+ && (!$router || $param->{'snmp-host'}->{'value'} eq $router)
+ && $param->{'RFC2863_IF_MIB::external-serviceid'}) {
+ my $serviceids =
+ $param->{'RFC2863_IF_MIB::external-serviceid'}->{'content'};
+ my %hash = ();
+ if ($serviceids) {
+ my @serviceids = split(',',$serviceids);
+ foreach my $serviceid ( @serviceids ) {
+ $serviceid =~ s/^\s+|\s+$//g;
+ my @s = split(':',$serviceid);
+ next unless scalar(@s) == 4;
+ $hash{$s[1]} = $s[0] if $router;
+ if ($find_serviceid && $find_serviceid eq $s[0]) {
+ $hash{$param->{'snmp-host'}->{'value'}} = $s[1];
+ $found_serviceid = 1;
+ }
+ }
+ }
+ return \%hash if ($router || $found_serviceid);
+ }
+ }
+ '';
+}
+
+#false laziness and probably should be merged w/above, but didn't want to mess
+# that up
+sub all_router_serviceids {
+ my $self = shift;
+ my $ddx_hash = $self->ddx2hash;
+ return () unless $ddx_hash->{'host'};
+
+ my %hash = ();
+ my @hosts = @{$ddx_hash->{host}};
+ foreach my $host ( @hosts ) {
+ my $param = $host->{param};
+ if($param && $param->{'snmp-host'}
+ && (!$router || $param->{'snmp-host'}->{'value'} eq $router)
+ && $param->{'RFC2863_IF_MIB::external-serviceid'}) {
+ my $serviceids =
+ $param->{'RFC2863_IF_MIB::external-serviceid'}->{'content'};
+ if ($serviceids) {
+ my @serviceids = split(',',$serviceids);
+ foreach my $serviceid ( @serviceids ) {
+ $serviceid =~ s/^\s+|\s+$//g;
+ my @s = split(':',$serviceid);
+ next unless scalar(@s) == 4;
+ $hash{$s[0]}=1;
+ }
+ }
}
- '';
+ }
+ return sort keys %hash;
}
sub port_graphs_link {
@@ -236,23 +268,30 @@ sub _torrus_reload {
}
+#sub torrus_serviceids {
+# my $self = shift;
+#
+# #is this going to get too slow or will the index make it okay?
+# my $sth = dbh->prepare("SELECT DISTINCT(serviceid) FROM srvexport")
+# or die dbh->errstr;
+# $sth->execute or die $sth->errstr;
+# my %serviceid = ();
+# while ( my $row = $sth->fetchrow_arrayref ) {
+# my $serviceid = $row->[0];
+# $serviceid =~ s/_(IN|OUT)$//;
+# $serviceid{$serviceid}=1;
+# }
+# my @serviceids = sort keys %serviceid;
+#
+# @serviceids;
+#
+#}
+
sub torrus_serviceids {
my $self = shift;
-
- #is this going to get too slow or will the index make it okay?
- my $sth = dbh->prepare("SELECT DISTINCT(serviceid) FROM srvexport")
- or die dbh->errstr;
- $sth->execute or die $sth->errstr;
- my %serviceid = ();
- while ( my $row = $sth->fetchrow_arrayref ) {
- my $serviceid = $row->[0];
- $serviceid =~ s/_(IN|OUT)$//;
- $serviceid{$serviceid}=1;
- }
- my @serviceids = sort keys %serviceid;
-
- @serviceids;
-
+ my @serviceids = $self->all_router_serviceids;
+ push @serviceids, map $_->serviceid, qsearch('torrus_srvderive', {});
+ return sort @serviceids;
}
1;