Add 'dns_dyn' DNS challenge validation script for Dyn Managed DNS API
dns_dyn.sh, remove empty line at end dns_dyn.sh, remove trailing spaces at end of line Replace 'head -n' with the '_head_n' function Update main README.md DNS API listpull/935/head
							parent
							
								
									dd9df068b0
								
							
						
					
					
						commit
						42b2adc03e
					
				| 
						 | 
					@ -40,7 +40,7 @@ script:
 | 
				
			||||||
  - if [ "$TRAVIS_OS_NAME" = "linux" ]; then ~/shfmt -l -w -i 2 . ; fi
 | 
					  - if [ "$TRAVIS_OS_NAME" = "linux" ]; then ~/shfmt -l -w -i 2 . ; fi
 | 
				
			||||||
  - if [ "$TRAVIS_OS_NAME" = "linux" ]; then git diff --exit-code && echo "shfmt OK" ; fi
 | 
					  - if [ "$TRAVIS_OS_NAME" = "linux" ]; then git diff --exit-code && echo "shfmt OK" ; fi
 | 
				
			||||||
  - if [ "$TRAVIS_OS_NAME" = "linux" ]; then shellcheck -V ; fi
 | 
					  - if [ "$TRAVIS_OS_NAME" = "linux" ]; then shellcheck -V ; fi
 | 
				
			||||||
  - if [ "$TRAVIS_OS_NAME" = "linux" ]; then shellcheck **/*.sh && echo "shellcheck OK" ; fi
 | 
					  - if [ "$TRAVIS_OS_NAME" = "linux" ]; then shellcheck -e SC2181 **/*.sh && echo "shellcheck OK" ; fi
 | 
				
			||||||
  - cd ..
 | 
					  - cd ..
 | 
				
			||||||
  - git clone https://github.com/Neilpang/acmetest.git && cp -r acme.sh acmetest/ && cd acmetest
 | 
					  - git clone https://github.com/Neilpang/acmetest.git && cp -r acme.sh acmetest/ && cd acmetest
 | 
				
			||||||
  - if [ "$TRAVIS_OS_NAME" = "linux" -a "$NGROK_TOKEN" ]; then sudo TEST_LOCAL="$TEST_LOCAL" NGROK_TOKEN="$NGROK_TOKEN" ./letest.sh ; fi
 | 
					  - if [ "$TRAVIS_OS_NAME" = "linux" -a "$NGROK_TOKEN" ]; then sudo TEST_LOCAL="$TEST_LOCAL" NGROK_TOKEN="$NGROK_TOKEN" ./letest.sh ; fi
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -44,6 +44,7 @@ RUN for verb in help \
 | 
				
			||||||
  create-domain-key \
 | 
					  create-domain-key \
 | 
				
			||||||
  createCSR \
 | 
					  createCSR \
 | 
				
			||||||
  deactivate \
 | 
					  deactivate \
 | 
				
			||||||
 | 
					  deactivate-account \
 | 
				
			||||||
  ; do \
 | 
					  ; do \
 | 
				
			||||||
    printf -- "%b" "#!/usr/bin/env sh\n/root/.acme.sh/acme.sh --${verb} --config-home /acme.sh \"\$@\"" >/usr/local/bin/--${verb} && chmod +x /usr/local/bin/--${verb} \
 | 
					    printf -- "%b" "#!/usr/bin/env sh\n/root/.acme.sh/acme.sh --${verb} --config-home /acme.sh \"\$@\"" >/usr/local/bin/--${verb} && chmod +x /usr/local/bin/--${verb} \
 | 
				
			||||||
  ; done
 | 
					  ; done
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -336,6 +336,7 @@ You don't have to do anything manually!
 | 
				
			||||||
1. NS1.com API
 | 
					1. NS1.com API
 | 
				
			||||||
1. DuckDNS.org API
 | 
					1. DuckDNS.org API
 | 
				
			||||||
1. Name.com API
 | 
					1. Name.com API
 | 
				
			||||||
 | 
					1. Dyn Managed DNS API
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
And: 
 | 
					And: 
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -540,6 +540,39 @@ acme.sh --issue --dns dns_namecom -d example.com -d www.example.com
 | 
				
			||||||
 | 
					
 | 
				
			||||||
