mirror of
https://github.com/qwibitai/nanoclaw.git
synced 2026-06-04 10:14:47 +08:00
fe942dd3dd
Major version for the v2 rewrite. CHANGELOG documents the breaking changes users will hit on upgrade: new entity model, two-DB session split, `bash nanoclaw.sh` as default install, channels/providers relocated to sibling branches, three-level isolation, Apple Container removed from default setup. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
7.3 KiB
7.3 KiB
Changelog
All notable changes to NanoClaw will be documented in this file.
For detailed release notes, see the full changelog on the documentation site.
[2.0.0] - 2026-04-22
Major version. NanoClaw v2 is a substantial architectural rewrite. Existing forks should run /migrate-nanoclaw (clean-base replay of customizations) or /update-nanoclaw (selective cherry-pick) before resuming work.
- [BREAKING] New entity model. Users, roles (owner/admin), messaging groups, and agent groups are now tracked as separate entities, wired via
messaging_group_agents. Privilege is user-level instead of channel-level, so the old "main channel = admin" concept is retired. See docs/architecture.md and docs/isolation-model.md. - [BREAKING] Two-DB session split. Each session now has
inbound.db(host writes, container reads) andoutbound.db(container writes, host reads) with exactly one writer each. Replaces the single shared session DB and eliminates cross-mount SQLite contention. See docs/db-session.md. - [BREAKING] Install flow replaced.
bash nanoclaw.shis the new default: a scripted installer that hands off to Claude Code for error recovery and guided decisions. The/setupClaude-guided skill still works as an alternative. - [BREAKING] Channels moved to the
channelsbranch. Trunk no longer ships Discord, Slack, Telegram, WhatsApp, iMessage, Teams, Linear, GitHub, WeChat, Matrix, Google Chat, Webex, Resend, or WhatsApp Cloud. Install them per fork via/add-<channel>skills, which copy from thechannelsbranch./update-nanoclawwill re-install the channels your fork had. - [BREAKING] Alternative providers moved to the
providersbranch. OpenCode, Codex, and Ollama install via/add-opencode,/add-codex,/add-ollama-provider. Claude remains the default provider baked into trunk. - [BREAKING] Three-level channel isolation. Wire channels to their own agent (separate agent groups), share an agent with independent conversations (
session_mode: 'shared'), or merge channels into one shared session (session_mode: 'agent-shared'). Chosen per channel via/manage-channels. - [BREAKING] Apple Container removed from default setup. Still available as an opt-in via
/convert-to-apple-container. - Shared-source agent-runner. Per-group
agent-runner-src/overlays are gone; all groups mount the same agent-runner read-only. Per-group customization flows through composedCLAUDE.md(shared base + per-group fragments). - Agent-runner runtime moved from Node to Bun. Container image is self-contained; no host-side impact. Host remains on Node + pnpm.
- OneCLI Agent Vault is the sole credential path. Containers never receive raw API keys; credentials are injected at request time.
[1.2.36] - 2026-03-26
- [BREAKING] Replaced pino logger with built-in logger. WhatsApp users must re-merge the WhatsApp fork to pick up the Baileys logger compatibility fix:
git fetch whatsapp main && git merge whatsapp/main. If thewhatsappremote is not configured:git remote add whatsapp https://github.com/qwibitai/nanoclaw-whatsapp.git.
[1.2.35] - 2026-03-26
- [BREAKING] OneCLI Agent Vault replaces the built-in credential proxy. Check your runtime:
grep CONTAINER_RUNTIME_BIN src/container-runtime.ts— if it shows'container'you are on Apple Container, if'docker'you are on Docker. Docker users: run/init-oneclito install OneCLI and migrate.envcredentials to the vault. Apple Container users: re-merge the skill branch (git fetch upstream skill/apple-container && git merge upstream/skill/apple-container) then run/convert-to-apple-containerand follow all instructions (configures credential proxy networking) — do NOT run/init-onecli, it requires Docker.
[1.2.21] - 2026-03-22
- Added opt-in diagnostics via PostHog with explicit user consent (Yes / No / Never ask again)
[1.2.20] - 2026-03-21
- Added ESLint configuration with error-handling rules
[1.2.19] - 2026-03-19
- Reduced
docker stoptimeout for faster container restarts (-t 1flag)
[1.2.18] - 2026-03-19
- User prompt content no longer logged on container errors — only input metadata
- Added Japanese README translation
[1.2.17] - 2026-03-18
- Added
/capabilitiesand/statuscontainer-agent skills
[1.2.16] - 2026-03-18
- Tasks snapshot now refreshes immediately after IPC task mutations
[1.2.15] - 2026-03-16
- Fixed remote-control prompt auto-accept to prevent immediate exit
- Added
KillMode=processso remote-control survives service restarts
[1.2.14] - 2026-03-14
- Added
/remote-controlcommand for host-level Claude Code access from within containers
[1.2.13] - 2026-03-14
Breaking: Skills are now git branches, channels are separate fork repos.
- Skills live as
skill/*git branches merged viagit merge - Added Docker Sandboxes support
- Fixed setup registration to use correct CLI commands
[1.2.12] - 2026-03-08
- Added
/compactskill for manual context compaction - Enhanced container environment isolation via credential proxy
[1.2.11] - 2026-03-08
- Added PDF reader, image vision, and WhatsApp reactions skills
- Fixed task container to close promptly when agent uses IPC-only messaging
[1.2.10] - 2026-03-06
- Added
LIMITto unbounded message history queries for better performance
[1.2.9] - 2026-03-06
- Agent prompts now include timezone context for accurate time references
[1.2.8] - 2026-03-06
- Fixed misleading
send_messagetool description for scheduled tasks
[1.2.7] - 2026-03-06
- Added
/add-ollamaskill for local model inference - Added
update_tasktool and return task ID fromschedule_task
[1.2.6] - 2026-03-04
- Updated
claude-agent-sdkto 0.2.68
[1.2.5] - 2026-03-04
- CI formatting fix
[1.2.4] - 2026-03-04
- Fixed
_chatJidrename tochatJidinonMessagecallback
[1.2.3] - 2026-03-04
- Added sender allowlist for per-chat access control
[1.2.2] - 2026-03-04
- Added
/use-local-whisperskill for local voice transcription - Atomic task claims prevent scheduled tasks from executing twice
[1.2.1] - 2026-03-02
- Version bump (no functional changes)
[1.2.0] - 2026-03-02
Breaking: WhatsApp removed from core, now a skill. Run /add-whatsapp to re-add.
- Channel registry: channels self-register at startup via
registerChannel()factory pattern isMainflag replaces folder-name-based main group detectionENABLED_CHANNELSremoved — channels detected by credential presence- Prevent scheduled tasks from executing twice when container runtime exceeds poll interval
[1.1.6] - 2026-03-01
- Added CJK font support for Chromium screenshots
[1.1.5] - 2026-03-01
- Fixed wrapped WhatsApp message normalization
[1.1.4] - 2026-03-01
- Added third-party model support
- Added
/update-nanoclawskill for syncing with upstream
[1.1.3] - 2026-02-25
- Added
/add-slackskill - Restructured Gmail skill for new architecture
[1.1.2] - 2026-02-24
- Improved error handling for WhatsApp Web version fetch
[1.1.1] - 2026-02-24
- Added Qodo skills and codebase intelligence
- Fixed WhatsApp 405 connection failures
[1.1.0] - 2026-02-23
- Added
/updateskill to pull upstream changes from within Claude Code - Enhanced container environment isolation via credential proxy