migrate-nanoclaw
The migrate-nanoclaw skill extracts user customizations from a forked NanoClaw repository into a structured migration guide, then applies those customizations to a clean upstream version in an isolated worktree, eliminating merge conflicts during upgrades. Use this when updating a customized NanoClaw fork to incorporate upstream changes while preserving your modifications to configuration, source files, personas, and skills.
git clone --depth 1 https://github.com/nanocoai/nanoclaw /tmp/migrate-nanoclaw && cp -r /tmp/migrate-nanoclaw/.claude/skills/migrate-nanoclaw ~/.claude/skills/migrate-nanoclawSKILL.md
# Context NanoClaw users fork the repo and customize it — changing config values, editing source files, modifying personas, adding skills. When upstream ships updates or refactors, `git merge` produces painful conflicts because the same core files were changed on both sides. This skill extracts the user's customizations into a migration guide — capturing both the intent (what they want) and the implementation details (how they did it, with code snippets, API calls, and specific configurations). On upgrade, it checks out clean upstream in a worktree, then reapplies customizations using the guide. No merge conflicts because there's nothing to merge. The migration guide is markdown, not structured data. It needs to capture the full range of what a user might customize, with enough implementation detail that a fresh Claude session can reapply it without having seen the original code. Standard changes (config values, simple logic) can be described briefly. Non-standard changes (specific APIs, custom integrations, unusual patterns) need code snippets and precise instructions. Two phases: **Extract** (build the migration guide) and **Upgrade** (use it). If a guide already exists, offer to skip to Upgrade. # Principles - Never proceed with a dirty working tree. - Always create a rollback point (backup branch + tag) before touching anything. - The migration guide is the source of truth, not diffs. - Use a worktree to validate before affecting the live install. - Data directories (`groups/`, `store/`, `data/`, `.env`) are never touched — only code. - Be helpful: offer to do things (stash, commit, stop services) rather than telling the user to do them. - **Use sub-agents for exploration.** Spawn haiku sub-agents to explore the codebase, trace skill merges, diff files, and identify customizations. This keeps the main context focused on the user conversation and decision-making. - **Always use absolute paths in worktrees.** The Bash tool resets the working directory between calls. Never use relative `cd .upgrade-worktree` — always use the full absolute path: `cd /absolute/path/.upgrade-worktree && <command>`. Store the worktree absolute path in a variable at creation time and reference it throughout. - **Balance exploration and asking.** Don't bombard the user with questions when you can figure things out from the code. Don't burn endless tokens exploring when the user could clarify in one sentence. Use sub-agents to explore first, then ask the user targeted questions about things that are ambiguous or where intent isn't clear from the code alone. - **Scale effort to complexity.** Not every migration needs the full process. Assess the scope early and take the lightest path that fits. --- # Phase 0: Refresh this skill first The migration process itself evolves, so run its newest version before doing anything else: - Ensure the `upstream` remote exists (default `https://github.com/nanocoai/nanoclaw.git`) and fetch: `git fetch upstream --prune`. Detect the upstream branch (`main` or `master`). - Refresh this skill from upstream: `git checkout upstream/<branch> -- .claude/skills/migrate-nanoclaw/` - Re-read `.claude/skills/migrate-nanoclaw/SKILL.md`. If it changed, **follow the updated version from the top** instead of this one. This is the only working-tree change expected before the preflight check below; changes limited to `.claude/skills/migrate-nanoclaw/` are this self-refresh — ignore them in the 1.0 clean-tree check and proceed. # Phase 1: Extract ## 1.0 Preflight Run `git status --porcelain`. If non-empty, offer to stash or commit for them (AskUserQuestion: "Stash changes" / "Commit changes" / "I'll handle it"). If they want to commit, stage and commit with a descriptive message. If they want to stash, run `git stash push -m "pre-migration stash"`. Check remotes with `git remote -v`. If `upstream` is missing, ask for the URL (default: `https://github.com/nanocoai/nanoclaw.git`), add it, then `git fetch upstream --prune`. Detect upstream branch: check `git branch -r | grep upstream/` for `main` or `master`. Store as UPSTREAM_BRANCH. ## 1.1 Assess scope and determine path Quickly assess the scale of divergence, check for an existing guide, and determine the right approach — all before asking the user anything. ```bash BASE=$(git merge-base HEAD upstream/$UPSTREAM_BRANCH) # Divergence stats git rev-list --count $BASE..upstream/$UPSTREAM_BRANCH # upstream commits git rev-list --count $BASE..HEAD # user commits git diff --name-only $BASE..HEAD | wc -l # user changed files git diff --stat $BASE..HEAD | tail -1 # insertions/deletions git diff --name-only $BASE..upstream/$UPSTREAM_BRANCH | wc -l # upstream changed files ``` Check for existing guide: `.nanoclaw-migrations/guide.md` or `.nanoclaw-migrations/index.md`. **Determine the tier based on the total diff from base:** ### Tier 1: Lightweight — suggest `/update-nanoclaw` instead Conditions (any of): - Very few upstream changes (< ~5 commits) AND few user changes (< ~3 changed files) - User recently updated/migrated (merge-base is close to upstream HEAD) Tell the user the scope is small and suggest `/update-nanoclaw` might be simpler. Let them choose. ### Tier 2: Standard Conditions: - Moderate total diff (3-15 changed files, no large number of new files) - Manageable scope that fits in a single guide file ### Tier 3: Complex Conditions (any of): - Many new files added (indicates many skills applied) — discount files that a skill's own apply owns when assessing complexity; a fork with 3 skills and no other changes is simpler than it looks by file count alone - Deep source changes to core files (`src/index.ts`, `src/container-runner.ts`, etc.) beyond what skills introduced - Lots of insertions/deletions in user-authored code (not skill-owned code) - Many skills applied (3+) AND the user confirms or sub-agents find customizations on top of them Use the full process: mul
Add Atomic Chat MCP server so the container agent can call local models served by the Atomic Chat desktop app via its OpenAI-compatible API.
Use Codex (CLI + AppServer) as the full agent provider — planning, tool orchestration, native compaction, MCP tools, session resume — in place of the Claude Agent SDK. ChatGPT subscription or OPENAI_API_KEY. Per-group via agent_provider. Distinct from using OpenAI as an MCP tool (where Claude remains the planner).
Add a monitoring dashboard to NanoClaw. Installs @nanoco/nanoclaw-dashboard and a pusher that sends periodic JSON snapshots.
Add DeltaChat channel integration via @deltachat/stdio-rpc-server. Native adapter — no Chat SDK bridge. Email-based messaging with end-to-end encryption.
Add Discord bot channel integration via Chat SDK.
Add Emacs as a channel. Opens an interactive chat buffer and org-mode integration so you can talk to NanoClaw from within Emacs (Doom, Spacemacs, or vanilla). Local HTTP bridge — no bot token or external service needed.
Add Google Calendar as an MCP tool (list calendars, list/search/create events, free/busy queries) using OneCLI-managed OAuth. Multi-calendar and multi-account supported. Mirrors /add-gmail-tool's stub pattern — no raw credentials ever reach the container; OneCLI injects real tokens at request time.
Add Google Chat channel integration via Chat SDK.