Finalize Temp
This commit is contained in:
parent
1301064929
commit
45cd93d43d
@ -11,18 +11,18 @@ NC='\033[0m'
|
|||||||
SECRETS_FILE="$HOME/.zsh_secrets"
|
SECRETS_FILE="$HOME/.zsh_secrets"
|
||||||
REMOTE_NAME="hetzner-box"
|
REMOTE_NAME="hetzner-box"
|
||||||
|
|
||||||
# 1. Dependency Check
|
# Dependency Check
|
||||||
if ! command -v rclone &> /dev/null; then
|
if ! command -v rclone &> /dev/null; then
|
||||||
echo -e "${RED}Error: rclone is not installed.${NC}"
|
echo -e "${RED}Error: rclone is not installed.${NC}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 2. Load Secrets
|
# Load Secrets
|
||||||
if [ -f "$SECRETS_FILE" ]; then
|
if [ -f "$SECRETS_FILE" ]; then
|
||||||
source "$SECRETS_FILE"
|
source "$SECRETS_FILE"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 3. Configure Remote (If missing)
|
# Configure Remote (If missing)
|
||||||
if ! rclone listremotes | grep -q "^${REMOTE_NAME}:$"; then
|
if ! rclone listremotes | grep -q "^${REMOTE_NAME}:$"; then
|
||||||
echo -e "${BLUE}Configuration missing. Starting setup...${NC}"
|
echo -e "${BLUE}Configuration missing. Starting setup...${NC}"
|
||||||
|
|
||||||
@ -67,12 +67,11 @@ if ! rclone listremotes | grep -q "^${REMOTE_NAME}:$"; then
|
|||||||
echo -e "${GREEN}Configuration created!${NC}"
|
echo -e "${GREEN}Configuration created!${NC}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 4. Interactive Menu
|
# Interactive Menu
|
||||||
echo -e "${BLUE}--- Hetzner Storage Box Manager ---${NC}"
|
echo -e "${BLUE}--- Hetzner Storage Box Manager ---${NC}"
|
||||||
echo "1) List files (ls)"
|
echo "1) List files (ls)"
|
||||||
echo "2) Upload (Copy LOCAL -> REMOTE)"
|
echo "2) Upload (Copy LOCAL -> REMOTE)"
|
||||||
echo "3) Download (Copy REMOTE -> LOCAL)"
|
echo "3) Download (Copy REMOTE -> LOCAL)"
|
||||||
echo "4) Mount (Fast NVMe Cache)"
|
|
||||||
echo "q) Quit"
|
echo "q) Quit"
|
||||||
|
|
||||||
read -p "Select option: " OPTION
|
read -p "Select option: " OPTION
|
||||||
@ -85,65 +84,29 @@ case $OPTION in
|
|||||||
rclone ls "${REMOTE_NAME}:" --max-depth "$DEPTH"
|
rclone ls "${REMOTE_NAME}:" --max-depth "$DEPTH"
|
||||||
;;
|
;;
|
||||||
2)
|
2)
|
||||||
# UPLOAD
|
|
||||||
read -p "Enter local folder/file to upload: " LOCAL_PATH
|
read -p "Enter local folder/file to upload: " LOCAL_PATH
|
||||||
# Remove trailing slash
|
|
||||||
LOCAL_PATH=${LOCAL_PATH%/}
|
LOCAL_PATH=${LOCAL_PATH%/}
|
||||||
|
|
||||||
read -p "Enter remote destination folder (e.g. Backup): " REMOTE_FOLDER
|
read -p "Enter remote destination folder (e.g. Backup): " REMOTE_FOLDER
|
||||||
# Remove leading/trailing slashes to ensure relative path safety (no //root/paths)
|
|
||||||
REMOTE_FOLDER=${REMOTE_FOLDER#/}
|
REMOTE_FOLDER=${REMOTE_FOLDER#/}
|
||||||
REMOTE_FOLDER=${REMOTE_FOLDER%/}
|
REMOTE_FOLDER=${REMOTE_FOLDER%/}
|
||||||
|
|
||||||
echo -e "${YELLOW}Uploading '$LOCAL_PATH' to '${REMOTE_NAME}:$REMOTE_FOLDER'...${NC}"
|
echo -e "${YELLOW}Uploading '$LOCAL_PATH' to '${REMOTE_NAME}:$REMOTE_FOLDER'...${NC}"
|
||||||
# FIX: Removed slash before $REMOTE_FOLDER to force relative path
|
|
||||||
rclone copy "$LOCAL_PATH" "${REMOTE_NAME}:$REMOTE_FOLDER" -P
|
rclone copy "$LOCAL_PATH" "${REMOTE_NAME}:$REMOTE_FOLDER" -P
|
||||||
;;
|
;;
|
||||||
3)
|
3)
|
||||||
# DOWNLOAD
|
|
||||||
echo -e "${BLUE}Contents of Root:${NC}"
|
echo -e "${BLUE}Contents of Root:${NC}"
|
||||||
rclone lsd "${REMOTE_NAME}:"
|
rclone lsd "${REMOTE_NAME}:"
|
||||||
|
|
||||||
read -p "Enter remote path to download (e.g. models/Test): " REMOTE_PATH
|
read -p "Enter remote path to download (e.g. models/Test): " REMOTE_PATH
|
||||||
# Strip leading slash to force relative path from Home
|
|
||||||
REMOTE_PATH=${REMOTE_PATH#/}
|
REMOTE_PATH=${REMOTE_PATH#/}
|
||||||
|
|
||||||
read -p "Enter local destination folder: " LOCAL_DEST
|
read -p "Enter local destination folder: " LOCAL_DEST
|
||||||
# Create dest if missing
|
|
||||||
mkdir -p "$LOCAL_DEST"
|
mkdir -p "$LOCAL_DEST"
|
||||||
|
|
||||||
echo -e "${YELLOW}Downloading '${REMOTE_NAME}:$REMOTE_PATH' to '$LOCAL_DEST'...${NC}"
|
echo -e "${YELLOW}Downloading '${REMOTE_NAME}:$REMOTE_PATH' to '$LOCAL_DEST'...${NC}"
|
||||||
rclone copy "${REMOTE_NAME}:$REMOTE_PATH" "$LOCAL_DEST" -P
|
rclone copy "${REMOTE_NAME}:$REMOTE_PATH" "$LOCAL_DEST" -P
|
||||||
;;
|
;;
|
||||||
4)
|
|
||||||
# MOUNT LOGIC (With Permission Fixes)
|
|
||||||
if [ -d "/mnt/resource" ]; then
|
|
||||||
BASE_DIR="/mnt/resource"
|
|
||||||
else
|
|
||||||
BASE_DIR="$HOME/mnt" # Fallback if no NVMe exists
|
|
||||||
mkdir -p "$BASE_DIR"
|
|
||||||
fi
|
|
||||||
|
|
||||||
MOUNT_POINT="$BASE_DIR/storagebox"
|
|
||||||
CACHE_DIR="$BASE_DIR/rclone_cache"
|
|
||||||
|
|
||||||
echo -e "${BLUE}Target: $MOUNT_POINT${NC}"
|
|
||||||
|
|
||||||
# Ensure permissions exist (sudo only if needed)
|
|
||||||
if [ ! -d "$MOUNT_POINT" ]; then
|
|
||||||
echo -e "${YELLOW}Creating mount points...${NC}"
|
|
||||||
sudo mkdir -p "$MOUNT_POINT" "$CACHE_DIR" || mkdir -p "$MOUNT_POINT" "$CACHE_DIR"
|
|
||||||
sudo chown $(whoami):$(id -gn) "$MOUNT_POINT" "$CACHE_DIR" 2>/dev/null || true
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo -e "${YELLOW}Mounting... (Ctrl+C to stop)${NC}"
|
|
||||||
|
|
||||||
rclone mount "${REMOTE_NAME}:" "$MOUNT_POINT" \
|
|
||||||
--vfs-cache-mode full \
|
|
||||||
--cache-dir "$CACHE_DIR" \
|
|
||||||
--vfs-cache-max-size 10G \
|
|
||||||
--vfs-cache-max-age 24h
|
|
||||||
;;
|
|
||||||
q)
|
q)
|
||||||
exit 0
|
exit 0
|
||||||
;;
|
;;
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user