Merge branch 'patch-1' into dev
						commit
						d1b197e339
					
				|  | @ -315,6 +315,7 @@ You don't have to do anything manually! | ||||||
| 1. zonomi.com DNS API | 1. zonomi.com DNS API | ||||||
| 1. DreamHost.com API | 1. DreamHost.com API | ||||||
| 1. DirectAdmin API | 1. DirectAdmin API | ||||||
|  | 1. KingHost (https://www.kinghost.com.br/) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| And:  | And:  | ||||||
|  |  | ||||||
|  | @ -787,6 +787,32 @@ acme.sh --issue --dns dns_da -d example.com -d www.example.com | ||||||
| 
 | 
 | ||||||
| The `DA_Api` and `DA_Api_Insecure` will be saved in `~/.acme.sh/account.conf` and will be reused when needed. | The `DA_Api` and `DA_Api_Insecure` will be saved in `~/.acme.sh/account.conf` and will be reused when needed. | ||||||
| 
 | 
 | ||||||
|  | ## 42. Use KingHost DNS API | ||||||
|  | 
 | ||||||
|  | API access must be enabled at https://painel.kinghost.com.br/painel.api.php | ||||||
|  | 
 | ||||||
|  | ``` | ||||||
|  | export KINGHOST_Username="yourusername" | ||||||
|  | export KINGHOST_Password="yourpassword" | ||||||
|  | acme.sh --issue --dns dns_kinghost -d example.com -d *.example.com | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | The `KINGHOST_username` and `KINGHOST_Password` will be saved in `~/.acme.sh/account.conf` and will be reused when needed. | ||||||
|  | 
 | ||||||
|  | ## 43. Use Zilore DNS API | ||||||
|  | 
 | ||||||
|  | First you need to login to your Zilore account to get your API key. | ||||||
|  | 
 | ||||||
|  | ``` | ||||||
|  | export Zilore_Key="5dcad3a2-36cb-50e8-cb92-000002f9" | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | Ok, let's issue a cert now: | ||||||
|  | ``` | ||||||
|  | acme.sh --issue --dns dns_zilore -d example.com -d www.example.com | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | The `Zilore_Key` will be saved in `~/.acme.sh/account.conf` and will be reused when needed. | ||||||
| 
 | 
 | ||||||
| # Use custom API | # Use custom API | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -39,34 +39,17 @@ dns_dnsimple_add() { | ||||||
| 
 | 
 | ||||||
|   _get_records "$_account_id" "$_domain" "$_sub_domain" |   _get_records "$_account_id" "$_domain" "$_sub_domain" | ||||||
| 
 | 
 | ||||||
|   if [ "$_records_count" = "0" ]; then |   _info "Adding record" | ||||||
|     _info "Adding record" |   if _dnsimple_rest POST "$_account_id/zones/$_domain/records" "{\"type\":\"TXT\",\"name\":\"$_sub_domain\",\"content\":\"$txtvalue\",\"ttl\":120}"; then | ||||||
|     if _dnsimple_rest POST "$_account_id/zones/$_domain/records" "{\"type\":\"TXT\",\"name\":\"$_sub_domain\",\"content\":\"$txtvalue\",\"ttl\":120}"; then |     if printf -- "%s" "$response" | grep "\"name\":\"$_sub_domain\"" >/dev/null; then | ||||||
|       if printf -- "%s" "$response" | grep "\"name\":\"$_sub_domain\"" >/dev/null; then |       _info "Added" | ||||||
|         _info "Added" |  | ||||||
|         return 0 |  | ||||||
|       else |  | ||||||
|         _err "Unexpected response while adding text record." |  | ||||||
|         return 1 |  | ||||||
|       fi |  | ||||||
|     fi |  | ||||||
|     _err "Add txt record error." |  | ||||||
|   else |  | ||||||
|     _info "Updating record" |  | ||||||
|     _extract_record_id "$_records" "$_sub_domain" |  | ||||||
| 
 |  | ||||||
|     if _dnsimple_rest \ |  | ||||||
|       PATCH \ |  | ||||||
|       "$_account_id/zones/$_domain/records/$_record_id" \ |  | ||||||
|       "{\"type\":\"TXT\",\"name\":\"$_sub_domain\",\"content\":\"$txtvalue\",\"ttl\":120}"; then |  | ||||||
| 
 |  | ||||||
|       _info "Updated!" |  | ||||||
|       return 0 |       return 0 | ||||||
|  |     else | ||||||
|  |       _err "Unexpected response while adding text record." | ||||||
|  |       return 1 | ||||||
|     fi |     fi | ||||||
| 
 |  | ||||||
|     _err "Update error" |  | ||||||
|     return 1 |  | ||||||
|   fi |   fi | ||||||
|  |   _err "Add txt record error." | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| # fulldomain | # fulldomain | ||||||
|  | @ -84,19 +67,19 @@ dns_dnsimple_rm() { | ||||||
|   fi |   fi | ||||||
| 
 | 
 | ||||||
|   _get_records "$_account_id" "$_domain" "$_sub_domain" |   _get_records "$_account_id" "$_domain" "$_sub_domain" | ||||||
|  | 
 | ||||||
|   _extract_record_id "$_records" "$_sub_domain" |   _extract_record_id "$_records" "$_sub_domain" | ||||||
| 
 |  | ||||||
|   if [ "$_record_id" ]; then |   if [ "$_record_id" ]; then | ||||||
| 
 |     echo "$_record_id" | while read -r item; do | ||||||
|     if _dnsimple_rest DELETE "$_account_id/zones/$_domain/records/$_record_id"; then |       if _dnsimple_rest DELETE "$_account_id/zones/$_domain/records/$item"; then | ||||||
|       _info "removed record" "$_record_id" |         _info "removed record" "$item" | ||||||
|       return 0 |         return 0 | ||||||
|     fi |       else | ||||||
|  |         _err "failed to remove record" "$item" | ||||||
|  |         return 1 | ||||||
|  |       fi | ||||||
|  |     done | ||||||
|   fi |   fi | ||||||
| 
 |  | ||||||
|   _err "failed to remove record" "$_record_id" |  | ||||||
|   return 1 |  | ||||||
| 
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ####################  Private functions bellow ################################## | ####################  Private functions bellow ################################## | ||||||
|  |  | ||||||
|  | @ -143,7 +143,7 @@ _find_zone() { | ||||||
| 
 | 
 | ||||||
|     _debug "Looking for zone \"${_attempted_zone}\"" |     _debug "Looking for zone \"${_attempted_zone}\"" | ||||||
| 
 | 
 | ||||||
|     line_num="$(echo "$_zone_names" | grep -n "$_attempted_zone" | cut -d : -f 1)" |     line_num="$(echo "$_zone_names" | grep -n "^$_attempted_zone" | cut -d : -f 1)" | ||||||
| 
 | 
 | ||||||
|     if [ "$line_num" ]; then |     if [ "$line_num" ]; then | ||||||
|       _zone_id=$(echo "$_zone_ids" | sed -n "${line_num}p") |       _zone_id=$(echo "$_zone_ids" | sed -n "${line_num}p") | ||||||
|  |  | ||||||
|  | @ -0,0 +1,107 @@ | ||||||
|  | #!/usr/bin/env sh | ||||||
|  | 
 | ||||||
|  | ############################################################ | ||||||
|  | # KingHost API support                                     # | ||||||
|  | # http://api.kinghost.net/doc/                             # | ||||||
|  | #                                                          # | ||||||
|  | # Author: Felipe Keller Braz <felipebraz@kinghost.com.br>  # | ||||||
|  | # Report Bugs here: https://github.com/kinghost/acme.sh    # | ||||||
|  | #                                                          # | ||||||
|  | # Values to export:                                        # | ||||||
|  | # export KINGHOST_Username="email@provider.com"            # | ||||||
|  | # export KINGHOST_Password="xxxxxxxxxx"                    # | ||||||
|  | ############################################################ | ||||||
|  | 
 | ||||||
|  | KING_Api="https://api.kinghost.net/acme" | ||||||
|  | 
 | ||||||
|  | # Usage: add  _acme-challenge.www.domain.com   "XKrxpRBosdIKFzxW_CT3KLZNf6q0HG9i01zxXp5CPBs" | ||||||
|  | # Used to add txt record | ||||||
|  | dns_kinghost_add() { | ||||||
|  |   fulldomain=$1 | ||||||
|  |   txtvalue=$2 | ||||||
|  | 
 | ||||||
|  |   KINGHOST_Username="${KINGHOST_Username:-$(_readaccountconf_mutable KINGHOST_Username)}" | ||||||
|  |   KINGHOST_Password="${KINGHOST_Password:-$(_readaccountconf_mutable KINGHOST_Password)}" | ||||||
|  |   if [ -z "$KINGHOST_Username" ] || [ -z "$KINGHOST_Password" ]; then | ||||||
|  |     KINGHOST_Username="" | ||||||
|  |     KINGHOST_Password="" | ||||||
|  |     _err "You don't specify KingHost api password and email yet." | ||||||
|  |     _err "Please create you key and try again." | ||||||
|  |     return 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   #save the credentials to the account conf file. | ||||||
|  |   _saveaccountconf_mutable KINGHOST_Username "$KINGHOST_Username" | ||||||
|  |   _saveaccountconf_mutable KINGHOST_Password "$KINGHOST_Password" | ||||||
|  | 
 | ||||||
|  |   _debug "Getting txt records" | ||||||
|  |   _kinghost_rest GET "dns" "name=$fulldomain&content=$txtvalue" | ||||||
|  | 
 | ||||||
|  |   #This API call returns "status":"ok" if dns record does not exists | ||||||
|  |   #We are creating a new txt record here, so we expect the "ok" status | ||||||
|  |   if ! echo "$response" | grep '"status":"ok"' >/dev/null; then | ||||||
|  |     _err "Error" | ||||||
|  |     _err "$response" | ||||||
|  |     return 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   _kinghost_rest POST "dns" "name=$fulldomain&content=$txtvalue" | ||||||
|  |   if ! echo "$response" | grep '"status":"ok"' >/dev/null; then | ||||||
|  |     _err "Error" | ||||||
|  |     _err "$response" | ||||||
|  |     return 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   return 0 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | # Usage: fulldomain txtvalue | ||||||
|  | # Used to remove the txt record after validation | ||||||
|  | dns_kinghost_rm() { | ||||||
|  |   fulldomain=$1 | ||||||
|  |   txtvalue=$2 | ||||||
|  | 
 | ||||||
|  |   KINGHOST_Password="${KINGHOST_Password:-$(_readaccountconf_mutable KINGHOST_Password)}" | ||||||
|  |   KINGHOST_Username="${KINGHOST_Username:-$(_readaccountconf_mutable KINGHOST_Username)}" | ||||||
|  |   if [ -z "$KINGHOST_Password" ] || [ -z "$KINGHOST_Username" ]; then | ||||||
|  |     KINGHOST_Password="" | ||||||
|  |     KINGHOST_Username="" | ||||||
|  |     _err "You don't specify KingHost api key and email yet." | ||||||
|  |     _err "Please create you key and try again." | ||||||
|  |     return 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   _kinghost_rest DELETE "dns" "name=$fulldomain&content=$txtvalue" | ||||||
|  |   if ! echo "$response" | grep '"status":"ok"' >/dev/null; then | ||||||
|  |     _err "Error" | ||||||
|  |     _err "$response" | ||||||
|  |     return 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   return 0 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | ####################  Private functions below ################################## | ||||||
|  | _kinghost_rest() { | ||||||
|  |   method=$1 | ||||||
|  |   uri="$2" | ||||||
|  |   data="$3" | ||||||
|  |   _debug "$uri" | ||||||
|  | 
 | ||||||
|  |   export _H1="X-Auth-Email: $KINGHOST_Username" | ||||||
|  |   export _H2="X-Auth-Key: $KINGHOST_Password" | ||||||
|  | 
 | ||||||
|  |   if [ "$method" != "GET" ]; then | ||||||
|  |     _debug data "$data" | ||||||
|  |     response="$(_post "$data" "$KING_Api/$uri.json" "" "$method")" | ||||||
|  |   else | ||||||
|  |     response="$(_get "$KING_Api/$uri.json?$data")" | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   if [ "$?" != "0" ]; then | ||||||
|  |     _err "error $uri" | ||||||
|  |     return 1 | ||||||
|  |   fi | ||||||
|  |   _debug2 response "$response" | ||||||
|  |   return 0 | ||||||
|  | } | ||||||
|  | @ -123,7 +123,7 @@ _namecom_login() { | ||||||
|   # Auth string |   # Auth string | ||||||
|   # Name.com API v4 uses http basic auth to authenticate |   # Name.com API v4 uses http basic auth to authenticate | ||||||
|   # need to convert the token for http auth |   # need to convert the token for http auth | ||||||
|   _namecom_auth=$(printf "%s:%s" "$Namecom_Username" "$Namecom_Token" | base64) |   _namecom_auth=$(printf "%s:%s" "$Namecom_Username" "$Namecom_Token" | _base64) | ||||||
| 
 | 
 | ||||||
|   if _namecom_rest GET "hello"; then |   if _namecom_rest GET "hello"; then | ||||||
|     retcode=$(printf "%s\n" "$response" | _egrep_o "\"username\"\:\"$Namecom_Username\"") |     retcode=$(printf "%s\n" "$response" | _egrep_o "\"username\"\:\"$Namecom_Username\"") | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Habetdin
						Habetdin