Add quick reference guide and upgrade script
- docs/QUICK-REFERENCE.md: Comprehensive quick reference card with - All commands organized by category - Shell aliases - Key paths - PA flags - Autonomy levels - Troubleshooting tips - automation/upgrade.sh: Version upgrade management - Check for available upgrades (git-aware) - Pre-upgrade backup creation - Migration runner for version upgrades - Post-upgrade validation - Updated shell completions with 16 aliases total - Test suite now covers 24 tests 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -45,6 +45,12 @@ _claude_mcp_status() {
|
|||||||
COMPREPLY=($(compgen -W "--json" -- "${cur}"))
|
COMPREPLY=($(compgen -W "--json" -- "${cur}"))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_claude_upgrade() {
|
||||||
|
local cur="${COMP_WORDS[COMP_CWORD]}"
|
||||||
|
|
||||||
|
COMPREPLY=($(compgen -W "--check --backup --apply --help" -- "${cur}"))
|
||||||
|
}
|
||||||
|
|
||||||
_claude_memory_add() {
|
_claude_memory_add() {
|
||||||
local cur="${COMP_WORDS[COMP_CWORD]}"
|
local cur="${COMP_WORDS[COMP_CWORD]}"
|
||||||
local prev="${COMP_WORDS[COMP_CWORD-1]}"
|
local prev="${COMP_WORDS[COMP_CWORD-1]}"
|
||||||
@@ -80,6 +86,7 @@ complete -F _claude_log log-viewer.py
|
|||||||
complete -F _claude_debug debug.sh
|
complete -F _claude_debug debug.sh
|
||||||
complete -F _claude_export session-export.py
|
complete -F _claude_export session-export.py
|
||||||
complete -F _claude_mcp_status mcp-status.sh
|
complete -F _claude_mcp_status mcp-status.sh
|
||||||
|
complete -F _claude_upgrade upgrade.sh
|
||||||
|
|
||||||
# Alias completions for convenience
|
# Alias completions for convenience
|
||||||
alias claude-validate='~/.claude/automation/validate-setup.sh'
|
alias claude-validate='~/.claude/automation/validate-setup.sh'
|
||||||
@@ -98,7 +105,8 @@ alias claude-log='python3 ~/.claude/automation/log-viewer.py'
|
|||||||
alias claude-debug='~/.claude/automation/debug.sh'
|
alias claude-debug='~/.claude/automation/debug.sh'
|
||||||
alias claude-export='python3 ~/.claude/automation/session-export.py'
|
alias claude-export='python3 ~/.claude/automation/session-export.py'
|
||||||
alias claude-mcp='~/.claude/automation/mcp-status.sh'
|
alias claude-mcp='~/.claude/automation/mcp-status.sh'
|
||||||
|
alias claude-upgrade='~/.claude/automation/upgrade.sh'
|
||||||
|
|
||||||
echo "Claude Code completions loaded. Available aliases:"
|
echo "Claude Code completions loaded. Available aliases:"
|
||||||
echo " claude-{validate,status,backup,restore,clean,memory-add,memory-list}"
|
echo " claude-{validate,status,backup,restore,clean,memory-add,memory-list}"
|
||||||
echo " claude-{search,history,install,test,maintenance,log,debug,export,mcp}"
|
echo " claude-{search,history,install,test,maintenance,log,debug,export,mcp,upgrade}"
|
||||||
|
|||||||
@@ -98,6 +98,15 @@ _claude_mcp_status() {
|
|||||||
'--json[JSON output]'
|
'--json[JSON output]'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Upgrade completion
|
||||||
|
_claude_upgrade() {
|
||||||
|
_arguments \
|
||||||
|
'--check[Check for upgrades]' \
|
||||||
|
'--backup[Create backup]' \
|
||||||
|
'--apply[Apply migrations]:version:' \
|
||||||
|
'--help[Show help]'
|
||||||
|
}
|
||||||
|
|
||||||
# Register completions
|
# Register completions
|
||||||
compdef _memory_add memory-add.py
|
compdef _memory_add memory-add.py
|
||||||
compdef _memory_list memory-list.py
|
compdef _memory_list memory-list.py
|
||||||
@@ -108,6 +117,7 @@ compdef _claude_log log-viewer.py
|
|||||||
compdef _claude_debug debug.sh
|
compdef _claude_debug debug.sh
|
||||||
compdef _claude_export session-export.py
|
compdef _claude_export session-export.py
|
||||||
compdef _claude_mcp_status mcp-status.sh
|
compdef _claude_mcp_status mcp-status.sh
|
||||||
|
compdef _claude_upgrade upgrade.sh
|
||||||
|
|
||||||
# Aliases
|
# Aliases
|
||||||
alias claude-validate='~/.claude/automation/validate-setup.sh'
|
alias claude-validate='~/.claude/automation/validate-setup.sh'
|
||||||
@@ -126,7 +136,8 @@ alias claude-log='python3 ~/.claude/automation/log-viewer.py'
|
|||||||
alias claude-debug='~/.claude/automation/debug.sh'
|
alias claude-debug='~/.claude/automation/debug.sh'
|
||||||
alias claude-export='python3 ~/.claude/automation/session-export.py'
|
alias claude-export='python3 ~/.claude/automation/session-export.py'
|
||||||
alias claude-mcp='~/.claude/automation/mcp-status.sh'
|
alias claude-mcp='~/.claude/automation/mcp-status.sh'
|
||||||
|
alias claude-upgrade='~/.claude/automation/upgrade.sh'
|
||||||
|
|
||||||
echo "Claude Code completions loaded (zsh)"
|
echo "Claude Code completions loaded (zsh)"
|
||||||
echo " Aliases: claude-{validate,status,backup,restore,clean,memory-add,memory-list}"
|
echo " Aliases: claude-{validate,status,backup,restore,clean,memory-add,memory-list}"
|
||||||
echo " claude-{search,history,install,test,maintenance,log,debug,export,mcp}"
|
echo " claude-{search,history,install,test,maintenance,log,debug,export,mcp,upgrade}"
|
||||||
|
|||||||
@@ -129,7 +129,7 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Test automation bash scripts
|
# Test automation bash scripts
|
||||||
for script in install.sh daily-maintenance.sh backup.sh restore.sh clean.sh debug.sh mcp-status.sh; do
|
for script in install.sh daily-maintenance.sh backup.sh restore.sh clean.sh debug.sh mcp-status.sh upgrade.sh; do
|
||||||
if [[ -f "${AUTOMATION_DIR}/${script}" ]]; then
|
if [[ -f "${AUTOMATION_DIR}/${script}" ]]; then
|
||||||
if bash -n "${AUTOMATION_DIR}/${script}" 2>/dev/null; then
|
if bash -n "${AUTOMATION_DIR}/${script}" 2>/dev/null; then
|
||||||
pass "${script} syntax valid"
|
pass "${script} syntax valid"
|
||||||
|
|||||||
225
automation/upgrade.sh
Executable file
225
automation/upgrade.sh
Executable file
@@ -0,0 +1,225 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# Upgrade script for Claude Code configuration
|
||||||
|
# Usage: ./upgrade.sh [--check|--backup|--apply]
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
CLAUDE_DIR="${HOME}/.claude"
|
||||||
|
VERSION_FILE="${CLAUDE_DIR}/VERSION"
|
||||||
|
BACKUP_DIR="${CLAUDE_DIR}/backups"
|
||||||
|
|
||||||
|
# Colors
|
||||||
|
RED='\033[0;31m'
|
||||||
|
GREEN='\033[0;32m'
|
||||||
|
YELLOW='\033[1;33m'
|
||||||
|
BLUE='\033[0;34m'
|
||||||
|
NC='\033[0m'
|
||||||
|
|
||||||
|
info() { echo -e "${BLUE}ℹ${NC} $1"; }
|
||||||
|
ok() { echo -e "${GREEN}✓${NC} $1"; }
|
||||||
|
warn() { echo -e "${YELLOW}⚠${NC} $1"; }
|
||||||
|
error() { echo -e "${RED}✗${NC} $1"; }
|
||||||
|
|
||||||
|
get_current_version() {
|
||||||
|
if [[ -f "$VERSION_FILE" ]]; then
|
||||||
|
cat "$VERSION_FILE" | tr -d '\n'
|
||||||
|
else
|
||||||
|
echo "0.0.0"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
compare_versions() {
|
||||||
|
local v1="$1"
|
||||||
|
local v2="$2"
|
||||||
|
|
||||||
|
# Returns: -1 if v1 < v2, 0 if equal, 1 if v1 > v2
|
||||||
|
if [[ "$v1" == "$v2" ]]; then
|
||||||
|
echo "0"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
local IFS='.'
|
||||||
|
local i v1_parts=($v1) v2_parts=($v2)
|
||||||
|
|
||||||
|
for ((i=0; i<3; i++)); do
|
||||||
|
local v1_part="${v1_parts[i]:-0}"
|
||||||
|
local v2_part="${v2_parts[i]:-0}"
|
||||||
|
|
||||||
|
if ((v1_part > v2_part)); then
|
||||||
|
echo "1"
|
||||||
|
return
|
||||||
|
elif ((v1_part < v2_part)); then
|
||||||
|
echo "-1"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "0"
|
||||||
|
}
|
||||||
|
|
||||||
|
check_upgrade() {
|
||||||
|
local current=$(get_current_version)
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "🔍 Checking for upgrades..."
|
||||||
|
echo ""
|
||||||
|
echo " Current version: $current"
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
# Check git status if in a repo
|
||||||
|
if [[ -d "${CLAUDE_DIR}/.git" ]]; then
|
||||||
|
cd "$CLAUDE_DIR"
|
||||||
|
|
||||||
|
# Fetch latest
|
||||||
|
if git fetch origin 2>/dev/null; then
|
||||||
|
local local_hash=$(git rev-parse HEAD 2>/dev/null || echo "unknown")
|
||||||
|
local remote_hash=$(git rev-parse origin/main 2>/dev/null || echo "unknown")
|
||||||
|
|
||||||
|
if [[ "$local_hash" != "$remote_hash" ]] && [[ "$remote_hash" != "unknown" ]]; then
|
||||||
|
local ahead=$(git rev-list --count origin/main..HEAD 2>/dev/null || echo "0")
|
||||||
|
local behind=$(git rev-list --count HEAD..origin/main 2>/dev/null || echo "0")
|
||||||
|
|
||||||
|
if [[ "$behind" -gt 0 ]]; then
|
||||||
|
warn "Behind origin/main by $behind commit(s)"
|
||||||
|
echo ""
|
||||||
|
echo " Run: cd ~/.claude && git pull"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "$ahead" -gt 0 ]]; then
|
||||||
|
info "Ahead of origin/main by $ahead commit(s)"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
ok "Up to date with origin/main"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
warn "Could not fetch from remote"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
info "Not a git repository - manual upgrade required"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
}
|
||||||
|
|
||||||
|
pre_upgrade_backup() {
|
||||||
|
echo ""
|
||||||
|
echo "📦 Creating pre-upgrade backup..."
|
||||||
|
|
||||||
|
mkdir -p "$BACKUP_DIR"
|
||||||
|
local timestamp=$(date +%Y%m%d-%H%M%S)
|
||||||
|
local backup_file="${BACKUP_DIR}/pre-upgrade-${timestamp}.tar.gz"
|
||||||
|
|
||||||
|
# Backup essential files only
|
||||||
|
tar -czf "$backup_file" \
|
||||||
|
-C "$CLAUDE_DIR" \
|
||||||
|
--exclude='backups' \
|
||||||
|
--exclude='logs' \
|
||||||
|
--exclude='*.pyc' \
|
||||||
|
--exclude='__pycache__' \
|
||||||
|
--exclude='.git' \
|
||||||
|
--exclude='venv' \
|
||||||
|
. 2>/dev/null || true
|
||||||
|
|
||||||
|
ok "Backup created: $backup_file"
|
||||||
|
echo ""
|
||||||
|
}
|
||||||
|
|
||||||
|
apply_migrations() {
|
||||||
|
local current="$1"
|
||||||
|
local target="$2"
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "🔄 Applying migrations from $current to $target..."
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
# Migration: 0.x.x -> 1.0.0
|
||||||
|
if [[ $(compare_versions "$current" "1.0.0") -lt 0 ]] && \
|
||||||
|
[[ $(compare_versions "$target" "1.0.0") -ge 0 ]]; then
|
||||||
|
info "Migration: Initializing plugin structure..."
|
||||||
|
|
||||||
|
# Create directories if missing
|
||||||
|
mkdir -p "${CLAUDE_DIR}/.claude-plugin"
|
||||||
|
mkdir -p "${CLAUDE_DIR}/hooks/scripts"
|
||||||
|
mkdir -p "${CLAUDE_DIR}/state/personal-assistant/memory"
|
||||||
|
mkdir -p "${CLAUDE_DIR}/state/personal-assistant/history"
|
||||||
|
|
||||||
|
ok "Plugin structure initialized"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Migration: 1.0.x -> 1.1.0
|
||||||
|
if [[ $(compare_versions "$current" "1.1.0") -lt 0 ]] && \
|
||||||
|
[[ $(compare_versions "$target" "1.1.0") -ge 0 ]]; then
|
||||||
|
info "Migration: Adding automation scripts..."
|
||||||
|
|
||||||
|
# Ensure automation directory exists
|
||||||
|
mkdir -p "${CLAUDE_DIR}/automation/systemd"
|
||||||
|
mkdir -p "${CLAUDE_DIR}/logs"
|
||||||
|
|
||||||
|
ok "Automation structure initialized"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
ok "Migrations complete"
|
||||||
|
}
|
||||||
|
|
||||||
|
run_post_upgrade() {
|
||||||
|
echo ""
|
||||||
|
echo "🔧 Running post-upgrade tasks..."
|
||||||
|
|
||||||
|
# Make scripts executable
|
||||||
|
find "${CLAUDE_DIR}/automation" -name "*.sh" -type f -exec chmod +x {} \; 2>/dev/null || true
|
||||||
|
find "${CLAUDE_DIR}/automation" -name "*.py" -type f -exec chmod +x {} \; 2>/dev/null || true
|
||||||
|
find "${CLAUDE_DIR}/hooks/scripts" -name "*.sh" -type f -exec chmod +x {} \; 2>/dev/null || true
|
||||||
|
|
||||||
|
ok "Scripts made executable"
|
||||||
|
|
||||||
|
# Validate
|
||||||
|
if "${CLAUDE_DIR}/automation/validate-setup.sh" > /dev/null 2>&1; then
|
||||||
|
ok "Validation passed"
|
||||||
|
else
|
||||||
|
warn "Validation had warnings (run claude-validate to see details)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
}
|
||||||
|
|
||||||
|
show_usage() {
|
||||||
|
echo "Usage: $0 [--check|--backup|--apply TARGET_VERSION]"
|
||||||
|
echo ""
|
||||||
|
echo "Options:"
|
||||||
|
echo " --check Check for available upgrades"
|
||||||
|
echo " --backup Create pre-upgrade backup"
|
||||||
|
echo " --apply Apply migrations (requires TARGET_VERSION)"
|
||||||
|
echo ""
|
||||||
|
echo "Examples:"
|
||||||
|
echo " $0 --check"
|
||||||
|
echo " $0 --backup && git pull && $0 --apply 1.2.0"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Main
|
||||||
|
case "${1:-}" in
|
||||||
|
--check)
|
||||||
|
check_upgrade
|
||||||
|
;;
|
||||||
|
--backup)
|
||||||
|
pre_upgrade_backup
|
||||||
|
;;
|
||||||
|
--apply)
|
||||||
|
if [[ -z "${2:-}" ]]; then
|
||||||
|
error "TARGET_VERSION required for --apply"
|
||||||
|
show_usage
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
pre_upgrade_backup
|
||||||
|
apply_migrations "$(get_current_version)" "$2"
|
||||||
|
echo "$2" > "$VERSION_FILE"
|
||||||
|
run_post_upgrade
|
||||||
|
ok "Upgrade to $2 complete!"
|
||||||
|
;;
|
||||||
|
--help|-h)
|
||||||
|
show_usage
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
check_upgrade
|
||||||
|
;;
|
||||||
|
esac
|
||||||
129
docs/QUICK-REFERENCE.md
Normal file
129
docs/QUICK-REFERENCE.md
Normal file
@@ -0,0 +1,129 @@
|
|||||||
|
# Claude Code Quick Reference
|
||||||
|
|
||||||
|
## Commands
|
||||||
|
|
||||||
|
### Core
|
||||||
|
| Command | Description |
|
||||||
|
|---------|-------------|
|
||||||
|
| `/pa <request>` | Ask the personal assistant |
|
||||||
|
| `/help` | Show all commands and skills |
|
||||||
|
| `/status` | Dashboard overview |
|
||||||
|
| `/config` | View/manage settings |
|
||||||
|
|
||||||
|
### Memory
|
||||||
|
| Command | Description |
|
||||||
|
|---------|-------------|
|
||||||
|
| `/remember <text>` | Save to memory |
|
||||||
|
| `/search <query>` | Search memory, history, config |
|
||||||
|
| `/summarize` | Summarize session to memory |
|
||||||
|
| `/export [id]` | Export session for sharing |
|
||||||
|
|
||||||
|
### Maintenance
|
||||||
|
| Command | Description |
|
||||||
|
|---------|-------------|
|
||||||
|
| `/maintain backup` | Create backup |
|
||||||
|
| `/maintain validate` | Validate config |
|
||||||
|
| `/maintain clean` | Clean old files |
|
||||||
|
| `/debug` | Debug report |
|
||||||
|
| `/log` | View logs |
|
||||||
|
| `/mcp-status` | Check MCP integrations |
|
||||||
|
|
||||||
|
### Domain: System
|
||||||
|
| Command | Description |
|
||||||
|
|---------|-------------|
|
||||||
|
| `/sysadmin:health` | System health check |
|
||||||
|
| `/sysadmin:update` | Update packages |
|
||||||
|
| `/sysadmin:autonomy` | Set autonomy level |
|
||||||
|
|
||||||
|
### Domain: Kubernetes
|
||||||
|
| Command | Description |
|
||||||
|
|---------|-------------|
|
||||||
|
| `/k8s:cluster-status` | Cluster health |
|
||||||
|
| `/k8s:deploy` | Deploy app |
|
||||||
|
| `/k8s:diagnose` | Troubleshoot |
|
||||||
|
|
||||||
|
### Other
|
||||||
|
| Command | Description |
|
||||||
|
|---------|-------------|
|
||||||
|
| `/gcal` | Calendar access |
|
||||||
|
| `/usage` | Usage statistics |
|
||||||
|
| `/programmer` | Code development |
|
||||||
|
|
||||||
|
## Shell Aliases
|
||||||
|
|
||||||
|
After sourcing completions:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
claude-status # Quick dashboard
|
||||||
|
claude-validate # Validate config
|
||||||
|
claude-backup # Create backup
|
||||||
|
claude-restore # Restore backup
|
||||||
|
claude-clean # Clean old files
|
||||||
|
claude-search # Search memory
|
||||||
|
claude-history # Browse sessions
|
||||||
|
claude-memory-add # Add to memory
|
||||||
|
claude-memory-list # List memory
|
||||||
|
claude-log # View logs
|
||||||
|
claude-debug # Debug report
|
||||||
|
claude-export # Export session
|
||||||
|
claude-mcp # MCP status
|
||||||
|
claude-test # Run tests
|
||||||
|
claude-install # First-time setup
|
||||||
|
claude-maintenance # Run maintenance
|
||||||
|
```
|
||||||
|
|
||||||
|
## Key Paths
|
||||||
|
|
||||||
|
```
|
||||||
|
~/.claude/
|
||||||
|
├── CLAUDE.md # Agent instructions
|
||||||
|
├── VERSION # Current version
|
||||||
|
├── automation/ # Scripts and tools
|
||||||
|
├── state/
|
||||||
|
│ ├── component-registry.json # Routing config
|
||||||
|
│ ├── personal-assistant/
|
||||||
|
│ │ ├── memory/ # Preferences, decisions, etc.
|
||||||
|
│ │ └── history/ # Session history
|
||||||
|
│ └── sysadmin/ # Sysadmin state
|
||||||
|
├── skills/ # Skill definitions
|
||||||
|
├── commands/ # Command definitions
|
||||||
|
├── agents/ # Agent personas
|
||||||
|
├── workflows/ # Workflow definitions
|
||||||
|
├── hooks/ # Event hooks
|
||||||
|
└── logs/ # Log files
|
||||||
|
```
|
||||||
|
|
||||||
|
## PA Flags
|
||||||
|
|
||||||
|
```
|
||||||
|
/pa --context none|minimal|moderate|comprehensive -- <request>
|
||||||
|
/pa --remember -- "<instruction>"
|
||||||
|
/pa --list-mem
|
||||||
|
/pa --forget <uuid>
|
||||||
|
/pa --show-config
|
||||||
|
```
|
||||||
|
|
||||||
|
## Autonomy Levels
|
||||||
|
|
||||||
|
| Level | Behavior |
|
||||||
|
|-------|----------|
|
||||||
|
| `conservative` | Confirm all writes (default) |
|
||||||
|
| `balanced` | Confirm destructive only |
|
||||||
|
| `aggressive` | Auto-execute most |
|
||||||
|
| `autonomous` | Full auto (careful!) |
|
||||||
|
|
||||||
|
Set with: `/sysadmin:autonomy <level>`
|
||||||
|
|
||||||
|
## Troubleshooting
|
||||||
|
|
||||||
|
1. **Config issues?** → `claude-validate`
|
||||||
|
2. **Something broken?** → `claude-debug`
|
||||||
|
3. **Check integrations?** → `claude-mcp`
|
||||||
|
4. **View what happened?** → `claude-log`
|
||||||
|
5. **Restore backup?** → `claude-restore`
|
||||||
|
|
||||||
|
## Getting Help
|
||||||
|
|
||||||
|
- `/help` - List all commands
|
||||||
|
- `/pa help me with <topic>` - Ask for guidance
|
||||||
|
- Check `~/.claude/docs/` for documentation
|
||||||
Reference in New Issue
Block a user