summaryrefslogtreecommitdiff
path: root/scripts/keepalived/VyattaKeepalived.pm
diff options
context:
space:
mode:
authorStig Thormodsrud <stig@vyatta.com>2008-05-23 20:39:24 -0700
committerStig Thormodsrud <stig@vyatta.com>2008-05-23 20:39:24 -0700
commit0cf777376bdf5b347afffff8b5ffe56b269f6614 (patch)
tree16da7e311d77360ec6a44ddf236b956f5ceecf62 /scripts/keepalived/VyattaKeepalived.pm
parentdf805435059fce399a070dab8d8497d0ec72b951 (diff)
downloadvyatta-cfg-quagga-0cf777376bdf5b347afffff8b5ffe56b269f6614.tar.gz
vyatta-cfg-quagga-0cf777376bdf5b347afffff8b5ffe56b269f6614.zip
Fix vrrp snoop_for_master() to also work with AH authentication.
Diffstat (limited to 'scripts/keepalived/VyattaKeepalived.pm')
-rwxr-xr-xscripts/keepalived/VyattaKeepalived.pm45
1 files changed, 34 insertions, 11 deletions
diff --git a/scripts/keepalived/VyattaKeepalived.pm b/scripts/keepalived/VyattaKeepalived.pm
index f4065766..c9abe49e 100755
--- a/scripts/keepalived/VyattaKeepalived.pm
+++ b/scripts/keepalived/VyattaKeepalived.pm
@@ -37,17 +37,6 @@ my $keepalived_pid = '/var/run/keepalived_vrrp.pid';
my $state_dir = '/var/log/vrrpd';
my $vrrp_log = "$state_dir/vrrp.log";
-sub snoop_for_master {
- my ($intf, $group, $vip, $timeout) = @_;
-
- my $file = get_master_file($intf, $group);
-
- my $cap_filt = "-f \"host 224.0.0.18 and proto VRRP and ip[21:1] = $group\"";
- my $dis_filt = "-R \"vrrp.virt_rtr_id == $group and vrrp.ip_addr == $vip\"";
- my $options = "-a duration:$timeout -p -i$intf -c1 -T pdml";
- my $cmd = "tshark $options $cap_filt $dis_filt";
- system("$cmd > $file 2> /dev/null");
-}
sub vrrp_log {
my $timestamp = strftime("%Y%m%d-%H:%M.%S", localtime);
@@ -190,6 +179,40 @@ sub vrrp_get_config {
return ($primary_addr, $priority, $preempt, $advert_int, $auth_type, @vips);
}
+sub snoop_for_master {
+ my ($intf, $group, $vip, $timeout) = @_;
+
+ my ($cap_filt, $dis_filt, $options, $cmd);
+
+ my $file = get_master_file($intf, $group);
+
+ #
+ # set up common tshark parameters
+ #
+ $cap_filt = "-f \"host 224.0.0.18";
+ $dis_filt = "-R \"vrrp.virt_rtr_id == $group and vrrp.ip_addr == $vip\"";
+ $options = "-a duration:$timeout -p -i$intf -c1 -T pdml";
+
+ my $auth_type = (vrrp_get_config($intf, $group))[4];
+ if (lc($auth_type) ne "ah") {
+ #
+ # the vrrp group is the 2nd byte in the vrrp header
+ #
+ $cap_filt .= " and proto VRRP and vrrp[1:1] = $group\"";
+ $cmd = "tshark $options $cap_filt $dis_filt";
+ system("$cmd > $file 2> /dev/null");
+ } else {
+ #
+ # if the vrrp group is using AH authentication, then the proto will be
+ # AH (0x33) instead of VRRP (0x70). So try snooping for AH and
+ # look for the vrrp group at byte 45 (ip_header=20, ah=24)
+ #
+ $cap_filt .= " and proto 0x33 and ip[45:1] = $group\"";
+ $cmd = "tshark $options $cap_filt $dis_filt";
+ system("$cmd > $file 2> /dev/null");
+ }
+}
+
sub vrrp_state_parse {
my ($file) = @_;