Merge branch 'main' into dev
This commit is contained in:
commit
235b0fbbb2
2 changed files with 16 additions and 10 deletions
12
README.md
12
README.md
|
@ -9,7 +9,7 @@ This is a python script designed to automatically create albums in [Immich](http
|
||||||
This is useful for automatically creating and populating albums for external libraries.
|
This is useful for automatically creating and populating albums for external libraries.
|
||||||
Using the provided docker image, the script can simply be added to the Immich compose stack and run along the rest of Immich's containers.
|
Using the provided docker image, the script can simply be added to the Immich compose stack and run along the rest of Immich's containers.
|
||||||
|
|
||||||
__Current compatibility:__ Immich v1.111.x and below
|
__Current compatibility:__ Immich v1.112.x and below
|
||||||
|
|
||||||
## Disclaimer
|
## Disclaimer
|
||||||
This script is mostly based on the following original script: [REDVM/immich_auto_album.py](https://gist.github.com/REDVM/d8b3830b2802db881f5b59033cf35702)
|
This script is mostly based on the following original script: [REDVM/immich_auto_album.py](https://gist.github.com/REDVM/d8b3830b2802db881f5b59033cf35702)
|
||||||
|
@ -221,7 +221,7 @@ Albums created for `root_path = /external_libs/photos/Birthdays`:
|
||||||
|
|
||||||
### Album Level Ranges
|
### Album Level Ranges
|
||||||
|
|
||||||
It is possible to specify not just a nunmber for `album-levels`, but a range from level x to level y in the folder structure that should make up an album's name:
|
It is possible to specify not just a number for `--album-levels`, but a range from level x to level y in the folder structure that should make up an album's name:
|
||||||
`--album-levels="2,3"`
|
`--album-levels="2,3"`
|
||||||
The range is applied to the folder structure beneath `root_path` from the top for positive levels and from the bottom for negative levels.
|
The range is applied to the folder structure beneath `root_path` from the top for positive levels and from the bottom for negative levels.
|
||||||
Suppose the following folder structure for an external library with the script's `root_path` set to `/external_libs/photos`:
|
Suppose the following folder structure for an external library with the script's `root_path` set to `/external_libs/photos`:
|
||||||
|
@ -236,13 +236,15 @@ Albums created for `root_path = /external_libs/photos/Birthdays`:
|
||||||
- `2020 02 Feb`
|
- `2020 02 Feb`
|
||||||
- `2020 08 Aug`
|
- `2020 08 Aug`
|
||||||
|
|
||||||
⚠️ Note that with negative `album-levels` or album level ranges, images from different parent folders will be mixed in the same album if they reside in sub-folders with the same name (see `Vacation` in example above).
|
⚠️ __Important:__ When passing negative ranges as album levels, you __must__ pass the argument in the form `--album-levels="-2,-2"`. Emphasis is on the equals sign `=` separating the option from the value. Otherwise, you might get an error `argument -a/--album-levels: expected one argument`!
|
||||||
|
|
||||||
|
⚠️ __Attention:__ Note that with negative `album-levels` or album level ranges, images from different parent folders will be mixed in the same album if they reside in sub-folders with the same name (see `Vacation` in example above).
|
||||||
|
|
||||||
Since Immich does not support real nested albums ([yet?](https://github.com/immich-app/immich/discussions/2073)), neither does this script.
|
Since Immich does not support real nested albums ([yet?](https://github.com/immich-app/immich/discussions/2073)), neither does this script.
|
||||||
|
|
||||||
## Cleaning Up Albums
|
## Cleaning Up Albums
|
||||||
|
|
||||||
The script supports differnt run modes (option -m/--mode or env variable `MODE` for Docker). The default mode is `CREATE`, which is used to create albums.
|
The script supports differnt run modes (option `-m`/`--mode` or env variable `MODE` for Docker). The default mode is `CREATE`, which is used to create albums.
|
||||||
The other two modes are `CLEANUP` and `DELETE_ALL`:
|
The other two modes are `CLEANUP` and `DELETE_ALL`:
|
||||||
- `CLEANUP`: The script will generate album names using the script's arguments and the assets found in Immich, but instead of creating the albums, it will delete them (if they exist). This is useful if a large number of albums was created with no/the wrong `--album-separator` or `--album-levels` settings.
|
- `CLEANUP`: The script will generate album names using the script's arguments and the assets found in Immich, but instead of creating the albums, it will delete them (if they exist). This is useful if a large number of albums was created with no/the wrong `--album-separator` or `--album-levels` settings.
|
||||||
- `DELETE_ALL`: ⚠️ As the name suggests, this mode blindly deletes ALL albums from Immich. Use with caution!
|
- `DELETE_ALL`: ⚠️ As the name suggests, this mode blindly deletes ALL albums from Immich. Use with caution!
|
||||||
|
@ -251,4 +253,4 @@ To prevent accidental deletions, setting the mode to `CLEANUP` or `DELETE_ALL` a
|
||||||
To actually delete albums, the option `-d/--delete-confirm` (or env variable `DELETE_CONFIRM` for Docker) must be set.
|
To actually delete albums, the option `-d/--delete-confirm` (or env variable `DELETE_CONFIRM` for Docker) must be set.
|
||||||
|
|
||||||
__WARNING ⚠️__
|
__WARNING ⚠️__
|
||||||
Deleting albums cannot be undone! The only option is to let the script run again and create new albums base on the passed arguments and current assets in Immich.
|
Deleting albums cannot be undone! The only option is to let the script run again and create new albums base on the passed arguments and current assets in Immich.
|
||||||
|
|
14
docker/immich_auto_album.sh
Normal file → Executable file
14
docker/immich_auto_album.sh
Normal file → Executable file
|
@ -1,16 +1,20 @@
|
||||||
#!/usr/bin/env sh
|
#!/usr/bin/env sh
|
||||||
|
|
||||||
# parse comma separated root paths
|
# parse comma separated root paths and wrap in quotes
|
||||||
root_paths=$(echo "$ROOT_PATH" | tr "," "\n")
|
oldIFS=$IFS
|
||||||
|
IFS=','
|
||||||
|
# disable globbing
|
||||||
|
set -f
|
||||||
main_root_path=""
|
main_root_path=""
|
||||||
additional_root_paths=""
|
additional_root_paths=""
|
||||||
for path in ${root_paths}; do
|
for path in ${ROOT_PATH}; do
|
||||||
if [ -z "$main_root_path" ]; then
|
if [ -z "$main_root_path" ]; then
|
||||||
main_root_path="$path"
|
main_root_path="\"$path\""
|
||||||
else
|
else
|
||||||
additional_root_paths="-r $path $additional_root_paths"
|
additional_root_paths="-r \"$path\" $additional_root_paths"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
IFS=$oldIFS
|
||||||
|
|
||||||
unattended=
|
unattended=
|
||||||
if [ ! -z "$UNATTENDED" ]; then
|
if [ ! -z "$UNATTENDED" ]; then
|
||||||
|
|
Loading…
Reference in a new issue