For issues, please report to https://github.com/raidenii/acme.sh/issues.
 | 
					For issues, please report to https://github.com/raidenii/acme.sh/issues.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## 29. Use Dyn Managed DNS API to automatically issue cert
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					First, login to your Dyn Managed DNS account: https://portal.dynect.net/login/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					It is recommended to add a new user specific for API access.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					The minimum "Zones & Records Permissions" required are:
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					RecordAdd
 | 
				
			||||||
 | 
					RecordUpdate
 | 
				
			||||||
 | 
					RecordDelete
 | 
				
			||||||
 | 
					RecordGet
 | 
				
			||||||
 | 
					ZoneGet
 | 
				
			||||||
 | 
					ZoneAddNode
 | 
				
			||||||
 | 
					ZoneRemoveNode
 | 
				
			||||||
 | 
					ZonePublish
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Pass the API user credentials to the environment:
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					export DYN_Customer="customer"
 | 
				
			||||||
 | 
					export DYN_Username="apiuser"
 | 
				
			||||||
 | 
					export DYN_Password="secret"
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Ok, let's issue a cert now:
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					acme.sh --issue --dns dns_dyn -d example.com -d www.example.com
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					The `DYN_Customer`, `DYN_Username` and `DYN_Password` will be saved in `~/.acme.sh/account.conf` and will be reused when needed.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Use custom API
 | 
					# Use custom API
 | 
				
			||||||
 | 
					
 | 
				
			||||||
