mirror of
https://github.com/shadoll/just-commons.git
synced 2025-12-20 01:25:43 +00:00
152 lines
5.3 KiB
Plaintext
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 |