mirror of
https://github.com/plantroon/acme.sh.git
synced 2025-01-22 04:12:02 +00:00
do not register account if already registered
This commit is contained in:
parent
00bcbd367f
commit
8a29fbc850
115
acme.sh
115
acme.sh
@ -1223,60 +1223,85 @@ _setopt() {
|
|||||||
_debug2 "$(grep -n "^$__opt$__sep" $__conf)"
|
_debug2 "$(grep -n "^$__opt$__sep" $__conf)"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#_save_conf file key value
|
||||||
|
#save to conf
|
||||||
|
_save_conf() {
|
||||||
|
_s_c_f="$1"
|
||||||
|
_sdkey="$2"
|
||||||
|
_sdvalue="$3"
|
||||||
|
if [ "$_s_c_f" ] ; then
|
||||||
|
_setopt "$_s_c_f" "$_sdkey" "=" "'$_sdvalue'"
|
||||||
|
else
|
||||||
|
_err "config file is empty, can not save $_sdkey=$_sdvalue"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
#_clear_conf file key
|
||||||
|
_clear_conf() {
|
||||||
|
_c_c_f="$1"
|
||||||
|
_sdkey="$2"
|
||||||
|
if [ "$_c_c_f" ] ; then
|
||||||
|
_sed_i "s/^$_sdkey.*$//" "$_c_c_f"
|
||||||
|
else
|
||||||
|
_err "config file is empty, can not clear"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
#_read_conf file key
|
||||||
|
_read_conf() {
|
||||||
|
_r_c_f="$1"
|
||||||
|
_sdkey="$2"
|
||||||
|
if [ -f "$_r_c_f" ] ; then
|
||||||
|
(
|
||||||
|
eval $(grep "^$_sdkey *=" "$_r_c_f")
|
||||||
|
eval "printf \"%s\" \"\$$_sdkey\""
|
||||||
|
)
|
||||||
|
else
|
||||||
|
_err "config file is empty, can not read $_sdkey"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#_savedomainconf key value
|
#_savedomainconf key value
|
||||||
#save to domain.conf
|
#save to domain.conf
|
||||||
_savedomainconf() {
|
_savedomainconf() {
|
||||||
_sdkey="$1"
|
_save_conf "$DOMAIN_CONF" "$1" "$2"
|
||||||
_sdvalue="$2"
|
|
||||||
if [ "$DOMAIN_CONF" ] ; then
|
|
||||||
_setopt "$DOMAIN_CONF" "$_sdkey" "=" "\"$_sdvalue\""
|
|
||||||
else
|
|
||||||
_err "DOMAIN_CONF is empty, can not save $_sdkey=$_sdvalue"
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#_cleardomainconf key
|
#_cleardomainconf key
|
||||||
_cleardomainconf() {
|
_cleardomainconf() {
|
||||||
_sdkey="$1"
|
_clear_conf "$DOMAIN_CONF" "$1"
|
||||||
if [ "$DOMAIN_CONF" ] ; then
|
|
||||||
_sed_i "s/^$_sdkey.*$//" "$DOMAIN_CONF"
|
|
||||||
else
|
|
||||||
_err "DOMAIN_CONF is empty, can not save $_sdkey=$value"
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#_readdomainconf key
|
#_readdomainconf key
|
||||||
_readdomainconf() {
|
_readdomainconf() {
|
||||||
_sdkey="$1"
|
_read_conf "$DOMAIN_CONF" "$1"
|
||||||
if [ "$DOMAIN_CONF" ] ; then
|
|
||||||
(
|
|
||||||
eval $(grep "^$_sdkey *=" "$DOMAIN_CONF")
|
|
||||||
eval "printf \"%s\" \"\$$_sdkey\""
|
|
||||||
)
|
|
||||||
else
|
|
||||||
_err "DOMAIN_CONF is empty, can not read $_sdkey"
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#_saveaccountconf key value
|
#_saveaccountconf key value
|
||||||
_saveaccountconf() {
|
_saveaccountconf() {
|
||||||
_sckey="$1"
|
_save_conf "$ACCOUNT_CONF_PATH" "$1" "$2"
|
||||||
_scvalue="$2"
|
|
||||||
if [ "$ACCOUNT_CONF_PATH" ] ; then
|
|
||||||
_setopt "$ACCOUNT_CONF_PATH" "$_sckey" "=" "'$_scvalue'"
|
|
||||||
else
|
|
||||||
_err "ACCOUNT_CONF_PATH is empty, can not save $_sckey=$_scvalue"
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#_clearaccountconf key
|
#_clearaccountconf key
|
||||||
_clearaccountconf() {
|
_clearaccountconf() {
|
||||||
_scvalue="$1"
|
_clear_conf "$ACCOUNT_CONF_PATH" "$1"
|
||||||
if [ "$ACCOUNT_CONF_PATH" ] ; then
|
}
|
||||||
_sed_i "s/^$_scvalue.*$//" "$ACCOUNT_CONF_PATH"
|
|
||||||
else
|
#_savecaconf key value
|
||||||
_err "ACCOUNT_CONF_PATH is empty, can not clear $_scvalue"
|
_savecaconf() {
|
||||||
fi
|
_save_conf "$CA_CONF" "$1" "$2"
|
||||||
|
}
|
||||||
|
|
||||||
|
#_readcaconf key
|
||||||
|
_readcaconf() {
|
||||||
|
_read_conf "$CA_CONF" "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
#_clearaccountconf key
|
||||||
|
_clearcaconf() {
|
||||||
|
_clear_conf "$CA_CONF" "$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
# content localaddress
|
# content localaddress
|
||||||
@ -2047,6 +2072,10 @@ registeraccount() {
|
|||||||
_regAccount
|
_regAccount
|
||||||
}
|
}
|
||||||
|
|
||||||
|
__calcAccountKeyHash() {
|
||||||
|
cat "$ACCOUNT_KEY_PATH" | _digest sha256
|
||||||
|
}
|
||||||
|
|
||||||
_regAccount() {
|
_regAccount() {
|
||||||
_initpath
|
_initpath
|
||||||
|
|
||||||
@ -2131,6 +2160,10 @@ _regAccount() {
|
|||||||
fi
|
fi
|
||||||
if [ "$code" = '202' ] ; then
|
if [ "$code" = '202' ] ; then
|
||||||
_info "Update success."
|
_info "Update success."
|
||||||
|
|
||||||
|
CA_KEY_HASH="$(__calcAccountKeyHash)"
|
||||||
|
_debug "Calc CA_KEY_HASH" "$CA_KEY_HASH"
|
||||||
|
_savecaconf CA_KEY_HASH "$CA_KEY_HASH"
|
||||||
else
|
else
|
||||||
_err "Update account error."
|
_err "Update account error."
|
||||||
return 1
|
return 1
|
||||||
@ -2280,11 +2313,15 @@ issue() {
|
|||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if ! _regAccount ; then
|
_saved_account_key_hash="$(_readcaconf "CA_KEY_HASH")"
|
||||||
_on_issue_err
|
_debug2 _saved_account_key_hash "$_saved_account_key_hash"
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
if [ -z "$_saved_account_key_hash" ] || [ "$_saved_account_key_hash" != "$(__calcAccountKeyHash)" ] ; then
|
||||||
|
if ! _regAccount ; then
|
||||||
|
_on_issue_err
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
if [ -f "$CSR_PATH" ] && [ ! -f "$CERT_KEY_PATH" ] ; then
|
if [ -f "$CSR_PATH" ] && [ ! -f "$CERT_KEY_PATH" ] ; then
|
||||||
_info "Signing from existing CSR."
|
_info "Signing from existing CSR."
|
||||||
|
Loading…
x
Reference in New Issue
Block a user