2010-04-23 07:18:43 -04:00
|
|
|
$OpenBSD: patch-bin_fnrancid_in,v 1.4 2010/04/23 11:18:43 pea Exp $
|
|
|
|
--- bin/fnrancid.in.orig Wed Mar 24 00:33:50 2010
|
|
|
|
+++ bin/fnrancid.in Fri Apr 16 10:34:08 2010
|
2009-02-11 08:17:28 -05:00
|
|
|
@@ -172,6 +172,7 @@ sub GetSystem {
|
2008-12-16 16:07:55 -05:00
|
|
|
|
2009-02-11 08:17:28 -05:00
|
|
|
while (<INPUT>) {
|
2008-12-16 16:07:55 -05:00
|
|
|
tr/\015//d;
|
2008-12-19 07:57:53 -05:00
|
|
|
+ s/exit//gi ;
|
2008-12-16 16:07:55 -05:00
|
|
|
next if /^\s*$/;
|
|
|
|
last if(/$prompt/);
|
|
|
|
ProcessHistory("","","","$_");
|
2010-04-23 07:18:43 -04:00
|
|
|
@@ -201,6 +202,15 @@ sub GetConf {
|
2009-02-11 08:17:28 -05:00
|
|
|
next;
|
|
|
|
}
|
|
|
|
ProcessHistory("","","","$_");
|
2010-04-23 07:18:43 -04:00
|
|
|
+ if (length($host) == 0) {
|
|
|
|
+ if ( $file) {
|
|
|
|
+ print(STDERR "Too few arguments: file name required\n");
|
|
|
|
+ exit(1);
|
|
|
|
+ } else {
|
|
|
|
+ print(STDERR "Too few arguments: host name required\n");
|
|
|
|
+ exit(1);
|
|
|
|
+ }
|
|
|
|
+ }
|
2009-02-11 08:17:28 -05:00
|
|
|
}
|
2010-04-23 07:18:43 -04:00
|
|
|
$found_end = 1;
|
|
|
|
return(1);
|
|
|
|
@@ -212,7 +222,7 @@ sub DoNothing {print STDOUT;}
|
2009-02-11 08:17:28 -05:00
|
|
|
# Main
|
|
|
|
@commandtable = (
|
|
|
|
{'get system status' => 'GetSystem'},
|
|
|
|
- {'get conf' => 'GetConf'}
|
|
|
|
+ {'show' => 'GetConf'}
|
|
|
|
);
|
|
|
|
# Use an array to preserve the order of the commands and a hash for mapping
|
|
|
|
# commands to the subroutine and track commands that have been completed.
|
2010-04-23 07:18:43 -04:00
|
|
|
@@ -241,13 +251,13 @@ if ($file) {
|
2009-02-11 08:17:28 -05:00
|
|
|
print STDOUT "opening file $host\n" if ($log);
|
2010-04-23 07:18:43 -04:00
|
|
|
open(INPUT,"<$host") || die "open failed for $host: $!\n";
|
|
|
|
} else {
|
2008-12-16 16:07:55 -05:00
|
|
|
- print STDERR "executing nlogin -t $timeo -c\"$cisco_cmds\" $host\n" if ($debug);
|
|
|
|
- print STDOUT "executing nlogin -t $timeo -c\"$cisco_cmds\" $host\n" if ($log);
|
|
|
|
+ print STDERR "executing fnlogin -t $timeo -c\"$cisco_cmds\" $host\n" if ($debug);
|
|
|
|
+ print STDOUT "executing fnlogin -t $timeo -c\"$cisco_cmds\" $host\n" if ($log);
|
|
|
|
if (defined($ENV{NOPIPE})) {
|
|
|
|
- system "nlogin -t $timeo -c \"$cisco_cmds\" $host </dev/null > $host.raw 2>&1" || die "nlogin failed for $host: $!\n";
|
2009-02-11 08:17:28 -05:00
|
|
|
- open(INPUT, "< $host.raw") || die "nlogin failed for $host: $!\n";
|
|
|
|
+ system "fnlogin -t $timeo -c \"$cisco_cmds\" $host </dev/null > $host.raw 2>&1" || die "fnlogin failed for $host: $!\n";
|
|
|
|
+ open(INPUT, "< $host.raw") || die "fnlogin failed for $host: $!\n";
|
2008-12-16 16:07:55 -05:00
|
|
|
} else {
|
|
|
|
- open(INPUT,"nlogin -t $timeo -c \"$cisco_cmds\" $host </dev/null |") || die "nlogin failed for $host: $!\n";
|
2009-02-11 08:17:28 -05:00
|
|
|
+ open(INPUT,"fnlogin -t $timeo -c \"$cisco_cmds\" $host </dev/null |") || die "fnlogin failed for $host: $!\n";
|
2008-12-16 16:07:55 -05:00
|
|
|
}
|
2009-02-11 08:17:28 -05:00
|
|
|
}
|
|
|
|
|
2010-04-23 07:18:43 -04:00
|
|
|
@@ -275,13 +285,32 @@ ProcessHistory("","","","!RANCID-CONTENT-TYPE: fortiga
|
2009-02-11 08:17:28 -05:00
|
|
|
TOP: while(<INPUT>) {
|
|
|
|
tr/\015//d;
|
2008-12-16 16:07:55 -05:00
|
|
|
if (/^Error:/) {
|
|
|
|
- print STDOUT ("$host nlogin error: $_");
|
|
|
|
- print STDERR ("$host nlogin error: $_") if ($debug);
|
|
|
|
+ print STDOUT ("$host fnlogin error: $_");
|
|
|
|
+ print STDERR ("$host fnlogin error: $_") if ($debug);
|
|
|
|
last;
|
|
|
|
}
|
|
|
|
- while (/>\s*($cmds_regexp)\s*$/) {
|
|
|
|
- $cmd = $1;
|
|
|
|
- if (!defined($prompt)) { $prompt = " >\s*"; }
|
|
|
|
+ while (/^.+(#|\$)\s*($cmds_regexp)\s*$/) {
|
|
|
|
+ $cmd = $2;
|
|
|
|
+ # - FortiGate prompts end with either '#' or '$'. Further, they may
|
|
|
|
+# be prepended with a '~' if the hostname is too long. Therefore,
|
|
|
|
+# we need to figure out what our prompt really is.
|
|
|
|
+ if (!defined($prompt)) {
|
|
|
|
+ if ( $_ =~ m/^.+\~\$/ ) {
|
|
|
|
+ $prompt = '\~\$ .*' ;
|
|
|
|
+ } else {
|
|
|
|
+ if ( $_ =~ m/^.+\$/ ) {
|
|
|
|
+ $prompt = ' \$ .*' ;
|
|
|
|
+ } else {
|
|
|
|
+ if ( $_ =~ m/^.+\~#/ ) {
|
|
|
|
+ $prompt = '\~# .*' ;
|
|
|
|
+ } else {
|
|
|
|
+ if ( $_ =~ m/^.+#/ ) {
|
|
|
|
+ $prompt = ' # .*' ;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
print STDERR ("HIT COMMAND:$_") if ($debug);
|
2009-02-11 08:17:28 -05:00
|
|
|
if (!defined($commands{$cmd})) {
|
|
|
|
print STDERR "$host: found unexpected command - \"$cmd\"\n";
|