durar-ai 2026.4.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +5497 -0
- package/LICENSE +21 -0
- package/README.md +614 -0
- package/assets/avatar-placeholder.svg +19 -0
- package/assets/chrome-extension/icons/icon128.png +0 -0
- package/assets/chrome-extension/icons/icon16.png +0 -0
- package/assets/chrome-extension/icons/icon32.png +0 -0
- package/assets/chrome-extension/icons/icon48.png +0 -0
- package/assets/dmg-background-small.png +0 -0
- package/assets/dmg-background.png +0 -0
- package/docs/.i18n/README.md +72 -0
- package/docs/.i18n/ar-navigation.json +18 -0
- package/docs/.i18n/de-navigation.json +18 -0
- package/docs/.i18n/es-navigation.json +18 -0
- package/docs/.i18n/fr-navigation.json +18 -0
- package/docs/.i18n/glossary.ar.json +5 -0
- package/docs/.i18n/glossary.de.json +5 -0
- package/docs/.i18n/glossary.es.json +5 -0
- package/docs/.i18n/glossary.fr.json +5 -0
- package/docs/.i18n/glossary.id.json +5 -0
- package/docs/.i18n/glossary.it.json +5 -0
- package/docs/.i18n/glossary.ja-JP.json +14 -0
- package/docs/.i18n/glossary.ko.json +5 -0
- package/docs/.i18n/glossary.pl.json +5 -0
- package/docs/.i18n/glossary.pt-BR.json +5 -0
- package/docs/.i18n/glossary.tr.json +5 -0
- package/docs/.i18n/glossary.zh-CN.json +358 -0
- package/docs/.i18n/id-navigation.json +18 -0
- package/docs/.i18n/it-navigation.json +18 -0
- package/docs/.i18n/ja-navigation.json +18 -0
- package/docs/.i18n/ko-navigation.json +18 -0
- package/docs/.i18n/pl-navigation.json +18 -0
- package/docs/.i18n/pt-BR-navigation.json +18 -0
- package/docs/.i18n/tr-navigation.json +18 -0
- package/docs/.i18n/zh-Hans-navigation.json +544 -0
- package/docs/assets/install-script.svg +1 -0
- package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
- package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
- package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
- package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
- package/docs/assets/macos-onboarding/05-permissions.png +0 -0
- package/docs/assets/openclaw-logo-text-dark.png +0 -0
- package/docs/assets/openclaw-logo-text-dark.svg +418 -0
- package/docs/assets/openclaw-logo-text.png +0 -0
- package/docs/assets/openclaw-logo-text.svg +418 -0
- package/docs/assets/pixel-lobster.svg +60 -0
- package/docs/assets/showcase/agents-ui.jpg +0 -0
- package/docs/assets/showcase/bambu-cli.png +0 -0
- package/docs/assets/showcase/codexmonitor.png +0 -0
- package/docs/assets/showcase/gohome-grafana.png +0 -0
- package/docs/assets/showcase/ios-testflight.jpg +0 -0
- package/docs/assets/showcase/oura-health.png +0 -0
- package/docs/assets/showcase/padel-cli.svg +11 -0
- package/docs/assets/showcase/padel-screenshot.jpg +0 -0
- package/docs/assets/showcase/papla-tts.jpg +0 -0
- package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
- package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
- package/docs/assets/showcase/roborock-status.svg +13 -0
- package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
- package/docs/assets/showcase/snag.png +0 -0
- package/docs/assets/showcase/tesco-shop.jpg +0 -0
- package/docs/assets/showcase/wienerlinien.png +0 -0
- package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
- package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
- package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
- package/docs/assets/sponsors/blacksmith-light.svg +14 -0
- package/docs/assets/sponsors/blacksmith.svg +14 -0
- package/docs/assets/sponsors/convex-light.svg +16 -0
- package/docs/assets/sponsors/convex.svg +16 -0
- package/docs/assets/sponsors/github-light.svg +3 -0
- package/docs/assets/sponsors/github.svg +3 -0
- package/docs/assets/sponsors/nvidia-dark.svg +9 -0
- package/docs/assets/sponsors/nvidia.svg +9 -0
- package/docs/assets/sponsors/openai-light.svg +3 -0
- package/docs/assets/sponsors/openai.svg +3 -0
- package/docs/assets/sponsors/vercel-light.svg +5 -0
- package/docs/assets/sponsors/vercel.svg +5 -0
- package/docs/auth-credential-semantics.md +80 -0
- package/docs/automation/auth-monitoring.md +8 -0
- package/docs/automation/clawflow.md +8 -0
- package/docs/automation/cron-jobs.md +410 -0
- package/docs/automation/cron-vs-heartbeat.md +8 -0
- package/docs/automation/gmail-pubsub.md +8 -0
- package/docs/automation/hooks.md +303 -0
- package/docs/automation/index.md +115 -0
- package/docs/automation/poll.md +8 -0
- package/docs/automation/standing-orders.md +254 -0
- package/docs/automation/taskflow.md +82 -0
- package/docs/automation/tasks.md +323 -0
- package/docs/automation/troubleshooting.md +8 -0
- package/docs/automation/webhook.md +8 -0
- package/docs/brave-search.md +103 -0
- package/docs/channels/bluebubbles.md +435 -0
- package/docs/channels/broadcast-groups.md +442 -0
- package/docs/channels/channel-routing.md +139 -0
- package/docs/channels/discord.md +1254 -0
- package/docs/channels/feishu.md +793 -0
- package/docs/channels/googlechat.md +270 -0
- package/docs/channels/group-messages.md +84 -0
- package/docs/channels/groups.md +410 -0
- package/docs/channels/imessage.md +427 -0
- package/docs/channels/index.md +50 -0
- package/docs/channels/irc.md +252 -0
- package/docs/channels/line.md +225 -0
- package/docs/channels/location.md +56 -0
- package/docs/channels/matrix.md +869 -0
- package/docs/channels/mattermost.md +472 -0
- package/docs/channels/msteams.md +805 -0
- package/docs/channels/nextcloud-talk.md +149 -0
- package/docs/channels/nostr.md +252 -0
- package/docs/channels/pairing.md +129 -0
- package/docs/channels/qqbot.md +193 -0
- package/docs/channels/signal.md +337 -0
- package/docs/channels/slack.md +681 -0
- package/docs/channels/synology-chat.md +185 -0
- package/docs/channels/telegram.md +1072 -0
- package/docs/channels/tlon.md +290 -0
- package/docs/channels/troubleshooting.md +133 -0
- package/docs/channels/twitch.md +394 -0
- package/docs/channels/whatsapp.md +488 -0
- package/docs/channels/zalo.md +254 -0
- package/docs/channels/zalouser.md +195 -0
- package/docs/ci.md +66 -0
- package/docs/cli/acp.md +316 -0
- package/docs/cli/agent.md +57 -0
- package/docs/cli/agents.md +220 -0
- package/docs/cli/approvals.md +136 -0
- package/docs/cli/backup.md +84 -0
- package/docs/cli/browser.md +233 -0
- package/docs/cli/channels.md +131 -0
- package/docs/cli/clawbot.md +21 -0
- package/docs/cli/completion.md +35 -0
- package/docs/cli/config.md +353 -0
- package/docs/cli/configure.md +70 -0
- package/docs/cli/cron.md +167 -0
- package/docs/cli/daemon.md +57 -0
- package/docs/cli/dashboard.md +22 -0
- package/docs/cli/devices.md +171 -0
- package/docs/cli/directory.md +63 -0
- package/docs/cli/dns.md +48 -0
- package/docs/cli/docs.md +28 -0
- package/docs/cli/doctor.md +63 -0
- package/docs/cli/flows.md +18 -0
- package/docs/cli/gateway.md +307 -0
- package/docs/cli/health.md +36 -0
- package/docs/cli/hooks.md +337 -0
- package/docs/cli/index.md +1836 -0
- package/docs/cli/logs.md +59 -0
- package/docs/cli/mcp.md +505 -0
- package/docs/cli/memory.md +139 -0
- package/docs/cli/message.md +300 -0
- package/docs/cli/models.md +136 -0
- package/docs/cli/node.md +137 -0
- package/docs/cli/nodes.md +66 -0
- package/docs/cli/onboard.md +171 -0
- package/docs/cli/pairing.md +65 -0
- package/docs/cli/plugins.md +305 -0
- package/docs/cli/qr.md +52 -0
- package/docs/cli/reset.md +35 -0
- package/docs/cli/sandbox.md +197 -0
- package/docs/cli/secrets.md +197 -0
- package/docs/cli/security.md +86 -0
- package/docs/cli/sessions.md +113 -0
- package/docs/cli/setup.md +45 -0
- package/docs/cli/skills.md +59 -0
- package/docs/cli/status.md +35 -0
- package/docs/cli/system.md +71 -0
- package/docs/cli/tui.md +30 -0
- package/docs/cli/uninstall.md +39 -0
- package/docs/cli/update.md +113 -0
- package/docs/cli/voicecall.md +34 -0
- package/docs/cli/webhooks.md +91 -0
- package/docs/concepts/agent-loop.md +168 -0
- package/docs/concepts/agent-workspace.md +246 -0
- package/docs/concepts/agent.md +129 -0
- package/docs/concepts/architecture.md +156 -0
- package/docs/concepts/compaction.md +122 -0
- package/docs/concepts/context-engine.md +274 -0
- package/docs/concepts/context.md +179 -0
- package/docs/concepts/delegate-architecture.md +307 -0
- package/docs/concepts/dreaming.md +173 -0
- package/docs/concepts/features.md +76 -0
- package/docs/concepts/markdown-formatting.md +130 -0
- package/docs/concepts/memory-builtin.md +105 -0
- package/docs/concepts/memory-honcho.md +140 -0
- package/docs/concepts/memory-qmd.md +163 -0
- package/docs/concepts/memory-search.md +141 -0
- package/docs/concepts/memory.md +121 -0
- package/docs/concepts/messages.md +161 -0
- package/docs/concepts/model-failover.md +349 -0
- package/docs/concepts/model-providers.md +799 -0
- package/docs/concepts/models.md +255 -0
- package/docs/concepts/multi-agent.md +615 -0
- package/docs/concepts/oauth.md +225 -0
- package/docs/concepts/presence.md +102 -0
- package/docs/concepts/queue.md +89 -0
- package/docs/concepts/retry.md +69 -0
- package/docs/concepts/session-pruning.md +92 -0
- package/docs/concepts/session-tool.md +141 -0
- package/docs/concepts/session.md +116 -0
- package/docs/concepts/soul.md +110 -0
- package/docs/concepts/streaming.md +161 -0
- package/docs/concepts/system-prompt.md +182 -0
- package/docs/concepts/timezone.md +97 -0
- package/docs/concepts/typebox.md +307 -0
- package/docs/concepts/typing-indicators.md +69 -0
- package/docs/concepts/usage-tracking.md +59 -0
- package/docs/date-time.md +128 -0
- package/docs/debug/node-issue.md +85 -0
- package/docs/diagnostics/flags.md +91 -0
- package/docs/docs.json +1601 -0
- package/docs/gateway/authentication.md +218 -0
- package/docs/gateway/background-process.md +131 -0
- package/docs/gateway/bonjour.md +179 -0
- package/docs/gateway/bridge-protocol.md +89 -0
- package/docs/gateway/cli-backends.md +310 -0
- package/docs/gateway/configuration-examples.md +631 -0
- package/docs/gateway/configuration-reference.md +3618 -0
- package/docs/gateway/configuration.md +698 -0
- package/docs/gateway/discovery.md +141 -0
- package/docs/gateway/doctor.md +494 -0
- package/docs/gateway/gateway-lock.md +37 -0
- package/docs/gateway/health.md +61 -0
- package/docs/gateway/heartbeat.md +443 -0
- package/docs/gateway/index.md +367 -0
- package/docs/gateway/local-models.md +163 -0
- package/docs/gateway/logging.md +113 -0
- package/docs/gateway/multiple-gateways.md +120 -0
- package/docs/gateway/network-model.md +25 -0
- package/docs/gateway/openai-http-api.md +280 -0
- package/docs/gateway/openresponses-http-api.md +340 -0
- package/docs/gateway/openshell.md +307 -0
- package/docs/gateway/pairing.md +138 -0
- package/docs/gateway/protocol.md +588 -0
- package/docs/gateway/remote-gateway-readme.md +164 -0
- package/docs/gateway/remote.md +251 -0
- package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +141 -0
- package/docs/gateway/sandboxing.md +473 -0
- package/docs/gateway/secrets-plan-contract.md +116 -0
- package/docs/gateway/secrets.md +541 -0
- package/docs/gateway/security/index.md +1362 -0
- package/docs/gateway/tailscale.md +136 -0
- package/docs/gateway/tools-invoke-http-api.md +161 -0
- package/docs/gateway/troubleshooting.md +451 -0
- package/docs/gateway/trusted-proxy-auth.md +399 -0
- package/docs/help/debugging.md +168 -0
- package/docs/help/environment.md +165 -0
- package/docs/help/faq.md +3244 -0
- package/docs/help/index.md +28 -0
- package/docs/help/scripts.md +27 -0
- package/docs/help/testing.md +640 -0
- package/docs/help/troubleshooting.md +372 -0
- package/docs/images/configure-model-picker-unsearchable.png +0 -0
- package/docs/images/feishu-step2-create-app.png +0 -0
- package/docs/images/feishu-step3-credentials.png +0 -0
- package/docs/images/feishu-step4-permissions.png +0 -0
- package/docs/images/feishu-step5-bot-capability.png +0 -0
- package/docs/images/feishu-step6-event-subscription.png +0 -0
- package/docs/images/feishu-verification-token.png +0 -0
- package/docs/images/groups-flow.svg +52 -0
- package/docs/images/mobile-ui-screenshot.png +0 -0
- package/docs/index.md +196 -0
- package/docs/install/ansible.md +230 -0
- package/docs/install/azure.md +311 -0
- package/docs/install/bun.md +55 -0
- package/docs/install/clawdock.md +106 -0
- package/docs/install/development-channels.md +131 -0
- package/docs/install/digitalocean.md +129 -0
- package/docs/install/docker-vm-runtime.md +142 -0
- package/docs/install/docker.md +412 -0
- package/docs/install/exe-dev.md +133 -0
- package/docs/install/fly.md +504 -0
- package/docs/install/gcp.md +412 -0
- package/docs/install/hetzner.md +259 -0
- package/docs/install/index.md +212 -0
- package/docs/install/installer.md +443 -0
- package/docs/install/kubernetes.md +192 -0
- package/docs/install/macos-vm.md +281 -0
- package/docs/install/migrating-matrix.md +349 -0
- package/docs/install/migrating.md +112 -0
- package/docs/install/nix.md +89 -0
- package/docs/install/node.md +144 -0
- package/docs/install/northflank.mdx +42 -0
- package/docs/install/oracle.md +158 -0
- package/docs/install/podman.md +210 -0
- package/docs/install/railway.mdx +90 -0
- package/docs/install/raspberry-pi.md +159 -0
- package/docs/install/render.mdx +165 -0
- package/docs/install/uninstall.md +128 -0
- package/docs/install/updating.md +142 -0
- package/docs/logging.md +389 -0
- package/docs/nav-tabs-underline.js +100 -0
- package/docs/network.md +69 -0
- package/docs/nodes/audio.md +191 -0
- package/docs/nodes/camera.md +162 -0
- package/docs/nodes/images.md +73 -0
- package/docs/nodes/index.md +408 -0
- package/docs/nodes/location-command.md +98 -0
- package/docs/nodes/media-understanding.md +432 -0
- package/docs/nodes/talk.md +92 -0
- package/docs/nodes/troubleshooting.md +123 -0
- package/docs/nodes/voicewake.md +66 -0
- package/docs/perplexity.md +181 -0
- package/docs/pi-dev.md +80 -0
- package/docs/pi.md +570 -0
- package/docs/platforms/android.md +244 -0
- package/docs/platforms/digitalocean.md +266 -0
- package/docs/platforms/index.md +55 -0
- package/docs/platforms/ios.md +223 -0
- package/docs/platforms/linux.md +100 -0
- package/docs/platforms/mac/bundled-gateway.md +75 -0
- package/docs/platforms/mac/canvas.md +125 -0
- package/docs/platforms/mac/child-process.md +69 -0
- package/docs/platforms/mac/dev-setup.md +107 -0
- package/docs/platforms/mac/health.md +34 -0
- package/docs/platforms/mac/icon.md +31 -0
- package/docs/platforms/mac/logging.md +57 -0
- package/docs/platforms/mac/menu-bar.md +81 -0
- package/docs/platforms/mac/peekaboo.md +65 -0
- package/docs/platforms/mac/permissions.md +50 -0
- package/docs/platforms/mac/remote.md +84 -0
- package/docs/platforms/mac/signing.md +47 -0
- package/docs/platforms/mac/skills.md +40 -0
- package/docs/platforms/mac/voice-overlay.md +60 -0
- package/docs/platforms/mac/voicewake.md +67 -0
- package/docs/platforms/mac/webchat.md +51 -0
- package/docs/platforms/mac/xpc.md +61 -0
- package/docs/platforms/macos.md +229 -0
- package/docs/platforms/oracle.md +305 -0
- package/docs/platforms/raspberry-pi.md +420 -0
- package/docs/platforms/windows.md +241 -0
- package/docs/plugins/agent-tools.md +10 -0
- package/docs/plugins/architecture.md +1609 -0
- package/docs/plugins/building-extensions.md +10 -0
- package/docs/plugins/building-plugins.md +319 -0
- package/docs/plugins/bundles.md +292 -0
- package/docs/plugins/community.md +149 -0
- package/docs/plugins/manifest.md +412 -0
- package/docs/plugins/sdk-channel-plugins.md +508 -0
- package/docs/plugins/sdk-entrypoints.md +210 -0
- package/docs/plugins/sdk-migration.md +359 -0
- package/docs/plugins/sdk-overview.md +475 -0
- package/docs/plugins/sdk-provider-plugins.md +712 -0
- package/docs/plugins/sdk-runtime.md +381 -0
- package/docs/plugins/sdk-setup.md +516 -0
- package/docs/plugins/sdk-testing.md +263 -0
- package/docs/plugins/voice-call.md +466 -0
- package/docs/plugins/zalouser.md +78 -0
- package/docs/prose.md +134 -0
- package/docs/providers/anthropic.md +402 -0
- package/docs/providers/bedrock-mantle.md +91 -0
- package/docs/providers/bedrock.md +273 -0
- package/docs/providers/chutes.md +103 -0
- package/docs/providers/claude-max-api-proxy.md +163 -0
- package/docs/providers/cloudflare-ai-gateway.md +71 -0
- package/docs/providers/deepgram.md +93 -0
- package/docs/providers/deepseek.md +53 -0
- package/docs/providers/fireworks.md +69 -0
- package/docs/providers/github-copilot.md +80 -0
- package/docs/providers/glm.md +68 -0
- package/docs/providers/google.md +149 -0
- package/docs/providers/groq.md +105 -0
- package/docs/providers/huggingface.md +193 -0
- package/docs/providers/index.md +81 -0
- package/docs/providers/kilocode.md +89 -0
- package/docs/providers/litellm.md +159 -0
- package/docs/providers/minimax.md +281 -0
- package/docs/providers/mistral.md +68 -0
- package/docs/providers/models.md +56 -0
- package/docs/providers/moonshot.md +224 -0
- package/docs/providers/nvidia.md +58 -0
- package/docs/providers/ollama.md +379 -0
- package/docs/providers/openai.md +472 -0
- package/docs/providers/opencode-go.md +45 -0
- package/docs/providers/opencode.md +68 -0
- package/docs/providers/openrouter.md +59 -0
- package/docs/providers/perplexity-provider.md +62 -0
- package/docs/providers/qianfan.md +90 -0
- package/docs/providers/qwen.md +128 -0
- package/docs/providers/qwen_modelstudio.md +137 -0
- package/docs/providers/sglang.md +115 -0
- package/docs/providers/stepfun.md +152 -0
- package/docs/providers/synthetic.md +101 -0
- package/docs/providers/together.md +70 -0
- package/docs/providers/venice.md +282 -0
- package/docs/providers/vercel-ai-gateway.md +60 -0
- package/docs/providers/vllm.md +103 -0
- package/docs/providers/volcengine.md +94 -0
- package/docs/providers/xai.md +94 -0
- package/docs/providers/xiaomi.md +89 -0
- package/docs/providers/zai.md +75 -0
- package/docs/reference/AGENTS.default.md +126 -0
- package/docs/reference/RELEASING.md +138 -0
- package/docs/reference/api-usage-costs.md +198 -0
- package/docs/reference/credits.md +30 -0
- package/docs/reference/device-models.md +47 -0
- package/docs/reference/memory-config.md +421 -0
- package/docs/reference/prompt-caching.md +344 -0
- package/docs/reference/rpc.md +43 -0
- package/docs/reference/secretref-credential-surface.md +148 -0
- package/docs/reference/secretref-user-supplied-credentials-matrix.json +607 -0
- package/docs/reference/session-management-compaction.md +352 -0
- package/docs/reference/templates/AGENTS.dev.md +84 -0
- package/docs/reference/templates/AGENTS.md +219 -0
- package/docs/reference/templates/BOOT.md +12 -0
- package/docs/reference/templates/BOOTSTRAP.md +62 -0
- package/docs/reference/templates/CLAUDE.md +1 -0
- package/docs/reference/templates/HEARTBEAT.md +14 -0
- package/docs/reference/templates/IDENTITY.dev.md +48 -0
- package/docs/reference/templates/IDENTITY.md +30 -0
- package/docs/reference/templates/SOUL.dev.md +77 -0
- package/docs/reference/templates/SOUL.md +45 -0
- package/docs/reference/templates/TOOLS.dev.md +25 -0
- package/docs/reference/templates/TOOLS.md +47 -0
- package/docs/reference/templates/USER.dev.md +19 -0
- package/docs/reference/templates/USER.md +24 -0
- package/docs/reference/test.md +119 -0
- package/docs/reference/token-use.md +197 -0
- package/docs/reference/transcript-hygiene.md +151 -0
- package/docs/reference/wizard.md +245 -0
- package/docs/security/CONTRIBUTING-THREAT-MODEL.md +98 -0
- package/docs/security/THREAT-MODEL-ATLAS.md +608 -0
- package/docs/security/formal-verification.md +167 -0
- package/docs/snippets/plugin-publish/minimal-openclaw.plugin.json +9 -0
- package/docs/snippets/plugin-publish/minimal-package.json +16 -0
- package/docs/start/bootstrapping.md +41 -0
- package/docs/start/docs-directory.md +67 -0
- package/docs/start/getting-started.md +148 -0
- package/docs/start/hubs.md +199 -0
- package/docs/start/lore.md +219 -0
- package/docs/start/onboarding-overview.md +69 -0
- package/docs/start/onboarding.md +92 -0
- package/docs/start/openclaw.md +225 -0
- package/docs/start/quickstart.md +22 -0
- package/docs/start/setup.md +172 -0
- package/docs/start/showcase.md +418 -0
- package/docs/start/wizard-cli-automation.md +233 -0
- package/docs/start/wizard-cli-reference.md +324 -0
- package/docs/start/wizard.md +127 -0
- package/docs/style.css +37 -0
- package/docs/tools/acp-agents.md +837 -0
- package/docs/tools/agent-send.md +100 -0
- package/docs/tools/apply-patch.md +52 -0
- package/docs/tools/brave-search.md +107 -0
- package/docs/tools/browser-linux-troubleshooting.md +145 -0
- package/docs/tools/browser-login.md +73 -0
- package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +221 -0
- package/docs/tools/browser.md +890 -0
- package/docs/tools/btw.md +142 -0
- package/docs/tools/capability-cookbook.md +119 -0
- package/docs/tools/clawhub.md +348 -0
- package/docs/tools/code-execution.md +90 -0
- package/docs/tools/creating-skills.md +119 -0
- package/docs/tools/diffs.md +434 -0
- package/docs/tools/duckduckgo-search.md +102 -0
- package/docs/tools/elevated.md +116 -0
- package/docs/tools/exa-search.md +127 -0
- package/docs/tools/exec-approvals.md +635 -0
- package/docs/tools/exec.md +237 -0
- package/docs/tools/firecrawl.md +147 -0
- package/docs/tools/gemini-search.md +98 -0
- package/docs/tools/grok-search.md +102 -0
- package/docs/tools/image-generation.md +139 -0
- package/docs/tools/index.md +174 -0
- package/docs/tools/kimi-search.md +98 -0
- package/docs/tools/llm-task.md +119 -0
- package/docs/tools/lobster.md +348 -0
- package/docs/tools/loop-detection.md +100 -0
- package/docs/tools/minimax-search.md +99 -0
- package/docs/tools/multi-agent-sandbox-tools.md +373 -0
- package/docs/tools/ollama-search.md +100 -0
- package/docs/tools/pdf.md +176 -0
- package/docs/tools/perplexity-search.md +185 -0
- package/docs/tools/plugin.md +348 -0
- package/docs/tools/reactions.md +78 -0
- package/docs/tools/searxng-search.md +132 -0
- package/docs/tools/skills-config.md +133 -0
- package/docs/tools/skills.md +377 -0
- package/docs/tools/slash-commands.md +322 -0
- package/docs/tools/subagents.md +341 -0
- package/docs/tools/tavily.md +129 -0
- package/docs/tools/thinking.md +102 -0
- package/docs/tools/tts.md +452 -0
- package/docs/tools/web-fetch.md +159 -0
- package/docs/tools/web.md +417 -0
- package/docs/tts.md +452 -0
- package/docs/vps.md +115 -0
- package/docs/web/control-ui.md +318 -0
- package/docs/web/dashboard.md +93 -0
- package/docs/web/index.md +126 -0
- package/docs/web/tui.md +176 -0
- package/docs/web/webchat.md +77 -0
- package/docs/whatsapp-openclaw-ai-zh.jpg +0 -0
- package/docs/whatsapp-openclaw.jpg +0 -0
- package/durar.mjs +180 -0
- package/package.json +1259 -0
- package/scripts/npm-runner.mjs +111 -0
- package/scripts/postinstall-bundled-plugins.mjs +188 -0
- package/skills/1password/SKILL.md +70 -0
- package/skills/1password/references/cli-examples.md +29 -0
- package/skills/1password/references/get-started.md +17 -0
- package/skills/apple-notes/SKILL.md +77 -0
- package/skills/apple-reminders/SKILL.md +118 -0
- package/skills/bear-notes/SKILL.md +107 -0
- package/skills/blogwatcher/SKILL.md +69 -0
- package/skills/blucli/SKILL.md +47 -0
- package/skills/bluebubbles/SKILL.md +131 -0
- package/skills/camsnap/SKILL.md +45 -0
- package/skills/canvas/SKILL.md +199 -0
- package/skills/clawhub/SKILL.md +77 -0
- package/skills/coding-agent/SKILL.md +316 -0
- package/skills/discord/SKILL.md +197 -0
- package/skills/eightctl/SKILL.md +50 -0
- package/skills/gemini/SKILL.md +43 -0
- package/skills/gh-issues/SKILL.md +885 -0
- package/skills/gifgrep/SKILL.md +79 -0
- package/skills/github/SKILL.md +163 -0
- package/skills/gog/SKILL.md +116 -0
- package/skills/goplaces/SKILL.md +52 -0
- package/skills/healthcheck/SKILL.md +245 -0
- package/skills/himalaya/SKILL.md +257 -0
- package/skills/himalaya/references/configuration.md +184 -0
- package/skills/himalaya/references/message-composition.md +199 -0
- package/skills/imsg/SKILL.md +122 -0
- package/skills/mcporter/SKILL.md +61 -0
- package/skills/model-usage/SKILL.md +69 -0
- package/skills/model-usage/references/codexbar-cli.md +33 -0
- package/skills/model-usage/scripts/model_usage.py +320 -0
- package/skills/model-usage/scripts/test_model_usage.py +40 -0
- package/skills/nano-pdf/SKILL.md +38 -0
- package/skills/node-connect/SKILL.md +142 -0
- package/skills/notion/SKILL.md +174 -0
- package/skills/obsidian/SKILL.md +81 -0
- package/skills/openai-whisper/SKILL.md +38 -0
- package/skills/openai-whisper-api/SKILL.md +62 -0
- package/skills/openai-whisper-api/scripts/transcribe.sh +88 -0
- package/skills/openhue/SKILL.md +112 -0
- package/skills/oracle/SKILL.md +125 -0
- package/skills/ordercli/SKILL.md +78 -0
- package/skills/peekaboo/SKILL.md +190 -0
- package/skills/sag/SKILL.md +87 -0
- package/skills/session-logs/SKILL.md +151 -0
- package/skills/sherpa-onnx-tts/SKILL.md +109 -0
- package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
- package/skills/skill-creator/SKILL.md +372 -0
- package/skills/skill-creator/license.txt +202 -0
- package/skills/skill-creator/scripts/init_skill.py +378 -0
- package/skills/skill-creator/scripts/package_skill.py +139 -0
- package/skills/skill-creator/scripts/quick_validate.py +159 -0
- package/skills/skill-creator/scripts/test_package_skill.py +160 -0
- package/skills/skill-creator/scripts/test_quick_validate.py +72 -0
- package/skills/slack/SKILL.md +144 -0
- package/skills/songsee/SKILL.md +49 -0
- package/skills/sonoscli/SKILL.md +65 -0
- package/skills/spotify-player/SKILL.md +64 -0
- package/skills/summarize/SKILL.md +87 -0
- package/skills/taskflow/SKILL.md +149 -0
- package/skills/taskflow/examples/inbox-triage.lobster +33 -0
- package/skills/taskflow/examples/pr-intake.lobster +32 -0
- package/skills/taskflow-inbox-triage/SKILL.md +119 -0
- package/skills/things-mac/SKILL.md +86 -0
- package/skills/tmux/SKILL.md +170 -0
- package/skills/tmux/scripts/find-sessions.sh +112 -0
- package/skills/tmux/scripts/wait-for-text.sh +83 -0
- package/skills/trello/SKILL.md +108 -0
- package/skills/video-frames/SKILL.md +46 -0
- package/skills/video-frames/scripts/frame.sh +81 -0
- package/skills/voice-call/SKILL.md +45 -0
- package/skills/wacli/SKILL.md +72 -0
- package/skills/weather/SKILL.md +129 -0
- package/skills/xurl/SKILL.md +461 -0
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: songsee
|
|
3
|
+
description: Generate spectrograms and feature-panel visualizations from audio with the songsee CLI.
|
|
4
|
+
homepage: https://github.com/steipete/songsee
|
|
5
|
+
metadata:
|
|
6
|
+
{
|
|
7
|
+
"openclaw":
|
|
8
|
+
{
|
|
9
|
+
"emoji": "🌊",
|
|
10
|
+
"requires": { "bins": ["songsee"] },
|
|
11
|
+
"install":
|
|
12
|
+
[
|
|
13
|
+
{
|
|
14
|
+
"id": "brew",
|
|
15
|
+
"kind": "brew",
|
|
16
|
+
"formula": "steipete/tap/songsee",
|
|
17
|
+
"bins": ["songsee"],
|
|
18
|
+
"label": "Install songsee (brew)",
|
|
19
|
+
},
|
|
20
|
+
],
|
|
21
|
+
},
|
|
22
|
+
}
|
|
23
|
+
---
|
|
24
|
+
|
|
25
|
+
# songsee
|
|
26
|
+
|
|
27
|
+
Generate spectrograms + feature panels from audio.
|
|
28
|
+
|
|
29
|
+
Quick start
|
|
30
|
+
|
|
31
|
+
- Spectrogram: `songsee track.mp3`
|
|
32
|
+
- Multi-panel: `songsee track.mp3 --viz spectrogram,mel,chroma,hpss,selfsim,loudness,tempogram,mfcc,flux`
|
|
33
|
+
- Time slice: `songsee track.mp3 --start 12.5 --duration 8 -o slice.jpg`
|
|
34
|
+
- Stdin: `cat track.mp3 | songsee - --format png -o out.png`
|
|
35
|
+
|
|
36
|
+
Common flags
|
|
37
|
+
|
|
38
|
+
- `--viz` list (repeatable or comma-separated)
|
|
39
|
+
- `--style` palette (classic, magma, inferno, viridis, gray)
|
|
40
|
+
- `--width` / `--height` output size
|
|
41
|
+
- `--window` / `--hop` FFT settings
|
|
42
|
+
- `--min-freq` / `--max-freq` frequency range
|
|
43
|
+
- `--start` / `--duration` time slice
|
|
44
|
+
- `--format` jpg|png
|
|
45
|
+
|
|
46
|
+
Notes
|
|
47
|
+
|
|
48
|
+
- WAV/MP3 decode native; other formats use ffmpeg if available.
|
|
49
|
+
- Multiple `--viz` renders a grid.
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: sonoscli
|
|
3
|
+
description: Control Sonos speakers (discover/status/play/volume/group).
|
|
4
|
+
homepage: https://sonoscli.sh
|
|
5
|
+
metadata:
|
|
6
|
+
{
|
|
7
|
+
"openclaw":
|
|
8
|
+
{
|
|
9
|
+
"emoji": "🔊",
|
|
10
|
+
"requires": { "bins": ["sonos"] },
|
|
11
|
+
"install":
|
|
12
|
+
[
|
|
13
|
+
{
|
|
14
|
+
"id": "go",
|
|
15
|
+
"kind": "go",
|
|
16
|
+
"module": "github.com/steipete/sonoscli/cmd/sonos@latest",
|
|
17
|
+
"bins": ["sonos"],
|
|
18
|
+
"label": "Install sonoscli (go)",
|
|
19
|
+
},
|
|
20
|
+
],
|
|
21
|
+
},
|
|
22
|
+
}
|
|
23
|
+
---
|
|
24
|
+
|
|
25
|
+
# Sonos CLI
|
|
26
|
+
|
|
27
|
+
Use `sonos` to control Sonos speakers on the local network.
|
|
28
|
+
|
|
29
|
+
## Quick start
|
|
30
|
+
|
|
31
|
+
- `sonos discover`
|
|
32
|
+
- `sonos status --name "Kitchen"`
|
|
33
|
+
- `sonos play|pause|stop --name "Kitchen"`
|
|
34
|
+
- `sonos volume set 15 --name "Kitchen"`
|
|
35
|
+
|
|
36
|
+
## Common tasks
|
|
37
|
+
|
|
38
|
+
- Grouping: `sonos group status|join|unjoin|party|solo`
|
|
39
|
+
- Favorites: `sonos favorites list|open`
|
|
40
|
+
- Queue: `sonos queue list|play|clear`
|
|
41
|
+
- Spotify search (via SMAPI): `sonos smapi search --service "Spotify" --category tracks "query"`
|
|
42
|
+
|
|
43
|
+
## Notes
|
|
44
|
+
|
|
45
|
+
- If SSDP fails, specify `--ip <speaker-ip>`.
|
|
46
|
+
- Spotify Web API search is optional and requires `SPOTIFY_CLIENT_ID/SECRET`.
|
|
47
|
+
- If there is an error, check the troubleshooting section and offer advice if there is a decent match.
|
|
48
|
+
|
|
49
|
+
## Troubleshooting
|
|
50
|
+
|
|
51
|
+
### `sonos discover` - `no route to host`
|
|
52
|
+
|
|
53
|
+
- On error `Error: write udp4 0.0.0.0:64326->239.255.255.250:1900: sendto: no route to host (Command exited with code 1)`
|
|
54
|
+
- Note that the port number after `0.0.0.0:` is ephemeral and will change and the netmask may not match exactly either
|
|
55
|
+
- The `sendto: no route to host` should stay consistent
|
|
56
|
+
- Advise the user that in `direct` (no Docker sandbox) mode on Mac OS that Settings -> Privacy & Security -> Local Network will need to be enabled for the top-level host parent process of the Gateway
|
|
57
|
+
- `node` if running via `launchd`
|
|
58
|
+
- `Terminal` if running the gateway directly in the terminal
|
|
59
|
+
- `Visual Studio Code` if running via terminal in VS Code
|
|
60
|
+
- An alternative option is to use `sandbox` (docker container) with network access allowed for that sandbox
|
|
61
|
+
|
|
62
|
+
### `sonos discover` - `bind: operation not permitted`
|
|
63
|
+
|
|
64
|
+
- On error `Error: listen udp4 0.0.0.0:0: bind: operation not permitted`
|
|
65
|
+
- Advise the user that they may be running via a Codex or other sandbox that does not permit network access (this can be replicated by running `sonos discover` within a Codex CLI session with sandbox enabled and not approving the escalation request)
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: spotify-player
|
|
3
|
+
description: Terminal Spotify playback/search via spogo (preferred) or spotify_player.
|
|
4
|
+
homepage: https://www.spotify.com
|
|
5
|
+
metadata:
|
|
6
|
+
{
|
|
7
|
+
"openclaw":
|
|
8
|
+
{
|
|
9
|
+
"emoji": "🎵",
|
|
10
|
+
"requires": { "anyBins": ["spogo", "spotify_player"] },
|
|
11
|
+
"install":
|
|
12
|
+
[
|
|
13
|
+
{
|
|
14
|
+
"id": "brew",
|
|
15
|
+
"kind": "brew",
|
|
16
|
+
"formula": "spogo",
|
|
17
|
+
"tap": "steipete/tap",
|
|
18
|
+
"bins": ["spogo"],
|
|
19
|
+
"label": "Install spogo (brew)",
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
"id": "brew",
|
|
23
|
+
"kind": "brew",
|
|
24
|
+
"formula": "spotify_player",
|
|
25
|
+
"bins": ["spotify_player"],
|
|
26
|
+
"label": "Install spotify_player (brew)",
|
|
27
|
+
},
|
|
28
|
+
],
|
|
29
|
+
},
|
|
30
|
+
}
|
|
31
|
+
---
|
|
32
|
+
|
|
33
|
+
# spogo / spotify_player
|
|
34
|
+
|
|
35
|
+
Use `spogo` **(preferred)** for Spotify playback/search. Fall back to `spotify_player` if needed.
|
|
36
|
+
|
|
37
|
+
Requirements
|
|
38
|
+
|
|
39
|
+
- Spotify Premium account.
|
|
40
|
+
- Either `spogo` or `spotify_player` installed.
|
|
41
|
+
|
|
42
|
+
spogo setup
|
|
43
|
+
|
|
44
|
+
- Import cookies: `spogo auth import --browser chrome`
|
|
45
|
+
|
|
46
|
+
Common CLI commands
|
|
47
|
+
|
|
48
|
+
- Search: `spogo search track "query"`
|
|
49
|
+
- Playback: `spogo play|pause|next|prev`
|
|
50
|
+
- Devices: `spogo device list`, `spogo device set "<name|id>"`
|
|
51
|
+
- Status: `spogo status`
|
|
52
|
+
|
|
53
|
+
spotify_player commands (fallback)
|
|
54
|
+
|
|
55
|
+
- Search: `spotify_player search "query"`
|
|
56
|
+
- Playback: `spotify_player playback play|pause|next|previous`
|
|
57
|
+
- Connect device: `spotify_player connect`
|
|
58
|
+
- Like track: `spotify_player like`
|
|
59
|
+
|
|
60
|
+
Notes
|
|
61
|
+
|
|
62
|
+
- Config folder: `~/.config/spotify-player` (e.g., `app.toml`).
|
|
63
|
+
- For Spotify Connect integration, set a user `client_id` in config.
|
|
64
|
+
- TUI shortcuts are available via `?` in the app.
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: summarize
|
|
3
|
+
description: Summarize or extract text/transcripts from URLs, podcasts, and local files (great fallback for “transcribe this YouTube/video”).
|
|
4
|
+
homepage: https://summarize.sh
|
|
5
|
+
metadata:
|
|
6
|
+
{
|
|
7
|
+
"openclaw":
|
|
8
|
+
{
|
|
9
|
+
"emoji": "🧾",
|
|
10
|
+
"requires": { "bins": ["summarize"] },
|
|
11
|
+
"install":
|
|
12
|
+
[
|
|
13
|
+
{
|
|
14
|
+
"id": "brew",
|
|
15
|
+
"kind": "brew",
|
|
16
|
+
"formula": "steipete/tap/summarize",
|
|
17
|
+
"bins": ["summarize"],
|
|
18
|
+
"label": "Install summarize (brew)",
|
|
19
|
+
},
|
|
20
|
+
],
|
|
21
|
+
},
|
|
22
|
+
}
|
|
23
|
+
---
|
|
24
|
+
|
|
25
|
+
# Summarize
|
|
26
|
+
|
|
27
|
+
Fast CLI to summarize URLs, local files, and YouTube links.
|
|
28
|
+
|
|
29
|
+
## When to use (trigger phrases)
|
|
30
|
+
|
|
31
|
+
Use this skill immediately when the user asks any of:
|
|
32
|
+
|
|
33
|
+
- “use summarize.sh”
|
|
34
|
+
- “what’s this link/video about?”
|
|
35
|
+
- “summarize this URL/article”
|
|
36
|
+
- “transcribe this YouTube/video” (best-effort transcript extraction; no `yt-dlp` needed)
|
|
37
|
+
|
|
38
|
+
## Quick start
|
|
39
|
+
|
|
40
|
+
```bash
|
|
41
|
+
summarize "https://example.com" --model google/gemini-3-flash-preview
|
|
42
|
+
summarize "/path/to/file.pdf" --model google/gemini-3-flash-preview
|
|
43
|
+
summarize "https://youtu.be/dQw4w9WgXcQ" --youtube auto
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
## YouTube: summary vs transcript
|
|
47
|
+
|
|
48
|
+
Best-effort transcript (URLs only):
|
|
49
|
+
|
|
50
|
+
```bash
|
|
51
|
+
summarize "https://youtu.be/dQw4w9WgXcQ" --youtube auto --extract-only
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
If the user asked for a transcript but it’s huge, return a tight summary first, then ask which section/time range to expand.
|
|
55
|
+
|
|
56
|
+
## Model + keys
|
|
57
|
+
|
|
58
|
+
Set the API key for your chosen provider:
|
|
59
|
+
|
|
60
|
+
- OpenAI: `OPENAI_API_KEY`
|
|
61
|
+
- Anthropic: `ANTHROPIC_API_KEY`
|
|
62
|
+
- xAI: `XAI_API_KEY`
|
|
63
|
+
- Google: `GEMINI_API_KEY` (aliases: `GOOGLE_GENERATIVE_AI_API_KEY`, `GOOGLE_API_KEY`)
|
|
64
|
+
|
|
65
|
+
Default model is `google/gemini-3-flash-preview` if none is set.
|
|
66
|
+
|
|
67
|
+
## Useful flags
|
|
68
|
+
|
|
69
|
+
- `--length short|medium|long|xl|xxl|<chars>`
|
|
70
|
+
- `--max-output-tokens <count>`
|
|
71
|
+
- `--extract-only` (URLs only)
|
|
72
|
+
- `--json` (machine readable)
|
|
73
|
+
- `--firecrawl auto|off|always` (fallback extraction)
|
|
74
|
+
- `--youtube auto` (Apify fallback if `APIFY_API_TOKEN` set)
|
|
75
|
+
|
|
76
|
+
## Config
|
|
77
|
+
|
|
78
|
+
Optional config file: `~/.summarize/config.json`
|
|
79
|
+
|
|
80
|
+
```json
|
|
81
|
+
{ "model": "openai/gpt-5.2" }
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
Optional services:
|
|
85
|
+
|
|
86
|
+
- `FIRECRAWL_API_KEY` for blocked sites
|
|
87
|
+
- `APIFY_API_TOKEN` for YouTube fallback
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
name: taskflow
|
|
2
|
+
description: Use when work should span one or more detached tasks but still behave like one job with a single owner context. TaskFlow is the durable flow substrate under authoring layers like Lobster, ACPX, plugins, or plain code. Keep conditional logic in the caller; use TaskFlow for flow identity, child-task linkage, waiting state, revision-checked mutations, and user-facing emergence.
|
|
3
|
+
metadata: { "openclaw": { "emoji": "🪝" } }
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# TaskFlow
|
|
8
|
+
|
|
9
|
+
Use TaskFlow when a job needs to outlive one prompt or one detached run, but you still want one owner session, one return context, and one place to inspect or resume the work.
|
|
10
|
+
|
|
11
|
+
## When to use it
|
|
12
|
+
|
|
13
|
+
- Multi-step background work with one owner
|
|
14
|
+
- Work that waits on detached ACP or subagent tasks
|
|
15
|
+
- Jobs that may need to emit one clear update back to the owner
|
|
16
|
+
- Jobs that need small persisted state between steps
|
|
17
|
+
- Plugin or tool work that must survive restarts and revision conflicts cleanly
|
|
18
|
+
|
|
19
|
+
## What TaskFlow owns
|
|
20
|
+
|
|
21
|
+
- flow identity
|
|
22
|
+
- owner session and requester origin
|
|
23
|
+
- `currentStep`, `stateJson`, and `waitJson`
|
|
24
|
+
- linked child tasks and their parent flow id
|
|
25
|
+
- finish, fail, cancel, waiting, and blocked state
|
|
26
|
+
- revision tracking for conflict-safe mutations
|
|
27
|
+
|
|
28
|
+
It does **not** own branching or business logic. Put that in Lobster, acpx, or the calling code.
|
|
29
|
+
|
|
30
|
+
## Current runtime shape
|
|
31
|
+
|
|
32
|
+
Canonical plugin/runtime entrypoint:
|
|
33
|
+
|
|
34
|
+
- `api.runtime.tasks.flow`
|
|
35
|
+
- `api.runtime.taskFlow` still exists as an alias, but `api.runtime.tasks.flow` is the canonical shape
|
|
36
|
+
|
|
37
|
+
Binding:
|
|
38
|
+
|
|
39
|
+
- `api.runtime.tasks.flow.fromToolContext(ctx)` when you already have trusted tool context with `sessionKey`
|
|
40
|
+
- `api.runtime.tasks.flow.bindSession({ sessionKey, requesterOrigin })` when your binding layer already resolved the session and delivery context
|
|
41
|
+
|
|
42
|
+
Managed-flow lifecycle:
|
|
43
|
+
|
|
44
|
+
1. `createManaged(...)`
|
|
45
|
+
2. `runTask(...)`
|
|
46
|
+
3. `setWaiting(...)` when waiting on a person or an external system
|
|
47
|
+
4. `resume(...)` when work can continue
|
|
48
|
+
5. `finish(...)` or `fail(...)`
|
|
49
|
+
6. `requestCancel(...)` or `cancel(...)` when the whole job should stop
|
|
50
|
+
|
|
51
|
+
## Design constraints
|
|
52
|
+
|
|
53
|
+
- Use **managed** TaskFlows when your code owns the orchestration.
|
|
54
|
+
- One-task **mirrored** flows are created by core runtime for detached ACP/subagent work; this skill is mainly about managed flows.
|
|
55
|
+
- Treat `stateJson` as the persisted state bag. There is no separate `setFlowOutput` or `appendFlowOutput` API.
|
|
56
|
+
- Every mutating method after creation is revision-checked. Carry forward the latest `flow.revision` after each successful mutation.
|
|
57
|
+
- `runTask(...)` links the child task to the flow. Use it instead of manually creating detached tasks when you want parent orchestration.
|
|
58
|
+
|
|
59
|
+
## Example shape
|
|
60
|
+
|
|
61
|
+
```ts
|
|
62
|
+
const taskFlow = api.runtime.tasks.flow.fromToolContext(ctx);
|
|
63
|
+
|
|
64
|
+
const created = taskFlow.createManaged({
|
|
65
|
+
controllerId: "my-plugin/inbox-triage",
|
|
66
|
+
goal: "triage inbox",
|
|
67
|
+
currentStep: "classify",
|
|
68
|
+
stateJson: {
|
|
69
|
+
businessThreads: [],
|
|
70
|
+
personalItems: [],
|
|
71
|
+
eodSummary: [],
|
|
72
|
+
},
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
const classify = taskFlow.runTask({
|
|
76
|
+
flowId: created.flowId,
|
|
77
|
+
runtime: "acp",
|
|
78
|
+
childSessionKey: "agent:main:subagent:classifier",
|
|
79
|
+
runId: "inbox-classify-1",
|
|
80
|
+
task: "Classify inbox messages",
|
|
81
|
+
status: "running",
|
|
82
|
+
startedAt: Date.now(),
|
|
83
|
+
lastEventAt: Date.now(),
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
if (!classify.created) {
|
|
87
|
+
throw new Error(classify.reason);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
const waiting = taskFlow.setWaiting({
|
|
91
|
+
flowId: created.flowId,
|
|
92
|
+
expectedRevision: created.revision,
|
|
93
|
+
currentStep: "await_business_reply",
|
|
94
|
+
stateJson: {
|
|
95
|
+
businessThreads: ["slack:thread-1"],
|
|
96
|
+
personalItems: [],
|
|
97
|
+
eodSummary: [],
|
|
98
|
+
},
|
|
99
|
+
waitJson: {
|
|
100
|
+
kind: "reply",
|
|
101
|
+
channel: "slack",
|
|
102
|
+
threadKey: "slack:thread-1",
|
|
103
|
+
},
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
if (!waiting.applied) {
|
|
107
|
+
throw new Error(waiting.code);
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
const resumed = taskFlow.resume({
|
|
111
|
+
flowId: waiting.flow.flowId,
|
|
112
|
+
expectedRevision: waiting.flow.revision,
|
|
113
|
+
status: "running",
|
|
114
|
+
currentStep: "finalize",
|
|
115
|
+
stateJson: waiting.flow.stateJson,
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
if (!resumed.applied) {
|
|
119
|
+
throw new Error(resumed.code);
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
taskFlow.finish({
|
|
123
|
+
flowId: resumed.flow.flowId,
|
|
124
|
+
expectedRevision: resumed.flow.revision,
|
|
125
|
+
stateJson: resumed.flow.stateJson,
|
|
126
|
+
});
|
|
127
|
+
```
|
|
128
|
+
|
|
129
|
+
## Keep conditionals above the runtime
|
|
130
|
+
|
|
131
|
+
Use the flow runtime for state and task linkage. Keep decisions in the authoring layer:
|
|
132
|
+
|
|
133
|
+
- `business` → post to Slack and wait
|
|
134
|
+
- `personal` → notify the owner now
|
|
135
|
+
- `later` → append to an end-of-day summary bucket
|
|
136
|
+
|
|
137
|
+
## Operational pattern
|
|
138
|
+
|
|
139
|
+
- Store only the minimum state needed to resume.
|
|
140
|
+
- Put human-readable wait reasons in `blockedSummary` or structured wait metadata in `waitJson`.
|
|
141
|
+
- Use `getTaskSummary(flowId)` when the orchestrator needs a compact health view of child work.
|
|
142
|
+
- Use `requestCancel(...)` when a caller wants the flow to stop scheduling immediately.
|
|
143
|
+
- Use `cancel(...)` when you also want active linked child tasks cancelled.
|
|
144
|
+
|
|
145
|
+
## Examples
|
|
146
|
+
|
|
147
|
+
- See `skills/taskflow/examples/inbox-triage.lobster`
|
|
148
|
+
- See `skills/taskflow/examples/pr-intake.lobster`
|
|
149
|
+
- See `skills/taskflow-inbox-triage/SKILL.md` for a concrete routing pattern
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
# Illustrative Lobster authoring example for a TaskFlow-style inbox triage job.
|
|
2
|
+
# Swap the placeholder commands for your own tools or scripts.
|
|
3
|
+
|
|
4
|
+
name: inbox-triage
|
|
5
|
+
steps:
|
|
6
|
+
- id: fetch
|
|
7
|
+
command: gog.gmail.search --query 'newer_than:1d' --max 20
|
|
8
|
+
|
|
9
|
+
- id: classify
|
|
10
|
+
command: >-
|
|
11
|
+
openclaw.invoke --tool llm-task --action json --args-json
|
|
12
|
+
'{"prompt":"Classify each inbox item as business, personal, or later. Return one JSON object per item with route and summary.","thinking":"low","schema":{"type":"object","properties":{"items":{"type":"array"}},"required":["items"],"additionalProperties":false}}'
|
|
13
|
+
stdin: $fetch.stdout
|
|
14
|
+
|
|
15
|
+
- id: post_business
|
|
16
|
+
command: slack-route --bucket business
|
|
17
|
+
stdin: $classify.stdout
|
|
18
|
+
condition: $classify.json.items[0].route == "business"
|
|
19
|
+
|
|
20
|
+
- id: wait_for_business_reply
|
|
21
|
+
command: echo '{"status":"waiting","reason":"slack_reply"}'
|
|
22
|
+
condition: $classify.json.items[0].route == "business"
|
|
23
|
+
|
|
24
|
+
- id: notify_personal
|
|
25
|
+
command: >-
|
|
26
|
+
openclaw.invoke --tool message --action send --args-json
|
|
27
|
+
'{"provider":"telegram","to":"owner-thread","content":"Personal inbox item needs attention."}'
|
|
28
|
+
condition: $classify.json.items[0].route == "personal"
|
|
29
|
+
|
|
30
|
+
- id: stash_for_eod
|
|
31
|
+
command: summary-append --bucket eod
|
|
32
|
+
stdin: $classify.stdout
|
|
33
|
+
condition: $classify.json.items[0].route == "later"
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
# Illustrative Lobster authoring example for a TaskFlow-style PR intake lane.
|
|
2
|
+
# Replace the placeholder commands with repo-specific tooling.
|
|
3
|
+
|
|
4
|
+
name: pr-intake
|
|
5
|
+
steps:
|
|
6
|
+
- id: fetch
|
|
7
|
+
command: gh pr list --repo owner/repo --state open --json number,title,body,headRefName
|
|
8
|
+
|
|
9
|
+
- id: classify
|
|
10
|
+
command: >-
|
|
11
|
+
openclaw.invoke --tool llm-task --action json --args-json
|
|
12
|
+
'{"prompt":"Classify each PR as close, request_changes, refactor, or maintainer_review. Return intent and recommended next action.","thinking":"low","schema":{"type":"object","properties":{"items":{"type":"array"}},"required":["items"],"additionalProperties":false}}'
|
|
13
|
+
stdin: $fetch.stdout
|
|
14
|
+
|
|
15
|
+
- id: close_low_signal
|
|
16
|
+
command: pr-close-low-signal
|
|
17
|
+
stdin: $classify.stdout
|
|
18
|
+
condition: $classify.json.items[0].nextAction == "close"
|
|
19
|
+
|
|
20
|
+
- id: request_changes
|
|
21
|
+
command: pr-request-changes
|
|
22
|
+
stdin: $classify.stdout
|
|
23
|
+
condition: $classify.json.items[0].nextAction == "request_changes"
|
|
24
|
+
|
|
25
|
+
- id: refactor_branch
|
|
26
|
+
command: pr-refactor-branch
|
|
27
|
+
stdin: $classify.stdout
|
|
28
|
+
condition: $classify.json.items[0].nextAction == "refactor"
|
|
29
|
+
|
|
30
|
+
- id: escalate
|
|
31
|
+
command: echo '{"status":"notify","target":"maintainer"}'
|
|
32
|
+
condition: $classify.json.items[0].nextAction == "maintainer_review"
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
name: taskflow-inbox-triage
|
|
2
|
+
description: Example TaskFlow authoring pattern for inbox triage. Use when messages need different treatment based on intent, with some routes notifying immediately, some waiting on outside answers, and others rolling into a later summary.
|
|
3
|
+
metadata: { "openclaw": { "emoji": "📥" } }
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# TaskFlow inbox triage
|
|
8
|
+
|
|
9
|
+
This is a concrete example of how to think about TaskFlow without turning the core runtime into a DSL.
|
|
10
|
+
|
|
11
|
+
## Goal
|
|
12
|
+
|
|
13
|
+
Triage inbox items with one owner flow:
|
|
14
|
+
|
|
15
|
+
- business → post to Slack and wait for reply
|
|
16
|
+
- personal → notify the owner now
|
|
17
|
+
- everything else → keep for end-of-day summary
|
|
18
|
+
|
|
19
|
+
## Pattern
|
|
20
|
+
|
|
21
|
+
1. Create one flow for the inbox batch.
|
|
22
|
+
2. Run one detached task to classify new items.
|
|
23
|
+
3. Persist the routing state in `stateJson`.
|
|
24
|
+
4. Move to `waiting` only when an outside reply is required.
|
|
25
|
+
5. Resume the flow when classification or human input completes.
|
|
26
|
+
6. Finish when the batch has been routed.
|
|
27
|
+
|
|
28
|
+
## Suggested `stateJson` shape
|
|
29
|
+
|
|
30
|
+
```json
|
|
31
|
+
{
|
|
32
|
+
"businessThreads": [],
|
|
33
|
+
"personalItems": [],
|
|
34
|
+
"eodSummary": []
|
|
35
|
+
}
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
Suggested `waitJson` when blocked on Slack:
|
|
39
|
+
|
|
40
|
+
```json
|
|
41
|
+
{
|
|
42
|
+
"kind": "reply",
|
|
43
|
+
"channel": "slack",
|
|
44
|
+
"threadKey": "slack:thread-1"
|
|
45
|
+
}
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
## Minimal runtime calls
|
|
49
|
+
|
|
50
|
+
```ts
|
|
51
|
+
const taskFlow = api.runtime.tasks.flow.fromToolContext(ctx);
|
|
52
|
+
|
|
53
|
+
const created = taskFlow.createManaged({
|
|
54
|
+
controllerId: "my-plugin/inbox-triage",
|
|
55
|
+
goal: "triage inbox",
|
|
56
|
+
currentStep: "classify",
|
|
57
|
+
stateJson: {
|
|
58
|
+
businessThreads: [],
|
|
59
|
+
personalItems: [],
|
|
60
|
+
eodSummary: [],
|
|
61
|
+
},
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
const child = taskFlow.runTask({
|
|
65
|
+
flowId: created.flowId,
|
|
66
|
+
runtime: "acp",
|
|
67
|
+
childSessionKey: "agent:main:subagent:classifier",
|
|
68
|
+
task: "Classify inbox messages",
|
|
69
|
+
status: "running",
|
|
70
|
+
startedAt: Date.now(),
|
|
71
|
+
lastEventAt: Date.now(),
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
if (!child.created) {
|
|
75
|
+
throw new Error(child.reason);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
const waiting = taskFlow.setWaiting({
|
|
79
|
+
flowId: created.flowId,
|
|
80
|
+
expectedRevision: created.revision,
|
|
81
|
+
currentStep: "await_business_reply",
|
|
82
|
+
stateJson: {
|
|
83
|
+
businessThreads: ["slack:thread-1"],
|
|
84
|
+
personalItems: [],
|
|
85
|
+
eodSummary: [],
|
|
86
|
+
},
|
|
87
|
+
waitJson: {
|
|
88
|
+
kind: "reply",
|
|
89
|
+
channel: "slack",
|
|
90
|
+
threadKey: "slack:thread-1",
|
|
91
|
+
},
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
if (!waiting.applied) {
|
|
95
|
+
throw new Error(waiting.code);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
const resumed = taskFlow.resume({
|
|
99
|
+
flowId: waiting.flow.flowId,
|
|
100
|
+
expectedRevision: waiting.flow.revision,
|
|
101
|
+
status: "running",
|
|
102
|
+
currentStep: "route_items",
|
|
103
|
+
stateJson: waiting.flow.stateJson,
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
if (!resumed.applied) {
|
|
107
|
+
throw new Error(resumed.code);
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
taskFlow.finish({
|
|
111
|
+
flowId: resumed.flow.flowId,
|
|
112
|
+
expectedRevision: resumed.flow.revision,
|
|
113
|
+
stateJson: resumed.flow.stateJson,
|
|
114
|
+
});
|
|
115
|
+
```
|
|
116
|
+
|
|
117
|
+
## Related example
|
|
118
|
+
|
|
119
|
+
- `skills/taskflow/examples/inbox-triage.lobster`
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: things-mac
|
|
3
|
+
description: Manage Things 3 via the `things` CLI on macOS (add/update projects+todos via URL scheme; read/search/list from the local Things database). Use when a user asks OpenClaw to add a task to Things, list inbox/today/upcoming, search tasks, or inspect projects/areas/tags.
|
|
4
|
+
homepage: https://github.com/ossianhempel/things3-cli
|
|
5
|
+
metadata:
|
|
6
|
+
{
|
|
7
|
+
"openclaw":
|
|
8
|
+
{
|
|
9
|
+
"emoji": "✅",
|
|
10
|
+
"os": ["darwin"],
|
|
11
|
+
"requires": { "bins": ["things"] },
|
|
12
|
+
"install":
|
|
13
|
+
[
|
|
14
|
+
{
|
|
15
|
+
"id": "go",
|
|
16
|
+
"kind": "go",
|
|
17
|
+
"module": "github.com/ossianhempel/things3-cli/cmd/things@latest",
|
|
18
|
+
"bins": ["things"],
|
|
19
|
+
"label": "Install things3-cli (go)",
|
|
20
|
+
},
|
|
21
|
+
],
|
|
22
|
+
},
|
|
23
|
+
}
|
|
24
|
+
---
|
|
25
|
+
|
|
26
|
+
# Things 3 CLI
|
|
27
|
+
|
|
28
|
+
Use `things` to read your local Things database (inbox/today/search/projects/areas/tags) and to add/update todos via the Things URL scheme.
|
|
29
|
+
|
|
30
|
+
Setup
|
|
31
|
+
|
|
32
|
+
- Install (recommended, Apple Silicon): `GOBIN=/opt/homebrew/bin go install github.com/ossianhempel/things3-cli/cmd/things@latest`
|
|
33
|
+
- If DB reads fail: grant **Full Disk Access** to the calling app (Terminal for manual runs; `OpenClaw.app` for gateway runs).
|
|
34
|
+
- Optional: set `THINGSDB` (or pass `--db`) to point at your `ThingsData-*` folder.
|
|
35
|
+
- Optional: set `THINGS_AUTH_TOKEN` to avoid passing `--auth-token` for update ops.
|
|
36
|
+
|
|
37
|
+
Read-only (DB)
|
|
38
|
+
|
|
39
|
+
- `things inbox --limit 50`
|
|
40
|
+
- `things today`
|
|
41
|
+
- `things upcoming`
|
|
42
|
+
- `things search "query"`
|
|
43
|
+
- `things projects` / `things areas` / `things tags`
|
|
44
|
+
|
|
45
|
+
Write (URL scheme)
|
|
46
|
+
|
|
47
|
+
- Prefer safe preview: `things --dry-run add "Title"`
|
|
48
|
+
- Add: `things add "Title" --notes "..." --when today --deadline 2026-01-02`
|
|
49
|
+
- Bring Things to front: `things --foreground add "Title"`
|
|
50
|
+
|
|
51
|
+
Examples: add a todo
|
|
52
|
+
|
|
53
|
+
- Basic: `things add "Buy milk"`
|
|
54
|
+
- With notes: `things add "Buy milk" --notes "2% + bananas"`
|
|
55
|
+
- Into a project/area: `things add "Book flights" --list "Travel"`
|
|
56
|
+
- Into a project heading: `things add "Pack charger" --list "Travel" --heading "Before"`
|
|
57
|
+
- With tags: `things add "Call dentist" --tags "health,phone"`
|
|
58
|
+
- Checklist: `things add "Trip prep" --checklist-item "Passport" --checklist-item "Tickets"`
|
|
59
|
+
- From STDIN (multi-line => title + notes):
|
|
60
|
+
- `cat <<'EOF' | things add -`
|
|
61
|
+
- `Title line`
|
|
62
|
+
- `Notes line 1`
|
|
63
|
+
- `Notes line 2`
|
|
64
|
+
- `EOF`
|
|
65
|
+
|
|
66
|
+
Examples: modify a todo (needs auth token)
|
|
67
|
+
|
|
68
|
+
- First: get the ID (UUID column): `things search "milk" --limit 5`
|
|
69
|
+
- Auth: set `THINGS_AUTH_TOKEN` or pass `--auth-token <TOKEN>`
|
|
70
|
+
- Title: `things update --id <UUID> --auth-token <TOKEN> "New title"`
|
|
71
|
+
- Notes replace: `things update --id <UUID> --auth-token <TOKEN> --notes "New notes"`
|
|
72
|
+
- Notes append/prepend: `things update --id <UUID> --auth-token <TOKEN> --append-notes "..."` / `--prepend-notes "..."`
|
|
73
|
+
- Move lists: `things update --id <UUID> --auth-token <TOKEN> --list "Travel" --heading "Before"`
|
|
74
|
+
- Tags replace/add: `things update --id <UUID> --auth-token <TOKEN> --tags "a,b"` / `things update --id <UUID> --auth-token <TOKEN> --add-tags "a,b"`
|
|
75
|
+
- Complete/cancel (soft-delete-ish): `things update --id <UUID> --auth-token <TOKEN> --completed` / `--canceled`
|
|
76
|
+
- Safe preview: `things --dry-run update --id <UUID> --auth-token <TOKEN> --completed`
|
|
77
|
+
|
|
78
|
+
Delete a todo?
|
|
79
|
+
|
|
80
|
+
- Not supported by `things3-cli` right now (no “delete/move-to-trash” write command; `things trash` is read-only listing).
|
|
81
|
+
- Options: use Things UI to delete/trash, or mark as `--completed` / `--canceled` via `things update`.
|
|
82
|
+
|
|
83
|
+
Notes
|
|
84
|
+
|
|
85
|
+
- macOS-only.
|
|
86
|
+
- `--dry-run` prints the URL and does not open Things.
|