mirror of
https://github.com/mag37/dockcheck.git
synced 2026-04-17 09:57:49 +00:00
New option -R and bugfix + cleanup (#236)
* Cleaned up legacy structure * Add -R flag to skip container recreation after pulling images (#235) * Added new -R option: Skip Container recreation --------- Co-authored-by: mag37 <robin.ivehult@gmail.com> Co-authored-by: NapalmZ <willy.baessato@gmail.com>
This commit is contained in:
12
README.md
12
README.md
@@ -22,6 +22,13 @@
|
|||||||
___
|
___
|
||||||
## Changelog
|
## Changelog
|
||||||
|
|
||||||
|
- **v0.7.4**:
|
||||||
|
- Added new option `-R`:
|
||||||
|
- Will skip container recreation after pulling images.
|
||||||
|
- Allows for more control and possible pipeline integration.
|
||||||
|
- Fixes:
|
||||||
|
- Bugfix for *value too great* error due to leading zeroes - solved with base10 conversion.
|
||||||
|
- Clean up of some legacy readme sections.
|
||||||
- **v0.7.3**: Bugfix - unquoted variable in printf list caused occasional issues.
|
- **v0.7.3**: Bugfix - unquoted variable in printf list caused occasional issues.
|
||||||
- **v0.7.2**:
|
- **v0.7.2**:
|
||||||
- Label rework:
|
- Label rework:
|
||||||
@@ -41,10 +48,6 @@ ___
|
|||||||
- `<channel>_CONTAINERSONLY` : Only notify for docker container related updates
|
- `<channel>_CONTAINERSONLY` : Only notify for docker container related updates
|
||||||
- `<channel>_ALLOWEMPTY` : Always send notifications, even when empty
|
- `<channel>_ALLOWEMPTY` : Always send notifications, even when empty
|
||||||
- `<channel>_OUTPUT` : Define output format
|
- `<channel>_OUTPUT` : Define output format
|
||||||
- **v0.7.0**:
|
|
||||||
- Bugfix: snooze dockcheck.sh-self-notification and some config clarification.
|
|
||||||
- Added authentication support to Ntfy.sh.
|
|
||||||
- Added suport for sendmail in the SMTP-template.
|
|
||||||
___
|
___
|
||||||
|
|
||||||
|
|
||||||
@@ -72,6 +75,7 @@ Options:
|
|||||||
-n No updates, only checking availability.
|
-n No updates, only checking availability.
|
||||||
-p Auto-Prune dangling images after update.
|
-p Auto-Prune dangling images after update.
|
||||||
-r Allow checking for updates/updating images for docker run containers. Won't update the container.
|
-r Allow checking for updates/updating images for docker run containers. Won't update the container.
|
||||||
|
-R Skip container recreation after pulling images.
|
||||||
-s Include stopped containers in the check. (Logic: docker ps -a).
|
-s Include stopped containers in the check. (Logic: docker ps -a).
|
||||||
-t N Set a timeout (in seconds) per container for registry checkups, 10 is default.
|
-t N Set a timeout (in seconds) per container for registry checkups, 10 is default.
|
||||||
-u Allow automatic self updates - caution as this will pull new code and autorun it.
|
-u Allow automatic self updates - caution as this will pull new code and autorun it.
|
||||||
|
|||||||
@@ -19,6 +19,7 @@
|
|||||||
#OnlyLabel=true # Only update if label is set. See readme.
|
#OnlyLabel=true # Only update if label is set. See readme.
|
||||||
#ForceRestartStacks=true # Force stop+start stack after update. Caution: restarts once for every updated container within stack.
|
#ForceRestartStacks=true # Force stop+start stack after update. Caution: restarts once for every updated container within stack.
|
||||||
#DRunUp=true # Allow updating images for docker run, wont update the container.
|
#DRunUp=true # Allow updating images for docker run, wont update the container.
|
||||||
|
#SkipRecreate # Skip container recreation after pulling images.
|
||||||
#MonoMode=true # Monochrome mode, no printf colour codes and hides progress bar.
|
#MonoMode=true # Monochrome mode, no printf colour codes and hides progress bar.
|
||||||
#PrintReleaseURL=true # Prints custom releasenote urls alongside each container with updates (requires urls.list)`
|
#PrintReleaseURL=true # Prints custom releasenote urls alongside each container with updates (requires urls.list)`
|
||||||
#PrintMarkdownURL=true # Prints custom releasenote urls as markdown
|
#PrintMarkdownURL=true # Prints custom releasenote urls as markdown
|
||||||
@@ -89,4 +90,3 @@
|
|||||||
# TELEGRAM_TOPIC_ID="0"
|
# TELEGRAM_TOPIC_ID="0"
|
||||||
#
|
#
|
||||||
# FILE_PATH="${ScriptWorkDir}/updates_available.txt"
|
# FILE_PATH="${ScriptWorkDir}/updates_available.txt"
|
||||||
|
|
||||||
|
|||||||
101
dockcheck.sh
101
dockcheck.sh
@@ -1,6 +1,6 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
VERSION="v0.7.3"
|
VERSION="v0.7.4"
|
||||||
# ChangeNotes: Bugfix - unquoted variable in list. Also: Please consider donating.
|
# ChangeNotes: New option -R to pull without recreation. Fixes: value too great error, legacy cleanups.
|
||||||
Github="https://github.com/mag37/dockcheck"
|
Github="https://github.com/mag37/dockcheck"
|
||||||
RawUrl="https://raw.githubusercontent.com/mag37/dockcheck/main/dockcheck.sh"
|
RawUrl="https://raw.githubusercontent.com/mag37/dockcheck/main/dockcheck.sh"
|
||||||
|
|
||||||
@@ -47,6 +47,7 @@ Help() {
|
|||||||
echo "-M Prints custom releasenote urls as markdown (requires template support)."
|
echo "-M Prints custom releasenote urls as markdown (requires template support)."
|
||||||
echo "-n No updates; only checking availability without interaction."
|
echo "-n No updates; only checking availability without interaction."
|
||||||
echo "-p Auto-prune dangling images after update."
|
echo "-p Auto-prune dangling images after update."
|
||||||
|
echo "-R Skip container recreation after pulling images."
|
||||||
echo "-r Allow checking for updates/updating images for docker run containers. Won't update the container."
|
echo "-r Allow checking for updates/updating images for docker run containers. Won't update the container."
|
||||||
echo "-s Include stopped containers in the check. (Logic: docker ps -a)."
|
echo "-s Include stopped containers in the check. (Logic: docker ps -a)."
|
||||||
echo "-t Set a timeout (in seconds) per container for registry checkups, 10 is default."
|
echo "-t Set a timeout (in seconds) per container for registry checkups, 10 is default."
|
||||||
@@ -78,6 +79,7 @@ Exclude=${Exclude:-}
|
|||||||
DaysOld=${DaysOld:-}
|
DaysOld=${DaysOld:-}
|
||||||
OnlySpecific=${OnlySpecific:-false}
|
OnlySpecific=${OnlySpecific:-false}
|
||||||
SpecificContainer=${SpecificContainer:-""}
|
SpecificContainer=${SpecificContainer:-""}
|
||||||
|
SkipRecreate=${SkipRecreate:-false}
|
||||||
Excludes=()
|
Excludes=()
|
||||||
GotUpdates=()
|
GotUpdates=()
|
||||||
NoUpdates=()
|
NoUpdates=()
|
||||||
@@ -95,7 +97,7 @@ c_blue="\033[0;34m"
|
|||||||
c_teal="\033[0;36m"
|
c_teal="\033[0;36m"
|
||||||
c_reset="\033[0m"
|
c_reset="\033[0m"
|
||||||
|
|
||||||
while getopts "ayfFhiIlmMnprsuvc:e:d:t:x:" options; do
|
while getopts "ayfFhiIlmMnprsuvc:e:d:t:x:R" options; do
|
||||||
case "${options}" in
|
case "${options}" in
|
||||||
a|y) AutoMode=true ;;
|
a|y) AutoMode=true ;;
|
||||||
c) CollectorTextFileDirectory="${OPTARG}" ;;
|
c) CollectorTextFileDirectory="${OPTARG}" ;;
|
||||||
@@ -110,6 +112,7 @@ while getopts "ayfFhiIlmMnprsuvc:e:d:t:x:" options; do
|
|||||||
M) PrintMarkdownURL=true ;;
|
M) PrintMarkdownURL=true ;;
|
||||||
n) DontUpdate=true; AutoMode=true;;
|
n) DontUpdate=true; AutoMode=true;;
|
||||||
p) AutoPrune=true ;;
|
p) AutoPrune=true ;;
|
||||||
|
R) SkipRecreate=true ;;
|
||||||
r) DRunUp=true ;;
|
r) DRunUp=true ;;
|
||||||
s) Stopped="-a" ;;
|
s) Stopped="-a" ;;
|
||||||
t) Timeout="${OPTARG}" ;;
|
t) Timeout="${OPTARG}" ;;
|
||||||
@@ -213,6 +216,7 @@ choosecontainers() {
|
|||||||
else
|
else
|
||||||
ChoiceClean=${Choice//[,.:;]/ }
|
ChoiceClean=${Choice//[,.:;]/ }
|
||||||
for CC in $ChoiceClean; do
|
for CC in $ChoiceClean; do
|
||||||
|
CC=$((10#$CC)) # Base 10 interpretation to strip leading zeroes
|
||||||
if [[ "$CC" -lt 1 || "$CC" -gt $UpdCount ]]; then # Reset choice if out of bounds
|
if [[ "$CC" -lt 1 || "$CC" -gt $UpdCount ]]; then # Reset choice if out of bounds
|
||||||
echo "Number not in list: $CC"; unset ChoiceClean; break 1
|
echo "Number not in list: $CC"; unset ChoiceClean; break 1
|
||||||
else
|
else
|
||||||
@@ -554,53 +558,58 @@ if [[ -n "${GotUpdates:-}" ]]; then
|
|||||||
|
|
||||||
docker pull "$ContImage" || { printf "\n%bDocker error, exiting!%b\n" "$c_red" "$c_reset" ; exit 1; }
|
docker pull "$ContImage" || { printf "\n%bDocker error, exiting!%b\n" "$c_red" "$c_reset" ; exit 1; }
|
||||||
done
|
done
|
||||||
printf "\n%bDone pulling updates. %bRecreating updated containers.%b\n" "$c_green" "$c_blue" "$c_reset"
|
printf "\n%bDone pulling updates.%b\n" "$c_green" "$c_reset"
|
||||||
|
|
||||||
CurrentQue=0
|
if [[ "$SkipRecreate" == true ]]; then
|
||||||
for i in "${SelectedUpdates[@]}"; do
|
printf "%bSkipping container recreation due to -R.%b\n" "$c_yellow" "$c_reset"
|
||||||
((CurrentQue+=1))
|
else
|
||||||
unset CompleteConfs
|
printf "%bRecreating updated containers.%b\n" "$c_blue" "$c_reset"
|
||||||
# Extract labels and metadata
|
CurrentQue=0
|
||||||
ContLabels=$(docker inspect "$i" --format '{{json .Config.Labels}}')
|
for i in "${SelectedUpdates[@]}"; do
|
||||||
ContImage=$(docker inspect "$i" --format='{{.Config.Image}}')
|
((CurrentQue+=1))
|
||||||
ContPath=$($jqbin -r '."com.docker.compose.project.working_dir"' <<< "$ContLabels")
|
unset CompleteConfs
|
||||||
[[ "$ContPath" == "null" ]] && ContPath=""
|
# Extract labels and metadata
|
||||||
ContConfigFile=$($jqbin -r '."com.docker.compose.project.config_files"' <<< "$ContLabels")
|
ContLabels=$(docker inspect "$i" --format '{{json .Config.Labels}}')
|
||||||
[[ "$ContConfigFile" == "null" ]] && ContConfigFile=""
|
ContImage=$(docker inspect "$i" --format='{{.Config.Image}}')
|
||||||
ContName=$($jqbin -r '."com.docker.compose.service"' <<< "$ContLabels")
|
ContPath=$($jqbin -r '."com.docker.compose.project.working_dir"' <<< "$ContLabels")
|
||||||
[[ "$ContName" == "null" ]] && ContName=""
|
[[ "$ContPath" == "null" ]] && ContPath=""
|
||||||
ContEnv=$($jqbin -r '."com.docker.compose.project.environment_file"' <<< "$ContLabels")
|
ContConfigFile=$($jqbin -r '."com.docker.compose.project.config_files"' <<< "$ContLabels")
|
||||||
[[ "$ContEnv" == "null" ]] && ContEnv=""
|
[[ "$ContConfigFile" == "null" ]] && ContConfigFile=""
|
||||||
ContRestartStack=$($jqbin -r '."mag37.dockcheck.restart-stack"' <<< "$ContLabels")
|
ContName=$($jqbin -r '."com.docker.compose.service"' <<< "$ContLabels")
|
||||||
[[ "$ContRestartStack" == "null" ]] && ContRestartStack=""
|
[[ "$ContName" == "null" ]] && ContName=""
|
||||||
ContOnlySpecific=$($jqbin -r '."mag37.dockcheck.only-specific-container"' <<< "$ContLabels")
|
ContEnv=$($jqbin -r '."com.docker.compose.project.environment_file"' <<< "$ContLabels")
|
||||||
[[ "$ContOnlySpecific" == "null" ]] && ContRestartStack=""
|
[[ "$ContEnv" == "null" ]] && ContEnv=""
|
||||||
|
ContRestartStack=$($jqbin -r '."mag37.dockcheck.restart-stack"' <<< "$ContLabels")
|
||||||
|
[[ "$ContRestartStack" == "null" ]] && ContRestartStack=""
|
||||||
|
ContOnlySpecific=$($jqbin -r '."mag37.dockcheck.only-specific-container"' <<< "$ContLabels")
|
||||||
|
[[ "$ContOnlySpecific" == "null" ]] && ContRestartStack=""
|
||||||
|
|
||||||
printf "\n%bNow recreating (%s/%s): %b%s%b\n" "$c_teal" "$CurrentQue" "$NumberofUpdates" "$c_blue" "$i" "$c_reset"
|
printf "\n%bNow recreating (%s/%s): %b%s%b\n" "$c_teal" "$CurrentQue" "$NumberofUpdates" "$c_blue" "$i" "$c_reset"
|
||||||
# Checking if compose-values are empty - hence started with docker run
|
# Checking if compose-values are empty - hence started with docker run
|
||||||
[[ -z "$ContPath" ]] && { echo "Not a compose container, skipping."; continue; }
|
[[ -z "$ContPath" ]] && { echo "Not a compose container, skipping."; continue; }
|
||||||
|
|
||||||
# cd to the compose-file directory to account for people who use relative volumes
|
# cd to the compose-file directory to account for people who use relative volumes
|
||||||
cd "$ContPath" || { printf "\n%bPath error - skipping%b %s" "$c_red" "$c_reset" "$i"; continue; }
|
cd "$ContPath" || { printf "\n%bPath error - skipping%b %s" "$c_red" "$c_reset" "$i"; continue; }
|
||||||
## Reformatting path + multi compose
|
## Reformatting path + multi compose
|
||||||
if [[ $ContConfigFile == '/'* ]]; then
|
if [[ $ContConfigFile == '/'* ]]; then
|
||||||
CompleteConfs=$(for conf in ${ContConfigFile//,/ }; do printf -- "-f %s " "$conf"; done)
|
CompleteConfs=$(for conf in ${ContConfigFile//,/ }; do printf -- "-f %s " "$conf"; done)
|
||||||
else
|
else
|
||||||
CompleteConfs=$(for conf in ${ContConfigFile//,/ }; do printf -- "-f %s/%s " "$ContPath" "$conf"; done)
|
CompleteConfs=$(for conf in ${ContConfigFile//,/ }; do printf -- "-f %s/%s " "$ContPath" "$conf"; done)
|
||||||
fi
|
fi
|
||||||
# Check if the container got an environment file set and reformat it
|
# Check if the container got an environment file set and reformat it
|
||||||
ContEnvs=""
|
ContEnvs=""
|
||||||
if [[ -n "$ContEnv" ]]; then ContEnvs=$(for env in ${ContEnv//,/ }; do printf -- "--env-file %s " "$env"; done); fi
|
if [[ -n "$ContEnv" ]]; then ContEnvs=$(for env in ${ContEnv//,/ }; do printf -- "--env-file %s " "$env"; done); fi
|
||||||
# Set variable when compose up should only target the specific container, not the stack
|
# Set variable when compose up should only target the specific container, not the stack
|
||||||
if [[ $OnlySpecific == true ]] || [[ $ContOnlySpecific == true ]]; then SpecificContainer="$ContName"; fi
|
if [[ $OnlySpecific == true ]] || [[ $ContOnlySpecific == true ]]; then SpecificContainer="$ContName"; fi
|
||||||
|
|
||||||
# Check if the whole stack should be restarted
|
# Check if the whole stack should be restarted
|
||||||
if [[ "$ContRestartStack" == true ]] || [[ "$ForceRestartStacks" == true ]]; then
|
if [[ "$ContRestartStack" == true ]] || [[ "$ForceRestartStacks" == true ]]; then
|
||||||
${DockerBin} ${CompleteConfs} stop; ${DockerBin} ${CompleteConfs} ${ContEnvs} up -d || { printf "\n%bDocker error, exiting!%b\n" "$c_red" "$c_reset" ; exit 1; }
|
${DockerBin} ${CompleteConfs} stop; ${DockerBin} ${CompleteConfs} ${ContEnvs} up -d || { printf "\n%bDocker error, exiting!%b\n" "$c_red" "$c_reset" ; exit 1; }
|
||||||
else
|
else
|
||||||
${DockerBin} ${CompleteConfs} ${ContEnvs} up -d ${SpecificContainer} || { printf "\n%bDocker error, exiting!%b\n" "$c_red" "$c_reset" ; exit 1; }
|
${DockerBin} ${CompleteConfs} ${ContEnvs} up -d ${SpecificContainer} || { printf "\n%bDocker error, exiting!%b\n" "$c_red" "$c_reset" ; exit 1; }
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
fi
|
||||||
if [[ "$AutoPrune" == false ]] && [[ "$AutoMode" == false ]]; then printf "\n"; read -rep "Would you like to prune all dangling images? y/[n]: " AutoPrune; fi
|
if [[ "$AutoPrune" == false ]] && [[ "$AutoMode" == false ]]; then printf "\n"; read -rep "Would you like to prune all dangling images? y/[n]: " AutoPrune; fi
|
||||||
if [[ "$AutoPrune" == true ]] || [[ "$AutoPrune" =~ [yY] ]]; then printf "\nAuto pruning.."; docker image prune -f; fi
|
if [[ "$AutoPrune" == true ]] || [[ "$AutoPrune" =~ [yY] ]]; then printf "\nAuto pruning.."; docker image prune -f; fi
|
||||||
printf "\n%bAll done!%b\n" "$c_green" "$c_reset"
|
printf "\n%bAll done!%b\n" "$c_green" "$c_reset"
|
||||||
|
|||||||
@@ -38,35 +38,15 @@ You can also use the [caronc/apprise-api](https://github.com/caronc/apprise-api)
|
|||||||
|
|
||||||
|
|
||||||
### Customize the **notify.sh** file.
|
### Customize the **notify.sh** file.
|
||||||
After you're done with the setup of the container and tried your notifications, you can copy the `notify_apprise.sh` file to `notify.sh` and start editing it.
|
After you're done with the setup of the container and tried your notifications, you need to follow the configuration setup (explained in detail in the README).
|
||||||
|
Briefly: Copy `default.config` to `dockcheck.config` then edit it to change the following, `APPRISE_URL` matching your environment:
|
||||||
|
|
||||||
Comment out/remove the bare metal apprise-command (starting with `apprise -vv -t...`).
|
|
||||||
Uncomment and edit the `AppriseURL` variable and *curl* line
|
|
||||||
It should look something like this when curling the API:
|
|
||||||
```bash
|
```bash
|
||||||
send_notification() {
|
NOTIFY_CHANNELS="apprise"
|
||||||
Updates=("$@")
|
APPRISE_URL="http://apprise.mydomain.tld:1234/notify/apprise"
|
||||||
UpdToString=$( printf "%s\n" "${Updates[@]}" )
|
|
||||||
FromHost=$(hostname)
|
|
||||||
|
|
||||||
printf "\nSending Apprise notification\n"
|
|
||||||
|
|
||||||
MessageTitle="$FromHost - updates available."
|
|
||||||
# Setting the MessageBody variable here.
|
|
||||||
read -d '\n' MessageBody << __EOF
|
|
||||||
Containers on $FromHost with updates available:
|
|
||||||
|
|
||||||
$UpdToString
|
|
||||||
|
|
||||||
__EOF
|
|
||||||
|
|
||||||
AppriseURL="http://IP.or.mydomain.tld:8000/notify/apprise"
|
|
||||||
curl -X POST -F "title=$MessageTitle" -F "body=$MessageBody" -F "tags=all" $AppriseURL
|
|
||||||
|
|
||||||
}
|
|
||||||
```
|
```
|
||||||
|
|
||||||
That's all!
|
That's it!
|
||||||
___
|
___
|
||||||
___
|
___
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user