summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xscripts/keepalived/vyatta-keepalived.pl21
-rw-r--r--templates/interfaces/ethernet/node.tag/vif/node.tag/vrrp/vrrp-group/node.tag/virtual-address/node.def7
-rw-r--r--templates/interfaces/ethernet/node.tag/vrrp/vrrp-group/node.tag/virtual-address/node.def7
3 files changed, 31 insertions, 4 deletions
diff --git a/scripts/keepalived/vyatta-keepalived.pl b/scripts/keepalived/vyatta-keepalived.pl
index b2f0ba3b..a553a1ce 100755
--- a/scripts/keepalived/vyatta-keepalived.pl
+++ b/scripts/keepalived/vyatta-keepalived.pl
@@ -26,6 +26,7 @@
use lib "/opt/vyatta/share/perl5/";
use Vyatta::Config;
use Vyatta::Keepalived;
+use Vyatta::TypeChecker;
use Getopt::Long;
use strict;
@@ -351,11 +352,12 @@ sub keepalived_write_file {
#
# main
#
-my ($action, $vrrp_intf, $vrrp_group);
+my ($action, $vrrp_intf, $vrrp_group, $vrrp_vip);
GetOptions("vrrp-action=s" => \$action,
"intf=s" => \$vrrp_intf,
- "group=s" => \$vrrp_group);
+ "group=s" => \$vrrp_group,
+ "vip=s" => \$vrrp_vip);
if (! defined $action) {
print "no action\n";
@@ -396,6 +398,21 @@ if ($action eq "delete") {
exit 0;
}
+if ($action eq "check-vip") {
+ if (! defined $vrrp_vip) {
+ print "must include the virtual-address to check";
+ exit 1;
+ }
+ my $rc = 1;
+ if ($vrrp_vip =~ /\//) {
+ $rc = Vyatta::TypeChecker::validateType('ipv4net', $vrrp_vip, 1);
+ } else {
+ $rc = Vyatta::TypeChecker::validateType('ipv4', $vrrp_vip, 1);
+ }
+ exit 1 if ! $rc;
+ exit 0;
+}
+
exit 0;
# end of file
diff --git a/templates/interfaces/ethernet/node.tag/vif/node.tag/vrrp/vrrp-group/node.tag/virtual-address/node.def b/templates/interfaces/ethernet/node.tag/vif/node.tag/vrrp/vrrp-group/node.tag/virtual-address/node.def
index 64b7b21e..363240cd 100644
--- a/templates/interfaces/ethernet/node.tag/vif/node.tag/vrrp/vrrp-group/node.tag/virtual-address/node.def
+++ b/templates/interfaces/ethernet/node.tag/vif/node.tag/vrrp/vrrp-group/node.tag/virtual-address/node.def
@@ -1,6 +1,11 @@
multi:
-type: ipv4
+type: txt
help: Set virtual address
+syntax:expression: exec "/opt/vyatta/sbin/vyatta-keepalived.pl \
+ --vrrp-action='check-vip' --vip='$VAR(@)' "\
+ ; "Invalid virtual-address [$VAR(@)] for vrrp-group $VAR(../@)"
+
comp_help: possible completions:
<x.x.x.x> Virtual IP address (up to 20 per group)
+ <x.x.x.x/x> Virtual IP address with prefix (up to 20 per group)
diff --git a/templates/interfaces/ethernet/node.tag/vrrp/vrrp-group/node.tag/virtual-address/node.def b/templates/interfaces/ethernet/node.tag/vrrp/vrrp-group/node.tag/virtual-address/node.def
index 64b7b21e..363240cd 100644
--- a/templates/interfaces/ethernet/node.tag/vrrp/vrrp-group/node.tag/virtual-address/node.def
+++ b/templates/interfaces/ethernet/node.tag/vrrp/vrrp-group/node.tag/virtual-address/node.def
@@ -1,6 +1,11 @@
multi:
-type: ipv4
+type: txt
help: Set virtual address
+syntax:expression: exec "/opt/vyatta/sbin/vyatta-keepalived.pl \
+ --vrrp-action='check-vip' --vip='$VAR(@)' "\
+ ; "Invalid virtual-address [$VAR(@)] for vrrp-group $VAR(../@)"
+
comp_help: possible completions:
<x.x.x.x> Virtual IP address (up to 20 per group)
+ <x.x.x.x/x> Virtual IP address with prefix (up to 20 per group)