#!/usr/bin/env sh # Author: @SBohomolov # Site: Fornex.com # Docs: github.com/acmesh-official/acme.sh/wiki/dnsapi2#dns_fornex # Bugs: https://github.com/acmesh-official/acme.sh/issues/5161 ## install jq ## # Check the operating system if [ "$(uname)" = "Darwin" ]; then # macOS - install jq using Homebrew if ! command -v brew >/dev/null 2>&1; then echo "Error: Homebrew is not installed. Please install Homebrew first." >&2 exit 1 fi brew install jq elif [ -f "/etc/redhat-release" ] || [ -f "/etc/centos-release" ] || [ -f "/etc/fedora-release" ]; then # RedHat/CentOS/Fedora - install jq using yum or dnf if command -v dnf >/dev/null 2>&1; then dnf install -y jq elif command -v yum >/dev/null 2>&1; then yum install -y jq else echo "Error: Neither yum nor dnf package manager found." >&2 exit 1 fi elif [ -f "/etc/lsb-release" ] || [ -f "/etc/debian_version" ]; then # Debian/Ubuntu - install jq using apt if command -v apt >/dev/null 2>&1; then apt update apt install -y jq else echo "Error: apt package manager not found." >&2 exit 1 fi else echo "Error: Unsupported operating system." >&2 exit 1 fi # jq installed successfully echo "jq installed successfully." ####################################################### FORNEX_API_URL="https://fornex.com/api/dns/domain" ######## Public functions ########################### # Usage: dns_fornex_add _acme-challenge.www.domain.com "XKrxpRBosdIKFzxW_CT3KLZNf6q0HG9i01zxXp5CPBs" dns_fornex_add() { fulldomain=$1 txtvalue=$2 if ! _Fornex_API; then return 1 fi domain=$(echo "$fulldomain" | sed 's/^\*\.//') if ! _get_domain_id "$domain"; then _err "Unable to determine domain ID" return 1 else _debug _domain_id "$_domain_id" fi _info "Adding TXT record for $fulldomain" # Add the TXT record if ! _rest POST "$domain/entry_set/" "type=TXT&host=_acme-challenge&value=$txtvalue"; then _err "Failed to add TXT record" return 1 fi _info "TXT record added successfully" return 0 } dns_fornex_rm() { fulldomain=$1 if ! _Fornex_API; then return 1 fi domain=$(echo "$fulldomain" | sed 's/^\*\.//') if ! _get_domain_id "$domain"; then _err "Unable to determine domain ID" return 1 else _debug _domain_id "$_domain_id" fi _info "Removing TXT records for domain: _acme-challenge.$domain" response=$(curl -X GET -H "Authorization: Api-Key $FORNEX_API_KEY" "https://fornex.com/api/dns/domain/$domain/entry_set/") # Extract TXT record IDs using jq txt_ids=$(echo "$response" | jq -r '.[] | select(.type == "TXT") | .id') if [ -z "$txt_ids" ]; then _info "No TXT records found for domain: _acme-challenge.$domain" return 0 fi for txt_id in $txt_ids; do _info "Removing TXT record with ID: $txt_id" if ! curl -X DELETE -H "Authorization: Api-Key $FORNEX_API_KEY" "https://fornex.com/api/dns/domain/$domain/entry_set/$txt_id/"; then _err "Failed to remove TXT record with ID: $txt_id" else _info "TXT record with ID $txt_id removed successfully" fi done return 0 } #################### Private functions below ################################## # _acme-challenge.www.domain.com # returns # _sub_domain=_acme-challenge.www # _domain=domain.com _get_domain_id() { domain=$1 _debug "Getting domain ID for $domain" if echo "$domain" | grep -q "_acme-challenge"; then # If yes, remove "_acme-challenge" from the domain name domain=$(echo "$domain" | sed 's/_acme-challenge\.//') fi if ! _rest GET "$domain/entry_set/"; then _err "Failed to get domain ID for $domain" return 1 fi _domain_id="$response" _debug "Domain ID for $domain is $_domain_id" return 0 } _Fornex_API() { FORNEX_API_KEY="${FORNEX_API_KEY:-$(_readaccountconf_mutable FORNEX_API_KEY)}" if [ -z "$FORNEX_API_KEY" ]; then FORNEX_API_KEY="" _err "You didn't specify the Fornex API key yet." _err "Please create your key and try again." return 1 fi _saveaccountconf_mutable FORNEX_API_KEY "$FORNEX_API_KEY" } # method method action data _rest() { m=$1 ep="$2" data="$3" _debug "$ep" export _H1="Accept: application/json" export _H2="Authorization: Api-Key $FORNEX_API_KEY" if [ "$m" != "GET" ]; then _debug data "$data" url="$FORNEX_API_URL/$ep" response=$(curl -X "$m" -H "Authorization: Api-Key $FORNEX_API_KEY" -d "$data" "$url") else url="$FORNEX_API_URL/$ep" response=$(curl -X GET -H "Authorization: Api-Key $FORNEX_API_KEY" "$url") fi _ret="$?" if [ "$_ret" != "0" ]; then _err "error $ep" return 1 fi _debug2 response "$response" return 0 }