mirror of
https://github.com/mag37/dockcheck.git
synced 2026-04-19 19:07:50 +00:00
Compare commits
14 Commits
v0.7.5
...
160f4a2c5f
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
160f4a2c5f | ||
|
|
85e2b2c02c | ||
|
|
644cbaedd1 | ||
|
|
eeb719296d | ||
|
|
9c44a5176d | ||
|
|
e191971933 | ||
|
|
c3c7206622 | ||
|
|
c1124676d1 | ||
|
|
6576a36fda | ||
|
|
42d35b7a03 | ||
|
|
fc58962f79 | ||
|
|
ff2006437f | ||
|
|
ac98e81172 | ||
|
|
6fefcbc3dd |
91
dockcheck.sh
91
dockcheck.sh
@@ -42,6 +42,7 @@ Help() {
|
|||||||
echo "-h Print this Help."
|
echo "-h Print this Help."
|
||||||
echo "-i Inform - send a preconfigured notification."
|
echo "-i Inform - send a preconfigured notification."
|
||||||
echo "-I Prints custom releasenote urls alongside each container with updates in CLI output (requires urls.list)."
|
echo "-I Prints custom releasenote urls alongside each container with updates in CLI output (requires urls.list)."
|
||||||
|
echo "-k N Number of days to store image backups before pruning - this also enables the backup function."
|
||||||
echo "-l Only include containers with label set. See readme."
|
echo "-l Only include containers with label set. See readme."
|
||||||
echo "-m Monochrome mode, no printf colour codes and hides progress bar."
|
echo "-m Monochrome mode, no printf colour codes and hides progress bar."
|
||||||
echo "-M Prints custom releasenote urls as markdown (requires template support)."
|
echo "-M Prints custom releasenote urls as markdown (requires template support)."
|
||||||
@@ -77,6 +78,7 @@ Stopped=${Stopped:-""}
|
|||||||
CollectorTextFileDirectory=${CollectorTextFileDirectory:-}
|
CollectorTextFileDirectory=${CollectorTextFileDirectory:-}
|
||||||
Exclude=${Exclude:-}
|
Exclude=${Exclude:-}
|
||||||
DaysOld=${DaysOld:-}
|
DaysOld=${DaysOld:-}
|
||||||
|
DaysKept=${DaysKept:-}
|
||||||
OnlySpecific=${OnlySpecific:-false}
|
OnlySpecific=${OnlySpecific:-false}
|
||||||
SpecificContainer=${SpecificContainer:-""}
|
SpecificContainer=${SpecificContainer:-""}
|
||||||
SkipRecreate=${SkipRecreate:-false}
|
SkipRecreate=${SkipRecreate:-false}
|
||||||
@@ -97,7 +99,11 @@ 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:R" options; do
|
# Timestamps
|
||||||
|
RunTimestamp=$(date +'%Y-%m-%d_%H%M')
|
||||||
|
RunEpoch=$(date +'%s')
|
||||||
|
|
||||||
|
while getopts "ayfFhiIlmMnprsuvc:e:d:k: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}" ;;
|
||||||
@@ -107,6 +113,7 @@ while getopts "ayfFhiIlmMnprsuvc:e:d:t:x:R" options; do
|
|||||||
F) OnlySpecific=true ;;
|
F) OnlySpecific=true ;;
|
||||||
i) Notify=true ;;
|
i) Notify=true ;;
|
||||||
I) PrintReleaseURL=true ;;
|
I) PrintReleaseURL=true ;;
|
||||||
|
k) DaysKept="${OPTARG}" ;;
|
||||||
l) OnlyLabel=true ;;
|
l) OnlyLabel=true ;;
|
||||||
m) MonoMode=true ;;
|
m) MonoMode=true ;;
|
||||||
M) PrintMarkdownURL=true ;;
|
M) PrintMarkdownURL=true ;;
|
||||||
@@ -156,6 +163,12 @@ if [[ -n "$DaysOld" ]]; then
|
|||||||
exit 2
|
exit 2
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
if [[ -n "$DaysKept" ]]; then
|
||||||
|
if ! [[ $DaysKept =~ ^[0-9]+$ ]]; then
|
||||||
|
printf "-k argument given (%s) is not a number.\n" "$DaysKept"
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
fi
|
||||||
if [[ -n "$CollectorTextFileDirectory" ]]; then
|
if [[ -n "$CollectorTextFileDirectory" ]]; then
|
||||||
if ! [[ -d $CollectorTextFileDirectory ]]; then
|
if ! [[ -d $CollectorTextFileDirectory ]]; then
|
||||||
printf "The directory (%s) does not exist.\n" "$CollectorTextFileDirectory"
|
printf "The directory (%s) does not exist.\n" "$CollectorTextFileDirectory"
|
||||||
@@ -196,11 +209,11 @@ self_update() {
|
|||||||
printf "\n%s\n" "Pulling the latest version."
|
printf "\n%s\n" "Pulling the latest version."
|
||||||
git pull --force || { printf "%bGit error,%b manually pull/clone.\n" "$c_red" "$c_reset"; return; }
|
git pull --force || { printf "%bGit error,%b manually pull/clone.\n" "$c_red" "$c_reset"; return; }
|
||||||
printf "\n%s\n" "--- starting over with the updated version ---"
|
printf "\n%s\n" "--- starting over with the updated version ---"
|
||||||
cd - || { printf "%bPath error.%b\n" "$c_red"; return; }
|
cd - || { printf "%bPath error.%b\n" "$c_red" "$c_reset"; return; }
|
||||||
exec "$ScriptPath" "${ScriptArgs[@]}" # run the new script with old arguments
|
exec "$ScriptPath" "${ScriptArgs[@]}" # run the new script with old arguments
|
||||||
exit 0 # exit the old instance
|
exit 0 # exit the old instance
|
||||||
else
|
else
|
||||||
cd - || { printf "%bPath error.%b\n" "$c_red"; return; }
|
cd - || { printf "%bPath error.%b\n" "$c_red" "$c_reset"; return; }
|
||||||
self_update_curl
|
self_update_curl
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@@ -228,10 +241,11 @@ choosecontainers() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
datecheck() {
|
datecheck() {
|
||||||
ImageDate=$("$regbin" -v error image inspect "$RepoUrl" --format='{{.Created}}' | cut -d" " -f1)
|
ImageDate="$1"
|
||||||
|
DaysMax="$2"
|
||||||
ImageEpoch=$(date -d "$ImageDate" +%s 2>/dev/null) || ImageEpoch=$(date -f "%Y-%m-%d" -j "$ImageDate" +%s)
|
ImageEpoch=$(date -d "$ImageDate" +%s 2>/dev/null) || ImageEpoch=$(date -f "%Y-%m-%d" -j "$ImageDate" +%s)
|
||||||
ImageAge=$(( ( $(date +%s) - ImageEpoch )/86400 ))
|
ImageAge=$(( ( RunEpoch - ImageEpoch )/86400 ))
|
||||||
if [[ "$ImageAge" -gt "$DaysOld" ]]; then
|
if [[ "$ImageAge" -gt "$DaysMax" ]]; then
|
||||||
return 0
|
return 0
|
||||||
else
|
else
|
||||||
return 1
|
return 1
|
||||||
@@ -443,7 +457,7 @@ check_image() {
|
|||||||
if [[ "$LocalHash" == *"$RegHash"* ]]; then
|
if [[ "$LocalHash" == *"$RegHash"* ]]; then
|
||||||
printf "%s\n" "NoUpdates $i"
|
printf "%s\n" "NoUpdates $i"
|
||||||
else
|
else
|
||||||
if [[ -n "${DaysOld:-}" ]] && ! datecheck; then
|
if [[ -n "${DaysOld:-}" ]] && ! datecheck $("$regbin" -v error image inspect "$RepoUrl" --format='{{.Created}}' | cut -d" " -f1) "$DaysOld" ; then
|
||||||
printf "%s\n" "NoUpdates +$i ${ImageAge}d"
|
printf "%s\n" "NoUpdates +$i ${ImageAge}d"
|
||||||
else
|
else
|
||||||
printf "%s\n" "GotUpdates $i"
|
printf "%s\n" "GotUpdates $i"
|
||||||
@@ -457,7 +471,7 @@ check_image() {
|
|||||||
# Make required functions and variables available to subprocesses
|
# Make required functions and variables available to subprocesses
|
||||||
export -f check_image datecheck
|
export -f check_image datecheck
|
||||||
export Excludes_string="${Excludes[*]:-}" # Can only export scalar variables
|
export Excludes_string="${Excludes[*]:-}" # Can only export scalar variables
|
||||||
export t_out regbin RepoUrl DaysOld DRunUp jqbin OnlyLabel
|
export t_out regbin RepoUrl DaysOld DRunUp jqbin OnlyLabel RunTimestamp RunEpoch
|
||||||
|
|
||||||
# Check for POSIX xargs with -P option, fallback without async
|
# Check for POSIX xargs with -P option, fallback without async
|
||||||
if (echo "test" | xargs -P 2 >/dev/null 2>&1) && [[ "$MaxAsync" != 0 ]]; then
|
if (echo "test" | xargs -P 2 >/dev/null 2>&1) && [[ "$MaxAsync" != 0 ]]; then
|
||||||
@@ -540,11 +554,23 @@ if [[ -n "${GotUpdates:-}" ]]; then
|
|||||||
for i in "${SelectedUpdates[@]}"; do
|
for i in "${SelectedUpdates[@]}"; do
|
||||||
((CurrentQue+=1))
|
((CurrentQue+=1))
|
||||||
printf "\n%bNow updating (%s/%s): %b%s%b\n" "$c_teal" "$CurrentQue" "$NumberofUpdates" "$c_blue" "$i" "$c_reset"
|
printf "\n%bNow updating (%s/%s): %b%s%b\n" "$c_teal" "$CurrentQue" "$NumberofUpdates" "$c_blue" "$i" "$c_reset"
|
||||||
ContLabels=$(docker inspect "$i" --format '{{json .Config.Labels}}')
|
ContConfig=$(docker inspect "$i" --format '{{json .}}')
|
||||||
ContImage=$(docker inspect "$i" --format='{{.Config.Image}}')
|
ContImage=$($jqbin -r '."Config"."Image"' <<< "$ContConfig")
|
||||||
ContPath=$($jqbin -r '."com.docker.compose.project.working_dir"' <<< "$ContLabels")
|
ImageId=$($jqbin -r '."Image"' <<< "$ContConfig")
|
||||||
|
ContPath=$($jqbin -r '."Config"."Labels"."com.docker.compose.project.working_dir"' <<< "$ContConfig")
|
||||||
[[ "$ContPath" == "null" ]] && ContPath=""
|
[[ "$ContPath" == "null" ]] && ContPath=""
|
||||||
|
|
||||||
|
# Add new backup tag prior to pulling if option is set
|
||||||
|
if [[ -n "${DaysKept:-}" ]]; then
|
||||||
|
ContRepoDigests=$(docker image inspect "$ImageId" --format "{{index .RepoDigests 0}}")
|
||||||
|
ContRepo=${ContImage%:*}
|
||||||
|
ContApp=${ContRepo#*/}
|
||||||
|
[[ "$ContImage" =~ ":" ]] && ContTag=${ContImage#*:} || ContTag="latest"
|
||||||
|
BackupName="dockcheck/${ContApp}:${RunTimestamp}_${ContTag}"
|
||||||
|
docker tag "$ImageId" "$BackupName"
|
||||||
|
printf "%b%s backed up as %s%b\n" "$c_teal" "$i" "$BackupName" "$c_reset"
|
||||||
|
fi
|
||||||
|
|
||||||
# Checking if compose-values are empty - hence started with docker run
|
# Checking if compose-values are empty - hence started with docker run
|
||||||
if [[ -z "$ContPath" ]]; then
|
if [[ -z "$ContPath" ]]; then
|
||||||
if [[ "$DRunUp" == true ]]; then
|
if [[ "$DRunUp" == true ]]; then
|
||||||
@@ -556,7 +582,13 @@ if [[ -n "${GotUpdates:-}" ]]; then
|
|||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
|
||||||
docker pull "$ContImage" || { printf "\n%bDocker error, exiting!%b\n" "$c_red" "$c_reset" ; exit 1; }
|
if docker pull "$ContImage"; then
|
||||||
|
# Removal of the <none>-tag image left behind from backup
|
||||||
|
[[ -n "${DaysKept:-}" ]] && docker rmi "$ContRepoDigests"
|
||||||
|
else
|
||||||
|
printf "\n%bDocker error, exiting!%b\n" "$c_red" "$c_reset" ; exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
done
|
done
|
||||||
printf "\n%bDone pulling updates.%b\n" "$c_green" "$c_reset"
|
printf "\n%bDone pulling updates.%b\n" "$c_green" "$c_reset"
|
||||||
|
|
||||||
@@ -569,8 +601,8 @@ if [[ -n "${GotUpdates:-}" ]]; then
|
|||||||
((CurrentQue+=1))
|
((CurrentQue+=1))
|
||||||
unset CompleteConfs
|
unset CompleteConfs
|
||||||
# Extract labels and metadata
|
# Extract labels and metadata
|
||||||
ContLabels=$(docker inspect "$i" --format '{{json .Config.Labels}}')
|
ContConfig=$(docker inspect "$i" --format '{{json .}}')
|
||||||
ContImage=$(docker inspect "$i" --format='{{.Config.Image}}')
|
ContLabels=$($jqbin -r '."Config"."Labels"' <<< "$ContConfig")
|
||||||
ContPath=$($jqbin -r '."com.docker.compose.project.working_dir"' <<< "$ContLabels")
|
ContPath=$($jqbin -r '."com.docker.compose.project.working_dir"' <<< "$ContLabels")
|
||||||
[[ "$ContPath" == "null" ]] && ContPath=""
|
[[ "$ContPath" == "null" ]] && ContPath=""
|
||||||
ContConfigFile=$($jqbin -r '."com.docker.compose.project.config_files"' <<< "$ContLabels")
|
ContConfigFile=$($jqbin -r '."com.docker.compose.project.config_files"' <<< "$ContLabels")
|
||||||
@@ -610,14 +642,39 @@ if [[ -n "${GotUpdates:-}" ]]; then
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
printf "\n%bAll updates done!%b\n" "$c_green" "$c_reset"
|
||||||
|
|
||||||
|
# Clean up old backup image tags if -k is used
|
||||||
|
if [[ -n "${DaysKept:-}" ]]; then
|
||||||
|
IFS=$'\n'
|
||||||
|
CleanupCount=0
|
||||||
|
for backup_img in $(docker images --format "{{.Repository}} {{.Tag}}" | sed -n '/^dockcheck/p'); do
|
||||||
|
repo_name=${backup_img% *}
|
||||||
|
backup_tag=${backup_img#* }
|
||||||
|
backup_date=${backup_tag%%_*}
|
||||||
|
# UNTAGGING HERE
|
||||||
|
if datecheck "$backup_date" "$DaysKept"; then
|
||||||
|
[[ "$CleanupCount" == 0 ]] && echo "Removing backed up images older then $DaysKept days."
|
||||||
|
docker rmi "${repo_name}:${backup_tag}" && ((CleanupCount+=1))
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
unset IFS
|
||||||
|
if [[ "$CleanupCount" == 0 ]]; then
|
||||||
|
printf "\nNo backup images to remove.\n"
|
||||||
|
else
|
||||||
|
printf "\n%b%s%b backup images removed.%b\n" "$c_green" "$CleanupCount" "$c_teal" "$c_reset"
|
||||||
|
docker image prune -f
|
||||||
|
fi
|
||||||
|
else
|
||||||
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"
|
fi
|
||||||
|
|
||||||
else
|
else
|
||||||
printf "\nNo updates installed, exiting.\n"
|
printf "\nNo updates installed.\n"
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
printf "\nNo updates available, exiting.\n"
|
printf "\nNo updates available.\n"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
exit 0
|
exit 0
|
||||||
|
|||||||
Reference in New Issue
Block a user