|
@@ -48,9 +48,6 @@ RENEW_SKIP=2
|
|
|
ECC_SEP="_"
|
|
|
ECC_SUFFIX="${ECC_SEP}ecc"
|
|
|
|
|
|
-if [ -z "$AGREEMENT" ] ; then
|
|
|
- AGREEMENT="$DEFAULT_AGREEMENT"
|
|
|
-fi
|
|
|
|
|
|
__INTERACTIVE=""
|
|
|
if [ -t 1 ] ; then
|
|
@@ -1767,6 +1764,93 @@ _on_issue_success() {
|
|
|
}
|
|
|
|
|
|
|
|
|
+
|
|
|
+_regAccount() {
|
|
|
+ _initpath
|
|
|
+ if [ ! -f "$ACCOUNT_KEY_PATH" ] ; then
|
|
|
+ _acck="no"
|
|
|
+ if [ "$Le_Keylength" ] ; then
|
|
|
+ _acck="$Le_Keylength"
|
|
|
+ fi
|
|
|
+ if ! createAccountKey "$_acck" ; then
|
|
|
+ _err "Create account key error."
|
|
|
+ return 1
|
|
|
+ fi
|
|
|
+ fi
|
|
|
+
|
|
|
+ if ! _calcjwk "$ACCOUNT_KEY_PATH" ; then
|
|
|
+ return 1
|
|
|
+ fi
|
|
|
+
|
|
|
+ _updateTos=""
|
|
|
+ _reg_res="new-reg"
|
|
|
+ while true ;
|
|
|
+ do
|
|
|
+ _debug AGREEMENT "$AGREEMENT"
|
|
|
+ accountkey_json=$(printf "%s" "$jwk" | tr -d ' ' )
|
|
|
+ thumbprint=$(printf "%s" "$accountkey_json" | _digest "sha256" | _urlencode)
|
|
|
+
|
|
|
+ regjson='{"resource": "'$_reg_res'", "agreement": "'$AGREEMENT'"}'
|
|
|
+
|
|
|
+ if [ "$ACCOUNT_EMAIL" ] ; then
|
|
|
+ regjson='{"resource": "'$_reg_res'", "contact": ["mailto: '$ACCOUNT_EMAIL'"], "agreement": "'$AGREEMENT'"}'
|
|
|
+ fi
|
|
|
+
|
|
|
+ if [ -z "$_updateTos" ] ; then
|
|
|
+ _info "Registering account"
|
|
|
+
|
|
|
+ if ! _send_signed_request "$API/acme/new-reg" "$regjson" ; then
|
|
|
+ _err "Register account Error: $response"
|
|
|
+ return 1
|
|
|
+ fi
|
|
|
+
|
|
|
+ if [ "$code" = "" ] || [ "$code" = '201' ] ; then
|
|
|
+ echo "$response" > $LE_WORKING_DIR/account.json
|
|
|
+ _info "Registered"
|
|
|
+ elif [ "$code" = '409' ] ; then
|
|
|
+ _info "Already registered"
|
|
|
+ else
|
|
|
+ _err "Register account Error: $response"
|
|
|
+ return 1
|
|
|
+ fi
|
|
|
+
|
|
|
+ _accUri="$(echo "$responseHeaders" | grep "^Location:" | cut -d ' ' -f 2| tr -d "\r\n")"
|
|
|
+ _debug "_accUri" "$_accUri"
|
|
|
+ ACCOUNT_URL="$_accUri"
|
|
|
+ _saveaccountconf ACCOUNT_URL "$ACCOUNT_URL"
|
|
|
+
|
|
|
+ _tos="$(echo "$responseHeaders" | grep "^Link:.*rel=\"terms-of-service\"" | _egrep_o "<.*>" | tr -d '<>')"
|
|
|
+ _debug "_tos" "$_tos"
|
|
|
+ if [ -z "$_tos" ] ; then
|
|
|
+ _debug "Use default tos: $DEFAULT_AGREEMENT"
|
|
|
+ _tos="$DEFAULT_AGREEMENT"
|
|
|
+ fi
|
|
|
+ if [ "$_tos" != "$AGREEMENT" ]; then
|
|
|
+ _updateTos=1
|
|
|
+ AGREEMENT="$_tos"
|
|
|
+ _reg_res="reg"
|
|
|
+ continue
|
|
|
+ fi
|
|
|
+
|
|
|
+ else
|
|
|
+ _debug "Update tos: $_tos"
|
|
|
+ if ! _send_signed_request "$_accUri" "$regjson" ; then
|
|
|
+ _err "Update tos error."
|
|
|
+ return 1
|
|
|
+ fi
|
|
|
+ if [ "$code" = '202' ] ; then
|
|
|
+ _debug "Update tos success."
|
|
|
+ else
|
|
|
+ _err "Update tos error."
|
|
|
+ return 1
|
|
|
+ fi
|
|
|
+ fi
|
|
|
+ return 0
|
|
|
+ done
|
|
|
+
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
#webroot, domain domainlist keylength
|
|
|
issue() {
|
|
|
if [ -z "$2" ] ; then
|
|
@@ -1826,69 +1910,21 @@ issue() {
|
|
|
Le_Alt=""
|
|
|
fi
|
|
|
|
|
|
+ if [ "$Le_Keylength" = "$NO_VALUE" ] ; then
|
|
|
+ Le_Keylength=""
|
|
|
+ fi
|
|
|
+
|
|
|
if ! _on_before_issue ; then
|
|
|
_err "_on_before_issue."
|
|
|
return 1
|
|
|
fi
|
|
|
|
|
|
- if [ ! -f "$ACCOUNT_KEY_PATH" ] ; then
|
|
|
- _acck="$NO_VALUE"
|
|
|
- if [ "$Le_Keylength" ] ; then
|
|
|
- _acck="$Le_Keylength"
|
|
|
- fi
|
|
|
- if ! createAccountKey "$_acck" ; then
|
|
|
- _err "Create account key error."
|
|
|
- if [ "$usingApache" ] ; then
|
|
|
- _restoreApache
|
|
|
- fi
|
|
|
- _on_issue_err
|
|
|
- return 1
|
|
|
- fi
|
|
|
- fi
|
|
|
-
|
|
|
- if ! _calcjwk "$ACCOUNT_KEY_PATH" ; then
|
|
|
- if [ "$usingApache" ] ; then
|
|
|
- _restoreApache
|
|
|
- fi
|
|
|
+ if ! _regAccount ; then
|
|
|
_on_issue_err
|
|
|
return 1
|
|
|
fi
|
|
|
|
|
|
- accountkey_json=$(printf "%s" "$jwk" | tr -d ' ' )
|
|
|
- thumbprint=$(printf "%s" "$accountkey_json" | _digest "sha256" | _urlencode)
|
|
|
-
|
|
|
- regjson='{"resource": "new-reg", "agreement": "'$AGREEMENT'"}'
|
|
|
- if [ "$ACCOUNT_EMAIL" ] ; then
|
|
|
- regjson='{"resource": "new-reg", "contact": ["mailto: '$ACCOUNT_EMAIL'"], "agreement": "'$AGREEMENT'"}'
|
|
|
- fi
|
|
|
-
|
|
|
- accountkeyhash="$(cat "$ACCOUNT_KEY_PATH" | _digest "sha256" )"
|
|
|
- accountkeyhash="$(echo $accountkeyhash$API$regjson | _digest "sha256" )"
|
|
|
- if [ "$accountkeyhash" != "$ACCOUNT_KEY_HASH" ] ; then
|
|
|
- _info "Registering account"
|
|
|
- _send_signed_request "$API/acme/new-reg" "$regjson"
|
|
|
- if [ "$code" = "" ] || [ "$code" = '201' ] ; then
|
|
|
- _info "Registered"
|
|
|
- echo "$response" > $LE_WORKING_DIR/account.json
|
|
|
- elif [ "$code" = '409' ] ; then
|
|
|
- _info "Already registered"
|
|
|
- else
|
|
|
- _err "Register account Error: $response"
|
|
|
- _clearup
|
|
|
- _on_issue_err
|
|
|
- return 1
|
|
|
- fi
|
|
|
- ACCOUNT_KEY_HASH="$accountkeyhash"
|
|
|
- _saveaccountconf "ACCOUNT_KEY_HASH" "$ACCOUNT_KEY_HASH"
|
|
|
- else
|
|
|
- _info "Skip register account key"
|
|
|
- fi
|
|
|
|
|
|
- if [ "$Le_Keylength" = "$NO_VALUE" ] ; then
|
|
|
- Le_Keylength=""
|
|
|
- fi
|
|
|
-
|
|
|
-
|
|
|
if [ -f "$CSR_PATH" ] && [ ! -f "$CERT_KEY_PATH" ] ; then
|
|
|
_info "Signing from existing CSR."
|
|
|
else
|
|
@@ -2301,13 +2337,18 @@ issue() {
|
|
|
return 1
|
|
|
fi
|
|
|
|
|
|
-
|
|
|
+ _rcert="$response"
|
|
|
Le_LinkCert="$(grep -i '^Location.*$' $HTTP_HEADER | head -1 | tr -d "\r\n" | cut -d " " -f 2)"
|
|
|
_savedomainconf "Le_LinkCert" "$Le_LinkCert"
|
|
|
|
|
|
if [ "$Le_LinkCert" ] ; then
|
|
|
echo "$BEGIN_CERT" > "$CERT_PATH"
|
|
|
- _get "$Le_LinkCert" | _base64 "multiline" >> "$CERT_PATH"
|
|
|
+
|
|
|
+ if ! _get "$Le_LinkCert" | _base64 "multiline" >> "$CERT_PATH" ; then
|
|
|
+ _debug "Get cert failed. Let's try last response."
|
|
|
+ printf -- "%s" "$_rcert" | _dbase64 "multiline" | _base64 "multiline" >> "$CERT_PATH"
|
|
|
+ fi
|
|
|
+
|
|
|
echo "$END_CERT" >> "$CERT_PATH"
|
|
|
_info "$(__green "Cert success.")"
|
|
|
cat "$CERT_PATH"
|
|
@@ -2918,6 +2959,9 @@ _initconf() {
|
|
|
#ACCOUNT_KEY_PATH=\"/path/to/account.key\"
|
|
|
#CERT_HOME=\"/path/to/cert/home\"
|
|
|
|
|
|
+#ACCOUNT_URL=\"\"
|
|
|
+
|
|
|
+
|
|
|
#LOG_FILE=\"$DEFAULT_LOG_FILE\"
|
|
|
|
|
|
#AUTO_UPGRADE=\"1\"
|