NAME
App::NetdiscoX::Web::Plugin::RANCID - Link to device backups in RANCID/WebSVN
SYNOPSIS
# in your ~/environments/deployment.yml file
extra_web_plugins:
- X::RANCID
plugin_rancid:
location: 'https://websvn.example.com/websvn/filedetails.php?repname=rancid&path=/%GROUP%/configs/%DEVICE%'
Description
This is a plugin for the App::Netdisco network management application. It adds a row to the Device Details page named "RANCID" with a link to your local RANCID/WebSVN installation hosting the device configuration backups.
Configuration
Create an entry in your ~/environments/deployment.yml
file named "plugin_rancid
", containing the following settings:
location
Value: String, Required.
Name of the server hosting your local WebSVN installation. This should also include the path under which backup files are stored for the devices.
The text "%DEVICE%
" must be included, and it will be substituted with the name or IP of the device. That is, this setting must be a complete link to a RANCID web page, only with the device name or ip changed to be "%DEVICE%
".
The text "%GROUP%
" will be replaced with the group name for this device, if known to Netdisco. This uses the same configuration as for App::Netdisco::Worker::Plugin::MakeRancidConf, an example of which is below:
rancid:
by_ip: [ other ]
by_hostname: 'group:grp-reversedns'
groups:
aerohive: 'group:grp-hiveos'
switch: [ 'name:.*[Ss][Ww].*' ]
rtr: [ 'name:[rR]tr.*' ]
ap: [ 'name:[aA][pP].*' ]
Briefly, each group value is a list of rules for matching devices similar to those used by any *_only
configuration item. You can provide an IP, subnet or prefix, regular expression to match a device name, or device attribute and 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 by_ip
will make the link include the device IP instead of the name. Adding the group to the list in by_hostname
will use the device FQDN minus the domain_suffix
config item (i.e. the hostname). by_hostname
will take precedence over by_ip
.
open_in_same_window
Value: Boolean. Default: false.
If set to true, the hyperlink is configured to open the WebSVN page in the same browser window or tab as Netdisco.
SEE ALSO
App::Netdisco::Worker::Plugin::MakeRancidConf
http://www.shrubbery.net/rancid/
https://github.com/viewvc/viewvc/
AUTHOR
Oliver Gorwits <oliver@cpan.org>
LICENSE AND COPYRIGHT
This software is copyright (c) 2013,2019 by The Netdisco Developer Team.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.
* Neither the name of the Netdisco Project nor the
names of its contributors may be used to endorse or promote products
derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE NETDISCO DEVELOPER TEAM BE LIABLE FOR ANY
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.