mirror of
				https://github.com/hiskang/acme.sh
				synced 2025-10-31 02:17:18 +00:00 
			
		
		
		
	
						commit
						5254f300f9
					
				
							
								
								
									
										5
									
								
								acme.sh
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								acme.sh
									
									
									
									
									
								
							| @ -1991,7 +1991,8 @@ _clearupdns() { | |||||||
|     keyauthorization=$(echo "$ventry" | cut -d "$sep" -f 2) |     keyauthorization=$(echo "$ventry" | cut -d "$sep" -f 2) | ||||||
|     vtype=$(echo "$ventry" | cut -d "$sep" -f 4) |     vtype=$(echo "$ventry" | cut -d "$sep" -f 4) | ||||||
|     _currentRoot=$(echo "$ventry" | cut -d "$sep" -f 5) |     _currentRoot=$(echo "$ventry" | cut -d "$sep" -f 5) | ||||||
| 
 |     txt="$(printf "%s" "$keyauthorization" | _digest "sha256" | _urlencode)" | ||||||
|  |     _debug txt "$txt" | ||||||
|     if [ "$keyauthorization" = "$STATE_VERIFIED" ]; then |     if [ "$keyauthorization" = "$STATE_VERIFIED" ]; then | ||||||
|       _info "$d is already verified, skip $vtype." |       _info "$d is already verified, skip $vtype." | ||||||
|       continue |       continue | ||||||
| @ -2024,7 +2025,7 @@ _clearupdns() { | |||||||
| 
 | 
 | ||||||
|       txtdomain="_acme-challenge.$d" |       txtdomain="_acme-challenge.$d" | ||||||
| 
 | 
 | ||||||
|       if ! $rmcommand "$txtdomain"; then |       if ! $rmcommand "$txtdomain" "$txt"; then | ||||||
|         _err "Error removing txt for domain:$txtdomain" |         _err "Error removing txt for domain:$txtdomain" | ||||||
|         return 1 |         return 1 | ||||||
|       fi |       fi | ||||||
|  | |||||||
| @ -55,9 +55,7 @@ dns_cf_add() { | |||||||
|     _info "Adding record" |     _info "Adding record" | ||||||
|     if _cf_rest POST "zones/$_domain_id/dns_records" "{\"type\":\"TXT\",\"name\":\"$fulldomain\",\"content\":\"$txtvalue\",\"ttl\":120}"; then |     if _cf_rest POST "zones/$_domain_id/dns_records" "{\"type\":\"TXT\",\"name\":\"$fulldomain\",\"content\":\"$txtvalue\",\"ttl\":120}"; then | ||||||
|       if printf -- "%s" "$response" | grep "$fulldomain" >/dev/null; then |       if printf -- "%s" "$response" | grep "$fulldomain" >/dev/null; then | ||||||
|         _info "Added, sleeping 10 seconds" |         _info "Added, OK" | ||||||
|         sleep 10 |  | ||||||
|         #todo: check if the record takes effect |  | ||||||
|         return 0 |         return 0 | ||||||
|       else |       else | ||||||
|         _err "Add txt record error." |         _err "Add txt record error." | ||||||
| @ -83,9 +81,44 @@ dns_cf_add() { | |||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #fulldomain | #fulldomain txtvalue | ||||||
| dns_cf_rm() { | dns_cf_rm() { | ||||||
|   fulldomain=$1 |   fulldomain=$1 | ||||||
|  |   txtvalue=$2 | ||||||
|  |   _debug "First detect the root zone" | ||||||
|  |   if ! _get_root "$fulldomain"; then | ||||||
|  |     _err "invalid domain" | ||||||
|  |     return 1 | ||||||
|  |   fi | ||||||
|  |   _debug _domain_id "$_domain_id" | ||||||
|  |   _debug _sub_domain "$_sub_domain" | ||||||
|  |   _debug _domain "$_domain" | ||||||
|  | 
 | ||||||
|  |   _debug "Getting txt records" | ||||||
|  |   _cf_rest GET "zones/${_domain_id}/dns_records?type=TXT&name=$fulldomain&content=$txtvalue" | ||||||
|  | 
 | ||||||
|  |   if ! printf "%s" "$response" | grep \"success\":true >/dev/null; then | ||||||
|  |     _err "Error" | ||||||
|  |     return 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   count=$(printf "%s\n" "$response" | _egrep_o "\"count\":[^,]*" | cut -d : -f 2) | ||||||
|  |   _debug count "$count" | ||||||
|  |   if [ "$count" = "0" ]; then | ||||||
|  |     _info "Don't need to remove." | ||||||
|  |   else | ||||||
|  |     record_id=$(printf "%s\n" "$response" | _egrep_o "\"id\":\"[^\"]*\"" | cut -d : -f 2 | tr -d \" | head -n 1) | ||||||
|  |     _debug "record_id" "$record_id" | ||||||
|  |     if [ -z "$record_id" ]; then | ||||||
|  |       _err "Can not get record id to remove." | ||||||
|  |       return 1 | ||||||
|  |     fi | ||||||
|  |     if ! _cf_rest DELETE "zones/$_domain_id/dns_records/$record_id"; then | ||||||
|  |       _err "Delete record error." | ||||||
|  |       return 1 | ||||||
|  |     fi | ||||||
|  |     _contains "$response" '"success":true' | ||||||
|  |   fi | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -135,7 +168,7 @@ _cf_rest() { | |||||||
|   _H2="X-Auth-Key: $CF_Key" |   _H2="X-Auth-Key: $CF_Key" | ||||||
|   _H3="Content-Type: application/json" |   _H3="Content-Type: application/json" | ||||||
| 
 | 
 | ||||||
|   if [ "$data" ]; then |   if [ "$m" != "GET" ]; then | ||||||
|     _debug data "$data" |     _debug data "$data" | ||||||
|     response="$(_post "$data" "$CF_Api/$ep" "" "$m")" |     response="$(_post "$data" "$CF_Api/$ep" "" "$m")" | ||||||
|   else |   else | ||||||
|  | |||||||
| @ -22,11 +22,14 @@ dns_myapi_add() { | |||||||
|   return 1 |   return 1 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #Usage: fulldomain | #Usage: fulldomain txtvalue | ||||||
| #Remove the txt record afer validation. | #Remove the txt record afer validation. | ||||||
| dns_myapi_rm() { | dns_myapi_rm() { | ||||||
|   fulldomain=$1 |   fulldomain=$1 | ||||||
| 
 |   txtvalue=$2 | ||||||
|  |   _info "Using myapi" | ||||||
|  |   _debug fulldomain "$fulldomain" | ||||||
|  |   _debug txtvalue "$txtvalue" | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ####################  Private functions bellow ################################## | ####################  Private functions bellow ################################## | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user