Enhance check_certificates.sh to initialize output file and improve JSON handling for domain status logging
All checks were successful
continuous-integration/drone/push Build is passing
All checks were successful
continuous-integration/drone/push Build is passing
This commit is contained in:
@@ -21,10 +21,21 @@ LETSENCRYPT_OUTPUT=$LOG_DIR/letsencrypt.json
|
|||||||
DATE=$(date +"%Y-%m-%d-%H-%M")
|
DATE=$(date +"%Y-%m-%d-%H-%M")
|
||||||
|
|
||||||
create_json() {
|
create_json() {
|
||||||
|
|
||||||
|
if [ ! -f $LETSENCRYPT_OUTPUT ]; then
|
||||||
|
install -m 664 -g 65534 /dev/null $LETSENCRYPT_OUTPUT
|
||||||
|
echo '[]' >$LETSENCRYPT_OUTPUT
|
||||||
|
fi
|
||||||
|
|
||||||
LOG=$(cat $LOG_FILE | base64 -w0)
|
LOG=$(cat $LOG_FILE | base64 -w0)
|
||||||
TMP_FILE=$(mktemp)
|
TMP_FILE=$(mktemp)
|
||||||
install -m 664 -g 65534 /dev/null $TMP_FILE
|
jq '
|
||||||
jq 'if . == null or . == [] then [{"'$DOMAIN'": { "date": "'$DATE'", "status": "'$STATUS'", "log": "'$LOG'"}}] else . + [{"'$DOMAIN'":{"date": "'$DATE'", "status": "'$STATUS'", "log": "'$LOG'"}}] end' $LETSENCRYPT_OUTPUT >$TMP_FILE
|
if . == null or . == [] then
|
||||||
|
[{"'$DOMAIN'":{"date": "'$DATE'", "status": "'$STATUS'", "log": "'$LOG'"}}]
|
||||||
|
else
|
||||||
|
(map(select(has("'$DOMAIN'") | not))) + [{"'$DOMAIN'":{"date": "'$DATE'", "status": "'$STATUS'", "log": "'$LOG'"}}]
|
||||||
|
end
|
||||||
|
' $LETSENCRYPT_OUTPUT >$TMP_FILE
|
||||||
cat $TMP_FILE >$LETSENCRYPT_OUTPUT
|
cat $TMP_FILE >$LETSENCRYPT_OUTPUT
|
||||||
rm $TMP_FILE
|
rm $TMP_FILE
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user