summaryrefslogtreecommitdiff
path: root/scripts/keepalived/vyatta-clear-vrrp.pl
diff options
context:
space:
mode:
authorStig Thormodsrud <stig@vyatta.com>2009-04-03 10:26:07 -0700
committerStig Thormodsrud <stig@vyatta.com>2009-04-03 10:26:07 -0700
commit14a7c196b5903e6e18fb2fe3072746d1891b13c8 (patch)
tree33949f6d68eed48c8890d22b1672b8ddf45f1fde /scripts/keepalived/vyatta-clear-vrrp.pl
parent71a341bf28c91c48d0e19bf077373a3f3113e4e8 (diff)
downloadvyatta-cfg-quagga-14a7c196b5903e6e18fb2fe3072746d1891b13c8.tar.gz
vyatta-cfg-quagga-14a7c196b5903e6e18fb2fe3072746d1891b13c8.zip
Fix "clear vrrp process". Use new perl lib hierarchy.
Change double quote to single quote when no interpretation is needed.
Diffstat (limited to 'scripts/keepalived/vyatta-clear-vrrp.pl')
-rw-r--r--scripts/keepalived/vyatta-clear-vrrp.pl45
1 files changed, 22 insertions, 23 deletions
diff --git a/scripts/keepalived/vyatta-clear-vrrp.pl b/scripts/keepalived/vyatta-clear-vrrp.pl
index 38d50149..17dedc59 100644
--- a/scripts/keepalived/vyatta-clear-vrrp.pl
+++ b/scripts/keepalived/vyatta-clear-vrrp.pl
@@ -13,7 +13,7 @@
# General Public License for more details.
#
# This code was originally developed by Vyatta, Inc.
-# Portions created by Vyatta are Copyright (C) 2007 Vyatta, Inc.
+# Portions created by Vyatta are Copyright (C) 2007-2009 Vyatta, Inc.
# All Rights Reserved.
#
# Author: Stig Thormodsrud
@@ -23,7 +23,7 @@
# **** End License ****
#
-use lib "/opt/vyatta/share/perl5/";
+use lib '/opt/vyatta/share/perl5/';
use Vyatta::Keepalived;
use Getopt::Long;
use Sys::Syslog qw(:standard :macros);
@@ -31,7 +31,7 @@ use Sys::Syslog qw(:standard :macros);
use strict;
use warnings;
-my $conf_file = Vyatta::Keepalived::get_conf_file();
+my $conf_file = get_conf_file();
sub keepalived_write_file {
@@ -45,11 +45,11 @@ sub keepalived_write_file {
sub set_instance_inital_state {
my ($instance, $init) = @_;
- if ($init eq "MASTER" and $instance =~ /state \s+ BACKUP/ix) {
+ if ($init eq 'MASTER' and $instance =~ /state \s+ BACKUP/ix) {
if ($instance !~ s/state \s+ BACKUP/state MASTER/ix) {
print "Error: unable to replace BACKUP/MASTER\n";
}
- } elsif ($init eq "BACKUP" and $instance =~ /state \s+ MASTER/ix) {
+ } elsif ($init eq 'BACKUP' and $instance =~ /state \s+ MASTER/ix) {
if ($instance !~ s/state \s+ MASTER/state BACKUP/ix) {
print "Error: unable to replace MASTER/BACKUP\n";
}
@@ -110,7 +110,7 @@ sub get_vrrp_intf_group {
#
my $config = new Vyatta::Config;
- $config->setLevel("interfaces ethernet");
+ $config->setLevel('interfaces ethernet');
my @eths = $config->listOrigNodes();
foreach my $eth (@eths) {
my $path = "interfaces ethernet $eth";
@@ -130,15 +130,15 @@ sub get_vrrp_intf_group {
$path = "interfaces ethernet $eth";
$config->setLevel($path);
- if ($config->existsOrig("vif")) {
+ if ($config->existsOrig('vif')) {
my $path = "$path vif";
$config->setLevel($path);
my @vifs = $config->listOrigNodes();
foreach my $vif (@vifs) {
- my $vif_intf = $eth . "." . $vif;
+ my $vif_intf = $eth . '.' . $vif;
my $vif_path = "$path $vif";
$config->setLevel($vif_path);
- if ($config->existsOrig("vrrp")) {
+ if ($config->existsOrig('vrrp')) {
$vif_path = "$vif_path vrrp vrrp-group";
$config->setLevel($vif_path);
my @groups = $config->listOrigNodes();
@@ -170,12 +170,11 @@ sub set_inital_state {
foreach my $hash (@vrrp_instances) {
my $intf = $hash->{'intf'};
my $group = $hash->{'group'};
- my $instance = "vyatta-" . "$intf" . "-" . "$group";
+ my $instance = 'vyatta-' . "$intf" . '-' . "$group";
my ($tmp_conf, $match_instance) =
vrrp_extract_instance($conf, $instance);
if (defined $match_instance) {
- my $init = Vyatta::Keepalived::vrrp_get_init_state($intf, $group,
- "", "false");
+ my $init = vrrp_get_init_state($intf, $group, '', 'false');
$match_instance = set_instance_inital_state($match_instance, $init);
$new_conf .= $match_instance . "\n\n";
}
@@ -199,20 +198,20 @@ if (! defined $action) {
exit 1;
}
-openlog($0, "", LOG_USER);
+openlog($0, '', LOG_USER);
my $login = getlogin();
#
# clear_process
#
if ($action eq "clear_process") {
- syslog("warning", "clear vrrp process requested by $login");
+ syslog('warning', "clear vrrp process requested by $login");
if (Vyatta::Keepalived::is_running()) {
print "Restarting VRRP...\n";
- Vyatta::Keepalived::restart_daemon(VyattaKeepalived::get_conf_file());
+ restart_daemon(get_conf_file());
} else {
print "Starting VRRP...\n";
- Vyatta::Keepalived::start_daemon(VyattaKeepalived::get_conf_file());
+ start_daemon(get_conf_file());
}
exit 0;
}
@@ -220,7 +219,7 @@ if ($action eq "clear_process") {
#
# clear_master
#
-if ($action eq "clear_master") {
+if ($action eq 'clear_master') {
#
# The kludge here to force a vrrp instance to switch from master to
@@ -238,7 +237,7 @@ if ($action eq "clear_master") {
exit 1;
}
- my $instance = "vyatta-" . "$vrrp_intf" . "-" . "$vrrp_group";
+ my $instance = 'vyatta-' . "$vrrp_intf" . '-' . "$vrrp_group";
my $state_file = Vyatta::Keepalived::get_state_file($vrrp_intf, $vrrp_group);
if (! -f $state_file) {
print "Invalid interface/group [$vrrp_intf][$vrrp_group]\n";
@@ -247,12 +246,12 @@ if ($action eq "clear_master") {
my ($start_time, $intf, $group, $state, $ltime) =
Vyatta::Keepalived::vrrp_state_parse($state_file);
- if ($state ne "master") {
+ if ($state ne 'master') {
print "vrrp group $vrrp_group on $vrrp_intf is already in backup\n";
exit 1;
}
- syslog("warning", "clear vrrp master [$instance] requested by $login");
+ syslog('warning', "clear vrrp master [$instance] requested by $login");
Vyatta::Keepalived::vrrp_log("vrrp clear_master $vrrp_intf $vrrp_group");
# should add a file lock
@@ -266,7 +265,7 @@ if ($action eq "clear_master") {
print "Warning: $instance is in preempt mode";
print " and may retake master\n";
}
- $match_instance = set_instance_inital_state($match_instance, "BACKUP");
+ $match_instance = set_instance_inital_state($match_instance, 'BACKUP');
#
# need to set the correct initial state for the remaining instances
@@ -279,11 +278,11 @@ if ($action eq "clear_master") {
my $tmp_conf_file = $conf_file . ".$$";
keepalived_write_file($tmp_conf_file, $new_conf);
- my $conf_file_bak = $conf_file . ".bak";
+ my $conf_file_bak = $conf_file . '.bak';
system("mv $conf_file $conf_file_bak");
system("cp $tmp_conf_file $conf_file");
- Vyatta::Keepalived::restart_daemon($conf_file);
+ restart_daemon($conf_file);
print "Forcing $vrrp_intf-$group to BACKUP...\n";
sleep(3);