mirror of
				https://github.com/hiskang/acme.sh
				synced 2025-11-03 20:07:43 +00:00 
			
		
		
		
	Merge branch 'patch-1' into dev
This commit is contained in:
		
						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")
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										107
									
								
								dnsapi/dns_kinghost.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								dnsapi/dns_kinghost.sh
									
									
									
									
									
										Normal file
									
								
							@ -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…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user