Compare commits
4 Commits
cccd548ee1
...
5e57814205
Author | SHA1 | Date | |
---|---|---|---|
Thord Johansson | 5e57814205 | ||
Thord Johansson | 334f331f3a | ||
Thord Johansson | c281a05a39 | ||
Thord Johansson | bb507a2778 |
|
@ -2,6 +2,8 @@
|
||||||
|
|
||||||
Some useful system scripts for things like fan control and other convenience.
|
Some useful system scripts for things like fan control and other convenience.
|
||||||
|
|
||||||
|
**USE FILESYSTEM SCRIPTS AT YOUR OWN RISK.**
|
||||||
|
|
||||||
You can regenerate `env-template.txt` based on the current .env file with:
|
You can regenerate `env-template.txt` based on the current .env file with:
|
||||||
```bash
|
```bash
|
||||||
./setup.sh --gentmpl
|
./setup.sh --gentmpl
|
||||||
|
|
|
@ -0,0 +1,41 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if [ "$#" -eq 0 ]; then
|
||||||
|
echo "Error: Please provide the source directory as an argument."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
basedir="${1%/}"
|
||||||
|
|
||||||
|
echo "Found these directories:"
|
||||||
|
for dir in $basedir/*; do
|
||||||
|
if [ -d "$dir" ]; then
|
||||||
|
echo " - $dir"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
read -n1 -p "Back them up? (y/n): " answer
|
||||||
|
echo
|
||||||
|
|
||||||
|
if [ "$answer" != "y" ]; then
|
||||||
|
echo "Exiting."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
for dir in $basedir/*; do
|
||||||
|
if [ -d "$dir" ]; then
|
||||||
|
echo -e "\e[1;36mProcessing folder: $dir\e[0m"
|
||||||
|
./backup2cloud.sh $dir
|
||||||
|
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo -en "\e[1;31mLast run failed. Do you want to continue? (y/n): \e[0m"
|
||||||
|
read -n1 answer
|
||||||
|
echo
|
||||||
|
if [ "$answer" != "y" ]; then
|
||||||
|
echo "Exiting."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
echo -e "\e[1;32mCompleted\e[0m"
|
|
@ -0,0 +1,93 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# ensure prerequisites are installed: rclone p7zip-full
|
||||||
|
# run `rclone config` to set up your target, put the name you choose as REMOTE_NAME
|
||||||
|
# edit .env and add an ENC_PASSWORD used for encryption, can also put variable overrides there
|
||||||
|
|
||||||
|
# the directory name will be used as archive name by default
|
||||||
|
# usage: script.sh [path] [archive name override]
|
||||||
|
|
||||||
|
# Default values
|
||||||
|
SOURCE_DIR="$1"
|
||||||
|
CURRENT_DATE_TIME=$(date +"%Y%m%d_%H%M%S_%s")
|
||||||
|
REMOTE_NAME="onedrive"
|
||||||
|
REMOTE_DIR="Backups/"
|
||||||
|
|
||||||
|
# Load environment variables from .env file
|
||||||
|
source .env
|
||||||
|
|
||||||
|
# Check if TEMP_DIR is set
|
||||||
|
if [ -z "$TEMP_DIR" ]; then
|
||||||
|
echo "Error: TEMP_DIR environment variable is not set."
|
||||||
|
exit 1
|
||||||
|
else
|
||||||
|
echo "Temporary directory: $TEMP_DIR"
|
||||||
|
sleep 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
DESTINATION_DIR=$(mktemp -d --tmpdir=$TEMP_DIR)
|
||||||
|
|
||||||
|
# Check if ENC_PASSWORD is set
|
||||||
|
if [ -z "$ENC_PASSWORD" ]; then
|
||||||
|
echo "Error: ENC_PASSWORD environment variable is not set."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if source directory is provided as an argument
|
||||||
|
if [ "$#" -eq 0 ]; then
|
||||||
|
echo "Error: Please provide the source directory as an argument."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if source directory exists
|
||||||
|
if [ ! -d "$SOURCE_DIR" ]; then
|
||||||
|
echo "Error: Source directory '$SOURCE_DIR' does not exist."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$SOURCE_DIR" == "." ]; then
|
||||||
|
SOURCE_DIR=$(pwd)
|
||||||
|
fi
|
||||||
|
|
||||||
|
SOURCE_DIR_NAME=$(basename "$SOURCE_DIR")
|
||||||
|
ARCHIVE_NAME="${SOURCE_DIR_NAME}"
|
||||||
|
|
||||||
|
# Use the provided archive name if the second parameter is present
|
||||||
|
if [ "$#" -eq 2 ]; then
|
||||||
|
ARCHIVE_NAME="$2"
|
||||||
|
fi
|
||||||
|
|
||||||
|
ARCHIVE_NAME="$(hostname)_${ARCHIVE_NAME}_${CURRENT_DATE_TIME}"
|
||||||
|
ARCHIVE_FILE="$DESTINATION_DIR/${ARCHIVE_NAME}.7z"
|
||||||
|
|
||||||
|
# Function to clean up temporary files on exit
|
||||||
|
cleanup() {
|
||||||
|
echo "Cleaning up at: $DESTINATION_DIR"
|
||||||
|
rm -rf "$DESTINATION_DIR"
|
||||||
|
}
|
||||||
|
|
||||||
|
echo "Temporary directory: $DESTINATION_DIR"
|
||||||
|
|
||||||
|
trap cleanup EXIT
|
||||||
|
|
||||||
|
# Archive, compress, and encrypt the directory
|
||||||
|
7z a -t7z -m0=lzma2 -mx=9 -mhe=on -p"$ENC_PASSWORD" "$ARCHIVE_FILE" "$SOURCE_DIR"
|
||||||
|
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "Archiving successful. Beginning upload."
|
||||||
|
else
|
||||||
|
echo "Error ($?): Archiving failed. Check path permissions."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Upload to OneDrive using rclone
|
||||||
|
rclone copy "$ARCHIVE_FILE" "$REMOTE_NAME:$REMOTE_DIR" -P
|
||||||
|
|
||||||
|
# Check if the upload was successful
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "Upload successful. Cleaning up temporary files."
|
||||||
|
cleanup
|
||||||
|
else
|
||||||
|
echo "Error: Upload failed. Check your internet connection or OneDrive configuration."
|
||||||
|
exit 1
|
||||||
|
fi
|
|
@ -0,0 +1,3 @@
|
||||||
|
#!/bin/bash
|
||||||
|
mkdir -p $HOME/.clamscan/
|
||||||
|
clamscan -r --remove --log=$HOME/.clamscan/$(date +"%Y%m%d-%H%M%S").log /mnt/data/downloads
|
|
@ -0,0 +1,95 @@
|
||||||
|
#!/usr/bin/env python
|
||||||
|
# - generated, gpt3.5
|
||||||
|
|
||||||
|
import os
|
||||||
|
import shutil
|
||||||
|
import sys
|
||||||
|
import datetime
|
||||||
|
from pathlib import Path
|
||||||
|
|
||||||
|
# Configurable variables
|
||||||
|
MOVIES_EXTENSION = {".mkv", ".mp4", ".avi"}
|
||||||
|
MUSIC_EXTENSION = {".mp3", ".ogg", ".flac", ".wma", ".wav"}
|
||||||
|
EPISODIC_THRESHOLD = 1 # Maximum number of video files to consider as episodic (inclusive)
|
||||||
|
MOVIES_PATH = "Movies"
|
||||||
|
MUSIC_PATH = "Music"
|
||||||
|
SHOWS_PATH = "Shows"
|
||||||
|
|
||||||
|
def organize_folders(directory, root_path):
|
||||||
|
log_file = create_log_file(directory, root_path)
|
||||||
|
write_log(log_file, f"Organizing folders in {directory}")
|
||||||
|
|
||||||
|
actions = preview_actions(directory, root_path)
|
||||||
|
if confirm_actions(actions):
|
||||||
|
execute_actions(actions, log_file)
|
||||||
|
else:
|
||||||
|
log_file.close()
|
||||||
|
os.remove(log_file.name)
|
||||||
|
print("Log file deleted.")
|
||||||
|
|
||||||
|
log_file_path = os.path.abspath(log_file.name)
|
||||||
|
print(f"Log file saved at: {log_file_path}")
|
||||||
|
|
||||||
|
def preview_actions(directory, root_path):
|
||||||
|
actions = []
|
||||||
|
|
||||||
|
for folder_name in os.listdir(directory):
|
||||||
|
folder_path = os.path.join(directory, folder_name)
|
||||||
|
|
||||||
|
if os.path.isdir(folder_path):
|
||||||
|
file_types = set()
|
||||||
|
|
||||||
|
for file in os.listdir(folder_path):
|
||||||
|
file_extension = Path(file).suffix.lower()
|
||||||
|
file_types.add(file_extension)
|
||||||
|
|
||||||
|
if MOVIES_EXTENSION.intersection(file_types) and len(file_types) <= EPISODIC_THRESHOLD:
|
||||||
|
actions.append((folder_path, os.path.join(root_path, MOVIES_PATH, folder_name)))
|
||||||
|
elif len(file_types.intersection(MUSIC_EXTENSION)) == len(file_types):
|
||||||
|
actions.append((folder_path, os.path.join(root_path, MUSIC_PATH, folder_name)))
|
||||||
|
elif len(file_types) > EPISODIC_THRESHOLD:
|
||||||
|
actions.append((folder_path, os.path.join(root_path, SHOWS_PATH, folder_name)))
|
||||||
|
|
||||||
|
return actions
|
||||||
|
|
||||||
|
def confirm_actions(actions):
|
||||||
|
print("Preview of actions:")
|
||||||
|
for source, destination in actions:
|
||||||
|
print(f"Move: {source} -> {destination}")
|
||||||
|
|
||||||
|
user_input = input("Do you want to proceed with the above actions? (y/n): ").lower()
|
||||||
|
return user_input == "y"
|
||||||
|
|
||||||
|
def execute_actions(actions, log_file):
|
||||||
|
for source, destination in actions:
|
||||||
|
message = f"Moving {os.path.basename(source)} to {destination}"
|
||||||
|
write_log(log_file, message)
|
||||||
|
print(message)
|
||||||
|
shutil.move(source, destination)
|
||||||
|
|
||||||
|
def move_folder(folder_path, destination):
|
||||||
|
if not os.path.exists(destination):
|
||||||
|
os.makedirs(destination)
|
||||||
|
shutil.move(folder_path, os.path.join(destination, os.path.basename(folder_path)))
|
||||||
|
|
||||||
|
def create_log_file(directory, root_path):
|
||||||
|
current_time = datetime.datetime.now().strftime("%y%m%d_%H%M%S")
|
||||||
|
log_file_name = f"{current_time}.log"
|
||||||
|
log_file_path = os.path.join(root_path, directory, log_file_name)
|
||||||
|
return open(log_file_path, "w")
|
||||||
|
|
||||||
|
def write_log(log_file, message):
|
||||||
|
timestamp = datetime.datetime.now().strftime("[%Y-%m-%d %H:%M:%S]")
|
||||||
|
log_message = f"{timestamp} {message}\n"
|
||||||
|
log_file.write(log_message)
|
||||||
|
print(log_message, end="")
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
if len(sys.argv) != 3:
|
||||||
|
print("Usage: ./organize_folders.py <directory_path> <root_path>")
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
directory = sys.argv[1]
|
||||||
|
root_path = sys.argv[2]
|
||||||
|
organize_folders(directory, root_path)
|
||||||
|
|
|
@ -0,0 +1,15 @@
|
||||||
|
human_readable_size() {
|
||||||
|
local bytes="$1"
|
||||||
|
local sizes=("B" "KB" "MB" "GB" "TB" "PB" "EB" "ZB" "YB")
|
||||||
|
|
||||||
|
local i=0
|
||||||
|
while ((bytes > 1024)); do
|
||||||
|
((bytes /= 1024))
|
||||||
|
((i++))
|
||||||
|
done
|
||||||
|
|
||||||
|
printf "%d%s" "$bytes" "${sizes[i]}"
|
||||||
|
}
|
||||||
|
|
||||||
|
human_readable_size $1
|
||||||
|
echo ""
|
|
@ -0,0 +1,9 @@
|
||||||
|
folder_size=$(du -s /mnt/data/storage/ | awk '{print $1}')
|
||||||
|
available_space=$(df /tmp | awk 'NR==2 {print $4}')
|
||||||
|
echo $folder_size
|
||||||
|
echo $available_space
|
||||||
|
if [[ "$folder_size" -gt "$available_space" ]]; then
|
||||||
|
echo "Error: Folder size exceeds available space in $(realpath $DESTINATION_DIR/)."
|
||||||
|
else
|
||||||
|
echo "Folder size is within available space in $(realpath $DESTINATION_DIR/)."
|
||||||
|
fi
|
|
@ -73,11 +73,17 @@ def download_file(file_url, download_dir, ytdlp_format):
|
||||||
rgx_booru = r'https?://[a-z.]+/(index\.php.*id=([0-9]+)|posts/([0-9]+))'
|
rgx_booru = r'https?://[a-z.]+/(index\.php.*id=([0-9]+)|posts/([0-9]+))'
|
||||||
rgx_booru_v1 = r'(https?://.*/original/([A-Za-z0-9/_]*\.{0})|https?://img[a-z0-9.]+\.[a-z]+\.com/(.*?)))'.format(extensions)
|
rgx_booru_v1 = r'(https?://.*/original/([A-Za-z0-9/_]*\.{0})|https?://img[a-z0-9.]+\.[a-z]+\.com/(.*?)))'.format(extensions)
|
||||||
rgx_booru_v2 = r'(https?://.*/original/([A-Za-z0-9/_]*\.{0})|https?://img[a-z0-9.]+\.[a-z]+\.com/im)'.format(extensions)
|
rgx_booru_v2 = r'(https?://.*/original/([A-Za-z0-9/_]*\.{0})|https?://img[a-z0-9.]+\.[a-z]+\.com/im)'.format(extensions)
|
||||||
|
rgx_booru_v2_vid = r'https?://video-cdn[0-9]{1}.*booru.*\.com/images/.*\.mp4'
|
||||||
|
|
||||||
artist = None
|
artist = None
|
||||||
if re.match(rgx_booru, file_url):
|
if re.match(rgx_booru, file_url):
|
||||||
artist = find_booru_artist(file_url)
|
artist = find_booru_artist(file_url)
|
||||||
file_url = re.search(rgx_booru_v2, requests.get(file_url).text).group(1).strip()
|
booru_url = file_url
|
||||||
|
file_url = re.search(rgx_booru_v2, requests.get(booru_url).text)
|
||||||
|
file_url = file_url.group(1).strip() if file_url else None
|
||||||
|
if not file_url: #try video
|
||||||
|
file_url = re.search(rgx_booru_v2_vid, requests.get(booru_url).text)
|
||||||
|
file_url = file_url.group(0).strip() if file_url else None
|
||||||
|
|
||||||
if not file_url:
|
if not file_url:
|
||||||
return 1
|
return 1
|
||||||
|
|
Loading…
Reference in New Issue