Compare commits

..

24 Commits

Author SHA1 Message Date
mag37
5ef1236e16 matching main
Updated this alt.version to match the main release.
2023-02-09 19:58:53 +01:00
mag37
8b77b917da bug-squash
Added line about latest bugfix.
Re-ordered and cleaned some.
2023-02-09 19:38:00 +01:00
mag37
5a722e6d40 Merge pull request #12 from nnmalex/main
Merge fixes compatibility with value from `com.docker.compose.project.config_files` not giving full path in some cases, probably due to old `docker-compose` binary.

Thank you **nnmalex** for finding and contributing!
2023-02-09 19:30:32 +01:00
Alex
8b8ac84a44 Update dockcheck.sh
Fixed formatting.
2023-02-09 12:03:27 +00:00
Alex
d5c90fb98d Update dockcheck.sh
Added condition based on the contents of the `com.docker.compose.project.config_files` label.
2023-02-09 12:00:29 +00:00
Alex
4302d45033 Update dockcheck.sh
Adding `docker-config.yaml` file path handling.
2023-02-09 10:33:02 +00:00
mag37
a107c18d5f new example
New example to show the changes.
2023-02-09 10:48:20 +01:00
mag37
dd64079efd Delete example.gif
Replaced with new example-gif
2023-02-09 10:47:59 +01:00
mag37
27e9663167 Merge pull request #11 from mag37/dev
Streamlining selection.
Removing y/n confirmation - instead choose numbers straight away or q/n to quit.
2023-02-07 15:43:01 +01:00
mag37
03a3e49650 Streamlining selection.
No need to choose yes-no before choosing contianers, q/n to quit.
Cleaned some wording and order of messages.
2023-02-07 14:56:18 +01:00
mag37
44f9742bde Update README.md
Added new fixes to the list.
2023-02-04 13:10:03 +01:00
mag37
07a9269e76 fixed typo.
Quoting broke functionality, unquoted.
2023-02-04 12:56:51 +01:00
mag37
3f1be334d5 Merge pull request #10 from mag37/testing
Testing
2023-02-04 12:39:50 +01:00
mag37
dd42100a3d added new update from main
Added the fix to only update the service chosen, not the whole stack. thanx to @maanoobh
2023-02-04 12:35:08 +01:00
mag37
64c1f097b1 Merge pull request #9 from maanoobh/specify-service
Specify which service when pulling the update (to avoid pulling non-chosen containers of the same stack)
2023-02-04 12:30:50 +01:00
Mahmood Alansari
8f37417eab Fixed a bug, the command expects the service name in the file. 2023-02-04 08:42:05 +00:00
Mahmood Alansari
fb44099b0f specify which service to pull and update 2023-02-04 07:57:15 +00:00
mag37
bde81aad22 forgot quoting.
Quote the variables... again.
2023-02-02 22:07:33 +01:00
mag37
08175c87ab added ugly version-check
curl-check on the version in local VS raw on github to let the user know there's a new release.
2023-02-02 22:02:41 +01:00
mag37
a7bfb49fad version-format
Changed Version-format to a variable instead of comment, for future use with version-checking.
2023-02-02 21:29:10 +01:00
mag37
8ae13837f1 cleaning
Securing some variable calls with quoting.
Minor cleaning.
2023-02-02 13:17:15 +01:00
mag37
72a4ab889c quickfix
Removed unnecessary docker-compose binary check - as this should ONLY be used if no composes are used. Not recommended.
2023-02-02 10:13:46 +01:00
mag37
a4f58c317a quickfix
Fixed that (sometimes) calling old `docker-compose` binary returned error.
Thanks [xoseperez](https://github.com/xoseperez) for pointing out.
2023-02-02 10:12:05 +01:00
mag37
67fe04cb64 +webui reference 2023-02-01 20:55:20 +01:00
4 changed files with 64 additions and 70 deletions

View File

@@ -8,6 +8,10 @@ ___
Running docker (duh) and compose, either standalone or plugin.
`regctl` by [regclient](https://github.com/regclient/regclient) (will ask to download `regctl` if not in `PATH` or `PWD`)
___
![](https://github.com/mag37/dockcheck/blob/main/example.gif)
## `dockcheck.sh`
```bash
$ ./dockcheck.sh -h
@@ -20,10 +24,6 @@ Options:
-n No updates, only checking availability.
```
![](https://github.com/mag37/dockcheck/blob/main/example.gif)
Basic example:
```bash
$ ./dockcheck.sh
@@ -39,28 +39,13 @@ Containers with updates available:
3) whoogle-search
Do you want to update? y/[n] y
What containers do you like to update?
Enter number(s) separated by comma: 1,3
Choose what containers to update:
Enter number(s) separated by comma, [q] to quit: 1,3
```
Then it proceedes to run `pull` and `up -d` on every container with updates.
And with `-n` *No updates* and `gl` for `*gl*` filtering:
```bash
$ ./dockcheck.sh -n gl
. . .
Containers with updates available:
whoogle-search
Containers on latest version:
glances
No updates installed, exiting
```
### :beetle: Squashed Bugs:
- ~~No options for running without updates or auto update.~~
- ~~No filter to check only specific containers.~~
@@ -69,6 +54,9 @@ No updates installed, exiting
- ~~Multi-digest images didn't correctly check with registry, giving false positives on updates.~~
- ~~Not working with filenames other than `docker-compose.yml`~~
- ~~Lists are not alphabetically sorted (due to stacks and other parameters)~~
- ~~Old `docker-compose` binary-check sometimes returned false error~~
- ~~Stacks gets updated as whole, even if only one service is chosen.~~
- ~~Path broken occationally (from inspect) - probably due to old docker-compose binary.~~
### :hammer: Known issues
- ~~No granular choice of what to update (except initial name filter).~~
@@ -91,6 +79,8 @@ Updates available for local_nginx.
nginx_reverse is already latest.
Updates available for paperless-ng.
```
## Also check out a spinoff brother-project [Palleri/dockcheck-web](https://github.com/Palleri/dockcheck-web) for a WebUI-front!
---
## Special Thanks:
:bison: [t0rnis](https://github.com/t0rnis)

53
dockcheck.sh Normal file → Executable file
View File

@@ -1,5 +1,10 @@
#!/bin/bash
### VERSION v.0.1.1
VERSION="v0.1.5"
Github="https://github.com/mag37/dockcheck"
### Check if there's a new release of the script:
LatestRelease="$(curl -s -r 0-30 https://raw.githubusercontent.com/mag37/dockcheck/main/dockcheck.sh | sed -n "/VERSION/s/VERSION=//p" | tr -d '"')"
[ "$VERSION" != "$LatestRelease" ] && printf "New version available! Latest: "$LatestRelease" - Local: "$VERSION" \nGrab it here: "$Github" \n\n"
### Help Function:
Help() {
@@ -21,7 +26,7 @@ while getopts "aynh" options; do
done
shift "$((OPTIND-1))"
### Set $1 to a variable for later
### Set $1 to a variable for name filtering later.
SearchName="$1"
### Check if required binary exists in PATH or directory:
@@ -50,7 +55,7 @@ fi
### Check docker compose binary:
if docker compose &> /dev/null ; then
DockerBin="docker compose"
elif docker-compose &> /dev/null; then
elif docker-compose -v &> /dev/null; then
DockerBin="docker-compose"
else
printf "%s\n" "No docker compose binary available, quitting."
@@ -69,21 +74,22 @@ done
### Choose from list -function:
choosecontainers() {
while [[ "$ChoiceClean" =~ [A-Za-z] || -z "$ChoiceClean" ]]; do
printf "What containers do you like to update? \n"
# options
read -p 'Enter number(s) separated by comma (eg. 1,3,4): ' Choice
if [ "$Choice" == "0" ] ; then
SelectedUpdates=( ${NumberedUpdates[@]:1} )
ChoiceClean=$(echo $Choice|sed 's/[,.:;]/ /g')
read -p "Enter number(s) separated by comma, [q] to quit: " Choice
if [[ "$Choice" =~ [qQnN] ]] ; then
exit 0
elif [ "$Choice" == "0" ] ; then
SelectedUpdates=( "${NumberedUpdates[@]:1}" )
ChoiceClean=$(echo "$Choice" |sed 's/[,.:;]/ /g')
else
ChoiceClean=$(echo $Choice|sed 's/[,.:;]/ /g')
ChoiceClean=$(echo "$Choice" |sed 's/[,.:;]/ /g')
for s in $ChoiceClean; do
SelectedUpdates+=( ${NumberedUpdates[$s]} )
SelectedUpdates+=( "${NumberedUpdates[$s]}" )
done
fi
done
printf "\nYou've SelectedUpdates:\n"
printf "\nUpdating containers:\n"
printf "%s\n" "${SelectedUpdates[@]}"
printf "\n"
}
### Check the image-hash of every running container VS the registry
@@ -92,7 +98,7 @@ for i in $(docker ps --filter "name=$SearchName" --format '{{.Names}}') ; do
RepoUrl=$(docker inspect "$i" --format='{{.Config.Image}}')
LocalHash=$(docker image inspect "$RepoUrl" --format '{{.RepoDigests}}')
RegHash=$($regbin image digest --list "$RepoUrl" 2>/dev/null)
# Check if regtcl produces errors - add to GotErrors if so.
# Add container to GotErrors if regctl encounter problems.
if [ $? -eq 0 ] ; then
if [[ "$LocalHash" = *"$RegHash"* ]] ; then NoUpdates+=("$i"); else GotUpdates+=("$i"); fi
else
@@ -126,18 +132,25 @@ fi
### Optionally get updates if there's any
if [ -n "$GotUpdates" ] ; then
if [ -z "$UpdYes" ] ; then
printf "\n\033[36;1mDo you want to update? y/[n]\033[0m "
read UpdYes
[ "$UpdYes" != "${UpdYes#[Yy]}" ] && choosecontainers
printf "\n\033[36;1mChoose what containers to update.\033[0m\n"
choosecontainers
else
SelectedUpdates=( "${GotUpdates[@]}" )
fi
if [ "$UpdYes" != "${UpdYes#[Yy]}" ] ; then
if [ "$UpdYes" == "${UpdYes#[Nn]}" ] ; then
for i in "${SelectedUpdates[@]}"
do
ContPath=$(docker inspect "$i" --format '{{ index .Config.Labels "com.docker.compose.project.config_files"}}')
$DockerBin -f "$ContPath" pull
$DockerBin -f "$ContPath" up -d
ContPath=$(docker inspect "$i" --format '{{ index .Config.Labels "com.docker.compose.project.working_dir" }}')
ContConfigFile=$(docker inspect "$i" --format '{{ index .Config.Labels "com.docker.compose.project.config_files" }}')
ContName=$(docker inspect "$i" --format '{{ index .Config.Labels "com.docker.compose.service" }}')
### Checking if "com.docker.compose.project.config_files" returns the full path to the config file or just the file name
if [[ $ContConfigFile = '/'* ]] ; then
ComposeFile="$ContConfigFile"
else
ComposeFile="$ContPath/$ContConfigFile"
fi
$DockerBin -f "$ComposeFile" pull "$ContName"
$DockerBin -f "$ComposeFile" up -d "$ContName"
done
else
printf "\nNo updates installed, exiting.\n"

View File

@@ -1,10 +1,10 @@
#!/bin/bash
### VERSION v.0.1.1
VERSION="v0.1.5"
Github="https://github.com/mag37/dockcheck"
### DOCKER RUN - VERSION
### WARNING WONT REBUILD CONTAINERS - ONLY GRAB NEW IMAGES
### If running docker compose, use the main version. (recommended!)
### Check if there's a new release of the script:
LatestRelease="$(curl -s -r 0-30 https://raw.githubusercontent.com/mag37/dockcheck/main/dockcheck.sh | sed -n "/VERSION/s/VERSION=//p" | tr -d '"')"
[ "$VERSION" != "$LatestRelease" ] && printf "New version available! Latest: "$LatestRelease" - Local: "$VERSION" \nGrab it here: "$Github" \n\n"
### Help Function:
Help() {
@@ -26,7 +26,7 @@ while getopts "aynh" options; do
done
shift "$((OPTIND-1))"
### Set $1 to a variable for later
### Set $1 to a variable for name filtering later.
SearchName="$1"
### Check if required binary exists in PATH or directory:
@@ -52,15 +52,6 @@ else
exit
fi
fi
### Check docker compose binary:
if docker compose &> /dev/null ; then
DockerBin="docker compose"
elif docker-compose &> /dev/null; then
DockerBin="docker-compose"
else
printf "%s\n" "No docker compose binary available, quitting."
exit
fi
### Numbered List -function:
options() {
@@ -74,21 +65,22 @@ done
### Choose from list -function:
choosecontainers() {
while [[ "$ChoiceClean" =~ [A-Za-z] || -z "$ChoiceClean" ]]; do
printf "What containers do you like to update? \n"
# options
read -p 'Enter number(s) separated by comma (eg. 1,3,4): ' Choice
if [ "$Choice" == "0" ] ; then
SelectedUpdates=( ${NumberedUpdates[@]:1} )
ChoiceClean=$(echo $Choice|sed 's/[,.:;]/ /g')
read -p "Enter number(s) separated by comma, [q] to quit: " Choice
if [[ "$Choice" =~ [qQnN] ]] ; then
exit 0
elif [ "$Choice" == "0" ] ; then
SelectedUpdates=( "${NumberedUpdates[@]:1}" )
ChoiceClean=$(echo "$Choice" |sed 's/[,.:;]/ /g')
else
ChoiceClean=$(echo $Choice|sed 's/[,.:;]/ /g')
ChoiceClean=$(echo "$Choice" |sed 's/[,.:;]/ /g')
for s in $ChoiceClean; do
SelectedUpdates+=( ${NumberedUpdates[$s]} )
SelectedUpdates+=( "${NumberedUpdates[$s]}" )
done
fi
done
printf "\nYou've SelectedUpdates:\n"
printf "\nUpdating containers:\n"
printf "%s\n" "${SelectedUpdates[@]}"
printf "\n"
}
### Check the image-hash of every running container VS the registry
@@ -97,7 +89,7 @@ for i in $(docker ps --filter "name=$SearchName" --format '{{.Names}}') ; do
RepoUrl=$(docker inspect "$i" --format='{{.Config.Image}}')
LocalHash=$(docker image inspect "$RepoUrl" --format '{{.RepoDigests}}')
RegHash=$($regbin image digest --list "$RepoUrl" 2>/dev/null)
# Check if regtcl produces errors - add to GotErrors if so.
# Add container to GotErrors if regctl encounter problems.
if [ $? -eq 0 ] ; then
if [[ "$LocalHash" = *"$RegHash"* ]] ; then NoUpdates+=("$i"); else GotUpdates+=("$i"); fi
else
@@ -131,13 +123,12 @@ fi
### Optionally get updates if there's any
if [ -n "$GotUpdates" ] ; then
if [ -z "$UpdYes" ] ; then
printf "\n\033[36;1mDo you want to update? y/[n]\033[0m "
read UpdYes
[ "$UpdYes" != "${UpdYes#[Yy]}" ] && choosecontainers
printf "\n\033[36;1mChoose what container-images to update.\033[0m\n"
choosecontainers
else
SelectedUpdates=( "${GotUpdates[@]}" )
fi
if [ "$UpdYes" != "${UpdYes#[Yy]}" ] ; then
if [ "$UpdYes" == "${UpdYes#[Nn]}" ] ; then
for i in "${SelectedUpdates[@]}"; do
ContImage=$(docker inspect "$i" --format='{{.Config.Image}}')
docker pull $ContImage

Binary file not shown.

Before

Width:  |  Height:  |  Size: 510 KiB

After

Width:  |  Height:  |  Size: 345 KiB