use Data::Dumper;
-#my $patchlist = "/home/eirikn/patchlist.txt";
-#my $switches = "/home/eirikn/switches.txt";
-my $patchlist = "/home/eirikn/patchlist.txt.eirik";
-my $switches = "/home/eirikn/switches.txt.eirik";
+my $patchlist = "/root/patchlist.txt";
+my $switches = "/root/switches.txt";
+#my $patchlist = "/home/eirikn/patchlist.txt.eirik";
+#my $switches = "/home/eirikn/switches.txt.eirik";
+#my $patchlist = "/root/patchlist.txt.d05";
+#my $switches = "/root/switches.txt.d05";
+
+open LOG, ">>/tmp/zyxel.could.not.connect" or die "Could not open log";
+
BEGIN {
require "../include/config.pm";
# or die "Unable to connect to cisco";
+sub start_vlan {
+ my ($ios, $vlan) = @_;
+
+ $ios->cmd("conf t");
+ $ios->cmd("int vlan $vlan");
+ $ios->cmd("ip add 192.168.1.254 255.255.255.0 secondary");
+ $ios->cmd("exit");
+ $ios->cmd("exit");
+}
+
+sub stop_vlan {
+ my ($ios, $vlan) = @_;
+
+ $ios->cmd("conf t");
+ $ios->cmd("int vlan $vlan");
+ $ios->cmd("no ip add 192.168.1.254 255.255.255.0 secondary");
+ $ios->cmd("exit");
+ $ios->cmd("exit");
+}
+
+
sub do_distro {
- my ($dip, $newip, $vlan) = @_;
+ my ($dip, $newip, $vlan, $switchname) = @_;
my $ios = Net::Telnet::Cisco->new(Host => $dip,
Errmode => 'return',
- Prompt => '/[^\s\(]+(\([^\(]\)){0,1}[#>]/');
+ Prompt => '/\S+[#>]/');
+# Prompt => '/[^\s\(]+(\([^\(]\)){0,1}[#>]/');
+ if (!defined($ios)) {
+ print "Could not connect to $dip";
+ return;
+ }
$ios->login($nms::config::ios_user, $nms::config::ios_pass);
$ios->enable;
return;
}
- $ios->cmd("conf t");
- $ios->cmd("int vlan $vlan");
- $ios->cmd("ip add 192.168.1.254 255.255.255.0 secondary");
- $ios->cmd("exit");
- $ios->cmd("exit");
-
my $zyxeloldip = "192.168.1.1";
+ start_vlan($ios, $vlan);
### Do things
## ZyxelNG connect
my $p = Net::Ping->new();
printf "Waiting for zyxel to come up...\n";
+ my $counter = 0;
while (1) {
+ if ($counter > 6) {
+ print "Waiting for zyxel on $dip:$vlan timed out, wanted to set ip: $newip\n";
+ print LOG "Could not connect to $switchname\n";
+ stop_vlan($ios, $vlan);
+ return;
+ }
last if $p->ping($zyxeloldip);
print "pinging...\n";
sleep 1;
+ $counter++;
}
print "Zyxel is alive..\n";
$p->close();
- system("perl ./zyxelng.pl 192.168.1.1 $newip");
+ system("perl ./zyxelng.pl 192.168.1.1 $newip $switchname");
####
- $ios->cmd("conf t");
- $ios->cmd("int vlan $vlan");
- $ios->cmd("no ip add 192.168.1.254 255.255.255.0 secondary");
- $ios->cmd("exit");
- $ios->cmd("exit");
+ stop_vlan($ios, $vlan);
$ios->close();
}
-
## Collect switch ips
my %switchips;
while(<SWITCHES>) {
my ($ip, $net, $name) = split;
- print $name."\n";
if ($name =~ /e\d+-\d/) {
die "We only support /26 nets for now you wanted $net" if ($net ne "26");
$switchips{$name} = $ip;
}
close(SWITCHES);
+sub switch_info {
+ my ($switch, $distro, $port) = @_;
-open(PATCHLIST, $patchlist) or die "Unable to open patchlist";
-while (<PATCHLIST>) {
- my ($switch, $distro, $port) = split;
-
$switch =~ /e(\d+)-(\d)/;
my ($row, $place) = ($1, $2);
my $ipnet = $switchips{$switch};
my $vlan = $row . $place;
- print "Switch: $switch, Distro: $distro, vlan: $vlan\n";
- print "Ip net: $ipnet\n";
my ($first, $second, $third, $fourth) = split(/\./, $ipnet);
my $ip = "$first.$second.$third.".(int($fourth)+2);
- print "Ip: $ip\n";
my $dip = $distro.".net.tg07.gathering.org";
- do_distro($dip, $ip, $vlan);
+ return ($row, $place, $ipnet, $vlan, $ip, $dip);
+}
+
+sub first_run {
+
+ open(PATCHLIST, $patchlist) or die "Unable to open patchlist";
+ while (<PATCHLIST>) {
+ my ($switch, $distro, $port) = split;
+
+ #print "Testing: ".$ARGV[1]." $switch\n";
+ next if (defined($ARGV[1]) and $ARGV[1] ne $switch);
+
+ print "First run...\n";
+ my ($row, $place, $ipnet, $vlan, $ip, $dip) = switch_info($switch, $distro, $port);
+ print "Switch: $switch, Distro: $distro, vlan: $vlan\n";
+ print "Ip net: $ipnet\n";
+ print "Ip: $ip\n";
+
+ do_distro($dip, $ip, $vlan, $switch);
# my ($dip, $newip, $vlan) = @_;
+ }
+ close(PATCHLIST);
}
-close(PATCHLIST);
+sub verify_run {
+ open(PATCHLIST, $patchlist) or die "Unable to open patchlist";
+ while (<PATCHLIST>) {
+ print "Verify run....\n";
+ my ($switch, $distro, $port) = split;
+
+ my ($row, $place, $ipnet, $vlan, $ip, $dip) = switch_info($switch, $distro, $port);
+ print "Switch: $switch, Distro: $distro, vlan: $vlan\n";
+ print "Ip net: $ipnet\n";
+ print "Ip: $ip\n";
+
+ my $p = Net::Ping->new();
+ printf "Checking if zyxel is up $dip:$vlan $ip...\n";
+ my $counter = 0;
+ while (1) {
+ if ($counter > 4) {
+ print "No answer from $dip:$vlan $ip, trying to route it up\n";
+ do_distro($dip, $ip, $vlan, $switch);
+ my $pid = fork();
+ if ($pid == 0) {
+ sleep 100;
+ system("perl ./ciscong2.pl $switch");
+ exit 0;
+ }
+ last;
+ }
+ last if $p->ping($ip);
+ print "pinging...\n";
+ sleep 1;
+ $counter++;
+ }
+# my ($dip, $newip, $vlan) = @_;
+ }
+ close(PATCHLIST);
+}
+
+
+if ($#ARGV > -1) {
+ first_run();
+}
+else {
+ verify_run();
+}
+close(LOG);