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://websvnphp.github.io/>

    <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.