Skip to content

Instantly share code, notes, and snippets.

@soonix
Last active November 5, 2015 18:10
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save soonix/33708e882aa01b7f4e36 to your computer and use it in GitHub Desktop.
Save soonix/33708e882aa01b7f4e36 to your computer and use it in GitHub Desktop.
ciscodump - dump config info from routers into files - see http://www.perlmonks.org/?node_id=1146993
Files:
ciscodump.pl
ciscodump.ini
user=admin
pass=confidential
enable=top_secret
dir=C:\Users\Administrator\Desktop\ciscodump
[dump]
inventory=show inventory
version=show version
running-config=show running-config
startup-config=show startup-config
[192.168.0.1]
info=location with different parameters
user=otheruser
pass=public
timeout=30
[192.168.11.1]
info=somewhere else, but "central" parameters
[192.168.21.100]
info=ancient router
use=TELNET
[192.168.254.254]
debug=yes
info=lets see...
use strict;
use warnings;
use Data::Dumper;
use Config::Tiny;
use Path::Tiny 'path';
binmode STDOUT, ':encoding(cp437)';
use Control::CLI;
my $ini = Config::Tiny->read( 'ciscodump.ini' );
my $dumpdir = path($ini->{_}{dir});
my $debugdir = $dumpdir->child('debug');
my $debug = $ini->{_}{debug};
$Data::Dumper::Useqq = 1;
sub dbg {
print @_ if $debug;
@_;
}
dbg Dumper $ini;
my @k = grep { $_ !~ /^(_|dump)$/ } keys %$ini;
print Dumper \@k if $debug;
my %dumpcommands = %{$ini->{dump}};
my $prompt = '(?m:^\W?(?!Device#)[\w\/\d.:-]+[>#])';
my %cs_opts;
$cs_opts{Prompt} = $prompt;
$cs_opts{Errmode} = 'return';
$cs_opts{Output_record_separator} = "\r";
for my $host (@k) {
my $user = $ini->{$host}{user} // $ini->{_}{user};
my $pass = $ini->{$host}{pass} // $ini->{_}{pass};
my $enable = $ini->{$host}{enable} // $ini->{_}{enable};
my $info = $ini->{$host}{info} // $ini->{_}{info};
my $method = $ini->{$host}{use} // 'SSH';
print "$host\t- $info\n";
$debug = $ini->{_}{debug} // $ini->{$host}{debug};
$debugdir->mkpath if $debug;
$cs_opts{Dump_Log} = $debugdir->child($host . '.log')->stringify if $debug;
$cs_opts{Timeout} = $ini->{$host}{timeout} // 10;
my $hostdir = $dumpdir->child($host);
$hostdir->mkpath;
my $cc = Control::CLI->new( %cs_opts, Use => $method );
my %login_opts = (
Username => $user,
Password => $pass,
);
if ($method =~ /^TELNET$/i) {
if ($cc->connect(Host => $host)) {
dbg "TELNET connection established\n";
if ($cc->login(%login_opts)) {
dbg "logged in\n";
} else {
warn 'login failed: ' . $cc->errmsg();
}
} else {
warn 'connection could not be established: ' . $cc->errmsg();
next;
}
} else { # SSH
if ($cc->connect(Host => $host, %login_opts)) {
dbg "SSH connection established\n";
} else {
warn 'connection could not be established: ' . $cc->errmsg();
next;
}
}
dbg Dumper $cc->read(Blocking => 1, Timeout => 5);
dbg "enable>\n";
dbg Dumper $cc->cmd(command => 'enable', prompt => 'Password:');
# dbg "waiting>\n";
# my @wf = $cc->waitfor(Match => 'Password:');
# dbg Dumper \@wf;
dbg "sending>\n";
dbg Dumper $cc->cmd($enable);
dbg "after>\n";
my $out = $cc->cmd('term len 0');
dbg Dumper $out;
dbg Dumper $cc->cmd('term page 0') if grep { /invalid/i } $out;
for my $prefix (keys %dumpcommands) {
my $cmd = $dumpcommands{$prefix};
dbg "command: '$cmd'\n";
my $out = $cc->cmd($cmd);
dbg Dumper \$out;
$hostdir->child($prefix . '.txt')->spew_raw($out);
}
$cc->disconnect;
};
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment