|
|
919373 |
From 9b77d06bfe3308692946b8ac08bc7ec3399a762b Mon Sep 17 00:00:00 2001
|
|
|
919373 |
From: Oyvind Albrigtsen <oalbrigt@redhat.com>
|
|
|
919373 |
Date: Thu, 2 Apr 2020 13:38:30 +0200
|
|
|
919373 |
Subject: [PATCH 1/2] aws-vpc-route53: cleanup and improvements
|
|
|
919373 |
|
|
|
919373 |
---
|
|
|
919373 |
heartbeat/aws-vpc-route53.in | 73 ++++++++++++++++++++----------------
|
|
|
919373 |
1 file changed, 41 insertions(+), 32 deletions(-)
|
|
|
919373 |
|
|
|
919373 |
diff --git a/heartbeat/aws-vpc-route53.in b/heartbeat/aws-vpc-route53.in
|
|
|
919373 |
index b276dfb3c..1cfc2b01f 100644
|
|
|
919373 |
--- a/heartbeat/aws-vpc-route53.in
|
|
|
919373 |
+++ b/heartbeat/aws-vpc-route53.in
|
|
|
919373 |
@@ -43,8 +43,14 @@
|
|
|
919373 |
: ${OCF_FUNCTIONS_DIR=${OCF_ROOT}/lib/heartbeat}
|
|
|
919373 |
. ${OCF_FUNCTIONS_DIR}/ocf-shellfuncs
|
|
|
919373 |
|
|
|
919373 |
+OCF_RESKEY_hostedzoneid_default=""
|
|
|
919373 |
+OCF_RESKEY_fullname_default=""
|
|
|
919373 |
+OCF_RESKEY_ip_default="local"
|
|
|
919373 |
OCF_RESKEY_ttl_default=10
|
|
|
919373 |
|
|
|
919373 |
+: ${OCF_RESKEY_hostedzoneid:=${OCF_RESKEY_hostedzoneid_default}}
|
|
|
919373 |
+: ${OCF_RESKEY_fullname:=${OCF_RESKEY_fullname_default}}
|
|
|
919373 |
+: ${OCF_RESKEY_ip:=${OCF_RESKEY_ip_default}}
|
|
|
919373 |
: ${OCF_RESKEY_ttl:=${OCF_RESKEY_ttl_default}}
|
|
|
919373 |
|
|
|
919373 |
#######################################################################
|
|
|
919373 |
@@ -104,7 +110,7 @@ Hosted zone ID of Route 53. This is the table of
|
|
|
919373 |
the Route 53 record.
|
|
|
919373 |
</longdesc>
|
|
|
919373 |
<shortdesc lang="en">AWS hosted zone ID</shortdesc>
|
|
|
919373 |
-<content type="string" default="" />
|
|
|
919373 |
+<content type="string" default="${OCF_RESKEY_hostedzoneid_default}" />
|
|
|
919373 |
</parameter>
|
|
|
919373 |
<parameter name="fullname" required="1">
|
|
|
919373 |
<longdesc lang="en">
|
|
|
919373 |
@@ -113,7 +119,7 @@ Example: service.cloud.example.corp.
|
|
|
919373 |
Note: The trailing dot is important to Route53!
|
|
|
919373 |
</longdesc>
|
|
|
919373 |
<shortdesc lang="en">Full service name</shortdesc>
|
|
|
919373 |
-<content type="string" default="" />
|
|
|
919373 |
+<content type="string" default="${OCF_RESKEY_fullname_default}" />
|
|
|
919373 |
</parameter>
|
|
|
919373 |
<parameter name="ttl" required="0">
|
|
|
919373 |
<longdesc lang="en">
|
|
|
919373 |
@@ -189,6 +195,31 @@ r53_validate() {
|
|
|
919373 |
return $OCF_SUCCESS
|
|
|
919373 |
}
|
|
|
919373 |
|
|
|
919373 |
+r53_start() {
|
|
|
919373 |
+ #
|
|
|
919373 |
+ # Start agent and config DNS in Route53
|
|
|
919373 |
+ #
|
|
|
919373 |
+ ocf_log info "Starting Route53 DNS update...."
|
|
|
919373 |
+ IPADDRESS="$(curl -s http://169.254.169.254/latest/meta-data/local-ipv4)"
|
|
|
919373 |
+ r53_monitor
|
|
|
919373 |
+ if [ $? != $OCF_SUCCESS ]; then
|
|
|
919373 |
+ ocf_log info "Could not start agent - check configurations"
|
|
|
919373 |
+ return $OCF_ERR_GENERIC
|
|
|
919373 |
+ fi
|
|
|
919373 |
+ return $OCF_SUCCESS
|
|
|
919373 |
+}
|
|
|
919373 |
+
|
|
|
919373 |
+r53_stop() {
|
|
|
919373 |
+ #
|
|
|
919373 |
+ # Stop operation doesn't perform any API call or try to remove the DNS record
|
|
|
919373 |
+ # this mostly because this is not necessarily mandatory or desired
|
|
|
919373 |
+ # the start and monitor functions will take care of changing the DNS record
|
|
|
919373 |
+ # if the agent starts in a different cluster node
|
|
|
919373 |
+ #
|
|
|
919373 |
+ ocf_log info "Bringing down Route53 agent. (Will NOT remove Route53 DNS record)"
|
|
|
919373 |
+ return $OCF_SUCCESS
|
|
|
919373 |
+}
|
|
|
919373 |
+
|
|
|
919373 |
r53_monitor() {
|
|
|
919373 |
#
|
|
|
919373 |
# For every start action the agent will call Route53 API to check for DNS record
|
|
|
919373 |
@@ -339,31 +370,6 @@ _update_record() {
|
|
|
919373 |
done
|
|
|
919373 |
}
|
|
|
919373 |
|
|
|
919373 |
-r53_stop() {
|
|
|
919373 |
- #
|
|
|
919373 |
- # Stop operation doesn't perform any API call or try to remove the DNS record
|
|
|
919373 |
- # this mostly because this is not necessarily mandatory or desired
|
|
|
919373 |
- # the start and monitor functions will take care of changing the DNS record
|
|
|
919373 |
- # if the agent starts in a different cluster node
|
|
|
919373 |
- #
|
|
|
919373 |
- ocf_log info "Bringing down Route53 agent. (Will NOT remove Route53 DNS record)"
|
|
|
919373 |
- return $OCF_SUCCESS
|
|
|
919373 |
-}
|
|
|
919373 |
-
|
|
|
919373 |
-r53_start() {
|
|
|
919373 |
- #
|
|
|
919373 |
- # Start agent and config DNS in Route53
|
|
|
919373 |
- #
|
|
|
919373 |
- ocf_log info "Starting Route53 DNS update...."
|
|
|
919373 |
- IPADDRESS="$(curl -s http://169.254.169.254/latest/meta-data/local-ipv4)"
|
|
|
919373 |
- r53_monitor
|
|
|
919373 |
- if [ $? != $OCF_SUCCESS ]; then
|
|
|
919373 |
- ocf_log info "Could not start agent - check configurations"
|
|
|
919373 |
- return $OCF_ERR_GENERIC
|
|
|
919373 |
- fi
|
|
|
919373 |
- return $OCF_SUCCESS
|
|
|
919373 |
-}
|
|
|
919373 |
-
|
|
|
919373 |
###############################################################################
|
|
|
919373 |
|
|
|
919373 |
case $__OCF_ACTION in
|
|
|
919373 |
@@ -375,20 +381,23 @@ case $__OCF_ACTION in
|
|
|
919373 |
metadata
|
|
|
919373 |
exit $OCF_SUCCESS
|
|
|
919373 |
;;
|
|
|
919373 |
- monitor)
|
|
|
919373 |
- r53_monitor
|
|
|
919373 |
+ start)
|
|
|
919373 |
+ r53_validate || exit $?
|
|
|
919373 |
+ r53_start
|
|
|
919373 |
;;
|
|
|
919373 |
stop)
|
|
|
919373 |
r53_stop
|
|
|
919373 |
;;
|
|
|
919373 |
+ monitor)
|
|
|
919373 |
+ r53_monitor
|
|
|
919373 |
+ ;;
|
|
|
919373 |
validate-all)
|
|
|
919373 |
r53_validate
|
|
|
919373 |
;;
|
|
|
919373 |
- start)
|
|
|
919373 |
- r53_start
|
|
|
919373 |
- ;;
|
|
|
919373 |
*)
|
|
|
919373 |
usage
|
|
|
919373 |
exit $OCF_ERR_UNIMPLEMENTED
|
|
|
919373 |
;;
|
|
|
919373 |
esac
|
|
|
919373 |
+
|
|
|
919373 |
+exit $?
|
|
|
919373 |
|
|
|
919373 |
From 745c6b9b3e331ed3705a641f1ec03a2604de3a1d Mon Sep 17 00:00:00 2001
|
|
|
919373 |
From: Oyvind Albrigtsen <oalbrigt@redhat.com>
|
|
|
919373 |
Date: Thu, 2 Apr 2020 13:40:33 +0200
|
|
|
919373 |
Subject: [PATCH 2/2] aws-vpc-route53: add support for public and secondary
|
|
|
919373 |
private IPs
|
|
|
919373 |
|
|
|
919373 |
---
|
|
|
919373 |
heartbeat/aws-vpc-route53.in | 31 +++++++++++++++++++++++++++++--
|
|
|
919373 |
1 file changed, 29 insertions(+), 2 deletions(-)
|
|
|
919373 |
|
|
|
919373 |
diff --git a/heartbeat/aws-vpc-route53.in b/heartbeat/aws-vpc-route53.in
|
|
|
919373 |
index 1cfc2b01f..ca6556951 100644
|
|
|
919373 |
--- a/heartbeat/aws-vpc-route53.in
|
|
|
919373 |
+++ b/heartbeat/aws-vpc-route53.in
|
|
|
919373 |
@@ -121,6 +121,15 @@ Note: The trailing dot is important to Route53!
|
|
|
919373 |
<shortdesc lang="en">Full service name</shortdesc>
|
|
|
919373 |
<content type="string" default="${OCF_RESKEY_fullname_default}" />
|
|
|
919373 |
</parameter>
|
|
|
919373 |
+<parameter name="ip" required="0">
|
|
|
919373 |
+<longdesc lang="en">
|
|
|
919373 |
+IP (local (default), public or secondary private IP address (e.g. 10.0.0.1).
|
|
|
919373 |
+
|
|
|
919373 |
+A secondary private IP can be setup with the awsvip agent.
|
|
|
919373 |
+</longdesc>
|
|
|
919373 |
+<shortdesc lang="en">Type of IP or secondary private IP address (local, public or e.g. 10.0.0.1)</shortdesc>
|
|
|
919373 |
+<content type="string" default="${OCF_RESKEY_ip_default}" />
|
|
|
919373 |
+</parameter>
|
|
|
919373 |
<parameter name="ttl" required="0">
|
|
|
919373 |
<longdesc lang="en">
|
|
|
919373 |
Time to live for Route53 ARECORD
|
|
|
919373 |
@@ -173,6 +182,15 @@ r53_validate() {
|
|
|
919373 |
# Hosted Zone ID
|
|
|
919373 |
[[ -z "$OCF_RESKEY_hostedzoneid" ]] && ocf_log error "Hosted Zone ID parameter not set $OCF_RESKEY_hostedzoneid!" && exit $OCF_ERR_CONFIGURED
|
|
|
919373 |
|
|
|
919373 |
+ # Type of IP/secondary IP address
|
|
|
919373 |
+ case $OCF_RESKEY_ip in
|
|
|
919373 |
+ local|public|*.*.*.*)
|
|
|
919373 |
+ ;;
|
|
|
919373 |
+ *)
|
|
|
919373 |
+ ocf_exit_reason "Invalid value for ip: ${OCF_RESKEY_ip}"
|
|
|
919373 |
+ exit $OCF_ERR_CONFIGURED
|
|
|
919373 |
+ esac
|
|
|
919373 |
+
|
|
|
919373 |
# profile
|
|
|
919373 |
[[ -z "$OCF_RESKEY_profile" ]] && ocf_log error "AWS CLI profile not set $OCF_RESKEY_profile!" && exit $OCF_ERR_CONFIGURED
|
|
|
919373 |
|
|
|
919373 |
@@ -200,7 +218,7 @@ r53_start() {
|
|
|
919373 |
# Start agent and config DNS in Route53
|
|
|
919373 |
#
|
|
|
919373 |
ocf_log info "Starting Route53 DNS update...."
|
|
|
919373 |
- IPADDRESS="$(curl -s http://169.254.169.254/latest/meta-data/local-ipv4)"
|
|
|
919373 |
+ _get_ip
|
|
|
919373 |
r53_monitor
|
|
|
919373 |
if [ $? != $OCF_SUCCESS ]; then
|
|
|
919373 |
ocf_log info "Could not start agent - check configurations"
|
|
|
919373 |
@@ -239,7 +257,7 @@ r53_monitor() {
|
|
|
919373 |
r53_validate
|
|
|
919373 |
ocf_log debug "Checking Route53 record sets"
|
|
|
919373 |
#
|
|
|
919373 |
- IPADDRESS="$(curl -s http://169.254.169.254/latest/meta-data/local-ipv4)"
|
|
|
919373 |
+ _get_ip
|
|
|
919373 |
#
|
|
|
919373 |
if [ "$__OCF_ACTION" = "start" ] || ocf_is_probe ; then
|
|
|
919373 |
#
|
|
|
919373 |
@@ -308,6 +326,15 @@ r53_monitor() {
|
|
|
919373 |
return $OCF_SUCCESS
|
|
|
919373 |
}
|
|
|
919373 |
|
|
|
919373 |
+_get_ip() {
|
|
|
919373 |
+ case $OCF_RESKEY_ip in
|
|
|
919373 |
+ local|public)
|
|
|
919373 |
+ IPADDRESS="$(curl -s http://169.254.169.254/latest/meta-data/${OCF_RESKEY_ip}-ipv4)";;
|
|
|
919373 |
+ *.*.*.*)
|
|
|
919373 |
+ IPADDRESS="${OCF_RESKEY_ip}";;
|
|
|
919373 |
+ esac
|
|
|
919373 |
+}
|
|
|
919373 |
+
|
|
|
919373 |
_update_record() {
|
|
|
919373 |
#
|
|
|
919373 |
# This function is the one that will actually execute Route53's API call
|