mirror of
https://github.com/plantroon/acme.sh.git
synced 2024-11-10 00:11:45 +00:00
minor
This commit is contained in:
parent
c60883ef92
commit
bbbdcb091a
54
le.sh
54
le.sh
@ -5,6 +5,8 @@ PROJECT="https://github.com/Neilpang/le"
|
|||||||
DEFAULT_CA="https://acme-v01.api.letsencrypt.org"
|
DEFAULT_CA="https://acme-v01.api.letsencrypt.org"
|
||||||
DEFAULT_AGREEMENT="https://letsencrypt.org/documents/LE-SA-v1.0.1-July-27-2015.pdf"
|
DEFAULT_AGREEMENT="https://letsencrypt.org/documents/LE-SA-v1.0.1-July-27-2015.pdf"
|
||||||
|
|
||||||
|
DEFAULT_USER_AGENT="le.sh client: $PROJECT"
|
||||||
|
|
||||||
STAGE_CA="https://acme-staging.api.letsencrypt.org"
|
STAGE_CA="https://acme-staging.api.letsencrypt.org"
|
||||||
|
|
||||||
VTYPE_HTTP="http-01"
|
VTYPE_HTTP="http-01"
|
||||||
@ -33,7 +35,7 @@ _err() {
|
|||||||
if [ -z "$2" ] ; then
|
if [ -z "$2" ] ; then
|
||||||
echo "$1" >&2
|
echo "$1" >&2
|
||||||
else
|
else
|
||||||
echo "$1"="$2" >&2
|
echo "$1"="'$2'" >&2
|
||||||
fi
|
fi
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
@ -427,22 +429,17 @@ _post() {
|
|||||||
needbase64="$3"
|
needbase64="$3"
|
||||||
|
|
||||||
if _exists "curl" ; then
|
if _exists "curl" ; then
|
||||||
dp="$LE_WORKING_DIR/curl.dump"
|
CURL="$CURL --dump-header $HTTP_HEADER "
|
||||||
CURL="curl --silent --dump-header $HTTP_HEADER "
|
|
||||||
if [ "$DEBUG" ] ; then
|
|
||||||
CURL="$CURL --trace-ascii $dp "
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$needbase64" ] ; then
|
if [ "$needbase64" ] ; then
|
||||||
response="$($CURL -X POST --data "$body" $url | _base64)"
|
response="$($CURL -A "User-Agent: $USER_AGENT" -X POST --data "$body" $url | _base64)"
|
||||||
else
|
else
|
||||||
response="$($CURL -X POST --data "$body" $url)"
|
response="$($CURL -A "User-Agent: $USER_AGENT" -X POST --data "$body" $url)"
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
if [ "$needbase64" ] ; then
|
if [ "$needbase64" ] ; then
|
||||||
response="$(wget -q -S -O - --post-data="$body" $url 2>"$HTTP_HEADER" | _base64)"
|
response="$($WGET -S -O - --user-agent="$USER_AGENT" --post-data="$body" $url 2>"$HTTP_HEADER" | _base64)"
|
||||||
else
|
else
|
||||||
response="$(wget -q -S -O - --post-data="$body" $url 2>"$HTTP_HEADER")"
|
response="$($WGET -S -O - --user-agent="$USER_AGENT" --post-data="$body" $url 2>"$HTTP_HEADER")"
|
||||||
fi
|
fi
|
||||||
_sed_i "s/^ *//g" "$HTTP_HEADER"
|
_sed_i "s/^ *//g" "$HTTP_HEADER"
|
||||||
fi
|
fi
|
||||||
@ -457,15 +454,16 @@ _get() {
|
|||||||
_debug url $url
|
_debug url $url
|
||||||
if _exists "curl" ; then
|
if _exists "curl" ; then
|
||||||
if [ "$onlyheader" ] ; then
|
if [ "$onlyheader" ] ; then
|
||||||
curl -I --silent $url
|
$CURL -I -A "User-Agent: $USER_AGENT" $url
|
||||||
else
|
else
|
||||||
curl --silent $url
|
$CURL -A "User-Agent: $USER_AGENT" $url
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
|
_debug "WGET" "$WGET"
|
||||||
if [ "$onlyheader" ] ; then
|
if [ "$onlyheader" ] ; then
|
||||||
wget -S -q -O /dev/null $url 2>&1 | sed "s/^[ ]*//g"
|
eval $WGET --user-agent=\"$USER_AGENT\" -S -O /dev/null $url 2>&1 | sed 's/^[ ]*//g'
|
||||||
else
|
else
|
||||||
wget -q -O - $url
|
eval $WGET --user-agent=\"$USER_AGENT\" -O - $url
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
ret=$?
|
ret=$?
|
||||||
@ -492,7 +490,7 @@ _send_signed_request() {
|
|||||||
_debug payload64 $payload64
|
_debug payload64 $payload64
|
||||||
|
|
||||||
nonceurl="$API/directory"
|
nonceurl="$API/directory"
|
||||||
nonce="$(_get $nonceurl "onlyheader" | grep -o "Replay-Nonce:.*$" | tr -d "\r\n" | cut -d ' ' -f 2)"
|
nonce="$(_get $nonceurl "onlyheader" | grep -o "Replay-Nonce:.*$" | head -1 | tr -d "\r\n" | cut -d ' ' -f 2)"
|
||||||
|
|
||||||
_debug nonce "$nonce"
|
_debug nonce "$nonce"
|
||||||
|
|
||||||
@ -508,7 +506,7 @@ _send_signed_request() {
|
|||||||
body="{\"header\": $HEADER, \"protected\": \"$protected64\", \"payload\": \"$payload64\", \"signature\": \"$sig\"}"
|
body="{\"header\": $HEADER, \"protected\": \"$protected64\", \"payload\": \"$payload64\", \"signature\": \"$sig\"}"
|
||||||
_debug body "$body"
|
_debug body "$body"
|
||||||
|
|
||||||
HTTP_HEADER="$LE_WORKING_DIR/http.header"
|
|
||||||
response="$(_post "$body" $url "$needbase64" )"
|
response="$(_post "$body" $url "$needbase64" )"
|
||||||
|
|
||||||
responseHeaders="$(cat $HTTP_HEADER)"
|
responseHeaders="$(cat $HTTP_HEADER)"
|
||||||
@ -650,6 +648,23 @@ _initpath() {
|
|||||||
APACHE_CONF_BACKUP_DIR="$LE_WORKING_DIR/"
|
APACHE_CONF_BACKUP_DIR="$LE_WORKING_DIR/"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ -z "$USER_AGENT" ] ; then
|
||||||
|
USER_AGENT="$DEFAULT_USER_AGENT"
|
||||||
|
fi
|
||||||
|
|
||||||
|
HTTP_HEADER="$LE_WORKING_DIR/http.header"
|
||||||
|
|
||||||
|
WGET="wget -q"
|
||||||
|
if [ "$DEBUG" ] ; then
|
||||||
|
WGET="$WGET -d "
|
||||||
|
fi
|
||||||
|
|
||||||
|
dp="$LE_WORKING_DIR/curl.dump"
|
||||||
|
CURL="curl --silent"
|
||||||
|
if [ "$DEBUG" ] ; then
|
||||||
|
CURL="$CURL --trace-ascii $dp "
|
||||||
|
fi
|
||||||
|
|
||||||
domain="$1"
|
domain="$1"
|
||||||
if ! mkdir -p "$LE_WORKING_DIR" ; then
|
if ! mkdir -p "$LE_WORKING_DIR" ; then
|
||||||
_err "Can not craete working dir: $LE_WORKING_DIR"
|
_err "Can not craete working dir: $LE_WORKING_DIR"
|
||||||
@ -1153,7 +1168,7 @@ issue() {
|
|||||||
_send_signed_request "$API/acme/new-cert" "{\"resource\": \"new-cert\", \"csr\": \"$der\"}" "needbase64"
|
_send_signed_request "$API/acme/new-cert" "{\"resource\": \"new-cert\", \"csr\": \"$der\"}" "needbase64"
|
||||||
|
|
||||||
|
|
||||||
Le_LinkCert="$(grep -i -o '^Location.*$' $HTTP_HEADER | tr -d "\r\n" | cut -d " " -f 2)"
|
Le_LinkCert="$(grep -i -o '^Location.*$' $HTTP_HEADER | head -1 | tr -d "\r\n" | cut -d " " -f 2)"
|
||||||
_setopt "$DOMAIN_CONF" "Le_LinkCert" "=" "$Le_LinkCert"
|
_setopt "$DOMAIN_CONF" "Le_LinkCert" "=" "$Le_LinkCert"
|
||||||
|
|
||||||
if [ "$Le_LinkCert" ] ; then
|
if [ "$Le_LinkCert" ] ; then
|
||||||
@ -1176,7 +1191,7 @@ issue() {
|
|||||||
|
|
||||||
_setopt "$DOMAIN_CONF" 'Le_Vlist' '=' "\"\""
|
_setopt "$DOMAIN_CONF" 'Le_Vlist' '=' "\"\""
|
||||||
|
|
||||||
Le_LinkIssuer=$(grep -i '^Link' $HTTP_HEADER | cut -d " " -f 2| cut -d ';' -f 1 | tr -d '<>' )
|
Le_LinkIssuer=$(grep -i '^Link' $HTTP_HEADER | head -1 | cut -d " " -f 2| cut -d ';' -f 1 | tr -d '<>' )
|
||||||
_setopt "$DOMAIN_CONF" "Le_LinkIssuer" "=" "$Le_LinkIssuer"
|
_setopt "$DOMAIN_CONF" "Le_LinkIssuer" "=" "$Le_LinkIssuer"
|
||||||
|
|
||||||
if [ "$Le_LinkIssuer" ] ; then
|
if [ "$Le_LinkIssuer" ] ; then
|
||||||
@ -1423,6 +1438,7 @@ _initconf() {
|
|||||||
|
|
||||||
#ACCOUNT_KEY_HASH=account key hash
|
#ACCOUNT_KEY_HASH=account key hash
|
||||||
|
|
||||||
|
USER_AGENT=\"le.sh client: $PROJECT\"
|
||||||
#dns api
|
#dns api
|
||||||
#######################
|
#######################
|
||||||
#Cloudflare:
|
#Cloudflare:
|
||||||
|
Loading…
Reference in New Issue
Block a user