Files
just-commons/volumes/mod.just
2025-11-04 17:45:37 +02:00

152 lines
5.3 KiB
Plaintext

# Universal volume management operations
# Define custom colors not in Just's native set
DARK_GREY := '\033[2m' # Dark grey (dim) for optional parameters
alias help := default
# Default recipe - show available commands
[no-cd]
[private]
default:
#!/usr/bin/env bash
echo "{{BOLD}}Volume Management Commands{{NORMAL}}"
echo ""
echo "{{BOLD}}Usage:{{NORMAL}}"
echo " just volumes <command> [parameters]"
echo ""
echo "{{BOLD}}Parameters:{{NORMAL}}"
echo -e " {{YELLOW}}<required>{{NORMAL}} - Required parameter"
echo -e " {{DARK_GREY}}[optional]{{NORMAL}} - Optional parameter"
echo ""
echo "{{BOLD}}Commands:{{NORMAL}}"
echo -e " {{CYAN}}{{BOLD}}list{{NORMAL}} {{DARK_GREY}}[pattern]\033[0m - List all volumes or filter by pattern"
echo -e " {{CYAN}}{{BOLD}}remove{{NORMAL}} {{YELLOW}}<volume_name>{{NORMAL}} - Remove specific volume (with confirmation)"
echo -e " {{CYAN}}{{BOLD}}remove-pattern{{NORMAL}} {{YELLOW}}<pattern>{{NORMAL}} - Remove volumes matching pattern (with confirmation)"
echo -e " {{CYAN}}{{BOLD}}clean-all{{NORMAL}} {{DARK_GREY}}[compose-file]\033[0m - Clean all volumes from compose file (with confirmation)"
echo ""
echo "{{RED}}⚠️ WARNING: Remove operations are DESTRUCTIVE and will DELETE DATA!{{NORMAL}}"
echo ""
echo "{{BOLD}}Examples:{{NORMAL}}"
echo " just volumes list # List all volumes"
echo " just volumes list myproject # Filter volumes by pattern"
echo " just volumes remove myproject_db_data # Remove specific volume"
echo " just volumes remove-pattern 'myproject_*' # Remove all matching volumes"
echo " just volumes clean-all compose.yml # Remove all compose volumes"
echo ""
# Clean all volumes used by compose file (DESTRUCTIVE!)
[confirm]
clean-all compose-file="":
#!/usr/bin/env bash
set -euo pipefail
compose_file="{{compose-file}}"
compose_cmd=$(just _detect_compose)
# Build compose file argument
file_arg=""
if [ -n "$compose_file" ]; then
file_arg="-f $compose_file"
fi
echo -e "{{RED}}⚠️ WARNING: This will DELETE ALL DATA!{{NORMAL}}"
echo -e "{{YELLOW}}This will remove all volumes defined in the compose file{{NORMAL}}"
# Show which volumes would be removed
echo -e "{{BLUE}}Volumes that will be removed:{{NORMAL}}"
$compose_cmd $file_arg config --volumes 2>/dev/null || echo "Cannot list volumes from compose file"
echo ""
echo -e "{{BLUE}}Stopping services...{{NORMAL}}"
$compose_cmd $file_arg down
echo -e "{{BLUE}}Removing volumes...{{NORMAL}}"
$compose_cmd $file_arg down -v
echo -e "{{GREEN}}✓ All volumes removed{{NORMAL}}"
# Remove specific volume by name (DESTRUCTIVE!)
[confirm]
remove volume_name:
#!/usr/bin/env bash
set -euo pipefail
volume_name="{{volume_name}}"
if [ -z "$volume_name" ]; then
echo "{{BOLD}}{{RED}}Error:{{NORMAL}} Volume name is required" >&2
echo "{{YELLOW}}Usage:{{NORMAL}} just volumes remove my_volume_name" >&2
exit 1
fi
runtime=$(just _detect_runtime)
# Check if volume exists
if ! $runtime volume ls --format "table {{{{.Name}}}}" | grep -q "^${volume_name}$"; then
echo -e "{{YELLOW}}Volume '$volume_name' does not exist{{NORMAL}}"
exit 0
fi
echo -e "{{RED}}⚠️ WARNING: This will DELETE VOLUME DATA!{{NORMAL}}"
echo -e "{{YELLOW}}This will remove volume: $volume_name{{NORMAL}}"
echo -e "{{BLUE}}Removing volume: $volume_name{{NORMAL}}"
$runtime volume rm "$volume_name" 2>/dev/null || true
echo -e "{{GREEN}}✓ Volume '$volume_name' removed{{NORMAL}}"
# Remove volumes matching pattern (DESTRUCTIVE!)
[confirm]
remove-pattern pattern:
#!/usr/bin/env bash
set -euo pipefail
pattern="{{pattern}}"
if [ -z "$pattern" ]; then
echo "{{BOLD}}{{RED}}Error:{{NORMAL}} Volume pattern is required" >&2
echo "{{YELLOW}}Usage:{{NORMAL}} just volumes remove-pattern 'myproject_*'" >&2
exit 1
fi
runtime=$(just _detect_runtime)
# Find matching volumes
matching_volumes=$($runtime volume ls --format "table {{{{.Name}}}}" | grep "$pattern" || true)
if [ -z "$matching_volumes" ]; then
echo -e "{{YELLOW}}No volumes found matching pattern: $pattern{{NORMAL}}"
exit 0
fi
echo -e "{{RED}}⚠️ WARNING: This will DELETE VOLUME DATA!{{NORMAL}}"
echo -e "{{YELLOW}}Volumes matching pattern '$pattern':{{NORMAL}}"
echo "$matching_volumes"
echo ""
echo -e "{{BLUE}}Removing matching volumes...{{NORMAL}}"
echo "$matching_volumes" | while IFS= read -r volume; do
if [ -n "$volume" ]; then
echo "Removing: $volume"
$runtime volume rm "$volume" 2>/dev/null || true
fi
done
echo -e "{{GREEN}}✓ Matching volumes removed{{NORMAL}}"
# List all volumes or filter by pattern
list pattern="":
#!/usr/bin/env bash
set -euo pipefail
pattern="{{pattern}}"
runtime=$(just _detect_runtime)
if [ -n "$pattern" ]; then
echo -e "{{BLUE}}Volumes matching pattern '$pattern':{{NORMAL}}"
$runtime volume ls | grep "$pattern" || echo "No volumes found matching pattern: $pattern"
else
echo -e "{{BLUE}}All volumes:{{NORMAL}}"
$runtime volume ls
fi