Compare commits
5 commits
1397e9c9a3
...
f72ee7c85b
Author | SHA1 | Date | |
---|---|---|---|
![]() |
f72ee7c85b | ||
![]() |
5eac0e8c85 | ||
![]() |
fbee9a32df | ||
![]() |
1bde29bb17 | ||
![]() |
d10f2b1eb3 |
4 changed files with 55 additions and 32 deletions
|
@ -1,7 +1,9 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
USER="$1"
|
USER="$1"
|
||||||
SOURCEPATH="/var/lib/nextcloud/$1/files/$2"
|
|
||||||
|
REL_SOURCE_PATH="/$1/files/$2"
|
||||||
|
ABS_SOURCE_PATH="/var/lib/nextcloud/$1/files/$2"
|
||||||
|
|
||||||
REL_DEST_PATH="/$1/files/$3"
|
REL_DEST_PATH="/$1/files/$3"
|
||||||
ABS_DEST_PATH="/var/lib/nextcloud/$1/files/$3"
|
ABS_DEST_PATH="/var/lib/nextcloud/$1/files/$3"
|
||||||
|
@ -11,30 +13,41 @@ ABS_UNSORTABLE_PATH="/var/lib/nextcloud/$1/files/$4"
|
||||||
|
|
||||||
echo "STARTING..."
|
echo "STARTING..."
|
||||||
|
|
||||||
chown -R www-data:www-data "$SOURCEPATH"
|
chown -R www-data:www-data "$ABS_SOURCE_PATH"
|
||||||
chmod -R 770 "$SOURCEPATH"
|
chmod -R 770 "$ABS_SOURCE_PATH"
|
||||||
|
|
||||||
SCAN="FALSE"
|
SCAN="FALSE"
|
||||||
IFS=$'\n'
|
IFS=$'\n'
|
||||||
for f in `find "$SOURCEPATH" -iname *.PNG -o -iname *.JPG -o -iname *.HEIC -o -iname *.CR2 -o -iname *.CR3 -o -iname *.MP4 -o -iname *.MOV`; do
|
for f in `find "$ABS_SOURCE_PATH" -iname *.PNG -o -iname *.JPG -o -iname *.JPEG -o -iname *.HEIC -o -iname *.CR2 -o -iname *.CR3 -o -iname *.MP4 -o -iname *.MOV`; do
|
||||||
SCAN="TRUE"
|
SCAN="TRUE"
|
||||||
echo "PROCESSING: $f"
|
echo "PROCESSING: $f"
|
||||||
DATE=`exiftool "$f" | grep -m 1 "Create Date"`
|
|
||||||
if ! echo "$DATE" | grep "Create Date" >/dev/null
|
EXIF=`exiftool "$f"`
|
||||||
|
if grep -q '^Create Date' <<< $EXIF
|
||||||
then
|
then
|
||||||
RELPATH=$(realpath --relative-to="$SOURCEPATH" "$f")
|
DATETIME=`grep -m 1 "^Create Date" <<< $EXIF | cut -d: -f2- | xargs`
|
||||||
|
elif grep -q '^File Modification Date' <<< $EXIF
|
||||||
|
then
|
||||||
|
DATETIME=`grep -m 1 '^File Modification Date' <<< $EXIF | cut -d: -f2- | xargs`
|
||||||
|
else
|
||||||
|
RELPATH=$(realpath --relative-to="$ABS_SOURCE_PATH" "$f")
|
||||||
DIRNAME=$(dirname "$ABS_UNSORTABLE_PATH/$RELPATH")
|
DIRNAME=$(dirname "$ABS_UNSORTABLE_PATH/$RELPATH")
|
||||||
echo "UNSORTABLE: $f"
|
echo "UNSORTABLE: $f"
|
||||||
mkdir -p "$DIRNAME"
|
mkdir -p "$DIRNAME"
|
||||||
mv "$f" "$DIRNAME"
|
mv "$f" "$DIRNAME"
|
||||||
else
|
continue
|
||||||
YEAR=`echo $DATE | cut -d':' -f2 | cut -c 2-`
|
fi
|
||||||
MONTH=`echo $DATE | cut -d':' -f3`
|
|
||||||
DAY=`echo $DATE | cut -d':' -f4 | cut -d' ' -f1`
|
DATE=`cut -d' ' -f1 <<< $DATETIME`
|
||||||
HOUR=`echo $DATE | cut -d':' -f4 | cut -d' ' -f2`
|
TIME=`cut -d' ' -f2 <<< $DATETIME | cut -d'+' -f1`
|
||||||
MINUTE=`echo $DATE | cut -d':' -f5`
|
|
||||||
SECOND=`echo $DATE | cut -d':' -f6`
|
YEAR=`cut -d':' -f1 <<< $DATE`
|
||||||
SECOND=`echo $SECOND | cut -d'+' -f1` # remove timezone
|
MONTH=`cut -d':' -f2 <<< $DATE`
|
||||||
|
DAY=`cut -d':' -f3 <<< $DATE`
|
||||||
|
HOUR=`cut -d':' -f1 <<< $TIME`
|
||||||
|
MINUTE=`cut -d':' -f2 <<< $TIME`
|
||||||
|
SECOND=`cut -d':' -f3 <<< $TIME`
|
||||||
|
|
||||||
HASH=`sha256sum "$f" | xxd -r -p | base64 | head -c 3 | tr '/+' '_-'`
|
HASH=`sha256sum "$f" | xxd -r -p | base64 | head -c 3 | tr '/+' '_-'`
|
||||||
EXT=`echo "${f##*.}" | tr '[:upper:]' '[:lower:]'`
|
EXT=`echo "${f##*.}" | tr '[:upper:]' '[:lower:]'`
|
||||||
if [[ "$EXT" = "cr2" ]] || [[ "$EXT" = "cr3" ]]
|
if [[ "$EXT" = "cr2" ]] || [[ "$EXT" = "cr3" ]]
|
||||||
|
@ -47,16 +60,16 @@ for f in `find "$SOURCEPATH" -iname *.PNG -o -iname *.JPG -o -iname *.HEIC -o -i
|
||||||
echo "DESTINATION: $FILE"
|
echo "DESTINATION: $FILE"
|
||||||
mkdir -p "$(dirname "$FILE")"
|
mkdir -p "$(dirname "$FILE")"
|
||||||
mv -v "$f" "$FILE"
|
mv -v "$f" "$FILE"
|
||||||
fi
|
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ "$SCAN" == "TRUE" ]; then
|
if [ "$SCAN" == "TRUE" ]; then
|
||||||
echo "SCANNING..."
|
echo "SCANNING..."
|
||||||
# find "$SOURCEPATH/"* -type d -empty -delete >> /var/echo/nc-picsort.echo # nextcloud app bug when deleting folders
|
# find "$ABS_SOURCE_PATH/"* -type d -empty -delete >> /var/echo/nc-picsort.echo # nextcloud app bug when deleting folders
|
||||||
chown -R www-data:www-data "$ABS_DEST_PATH"
|
chown -R www-data:www-data "$ABS_DEST_PATH"
|
||||||
chown -R www-data:www-data "$ABS_UNSORTABLE_PATH"
|
chown -R www-data:www-data "$ABS_UNSORTABLE_PATH"
|
||||||
chmod -R 770 "$ABS_DEST_PATH"
|
chmod -R 770 "$ABS_DEST_PATH"
|
||||||
chmod -R 770 "$ABS_UNSORTABLE_PATH"
|
chmod -R 770 "$ABS_UNSORTABLE_PATH"
|
||||||
|
sudo -u www-data php /opt/nextcloud/occ files:scan --path "$REL_SOURCE_PATH"
|
||||||
sudo -u www-data php /opt/nextcloud/occ files:scan --path "$REL_UNSORTABLE_PATH"
|
sudo -u www-data php /opt/nextcloud/occ files:scan --path "$REL_UNSORTABLE_PATH"
|
||||||
sudo -u www-data php /opt/nextcloud/occ files:scan --path "$REL_DEST_PATH"
|
sudo -u www-data php /opt/nextcloud/occ files:scan --path "$REL_DEST_PATH"
|
||||||
sudo -u www-data php /opt/nextcloud/occ preview:pre-generate
|
sudo -u www-data php /opt/nextcloud/occ preview:pre-generate
|
||||||
|
|
|
@ -4,7 +4,7 @@ from shlex import quote as q
|
||||||
defaults = {
|
defaults = {
|
||||||
'apt': {
|
'apt': {
|
||||||
'packages': {
|
'packages': {
|
||||||
'exiftool': {},
|
'libimage-exiftool-perl': {},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,14 +4,23 @@ assert isinstance(size, int)
|
||||||
actions = {
|
actions = {
|
||||||
'stop_swap': {
|
'stop_swap': {
|
||||||
'command': f'systemctl stop swapfile.swap',
|
'command': f'systemctl stop swapfile.swap',
|
||||||
'unless': f'rm /swapfile',
|
'unless': f'! systemctl is-active swapfile.swap',
|
||||||
'triggered': True,
|
'triggered': True,
|
||||||
},
|
},
|
||||||
|
'remove_swapfile': {
|
||||||
|
'command': f'rm /swapfile',
|
||||||
|
'unless': f'! test -e /swapfile',
|
||||||
|
'triggered': True,
|
||||||
|
'needs': {
|
||||||
|
'action:stop_swap',
|
||||||
|
},
|
||||||
|
},
|
||||||
'create_swapfile': {
|
'create_swapfile': {
|
||||||
'command': f'dd if=/dev/zero of=/swapfile bs={size} count=1',
|
'command': f'dd if=/dev/zero of=/swapfile bs={size} count=1',
|
||||||
'unless': f'stat -c %s /swapfile | grep ^{size}$',
|
'unless': f'stat -c %s /swapfile | grep ^{size}$',
|
||||||
'preceded_by': {
|
'preceded_by': {
|
||||||
'action:stop_swap',
|
'action:stop_swap',
|
||||||
|
'action:remove_swapfile',
|
||||||
},
|
},
|
||||||
'triggers': {
|
'triggers': {
|
||||||
'action:initialize_swapfile',
|
'action:initialize_swapfile',
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
'smartctl',
|
'smartctl',
|
||||||
'steam-chat-logger',
|
'steam-chat-logger',
|
||||||
'steam-chat-viewer',
|
'steam-chat-viewer',
|
||||||
|
'systemd-swap',
|
||||||
'raspberrymatic-cert',
|
'raspberrymatic-cert',
|
||||||
'tasmota-charge',
|
'tasmota-charge',
|
||||||
'wireguard',
|
'wireguard',
|
||||||
|
@ -83,7 +84,6 @@
|
||||||
'nextcloud': {
|
'nextcloud': {
|
||||||
'hostname': 'cloud.sublimity.de',
|
'hostname': 'cloud.sublimity.de',
|
||||||
'version': '24.0.2',
|
'version': '24.0.2',
|
||||||
'instance_id': 'oci6dw1woodz',
|
|
||||||
},
|
},
|
||||||
'nextcloud-picsort': {
|
'nextcloud-picsort': {
|
||||||
'ckn': {
|
'ckn': {
|
||||||
|
@ -107,6 +107,7 @@
|
||||||
'steam-chat-viewer': {
|
'steam-chat-viewer': {
|
||||||
'hostname': 'steam-chats.ckn.li',
|
'hostname': 'steam-chats.ckn.li',
|
||||||
},
|
},
|
||||||
|
'systemd-swap': 4*10**9,
|
||||||
'tasmota-charge': {
|
'tasmota-charge': {
|
||||||
'phone': {
|
'phone': {
|
||||||
'ip': '10.0.0.175',
|
'ip': '10.0.0.175',
|
||||||
|
|
Loading…
Reference in a new issue