Compare commits

..

8 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
4 changed files with 38 additions and 46 deletions

View File

@@ -8,6 +8,10 @@ ___
Running docker (duh) and compose, either standalone or plugin. 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`) `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` ## `dockcheck.sh`
```bash ```bash
$ ./dockcheck.sh -h $ ./dockcheck.sh -h
@@ -20,10 +24,6 @@ Options:
-n No updates, only checking availability. -n No updates, only checking availability.
``` ```
![](https://github.com/mag37/dockcheck/blob/main/example.gif)
Basic example: Basic example:
```bash ```bash
$ ./dockcheck.sh $ ./dockcheck.sh
@@ -39,28 +39,13 @@ Containers with updates available:
3) whoogle-search 3) whoogle-search
Do you want to update? y/[n] y Choose what containers to update:
What containers do you like to update? Enter number(s) separated by comma, [q] to quit: 1,3
Enter number(s) separated by comma: 1,3
``` ```
Then it proceedes to run `pull` and `up -d` on every container with updates. 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: ### :beetle: Squashed Bugs:
- ~~No options for running without updates or auto update.~~ - ~~No options for running without updates or auto update.~~
- ~~No filter to check only specific containers.~~ - ~~No filter to check only specific containers.~~
@@ -71,6 +56,7 @@ No updates installed, exiting
- ~~Lists are not alphabetically sorted (due to stacks and other parameters)~~ - ~~Lists are not alphabetically sorted (due to stacks and other parameters)~~
- ~~Old `docker-compose` binary-check sometimes returned false error~~ - ~~Old `docker-compose` binary-check sometimes returned false error~~
- ~~Stacks gets updated as whole, even if only one service is chosen.~~ - ~~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 ### :hammer: Known issues
- ~~No granular choice of what to update (except initial name filter).~~ - ~~No granular choice of what to update (except initial name filter).~~

View File

@@ -1,5 +1,5 @@
#!/bin/bash #!/bin/bash
VERSION="v0.1.4" VERSION="v0.1.5"
Github="https://github.com/mag37/dockcheck" Github="https://github.com/mag37/dockcheck"
### Check if there's a new release of the script: ### Check if there's a new release of the script:
@@ -140,10 +140,17 @@ if [ -n "$GotUpdates" ] ; then
if [ "$UpdYes" == "${UpdYes#[Nn]}" ] ; then if [ "$UpdYes" == "${UpdYes#[Nn]}" ] ; then
for i in "${SelectedUpdates[@]}" for i in "${SelectedUpdates[@]}"
do do
ContPath=$(docker inspect "$i" --format '{{ index .Config.Labels "com.docker.compose.project.config_files" }}') 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" }}') ContName=$(docker inspect "$i" --format '{{ index .Config.Labels "com.docker.compose.service" }}')
$DockerBin -f "$ContPath" pull "$ContName" ### Checking if "com.docker.compose.project.config_files" returns the full path to the config file or just the file name
$DockerBin -f "$ContPath" up -d "$ContName" if [[ $ContConfigFile = '/'* ]] ; then
ComposeFile="$ContConfigFile"
else
ComposeFile="$ContPath/$ContConfigFile"
fi
$DockerBin -f "$ComposeFile" pull "$ContName"
$DockerBin -f "$ComposeFile" up -d "$ContName"
done done
else else
printf "\nNo updates installed, exiting.\n" printf "\nNo updates installed, exiting.\n"
@@ -153,4 +160,3 @@ else
fi fi
exit 0 exit 0

View File

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

Binary file not shown.

Before

Width:  |  Height:  |  Size: 510 KiB

After

Width:  |  Height:  |  Size: 345 KiB