If your API is not supported yet, you can write your own DNS API.
 | 
					If your API is not supported yet, you can write your own DNS API.
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -208,7 +208,7 @@ aws_rest() {
 | 
				
			||||||
  kServiceH="$(printf "$Service%s" | _hmac "$Hash" "$kRegionH" hex)"
 | 
					  kServiceH="$(printf "$Service%s" | _hmac "$Hash" "$kRegionH" hex)"
 | 
				
			||||||
  _debug2 kServiceH "$kServiceH"
 | 
					  _debug2 kServiceH "$kServiceH"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  kSigningH="$(printf "aws4_request%s" | _hmac "$Hash" "$kServiceH" hex)"
 | 
					  kSigningH="$(printf "%s" "aws4_request" | _hmac "$Hash" "$kServiceH" hex)"
 | 
				
			||||||
  _debug2 kSigningH "$kSigningH"
 | 
					  _debug2 kSigningH "$kSigningH"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  signature="$(printf "$StringToSign%s" | _hmac "$Hash" "$kSigningH" hex)"
 | 
					  signature="$(printf "$StringToSign%s" | _hmac "$Hash" "$kSigningH" hex)"
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,339 @@
 | 
				
			||||||
 | 
					#!/usr/bin/env sh
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# Dyn.com Domain API
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# Author: Gerd Naschenweng
 | 
				
			||||||
 | 
					# https://github.com/magicdude4eva
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# Dyn Managed DNS API
 | 
				
			||||||
 | 
					# https://help.dyn.com/dns-api-knowledge-base/
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# It is recommended to add a "Dyn Managed DNS" user specific for API access.
 | 
				
			||||||
 | 
					# The "Zones & Records Permissions" required by this script are:
 | 
				
			||||||
 | 
					# --
 | 
				
			||||||
 | 
					# RecordAdd
 | 
				
			||||||
 | 
					# RecordUpdate
 | 
				
			||||||
 | 
					# RecordDelete
 | 
				
			||||||
 | 
					# RecordGet
 | 
				
			||||||
 | 
					# ZoneGet
 | 
				
			||||||
 | 
					# ZoneAddNode
 | 
				
			||||||
 | 
					# ZoneRemoveNode
 | 
				
			||||||
 | 
					# ZonePublish
 | 
				
			||||||
 | 
					# --
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# Pass credentials before "acme.sh --issue --dns dns_dyn ..."
 | 
				
			||||||
 | 
					# --
 | 
				
			||||||
 | 
					# export DYN_Customer="customer"
 | 
				
			||||||
 | 
					# export DYN_Username="apiuser"
 | 
				
			||||||
 | 
					# export DYN_Password="secret"
 | 
				
			||||||
 | 
					# --
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					DYN_API="https://api.dynect.net/REST"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#REST_API
 | 
				
			||||||
 | 
					########  Public functions #####################
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#Usage: add  _acme-challenge.www.domain.com   "Challenge-code"
 | 
				
			||||||
 | 
					dns_dyn_add() {
 | 
				
			||||||
 | 
					  fulldomain="$1"
 | 
				
			||||||
 | 
					  txtvalue="$2"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  DYN_Customer="${DYN_Customer:-$(_readaccountconf_mutable DYN_Customer)}"
 | 
				
			||||||
 | 
					  DYN_Username="${DYN_Username:-$(_readaccountconf_mutable DYN_Username)}"
 | 
				
			||||||
 | 
					  DYN_Password="${DYN_Password:-$(_readaccountconf_mutable DYN_Password)}"
 | 
				
			||||||
 | 
					  if [ -z "$DYN_Customer" ] || [ -z "$DYN_Username" ] || [ -z "$DYN_Password" ]; then
 | 
				
			||||||
 | 
					    DYN_Customer=""
 | 
				
			||||||
 | 
					    DYN_Username=""
 | 
				
			||||||
 | 
					    DYN_Password=""
 | 
				
			||||||
 | 
					    _err "You must export variables: DYN_Customer, DYN_Username and DYN_Password"
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  #save the config variables to the account conf file.
 | 
				
			||||||
 | 
					  _saveaccountconf_mutable DYN_Customer "$DYN_Customer"
 | 
				
			||||||
 | 
					  _saveaccountconf_mutable DYN_Username "$DYN_Username"
 | 
				
			||||||
 | 
					  _saveaccountconf_mutable DYN_Password "$DYN_Password"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if ! _dyn_get_authtoken; then
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if [ -z "$_dyn_authtoken" ]; then
 | 
				
			||||||
 | 
					    _dyn_end_session
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if ! _dyn_get_zone; then
 | 
				
			||||||
 | 
					    _dyn_end_session
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if ! _dyn_add_record; then
 | 
				
			||||||
 | 
					    _dyn_end_session
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if ! _dyn_publish_zone; then
 | 
				
			||||||
 | 
					    _dyn_end_session
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _dyn_end_session
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  return 0
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#Usage: fulldomain txtvalue
 | 
				
			||||||
 | 
					#Remove the txt record after validation.
 | 
				
			||||||
 | 
					dns_dyn_rm() {
 | 
				
			||||||
 | 
					  fulldomain="$1"
 | 
				
			||||||
 | 
					  txtvalue="$2"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  DYN_Customer="${DYN_Customer:-$(_readaccountconf_mutable DYN_Customer)}"
 | 
				
			||||||
 | 
					  DYN_Username="${DYN_Username:-$(_readaccountconf_mutable DYN_Username)}"
 | 
				
			||||||
 | 
					  DYN_Password="${DYN_Password:-$(_readaccountconf_mutable DYN_Password)}"
 | 
				
			||||||
 | 
					  if [ -z "$DYN_Customer" ] || [ -z "$DYN_Username" ] || [ -z "$DYN_Password" ]; then
 | 
				
			||||||
 | 
					    DYN_Customer=""
 | 
				
			||||||
 | 
					    DYN_Username=""
 | 
				
			||||||
 | 
					    DYN_Password=""
 | 
				
			||||||
 | 
					    _err "You must export variables: DYN_Customer, DYN_Username and DYN_Password"
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if ! _dyn_get_authtoken; then
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if [ -z "$_dyn_authtoken" ]; then
 | 
				
			||||||
 | 
					    _dyn_end_session
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if ! _dyn_get_zone; then
 | 
				
			||||||
 | 
					    _dyn_end_session
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if ! _dyn_get_record_id; then
 | 
				
			||||||
 | 
					    _dyn_end_session
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if [ -z "$_dyn_record_id" ]; then
 | 
				
			||||||
 | 
					    _dyn_end_session
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if ! _dyn_rm_record; then
 | 
				
			||||||
 | 
					    _dyn_end_session
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if ! _dyn_publish_zone; then
 | 
				
			||||||
 | 
					    _dyn_end_session
 | 
				
			||||||
 | 
					    return 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _dyn_end_session
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  return 0
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					####################  Private functions below ##################################
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#get Auth-Token
 | 
				
			||||||
 | 
					_dyn_get_authtoken() {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _info "Start Dyn API Session"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  data="{\"customer_name\":\"$DYN_Customer\", \"user_name\":\"$DYN_Username\", \"password\":\"$DYN_Password\"}"
 | 
				
			||||||
 | 
					  dyn_url="$DYN_API/Session/"
 | 
				
			||||||
 | 
					  method="POST"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _debug data "$data"
 | 
				
			||||||
 | 
					  _debug dyn_url "$dyn_url"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  export _H1="Content-Type: application/json"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  response="$(_post "$data" "$dyn_url" "" "$method")"
 | 
				
			||||||
 | 
					  sessionstatus="$(printf "%s\n" "$response" | _egrep_o '"status" *: *"[^"]*' | _head_n 1 | sed 's#^"status" *: *"##')"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _debug response "$response"
 | 
				
			||||||
 | 
					  _debug sessionstatus "$sessionstatus"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if [ "$sessionstatus" = "success" ]; then
 | 
				
			||||||
 | 
					    _dyn_authtoken="$(printf "%s\n" "$response" | _egrep_o '"token" *: *"[^"]*' | _head_n 1 | sed 's#^"token" *: *"##')"
 | 
				
			||||||
 | 
					    _info "Token received"
 | 
				
			||||||
 | 
					    _debug _dyn_authtoken "$_dyn_authtoken"
 | 
				
			||||||
 | 
					    return 0
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _dyn_authtoken=""
 | 
				
			||||||
 | 
					  _err "get token failed"
 | 
				
			||||||
 | 
					  return 1
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#fulldomain=_acme-challenge.www.domain.com
 | 
				
			||||||
 | 
					#returns
 | 
				
			||||||
 | 
					# _dyn_zone=domain.com
 | 
				
			||||||
 | 
					_dyn_get_zone() {
 | 
				
			||||||
 | 
					  i=2
 | 
				
			||||||
 | 
					  while true; do
 | 
				
			||||||
 | 
					    domain="$(printf "%s" "$fulldomain" | cut -d . -f "$i-100")"
 | 
				
			||||||
 | 
					    if [ -z "$domain" ]; then
 | 
				
			||||||
 | 
					      break
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    dyn_url="$DYN_API/Zone/$domain/"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    export _H1="Auth-Token: $_dyn_authtoken"
 | 
				
			||||||
 | 
					    export _H2="Content-Type: application/json"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    response="$(_get "$dyn_url" "" "")"
 | 
				
			||||||
 | 
					    sessionstatus="$(printf "%s\n" "$response" | _egrep_o '"status" *: *"[^"]*' | _head_n 1 | sed 's#^"status" *: *"##')"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    _debug dyn_url "$dyn_url"
 | 
				
			||||||
 | 
					    _debug response "$response"
 | 
				
			||||||
 | 
					    _debug sessionstatus "$sessionstatus"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if [ "$sessionstatus" = "success" ]; then
 | 
				
			||||||
 | 
					      _dyn_zone="$domain"
 | 
				
			||||||
 | 
					      return 0
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					    i=$(_math "$i" + 1)
 | 
				
			||||||
 | 
					  done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _dyn_zone=""
 | 
				
			||||||
 | 
					  _err "get zone failed"
 | 
				
			||||||
 | 
					  return 1
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#add TXT record
 | 
				
			||||||
 | 
					_dyn_add_record() {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _info "Adding TXT record"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  data="{\"rdata\":{\"txtdata\":\"$txtvalue\"},\"ttl\":\"300\"}"
 | 
				
			||||||
 | 
					  dyn_url="$DYN_API/TXTRecord/$_dyn_zone/$fulldomain/"
 | 
				
			||||||
 | 
					  method="POST"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  export _H1="Auth-Token: $_dyn_authtoken"
 | 
				
			||||||
 | 
					  export _H2="Content-Type: application/json"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  response="$(_post "$data" "$dyn_url" "" "$method")"
 | 
				
			||||||
 | 
					  sessionstatus="$(printf "%s\n" "$response" | _egrep_o '"status" *: *"[^"]*' | _head_n 1 | sed 's#^"status" *: *"##')"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _debug response "$response"
 | 
				
			||||||
 | 
					  _debug sessionstatus "$sessionstatus"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if [ "$sessionstatus" = "success" ]; then
 | 
				
			||||||
 | 
					    _info "TXT Record successfully added"
 | 
				
			||||||
 | 
					    return 0
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _err "add TXT record failed"
 | 
				
			||||||
 | 
					  return 1
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#publish the zone
 | 
				
			||||||
 | 
					_dyn_publish_zone() {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _info "Publishing zone"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  data="{\"publish\":\"true\"}"
 | 
				
			||||||
 | 
					  dyn_url="$DYN_API/Zone/$_dyn_zone/"
 | 
				
			||||||
 | 
					  method="PUT"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  export _H1="Auth-Token: $_dyn_authtoken"
 | 
				
			||||||
 | 
					  export _H2="Content-Type: application/json"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  response="$(_post "$data" "$dyn_url" "" "$method")"
 | 
				
			||||||
 | 
					  sessionstatus="$(printf "%s\n" "$response" | _egrep_o '"status" *: *"[^"]*' | _head_n 1 | sed 's#^"status" *: *"##')"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _debug response "$response"
 | 
				
			||||||
 | 
					  _debug sessionstatus "$sessionstatus"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if [ "$sessionstatus" = "success" ]; then
 | 
				
			||||||
 | 
					    _info "Zone published"
 | 
				
			||||||
 | 
					    return 0
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _err "publish zone failed"
 | 
				
			||||||
 | 
					  return 1
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#get record_id of TXT record so we can delete the record
 | 
				
			||||||
 | 
					_dyn_get_record_id() {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _info "Getting record_id of TXT record"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  dyn_url="$DYN_API/TXTRecord/$_dyn_zone/$fulldomain/"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  export _H1="Auth-Token: $_dyn_authtoken"
 | 
				
			||||||
 | 
					  export _H2="Content-Type: application/json"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  response="$(_get "$dyn_url" "" "")"
 | 
				
			||||||
 | 
					  sessionstatus="$(printf "%s\n" "$response" | _egrep_o '"status" *: *"[^"]*' | _head_n 1 | sed 's#^"status" *: *"##')"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _debug response "$response"
 | 
				
			||||||
 | 
					  _debug sessionstatus "$sessionstatus"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if [ "$sessionstatus" = "success" ]; then
 | 
				
			||||||
 | 
					    _dyn_record_id="$(printf "%s\n" "$response" | _egrep_o "\"data\" *: *\[\"/REST/TXTRecord/$_dyn_zone/$fulldomain/[^\"]*" | _head_n 1 | sed "s#^\"data\" *: *\[\"/REST/TXTRecord/$_dyn_zone/$fulldomain/##")"
 | 
				
			||||||
 | 
					    _debug _dyn_record_id "$_dyn_record_id"
 | 
				
			||||||
 | 
					    return 0
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _dyn_record_id=""
 | 
				
			||||||
 | 
					  _err "getting record_id failed"
 | 
				
			||||||
 | 
					  return 1
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#delete TXT record
 | 
				
			||||||
 | 
					_dyn_rm_record() {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _info "Deleting TXT record"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  dyn_url="$DYN_API/TXTRecord/$_dyn_zone/$fulldomain/$_dyn_record_id/"
 | 
				
			||||||
 | 
					  method="DELETE"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _debug dyn_url "$dyn_url"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  export _H1="Auth-Token: $_dyn_authtoken"
 | 
				
			||||||
 | 
					  export _H2="Content-Type: application/json"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  response="$(_post "" "$dyn_url" "" "$method")"
 | 
				
			||||||
 | 
					  sessionstatus="$(printf "%s\n" "$response" | _egrep_o '"status" *: *"[^"]*' | _head_n 1 | sed 's#^"status" *: *"##')"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _debug response "$response"
 | 
				
			||||||
 | 
					  _debug sessionstatus "$sessionstatus"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if [ "$sessionstatus" = "success" ]; then
 | 
				
			||||||
 | 
					    _info "TXT record successfully deleted"
 | 
				
			||||||
 | 
					    return 0
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _err "delete TXT record failed"
 | 
				
			||||||
 | 
					  return 1
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#logout
 | 
				
			||||||
 | 
					_dyn_end_session() {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _info "End Dyn API Session"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  dyn_url="$DYN_API/Session/"
 | 
				
			||||||
 | 
					  method="DELETE"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _debug dyn_url "$dyn_url"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  export _H1="Auth-Token: $_dyn_authtoken"
 | 
				
			||||||
 | 
					  export _H2="Content-Type: application/json"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  response="$(_post "" "$dyn_url" "" "$method")"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _debug response "$response"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  _dyn_authtoken=""
 | 
				
			||||||
 | 
					  return 0
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -41,10 +41,10 @@ dns_infoblox_add() {
 | 
				
			||||||
  export _H2="Authorization: Basic $Infoblox_CredsEncoded"
 | 
					  export _H2="Authorization: Basic $Infoblox_CredsEncoded"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  ## Add the challenge record to the Infoblox grid member
 | 
					  ## Add the challenge record to the Infoblox grid member
 | 
				
			||||||
  result=$(_post "" "$baseurlnObject" "" "POST")
 | 
					  result="$(_post "" "$baseurlnObject" "" "POST")"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  ## Let's see if we get something intelligible back from the unit
 | 
					  ## Let's see if we get something intelligible back from the unit
 | 
				
			||||||
  if echo "$result" | egrep "record:txt/.*:.*/$Infoblox_View"; then
 | 
					  if [ "$(echo "$result" | _egrep_o "record:txt/.*:.*/$Infoblox_View")" ]; then
 | 
				
			||||||
    _info "Successfully created the txt record"
 | 
					    _info "Successfully created the txt record"
 | 
				
			||||||
    return 0
 | 
					    return 0
 | 
				
			||||||
  else
 | 
					  else
 | 
				
			||||||
| 
						 | 
					@ -66,7 +66,7 @@ dns_infoblox_rm() {
 | 
				
			||||||
  _debug txtvalue "$txtvalue"
 | 
					  _debug txtvalue "$txtvalue"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  ## Base64 encode the credentials
 | 
					  ## Base64 encode the credentials
 | 
				
			||||||
  Infoblox_CredsEncoded=$(printf "%b" "$Infoblox_Creds" | _base64)
 | 
					  Infoblox_CredsEncoded="$(printf "%b" "$Infoblox_Creds" | _base64)"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  ## Construct the HTTP Authorization header
 | 
					  ## Construct the HTTP Authorization header
 | 
				
			||||||
  export _H1="Accept-Language:en-US"
 | 
					  export _H1="Accept-Language:en-US"
 | 
				
			||||||
| 
						 | 
					@ -74,17 +74,17 @@ dns_infoblox_rm() {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  ## Does the record exist?  Let's check.
 | 
					  ## Does the record exist?  Let's check.
 | 
				
			||||||
  baseurlnObject="https://$Infoblox_Server/wapi/v2.2.2/record:txt?name=$fulldomain&text=$txtvalue&view=$Infoblox_View&_return_type=xml-pretty"
 | 
					  baseurlnObject="https://$Infoblox_Server/wapi/v2.2.2/record:txt?name=$fulldomain&text=$txtvalue&view=$Infoblox_View&_return_type=xml-pretty"
 | 
				
			||||||
  result=$(_get "$baseurlnObject")
 | 
					  result="$(_get "$baseurlnObject")"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  ## Let's see if we get something intelligible back from the grid
 | 
					  ## Let's see if we get something intelligible back from the grid
 | 
				
			||||||
  if echo "$result" | egrep "record:txt/.*:.*/$Infoblox_View"; then
 | 
					  if [ "$(echo "$result" | _egrep_o "record:txt/.*:.*/$Infoblox_View")" ]; then
 | 
				
			||||||
    ## Extract the object reference
 | 
					    ## Extract the object reference
 | 
				
			||||||
    objRef=$(printf "%b" "$result" | _egrep_o "record:txt/.*:.*/$Infoblox_View")
 | 
					    objRef="$(printf "%b" "$result" | _egrep_o "record:txt/.*:.*/$Infoblox_View")"
 | 
				
			||||||
    objRmUrl="https://$Infoblox_Server/wapi/v2.2.2/$objRef"
 | 
					    objRmUrl="https://$Infoblox_Server/wapi/v2.2.2/$objRef"
 | 
				
			||||||
    ## Delete them! All the stale records!
 | 
					    ## Delete them! All the stale records!
 | 
				
			||||||
    rmResult=$(_post "" "$objRmUrl" "" "DELETE")
 | 
					    rmResult="$(_post "" "$objRmUrl" "" "DELETE")"
 | 
				
			||||||
    ## Let's see if that worked
 | 
					    ## Let's see if that worked
 | 
				
			||||||
    if echo "$rmResult" | egrep "record:txt/.*:.*/$Infoblox_View"; then
 | 
					    if [ "$(echo "$rmResult" | _egrep_o "record:txt/.*:.*/$Infoblox_View")" ]; then
 | 
				
			||||||
      _info "Successfully deleted $objRef"
 | 
					      _info "Successfully deleted $objRef"
 | 
				
			||||||
      return 0
 | 
					      return 0
 | 
				
			||||||
    else
 | 
					    else
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue