0xkobold 0.0.1
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/.agents/skills/nextjs-best-practices/SKILL.md +208 -0
- package/.agents/skills/sql-optimization-patterns/SKILL.md +509 -0
- package/HEARTBEAT.md +45 -0
- package/README.md +197 -0
- package/USAGE.md +191 -0
- package/dist/package.json +77 -0
- package/dist/src/agent/pi-adapter.js +307 -0
- package/dist/src/agent/pi-adapter.js.map +1 -0
- package/dist/src/agent/tool-adapter.js +86 -0
- package/dist/src/agent/tool-adapter.js.map +1 -0
- package/dist/src/approval/queue.js +114 -0
- package/dist/src/approval/queue.js.map +1 -0
- package/dist/src/ascii-kobold.js +76 -0
- package/dist/src/ascii-kobold.js.map +1 -0
- package/dist/src/cli/client.js +217 -0
- package/dist/src/cli/client.js.map +1 -0
- package/dist/src/cli/commands/agent.js +272 -0
- package/dist/src/cli/commands/agent.js.map +1 -0
- package/dist/src/cli/commands/chat.js +234 -0
- package/dist/src/cli/commands/chat.js.map +1 -0
- package/dist/src/cli/commands/config.js +202 -0
- package/dist/src/cli/commands/config.js.map +1 -0
- package/dist/src/cli/commands/daemon.js +203 -0
- package/dist/src/cli/commands/daemon.js.map +1 -0
- package/dist/src/cli/commands/gateway.js +184 -0
- package/dist/src/cli/commands/gateway.js.map +1 -0
- package/dist/src/cli/commands/init.js +175 -0
- package/dist/src/cli/commands/init.js.map +1 -0
- package/dist/src/cli/commands/kobold.js +21 -0
- package/dist/src/cli/commands/kobold.js.map +1 -0
- package/dist/src/cli/commands/logs.js +27 -0
- package/dist/src/cli/commands/logs.js.map +1 -0
- package/dist/src/cli/commands/mode.js +121 -0
- package/dist/src/cli/commands/mode.js.map +1 -0
- package/dist/src/cli/commands/persona.js +261 -0
- package/dist/src/cli/commands/persona.js.map +1 -0
- package/dist/src/cli/commands/start.js +66 -0
- package/dist/src/cli/commands/start.js.map +1 -0
- package/dist/src/cli/commands/status.js +117 -0
- package/dist/src/cli/commands/status.js.map +1 -0
- package/dist/src/cli/commands/stop.js +27 -0
- package/dist/src/cli/commands/stop.js.map +1 -0
- package/dist/src/cli/commands/system.js +128 -0
- package/dist/src/cli/commands/system.js.map +1 -0
- package/dist/src/cli/commands/tui.js +103 -0
- package/dist/src/cli/commands/tui.js.map +1 -0
- package/dist/src/cli/commands/update.js +133 -0
- package/dist/src/cli/commands/update.js.map +1 -0
- package/dist/src/cli/extensions/discord.js +113 -0
- package/dist/src/cli/extensions/discord.js.map +1 -0
- package/dist/src/cli/extensions/env.js +91 -0
- package/dist/src/cli/extensions/env.js.map +1 -0
- package/dist/src/cli/extensions/heartbeat.js +78 -0
- package/dist/src/cli/extensions/heartbeat.js.map +1 -0
- package/dist/src/cli/index.js +24 -0
- package/dist/src/cli/index.js.map +1 -0
- package/dist/src/cli/program.js +70 -0
- package/dist/src/cli/program.js.map +1 -0
- package/dist/src/cli/repl.js +184 -0
- package/dist/src/cli/repl.js.map +1 -0
- package/dist/src/cli/shared/discord-service.js +102 -0
- package/dist/src/cli/shared/discord-service.js.map +1 -0
- package/dist/src/config/index.js +10 -0
- package/dist/src/config/index.js.map +1 -0
- package/dist/src/config/loader.js +401 -0
- package/dist/src/config/loader.js.map +1 -0
- package/dist/src/config/paths.js +84 -0
- package/dist/src/config/paths.js.map +1 -0
- package/dist/src/config/types.js +8 -0
- package/dist/src/config/types.js.map +1 -0
- package/dist/src/context-detector.js +60 -0
- package/dist/src/context-detector.js.map +1 -0
- package/dist/src/discord/index.js +376 -0
- package/dist/src/discord/index.js.map +1 -0
- package/dist/src/event-bus/index.js +97 -0
- package/dist/src/event-bus/index.js.map +1 -0
- package/dist/src/extensions/command-args.js +68 -0
- package/dist/src/extensions/command-args.js.map +1 -0
- package/dist/src/extensions/core/agent-registry-extension.js +541 -0
- package/dist/src/extensions/core/agent-registry-extension.js.map +1 -0
- package/dist/src/extensions/core/agent-worker.js +148 -0
- package/dist/src/extensions/core/agent-worker.js.map +1 -0
- package/dist/src/extensions/core/compaction-safeguard.js +154 -0
- package/dist/src/extensions/core/compaction-safeguard.js.map +1 -0
- package/dist/src/extensions/core/confirm-destructive.js +43 -0
- package/dist/src/extensions/core/confirm-destructive.js.map +1 -0
- package/dist/src/extensions/core/context-aware-extension.js +124 -0
- package/dist/src/extensions/core/context-aware-extension.js.map +1 -0
- package/dist/src/extensions/core/context-pruning/extension.js +124 -0
- package/dist/src/extensions/core/context-pruning/extension.js.map +1 -0
- package/dist/src/extensions/core/context-pruning/pruner.js +312 -0
- package/dist/src/extensions/core/context-pruning/pruner.js.map +1 -0
- package/dist/src/extensions/core/context-pruning/runtime.js +48 -0
- package/dist/src/extensions/core/context-pruning/runtime.js.map +1 -0
- package/dist/src/extensions/core/context-pruning/settings.js +105 -0
- package/dist/src/extensions/core/context-pruning/settings.js.map +1 -0
- package/dist/src/extensions/core/dirty-repo-guard.js +42 -0
- package/dist/src/extensions/core/dirty-repo-guard.js.map +1 -0
- package/dist/src/extensions/core/discord-channel-extension.js +205 -0
- package/dist/src/extensions/core/discord-channel-extension.js.map +1 -0
- package/dist/src/extensions/core/discord-extension.js +142 -0
- package/dist/src/extensions/core/discord-extension.js.map +1 -0
- package/dist/src/extensions/core/env-loader-extension.js +157 -0
- package/dist/src/extensions/core/env-loader-extension.js.map +1 -0
- package/dist/src/extensions/core/fileops-extension.js +699 -0
- package/dist/src/extensions/core/fileops-extension.js.map +1 -0
- package/dist/src/extensions/core/gateway-extension.js +730 -0
- package/dist/src/extensions/core/gateway-extension.js.map +1 -0
- package/dist/src/extensions/core/git-checkpoint.js +46 -0
- package/dist/src/extensions/core/git-checkpoint.js.map +1 -0
- package/dist/src/extensions/core/handoff-extension.js +206 -0
- package/dist/src/extensions/core/handoff-extension.js.map +1 -0
- package/dist/src/extensions/core/heartbeat-extension.js +373 -0
- package/dist/src/extensions/core/heartbeat-extension.js.map +1 -0
- package/dist/src/extensions/core/mcp-extension.js +413 -0
- package/dist/src/extensions/core/mcp-extension.js.map +1 -0
- package/dist/src/extensions/core/mode-manager-extension.js +562 -0
- package/dist/src/extensions/core/mode-manager-extension.js.map +1 -0
- package/dist/src/extensions/core/multi-channel-extension.js +435 -0
- package/dist/src/extensions/core/multi-channel-extension.js.map +1 -0
- package/dist/src/extensions/core/ollama-provider-extension.js +66 -0
- package/dist/src/extensions/core/ollama-provider-extension.js.map +1 -0
- package/dist/src/extensions/core/onboarding-extension.js +122 -0
- package/dist/src/extensions/core/onboarding-extension.js.map +1 -0
- package/dist/src/extensions/core/persona-loader-extension.js +139 -0
- package/dist/src/extensions/core/persona-loader-extension.js.map +1 -0
- package/dist/src/extensions/core/pi-notify-extension.js +70 -0
- package/dist/src/extensions/core/pi-notify-extension.js.map +1 -0
- package/dist/src/extensions/core/protected-paths.js +24 -0
- package/dist/src/extensions/core/protected-paths.js.map +1 -0
- package/dist/src/extensions/core/questionnaire-extension.js +242 -0
- package/dist/src/extensions/core/questionnaire-extension.js.map +1 -0
- package/dist/src/extensions/core/self-update-extension.js +181 -0
- package/dist/src/extensions/core/self-update-extension.js.map +1 -0
- package/dist/src/extensions/core/session-bridge-extension.js +78 -0
- package/dist/src/extensions/core/session-bridge-extension.js.map +1 -0
- package/dist/src/extensions/core/session-manager-extension.js +319 -0
- package/dist/src/extensions/core/session-manager-extension.js.map +1 -0
- package/dist/src/extensions/core/session-name-extension.js +88 -0
- package/dist/src/extensions/core/session-name-extension.js.map +1 -0
- package/dist/src/extensions/core/session-pruning-extension.js +480 -0
- package/dist/src/extensions/core/session-pruning-extension.js.map +1 -0
- package/dist/src/extensions/core/task-manager-extension.js +661 -0
- package/dist/src/extensions/core/task-manager-extension.js.map +1 -0
- package/dist/src/extensions/core/update-extension.js +438 -0
- package/dist/src/extensions/core/update-extension.js.map +1 -0
- package/dist/src/extensions/core/websearch-extension.js +463 -0
- package/dist/src/extensions/core/websearch-extension.js.map +1 -0
- package/dist/src/extensions/index.js +5 -0
- package/dist/src/extensions/index.js.map +1 -0
- package/dist/src/extensions/loader.js +80 -0
- package/dist/src/extensions/loader.js.map +1 -0
- package/dist/src/gateway/index.js +353 -0
- package/dist/src/gateway/index.js.map +1 -0
- package/dist/src/index.js +150 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/llm/anthropic.js +86 -0
- package/dist/src/llm/anthropic.js.map +1 -0
- package/dist/src/llm/index.js +9 -0
- package/dist/src/llm/index.js.map +1 -0
- package/dist/src/llm/ollama.js +113 -0
- package/dist/src/llm/ollama.js.map +1 -0
- package/dist/src/llm/router.js +145 -0
- package/dist/src/llm/router.js.map +1 -0
- package/dist/src/llm/types.js +7 -0
- package/dist/src/llm/types.js.map +1 -0
- package/dist/src/memory/index.js +5 -0
- package/dist/src/memory/index.js.map +1 -0
- package/dist/src/memory/store.js +91 -0
- package/dist/src/memory/store.js.map +1 -0
- package/dist/src/pi-config.js +80 -0
- package/dist/src/pi-config.js.map +1 -0
- package/dist/src/skills/builtin/file.js +184 -0
- package/dist/src/skills/builtin/file.js.map +1 -0
- package/dist/src/skills/builtin/shell.js +100 -0
- package/dist/src/skills/builtin/shell.js.map +1 -0
- package/dist/src/skills/builtin/subagent.js +62 -0
- package/dist/src/skills/builtin/subagent.js.map +1 -0
- package/dist/src/skills/hello.js +42 -0
- package/dist/src/skills/hello.js.map +1 -0
- package/dist/src/skills/index.js +11 -0
- package/dist/src/skills/index.js.map +1 -0
- package/dist/src/skills/loader.js +382 -0
- package/dist/src/skills/loader.js.map +1 -0
- package/dist/src/skills/types.js +8 -0
- package/dist/src/skills/types.js.map +1 -0
- package/dist/src/utils/working-dir.js +71 -0
- package/dist/src/utils/working-dir.js.map +1 -0
- package/package.json +77 -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 +198 -0
- package/skills/clawhub/SKILL.md +77 -0
- package/skills/coding-agent/SKILL.md +284 -0
- package/skills/discord/SKILL.md +197 -0
- package/skills/eightctl/SKILL.md +50 -0
- package/skills/food-order/SKILL.md +48 -0
- package/skills/gemini/SKILL.md +43 -0
- package/skills/gh-issues/SKILL.md +865 -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 +310 -0
- package/skills/nano-banana-pro/SKILL.md +58 -0
- package/skills/nano-banana-pro/scripts/generate_image.py +184 -0
- package/skills/nano-pdf/SKILL.md +38 -0
- package/skills/notion/SKILL.md +172 -0
- package/skills/obsidian/SKILL.md +81 -0
- package/skills/openai-image-gen/SKILL.md +89 -0
- package/skills/openai-image-gen/scripts/gen.py +240 -0
- package/skills/openai-whisper/SKILL.md +38 -0
- package/skills/openai-whisper-api/SKILL.md +52 -0
- package/skills/openai-whisper-api/scripts/transcribe.sh +85 -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 +115 -0
- package/skills/sherpa-onnx-tts/SKILL.md +103 -0
- package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
- package/skills/skill-creator/SKILL.md +370 -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 +111 -0
- package/skills/skill-creator/scripts/quick_validate.py +101 -0
- package/skills/slack/SKILL.md +144 -0
- package/skills/songsee/SKILL.md +49 -0
- package/skills/sonoscli/SKILL.md +46 -0
- package/skills/spotify-player/SKILL.md +64 -0
- package/skills/summarize/SKILL.md +87 -0
- package/skills/things-mac/SKILL.md +86 -0
- package/skills/tmux/SKILL.md +153 -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 +95 -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 +112 -0
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: bluebubbles
|
|
3
|
+
description: Use when you need to send or manage iMessages via BlueBubbles (recommended iMessage integration). Calls go through the generic message tool with channel="bluebubbles".
|
|
4
|
+
metadata: { "kobold": { "emoji": "🫧", "requires": { "config": ["channels.bluebubbles"] } } }
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# BlueBubbles Actions
|
|
8
|
+
|
|
9
|
+
## Overview
|
|
10
|
+
|
|
11
|
+
BlueBubbles is Kobold’s recommended iMessage integration. Use the `message` tool with `channel: "bluebubbles"` to send messages and manage iMessage conversations: send texts and attachments, react (tapbacks), edit/unsend, reply in threads, and manage group participants/names/icons.
|
|
12
|
+
|
|
13
|
+
## Inputs to collect
|
|
14
|
+
|
|
15
|
+
- `target` (prefer `chat_guid:...`; also `+15551234567` in E.164 or `user@example.com`)
|
|
16
|
+
- `message` text for send/edit/reply
|
|
17
|
+
- `messageId` for react/edit/unsend/reply
|
|
18
|
+
- Attachment `path` for local files, or `buffer` + `filename` for base64
|
|
19
|
+
|
|
20
|
+
If the user is vague ("text my mom"), ask for the recipient handle or chat guid and the exact message content.
|
|
21
|
+
|
|
22
|
+
## Actions
|
|
23
|
+
|
|
24
|
+
### Send a message
|
|
25
|
+
|
|
26
|
+
```json
|
|
27
|
+
{
|
|
28
|
+
"action": "send",
|
|
29
|
+
"channel": "bluebubbles",
|
|
30
|
+
"target": "+15551234567",
|
|
31
|
+
"message": "hello from Kobold"
|
|
32
|
+
}
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
### React (tapback)
|
|
36
|
+
|
|
37
|
+
```json
|
|
38
|
+
{
|
|
39
|
+
"action": "react",
|
|
40
|
+
"channel": "bluebubbles",
|
|
41
|
+
"target": "+15551234567",
|
|
42
|
+
"messageId": "<message-guid>",
|
|
43
|
+
"emoji": "❤️"
|
|
44
|
+
}
|
|
45
|
+
```
|
|
46
|
+
|
|
47
|
+
### Remove a reaction
|
|
48
|
+
|
|
49
|
+
```json
|
|
50
|
+
{
|
|
51
|
+
"action": "react",
|
|
52
|
+
"channel": "bluebubbles",
|
|
53
|
+
"target": "+15551234567",
|
|
54
|
+
"messageId": "<message-guid>",
|
|
55
|
+
"emoji": "❤️",
|
|
56
|
+
"remove": true
|
|
57
|
+
}
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
### Edit a previously sent message
|
|
61
|
+
|
|
62
|
+
```json
|
|
63
|
+
{
|
|
64
|
+
"action": "edit",
|
|
65
|
+
"channel": "bluebubbles",
|
|
66
|
+
"target": "+15551234567",
|
|
67
|
+
"messageId": "<message-guid>",
|
|
68
|
+
"message": "updated text"
|
|
69
|
+
}
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
### Unsend a message
|
|
73
|
+
|
|
74
|
+
```json
|
|
75
|
+
{
|
|
76
|
+
"action": "unsend",
|
|
77
|
+
"channel": "bluebubbles",
|
|
78
|
+
"target": "+15551234567",
|
|
79
|
+
"messageId": "<message-guid>"
|
|
80
|
+
}
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
### Reply to a specific message
|
|
84
|
+
|
|
85
|
+
```json
|
|
86
|
+
{
|
|
87
|
+
"action": "reply",
|
|
88
|
+
"channel": "bluebubbles",
|
|
89
|
+
"target": "+15551234567",
|
|
90
|
+
"replyTo": "<message-guid>",
|
|
91
|
+
"message": "replying to that"
|
|
92
|
+
}
|
|
93
|
+
```
|
|
94
|
+
|
|
95
|
+
### Send an attachment
|
|
96
|
+
|
|
97
|
+
```json
|
|
98
|
+
{
|
|
99
|
+
"action": "sendAttachment",
|
|
100
|
+
"channel": "bluebubbles",
|
|
101
|
+
"target": "+15551234567",
|
|
102
|
+
"path": "/tmp/photo.jpg",
|
|
103
|
+
"caption": "here you go"
|
|
104
|
+
}
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
### Send with an iMessage effect
|
|
108
|
+
|
|
109
|
+
```json
|
|
110
|
+
{
|
|
111
|
+
"action": "sendWithEffect",
|
|
112
|
+
"channel": "bluebubbles",
|
|
113
|
+
"target": "+15551234567",
|
|
114
|
+
"message": "big news",
|
|
115
|
+
"effect": "balloons"
|
|
116
|
+
}
|
|
117
|
+
```
|
|
118
|
+
|
|
119
|
+
## Notes
|
|
120
|
+
|
|
121
|
+
- Requires gateway config `channels.bluebubbles` (serverUrl/password/webhookPath).
|
|
122
|
+
- Prefer `chat_guid` targets when you have them (especially for group chats).
|
|
123
|
+
- BlueBubbles supports rich actions, but some are macOS-version dependent (for example, edit may be broken on macOS 26 Tahoe).
|
|
124
|
+
- The gateway may expose both short and full message ids; full ids are more durable across restarts.
|
|
125
|
+
- Developer reference for the underlying plugin lives in `extensions/bluebubbles/README.md`.
|
|
126
|
+
|
|
127
|
+
## Ideas to try
|
|
128
|
+
|
|
129
|
+
- React with a tapback to acknowledge a request.
|
|
130
|
+
- Reply in-thread when a user references a specific message.
|
|
131
|
+
- Send a file attachment with a short caption.
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: camsnap
|
|
3
|
+
description: Capture frames or clips from RTSP/ONVIF cameras.
|
|
4
|
+
homepage: https://camsnap.ai
|
|
5
|
+
metadata:
|
|
6
|
+
{
|
|
7
|
+
"kobold":
|
|
8
|
+
{
|
|
9
|
+
"emoji": "📸",
|
|
10
|
+
"requires": { "bins": ["camsnap"] },
|
|
11
|
+
"install":
|
|
12
|
+
[
|
|
13
|
+
{
|
|
14
|
+
"id": "brew",
|
|
15
|
+
"kind": "brew",
|
|
16
|
+
"formula": "steipete/tap/camsnap",
|
|
17
|
+
"bins": ["camsnap"],
|
|
18
|
+
"label": "Install camsnap (brew)",
|
|
19
|
+
},
|
|
20
|
+
],
|
|
21
|
+
},
|
|
22
|
+
}
|
|
23
|
+
---
|
|
24
|
+
|
|
25
|
+
# camsnap
|
|
26
|
+
|
|
27
|
+
Use `camsnap` to grab snapshots, clips, or motion events from configured cameras.
|
|
28
|
+
|
|
29
|
+
Setup
|
|
30
|
+
|
|
31
|
+
- Config file: `~/.config/camsnap/config.yaml`
|
|
32
|
+
- Add camera: `camsnap add --name kitchen --host 192.168.0.10 --user user --pass pass`
|
|
33
|
+
|
|
34
|
+
Common commands
|
|
35
|
+
|
|
36
|
+
- Discover: `camsnap discover --info`
|
|
37
|
+
- Snapshot: `camsnap snap kitchen --out shot.jpg`
|
|
38
|
+
- Clip: `camsnap clip kitchen --dur 5s --out clip.mp4`
|
|
39
|
+
- Motion watch: `camsnap watch kitchen --threshold 0.2 --action '...'`
|
|
40
|
+
- Doctor: `camsnap doctor --probe`
|
|
41
|
+
|
|
42
|
+
Notes
|
|
43
|
+
|
|
44
|
+
- Requires `ffmpeg` on PATH.
|
|
45
|
+
- Prefer a short test capture before longer clips.
|
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
# Canvas Skill
|
|
2
|
+
|
|
3
|
+
Display HTML content on connected Kobold nodes (Mac app, iOS, Android).
|
|
4
|
+
|
|
5
|
+
## Overview
|
|
6
|
+
|
|
7
|
+
The canvas tool lets you present web content on any connected node's canvas view. Great for:
|
|
8
|
+
|
|
9
|
+
- Displaying games, visualizations, dashboards
|
|
10
|
+
- Showing generated HTML content
|
|
11
|
+
- Interactive demos
|
|
12
|
+
|
|
13
|
+
## How It Works
|
|
14
|
+
|
|
15
|
+
### Architecture
|
|
16
|
+
|
|
17
|
+
```
|
|
18
|
+
┌─────────────────┐ ┌──────────────────┐ ┌─────────────┐
|
|
19
|
+
│ Canvas Host │────▶│ Node Bridge │────▶│ Node App │
|
|
20
|
+
│ (HTTP Server) │ │ (TCP Server) │ │ (Mac/iOS/ │
|
|
21
|
+
│ Port 18793 │ │ Port 18789 │ │ Android) │
|
|
22
|
+
└─────────────────┘ └──────────────────┘ └─────────────┘
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
1. **Canvas Host Server**: Serves static HTML/CSS/JS files from `canvasHost.root` directory
|
|
26
|
+
2. **Node Bridge**: Communicates canvas URLs to connected nodes
|
|
27
|
+
3. **Node Apps**: Render the content in a WebView
|
|
28
|
+
|
|
29
|
+
### Tailscale Integration
|
|
30
|
+
|
|
31
|
+
The canvas host server binds based on `gateway.bind` setting:
|
|
32
|
+
|
|
33
|
+
| Bind Mode | Server Binds To | Canvas URL Uses |
|
|
34
|
+
| ---------- | ------------------- | -------------------------- |
|
|
35
|
+
| `loopback` | 127.0.0.1 | localhost (local only) |
|
|
36
|
+
| `lan` | LAN interface | LAN IP address |
|
|
37
|
+
| `tailnet` | Tailscale interface | Tailscale hostname |
|
|
38
|
+
| `auto` | Best available | Tailscale > LAN > loopback |
|
|
39
|
+
|
|
40
|
+
**Key insight:** The `canvasHostHostForBridge` is derived from `bridgeHost`. When bound to Tailscale, nodes receive URLs like:
|
|
41
|
+
|
|
42
|
+
```
|
|
43
|
+
http://<tailscale-hostname>:18793/__kobold__/canvas/<file>.html
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
This is why localhost URLs don't work - the node receives the Tailscale hostname from the bridge!
|
|
47
|
+
|
|
48
|
+
## Actions
|
|
49
|
+
|
|
50
|
+
| Action | Description |
|
|
51
|
+
| ---------- | ------------------------------------ |
|
|
52
|
+
| `present` | Show canvas with optional target URL |
|
|
53
|
+
| `hide` | Hide the canvas |
|
|
54
|
+
| `navigate` | Navigate to a new URL |
|
|
55
|
+
| `eval` | Execute JavaScript in the canvas |
|
|
56
|
+
| `snapshot` | Capture screenshot of canvas |
|
|
57
|
+
|
|
58
|
+
## Configuration
|
|
59
|
+
|
|
60
|
+
In `~/.kobold/kobold.json`:
|
|
61
|
+
|
|
62
|
+
```json
|
|
63
|
+
{
|
|
64
|
+
"canvasHost": {
|
|
65
|
+
"enabled": true,
|
|
66
|
+
"port": 18793,
|
|
67
|
+
"root": "/Users/you/clawd/canvas",
|
|
68
|
+
"liveReload": true
|
|
69
|
+
},
|
|
70
|
+
"gateway": {
|
|
71
|
+
"bind": "auto"
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
### Live Reload
|
|
77
|
+
|
|
78
|
+
When `liveReload: true` (default), the canvas host:
|
|
79
|
+
|
|
80
|
+
- Watches the root directory for changes (via chokidar)
|
|
81
|
+
- Injects a WebSocket client into HTML files
|
|
82
|
+
- Automatically reloads connected canvases when files change
|
|
83
|
+
|
|
84
|
+
Great for development!
|
|
85
|
+
|
|
86
|
+
## Workflow
|
|
87
|
+
|
|
88
|
+
### 1. Create HTML content
|
|
89
|
+
|
|
90
|
+
Place files in the canvas root directory (default `~/clawd/canvas/`):
|
|
91
|
+
|
|
92
|
+
```bash
|
|
93
|
+
cat > ~/clawd/canvas/my-game.html << 'HTML'
|
|
94
|
+
<!DOCTYPE html>
|
|
95
|
+
<html>
|
|
96
|
+
<head><title>My Game</title></head>
|
|
97
|
+
<body>
|
|
98
|
+
<h1>Hello Canvas!</h1>
|
|
99
|
+
</body>
|
|
100
|
+
</html>
|
|
101
|
+
HTML
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
### 2. Find your canvas host URL
|
|
105
|
+
|
|
106
|
+
Check how your gateway is bound:
|
|
107
|
+
|
|
108
|
+
```bash
|
|
109
|
+
cat ~/.kobold/kobold.json | jq '.gateway.bind'
|
|
110
|
+
```
|
|
111
|
+
|
|
112
|
+
Then construct the URL:
|
|
113
|
+
|
|
114
|
+
- **loopback**: `http://127.0.0.1:18793/__kobold__/canvas/<file>.html`
|
|
115
|
+
- **lan/tailnet/auto**: `http://<hostname>:18793/__kobold__/canvas/<file>.html`
|
|
116
|
+
|
|
117
|
+
Find your Tailscale hostname:
|
|
118
|
+
|
|
119
|
+
```bash
|
|
120
|
+
tailscale status --json | jq -r '.Self.DNSName' | sed 's/\.$//'
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
### 3. Find connected nodes
|
|
124
|
+
|
|
125
|
+
```bash
|
|
126
|
+
kobold nodes list
|
|
127
|
+
```
|
|
128
|
+
|
|
129
|
+
Look for Mac/iOS/Android nodes with canvas capability.
|
|
130
|
+
|
|
131
|
+
### 4. Present content
|
|
132
|
+
|
|
133
|
+
```
|
|
134
|
+
canvas action:present node:<node-id> target:<full-url>
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
**Example:**
|
|
138
|
+
|
|
139
|
+
```
|
|
140
|
+
canvas action:present node:mac-63599bc4-b54d-4392-9048-b97abd58343a target:http://peters-mac-studio-1.sheep-coho.ts.net:18793/__kobold__/canvas/snake.html
|
|
141
|
+
```
|
|
142
|
+
|
|
143
|
+
### 5. Navigate, snapshot, or hide
|
|
144
|
+
|
|
145
|
+
```
|
|
146
|
+
canvas action:navigate node:<node-id> url:<new-url>
|
|
147
|
+
canvas action:snapshot node:<node-id>
|
|
148
|
+
canvas action:hide node:<node-id>
|
|
149
|
+
```
|
|
150
|
+
|
|
151
|
+
## Debugging
|
|
152
|
+
|
|
153
|
+
### White screen / content not loading
|
|
154
|
+
|
|
155
|
+
**Cause:** URL mismatch between server bind and node expectation.
|
|
156
|
+
|
|
157
|
+
**Debug steps:**
|
|
158
|
+
|
|
159
|
+
1. Check server bind: `cat ~/.kobold/kobold.json | jq '.gateway.bind'`
|
|
160
|
+
2. Check what port canvas is on: `lsof -i :18793`
|
|
161
|
+
3. Test URL directly: `curl http://<hostname>:18793/__kobold__/canvas/<file>.html`
|
|
162
|
+
|
|
163
|
+
**Solution:** Use the full hostname matching your bind mode, not localhost.
|
|
164
|
+
|
|
165
|
+
### "node required" error
|
|
166
|
+
|
|
167
|
+
Always specify `node:<node-id>` parameter.
|
|
168
|
+
|
|
169
|
+
### "node not connected" error
|
|
170
|
+
|
|
171
|
+
Node is offline. Use `kobold nodes list` to find online nodes.
|
|
172
|
+
|
|
173
|
+
### Content not updating
|
|
174
|
+
|
|
175
|
+
If live reload isn't working:
|
|
176
|
+
|
|
177
|
+
1. Check `liveReload: true` in config
|
|
178
|
+
2. Ensure file is in the canvas root directory
|
|
179
|
+
3. Check for watcher errors in logs
|
|
180
|
+
|
|
181
|
+
## URL Path Structure
|
|
182
|
+
|
|
183
|
+
The canvas host serves from `/__kobold__/canvas/` prefix:
|
|
184
|
+
|
|
185
|
+
```
|
|
186
|
+
http://<host>:18793/__kobold__/canvas/index.html → ~/clawd/canvas/index.html
|
|
187
|
+
http://<host>:18793/__kobold__/canvas/games/snake.html → ~/clawd/canvas/games/snake.html
|
|
188
|
+
```
|
|
189
|
+
|
|
190
|
+
The `/__kobold__/canvas/` prefix is defined by `CANVAS_HOST_PATH` constant.
|
|
191
|
+
|
|
192
|
+
## Tips
|
|
193
|
+
|
|
194
|
+
- Keep HTML self-contained (inline CSS/JS) for best results
|
|
195
|
+
- Use the default index.html as a test page (has bridge diagnostics)
|
|
196
|
+
- The canvas persists until you `hide` it or navigate away
|
|
197
|
+
- Live reload makes development fast - just save and it updates!
|
|
198
|
+
- A2UI JSON push is WIP - use HTML files for now
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: clawhub
|
|
3
|
+
description: Use the ClawHub CLI to search, install, update, and publish agent skills from clawhub.com. Use when you need to fetch new skills on the fly, sync installed skills to latest or a specific version, or publish new/updated skill folders with the npm-installed clawhub CLI.
|
|
4
|
+
metadata:
|
|
5
|
+
{
|
|
6
|
+
"kobold":
|
|
7
|
+
{
|
|
8
|
+
"requires": { "bins": ["clawhub"] },
|
|
9
|
+
"install":
|
|
10
|
+
[
|
|
11
|
+
{
|
|
12
|
+
"id": "node",
|
|
13
|
+
"kind": "node",
|
|
14
|
+
"package": "clawhub",
|
|
15
|
+
"bins": ["clawhub"],
|
|
16
|
+
"label": "Install ClawHub CLI (npm)",
|
|
17
|
+
},
|
|
18
|
+
],
|
|
19
|
+
},
|
|
20
|
+
}
|
|
21
|
+
---
|
|
22
|
+
|
|
23
|
+
# ClawHub CLI
|
|
24
|
+
|
|
25
|
+
Install
|
|
26
|
+
|
|
27
|
+
```bash
|
|
28
|
+
npm i -g clawhub
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
Auth (publish)
|
|
32
|
+
|
|
33
|
+
```bash
|
|
34
|
+
clawhub login
|
|
35
|
+
clawhub whoami
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
Search
|
|
39
|
+
|
|
40
|
+
```bash
|
|
41
|
+
clawhub search "postgres backups"
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
Install
|
|
45
|
+
|
|
46
|
+
```bash
|
|
47
|
+
clawhub install my-skill
|
|
48
|
+
clawhub install my-skill --version 1.2.3
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
Update (hash-based match + upgrade)
|
|
52
|
+
|
|
53
|
+
```bash
|
|
54
|
+
clawhub update my-skill
|
|
55
|
+
clawhub update my-skill --version 1.2.3
|
|
56
|
+
clawhub update --all
|
|
57
|
+
clawhub update my-skill --force
|
|
58
|
+
clawhub update --all --no-input --force
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
List
|
|
62
|
+
|
|
63
|
+
```bash
|
|
64
|
+
clawhub list
|
|
65
|
+
```
|
|
66
|
+
|
|
67
|
+
Publish
|
|
68
|
+
|
|
69
|
+
```bash
|
|
70
|
+
clawhub publish ./my-skill --slug my-skill --name "My Skill" --version 1.2.0 --changelog "Fixes + docs"
|
|
71
|
+
```
|
|
72
|
+
|
|
73
|
+
Notes
|
|
74
|
+
|
|
75
|
+
- Default registry: https://clawhub.com (override with CLAWHUB_REGISTRY or --registry)
|
|
76
|
+
- Default workdir: cwd (falls back to Kobold workspace); install dir: ./skills (override with --workdir / --dir / CLAWHUB_WORKDIR)
|
|
77
|
+
- Update command hashes local files, resolves matching version, and upgrades to latest unless --version is set
|