From 38cd5d98f9ebf0d7b462e6bb0280e2255d24dc70 Mon Sep 17 00:00:00 2001 From: Oliver Gorwits Date: Sun, 13 Jul 2014 18:36:30 +0100 Subject: [PATCH] Added by_hostname config option support --- Netdisco/bin/netdisco-rancid-export | 2 +- Web-Plugin-RANCID/Changes | 4 ++++ .../lib/App/NetdiscoX/Web/Plugin/RANCID.pm | 16 +++++++++++----- 3 files changed, 16 insertions(+), 6 deletions(-) diff --git a/Netdisco/bin/netdisco-rancid-export b/Netdisco/bin/netdisco-rancid-export index cf784fc7..60dfee22 100755 --- a/Netdisco/bin/netdisco-rancid-export +++ b/Netdisco/bin/netdisco-rancid-export @@ -43,7 +43,7 @@ use Dancer::Plugin::DBIC 'schema'; use App::Netdisco::Util::Permission ':all'; my $settings = setting( 'rancid' ); -my $domain_suffix = setting( 'domain_suffix' ); +my $domain_suffix = setting( 'domain_suffix' ) || ''; my $delimiter = $settings->{ 'delimiter' } || ':'; my $down_age = $settings->{ 'down_age' } || '1 day'; my $rancidhome = $settings->{ 'rancid_home' } || '/var/lib/rancid'; diff --git a/Web-Plugin-RANCID/Changes b/Web-Plugin-RANCID/Changes index 35146aae..fc192f7a 100644 --- a/Web-Plugin-RANCID/Changes +++ b/Web-Plugin-RANCID/Changes @@ -1,3 +1,7 @@ +2.004000 - 2014-07-13 + + * Added by_hostname config option support + 2.003002 - 2014-05-03 * POD fixups diff --git a/Web-Plugin-RANCID/lib/App/NetdiscoX/Web/Plugin/RANCID.pm b/Web-Plugin-RANCID/lib/App/NetdiscoX/Web/Plugin/RANCID.pm index 759130aa..93ac09c1 100644 --- a/Web-Plugin-RANCID/lib/App/NetdiscoX/Web/Plugin/RANCID.pm +++ b/Web-Plugin-RANCID/lib/App/NetdiscoX/Web/Plugin/RANCID.pm @@ -1,6 +1,6 @@ package App::NetdiscoX::Web::Plugin::RANCID; -our $VERSION = '2.003002'; +our $VERSION = '2.004000'; use Dancer ':syntax'; @@ -25,6 +25,7 @@ hook 'before_template' => sub { my $config = config; my $tokens = shift; my $device = $tokens->{d}; + my $domain_suffix = setting('domain_suffix') || ''; # defaults $tokens->{rancidgroup} = ''; @@ -33,14 +34,17 @@ hook 'before_template' => sub { return unless exists $config->{rancid}; my $rancid = $config->{rancid}; - $rancid->{groups} ||= {}; - $rancid->{by_ip} ||= []; + $rancid->{groups} ||= {}; + $rancid->{by_ip} ||= []; + $rancid->{by_hostname} ||= []; foreach my $g (keys %{ $rancid->{groups} }) { if (check_acl( get_device($device->{ip}), $rancid->{groups}->{$g} )) { $tokens->{rancidgroup} = $g; $tokens->{ranciddevice} = $device->{ip} if 0 < scalar grep {$_ eq $g} @{ $rancid->{by_ip} }; + $tokens->{ranciddevice} =~ s/$domain_suffix$// + if 0 < scalar grep {$_ eq $g} @{ $rancid->{by_hostname} }; last; } } @@ -89,7 +93,8 @@ known to Netdisco. This uses the same configuration as for L, an example of which is below: rancid: - by_ip: [ other ] + by_ip: [ other ] + by_hostname: [ other2 ] groups: switch: [ 'name:.*[Ss][Ww].*' ] rtr: [ 'name:[rR]tr.*' ] @@ -102,7 +107,8 @@ regular expression as in the above example. The device DNS name is used, or if missing the device SNMP sysName. Adding the group to the list in C will make the link include the device IP -instead of the name. +instead of the name. Adding the group to the list in C will +use the device FQDN minus the C config item (i.e. the hostname). =head2 open_in_same_window