跳至主要内容
小龙虾小龙虾AI
🤖

Smart Git Backup

Automates the backup of the OpenClaw workspace to a remote Git repository. Handles large file exclusions, validates git configuration, and performs intelligent sync with conflict resolution.

下载519
星标2
版本1.0.0
开发工具
安全通过
💬Prompt

技能说明


name: memory-git-sync description: Automates the backup of the OpenClaw workspace to a remote Git repository. Handles large file exclusions, validates git configuration, and performs intelligent sync with conflict resolution. metadata: openclaw: emoji: "📦" requires: bins: - bash - git compatibility: bash: "4.0 or higher" git: "2.0 or higher" system_requirements: - "Write access to repository directory" - "Access to remote Git repository (GitHub, GitLab, etc.)" configuration_required: - "Git user.name configured locally or globally" - "Git user.email configured locally or globally" - "Remote 'origin' configured in Git" - "Git credentials properly stored (credential helper or SSH key)" runtime_requirements: - "Network connectivity to push/pull from remote" - "Read/write access to .git directory and working tree" tags: - "git" - "backup" - "sync" - "automation"

Memory Sync Skill

Automates Git synchronization and backup of workspace memory to a remote repository.

Quick Start

bash ./scripts/sync.sh [COMMIT_MESSAGE]

Default message: chore: memory backup YYYY-MM-DD HH:MM

What It Does

  1. Validates Git repository, user config, and remote access
  2. Detects & excludes large files (>95MB) to prevent push failures
  3. Stages all changes automatically
  4. Pulls latest remote changes to avoid conflicts
  5. Commits changes with timestamped or custom message
  6. Pushes to remote, setting upstream if needed

Prerequisites

✓ Git repository initialized with origin remote ✓ git config user.name and git config user.email set ✓ Network access to remote repository ✓ Write permissions on repository directory

Execution Steps

StepActionSuccess OutputFailure OutputExit
1Validate Git repo[SUCCESS] Git repository found[ERROR] Not inside a git repository1
2Check Git config[SUCCESS] Git user configuration is valid[ERROR] Git user.name not configured1
3Check remote[SUCCESS] Remote 'origin' configured: [URL][ERROR] No 'origin' remote1
4Setup .gitignore[SUCCESS] Gitignore file is ready--
5Scan large files[SUCCESS] No large files detected[WARNING] Large files detected-
6Detect changes[SUCCESS] All changes staged[INFO] No uncommitted changes0
7Fetch remote[SUCCESS] Successfully fetched[WARNING] Fetch failed (continues)-
8Check sync[INFO] Local and remote synchronized[WARNING] Branches diverged (auto-pull)1*
9Commit[SUCCESS] Changes committed[ERROR] Commit failed1
10Push[SUCCESS] Successfully pushed[WARNING] No upstream (tries to set)1**
DoneComplete[SUCCESS] Sync completed-0

*Auto-resolves with git pull --no-edit **Auto-sets upstream with git push --set-upstream origin [branch]

Output Format

All messages use structured prefixes for LLM parsing:

[INFO]    - Informational messages
[SUCCESS] - Actions completed successfully
[WARNING] - Non-fatal issues (script recovers)
[ERROR]   - Fatal errors (requires intervention)

Common Scenarios

IssueOutputResolution
Not in a Git repo[ERROR] Not inside a git repositoryNavigate to repo: cd /path/to/repo
Missing user.name[ERROR] Git user.name not configuredgit config user.name "Name"
Missing user.email[ERROR] Git user.email not configuredgit config user.email "email@example.com"
No origin remote[ERROR] No 'origin' remote configuredgit remote add origin <URL>
Large files detected[WARNING] Large files detectedAutomatically added to .gitignore
Pull conflicts[ERROR] Pull encountered conflictsResolve manually, then run sync again
Network failures[WARNING] Fetch/Push failedCheck connectivity, script continues locally

Features

  • Auto Large-File Handling: Prevents Git failures by ignoring files >95MB
  • Conflict Resolution: Auto-pulls remote before pushing
  • Upstream Setup: Auto-configures tracking on first push
  • Validation: Pre-flight checks prevent common errors
  • LLM-Compatible Output: Structured logs for easy parsing

Security Notes

  • Don't commit credentials to the repository
  • Use SSH keys or credential helpers: git config credential.helper osxkeychain
  • Review changes before syncing: git status
  • Large files already pushed can't be auto-removed by this script

如何使用「Smart Git Backup」?

  1. 打开小龙虾AI(Web 或 iOS App)
  2. 点击上方「立即使用」按钮,或在对话框中输入任务描述
  3. 小龙虾AI 会自动匹配并调用「Smart Git Backup」技能完成任务
  4. 结果即时呈现,支持继续对话优化

相关技能