Install
openclaw skills install restic-workstation-backupDesign, implement, and operate encrypted restic backups for Linux home directories with encryption, deduplication, automated scheduling, and restore testing. Use when a user asks to back up ~/, set up daily/weekly/monthly backup jobs, harden backup security, troubleshoot restore/integrity issues, or roll out backup automation across multiple workstations.
openclaw skills install restic-workstation-backupDeliver a production-ready, unattended restic backup workflow for a Linux home directory, covering encryption, deduplication, versioned retention, systemd scheduling, retry logic, durable logging, email alerting, and restore validation.
restic-home-backup2.0.0local, sftp, s3, b2, etc.)America/Los_Angeles)/usr/local/bin/references/runbook.md)references/ops-checklist.md)--apply for system changes.--dry-run-prune to preview.Minimum required:
/home/alice)sftp:backupsvc@10.50.8.24:/srv/backups/home/devbox17)If any critical value is missing, ask targeted questions.
bash scripts/bootstrap_restic_home.sh \
--user alice \
--repo "sftp:backupsvc@10.50.8.24:/srv/backups/home/devbox17"
This prints the complete plan: files, schedule, retention, secrets approach, retry logic, legacy cron archival, and dry-run prune preview. Zero changes made.
sudo bash scripts/bootstrap_restic_home.sh \
--user alice \
--repo "sftp:backupsvc@10.50.8.24:/srv/backups/home/devbox17" \
--hostname devbox17 \
--timezone "America/Los_Angeles" \
--mail-to sre-oncall@example.com \
--keep-daily 14 --keep-weekly 8 --keep-monthly 12 \
--config-dir /etc/home-backup \
--log-dir /var/log/home-backup \
--apply \
--init-repo \
--enable-timers \
--run-initial-backup \
--archive-legacy-cron \
--dry-run-prune
What this does (in order):
/etc/home-backup/ (0700), generates password (0600, never printed)/var/log/home-backup/restic-home-log-run.sh)daemon-reloadrestic forget --dry-run output (no deletion)bash scripts/install_userlevel_restic.sh \
--repo /mnt/offsite/backups/labvm3-home \
--hostname labvm3 \
--timezone "America/Los_Angeles" \
--mail-to sre-oncall@example.com \
--apply --init-repo --enable-timers --run-initial-backup
# Enable linger (one-time, requires sudo):
sudo loginctl enable-linger bob
# Manage:
systemctl --user list-timers 'restic-home-*' # list
systemctl --user start restic-home-backup.service # manual backup
bash scripts/install_userlevel_restic.sh --remove # remove schedule
sudo bash scripts/validate_restic_setup.sh
Runs:
/tmp/restore-drill (verifies .ssh/config,
Documents/roadmap.md, .config/git/config)The bootstrap creates restic-home-audit.timer for a single scheduled restore
drill. By default: 2026-04-17 17:00:00 America/Los_Angeles.
# Inspect:
systemctl list-timers restic-home-audit.timer --no-pager
# Cancel:
systemctl disable --now restic-home-audit.timer
# Run now:
systemctl start restic-home-audit.service
# Validate skill structure:
clawhub validate .
# Publish:
clawhub publish .
# Verify clean install (fresh environment, no secrets carried over):
mkdir /tmp/clawhub-verify && cd /tmp/clawhub-verify
clawhub install restic-home-backup
# Run plan-only to confirm scripts are present and executable:
bash restic-home-backup/scripts/bootstrap_restic_home.sh \
--user testuser --repo sftp:test@localhost:/test
scripts/
bootstrap_restic_home.sh System-level install (plan + apply)
install_userlevel_restic.sh User-level install for non-root hosts
validate_restic_setup.sh End-to-end validation + failure drills
references/
runbook.md Full operator runbook (13 sections)
ops-checklist.md Quick daily/weekly/monthly reference
references/runbook.md for day-2 operational guidance.