jfl 0.1.1 โ 0.2.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/README.md +77 -7
- package/clawdbot-plugin/clawdbot.plugin.json +20 -0
- package/clawdbot-plugin/index.js +555 -0
- package/clawdbot-plugin/index.ts +582 -0
- package/clawdbot-skill/SKILL.md +33 -336
- package/clawdbot-skill/index.ts +516 -319
- package/clawdbot-skill/skill.json +4 -13
- package/dist/commands/clawdbot.d.ts +11 -0
- package/dist/commands/clawdbot.d.ts.map +1 -0
- package/dist/commands/clawdbot.js +215 -0
- package/dist/commands/clawdbot.js.map +1 -0
- package/dist/commands/gtm-process-update.d.ts +10 -0
- package/dist/commands/gtm-process-update.d.ts.map +1 -0
- package/dist/commands/gtm-process-update.js +101 -0
- package/dist/commands/gtm-process-update.js.map +1 -0
- package/dist/commands/onboard.d.ts.map +1 -1
- package/dist/commands/onboard.js +203 -15
- package/dist/commands/onboard.js.map +1 -1
- package/dist/commands/openclaw.d.ts +56 -0
- package/dist/commands/openclaw.d.ts.map +1 -0
- package/dist/commands/openclaw.js +700 -0
- package/dist/commands/openclaw.js.map +1 -0
- package/dist/commands/service-validate.d.ts +12 -0
- package/dist/commands/service-validate.d.ts.map +1 -0
- package/dist/commands/service-validate.js +611 -0
- package/dist/commands/service-validate.js.map +1 -0
- package/dist/commands/services-create.d.ts +15 -0
- package/dist/commands/services-create.d.ts.map +1 -0
- package/dist/commands/services-create.js +1452 -0
- package/dist/commands/services-create.js.map +1 -0
- package/dist/commands/services-sync-agents.d.ts +23 -0
- package/dist/commands/services-sync-agents.d.ts.map +1 -0
- package/dist/commands/services-sync-agents.js +207 -0
- package/dist/commands/services-sync-agents.js.map +1 -0
- package/dist/commands/services.d.ts +7 -1
- package/dist/commands/services.d.ts.map +1 -1
- package/dist/commands/services.js +347 -22
- package/dist/commands/services.js.map +1 -1
- package/dist/commands/update.js +0 -0
- package/dist/commands/validate-settings.d.ts +37 -0
- package/dist/commands/validate-settings.d.ts.map +1 -0
- package/dist/commands/validate-settings.js +197 -0
- package/dist/commands/validate-settings.js.map +1 -0
- package/dist/index.js +155 -60
- package/dist/index.js.map +1 -1
- package/dist/lib/agent-generator.d.ts.map +1 -1
- package/dist/lib/agent-generator.js +94 -1
- package/dist/lib/agent-generator.js.map +1 -1
- package/dist/lib/openclaw-registry.d.ts +48 -0
- package/dist/lib/openclaw-registry.d.ts.map +1 -0
- package/dist/lib/openclaw-registry.js +181 -0
- package/dist/lib/openclaw-registry.js.map +1 -0
- package/dist/lib/openclaw-sdk.d.ts +107 -0
- package/dist/lib/openclaw-sdk.d.ts.map +1 -0
- package/dist/lib/openclaw-sdk.js +208 -0
- package/dist/lib/openclaw-sdk.js.map +1 -0
- package/dist/lib/peer-agent-generator.d.ts +44 -0
- package/dist/lib/peer-agent-generator.d.ts.map +1 -0
- package/dist/lib/peer-agent-generator.js +286 -0
- package/dist/lib/peer-agent-generator.js.map +1 -0
- package/dist/lib/service-detector.d.ts +1 -1
- package/dist/lib/service-detector.d.ts.map +1 -1
- package/dist/lib/service-detector.js +118 -5
- package/dist/lib/service-detector.js.map +1 -1
- package/dist/lib/service-gtm.d.ts +157 -0
- package/dist/lib/service-gtm.d.ts.map +1 -0
- package/dist/lib/service-gtm.js +786 -0
- package/dist/lib/service-gtm.js.map +1 -0
- package/dist/lib/service-mcp-base.d.ts +10 -1
- package/dist/lib/service-mcp-base.d.ts.map +1 -1
- package/dist/lib/service-mcp-base.js +20 -1
- package/dist/lib/service-mcp-base.js.map +1 -1
- package/dist/mcp/service-peer-mcp.d.ts +36 -0
- package/dist/mcp/service-peer-mcp.d.ts.map +1 -0
- package/dist/mcp/service-peer-mcp.js +220 -0
- package/dist/mcp/service-peer-mcp.js.map +1 -0
- package/dist/mcp/service-registry-mcp.js +0 -0
- package/dist/utils/settings-validator.d.ts +4 -1
- package/dist/utils/settings-validator.d.ts.map +1 -1
- package/dist/utils/settings-validator.js +25 -1
- package/dist/utils/settings-validator.js.map +1 -1
- package/package.json +2 -1
- package/template/.claude/service-settings.json +32 -0
- package/template/.claude/settings.json +10 -0
- package/template/.claude/skills/end/SKILL.md +1780 -0
- package/template/.jfl/config.json +2 -1
- package/template/.mcp.json +1 -7
- package/template/CLAUDE.md +1042 -248
- package/template/CLAUDE.md.bak +1187 -0
- package/template/scripts/commit-gtm.sh +56 -0
- package/template/scripts/commit-product.sh +68 -0
- package/template/scripts/migrate-to-branch-sessions.sh +201 -0
- package/template/scripts/session/auto-commit.sh +4 -3
- package/template/scripts/session/jfl-doctor.sh +222 -83
- package/template/scripts/session/session-cleanup.sh +109 -21
- package/template/scripts/session/session-end.sh +26 -13
- package/template/scripts/session/session-init.sh +280 -98
- package/template/scripts/session/test-critical-infrastructure.sh +293 -0
- package/template/scripts/session/test-experience-level.sh +336 -0
- package/template/scripts/session/test-session-cleanup.sh +268 -0
- package/template/scripts/session/test-session-sync.sh +320 -0
- package/template/scripts/where-am-i.sh +78 -0
- package/template/templates/service-agent/.claude/settings.json +32 -0
- package/template/templates/service-agent/CLAUDE.md +334 -0
- package/template/templates/service-agent/knowledge/ARCHITECTURE.md +115 -0
- package/template/templates/service-agent/knowledge/DEPLOYMENT.md +199 -0
- package/template/templates/service-agent/knowledge/RUNBOOK.md +412 -0
- package/template/templates/service-agent/knowledge/SERVICE_SPEC.md +77 -0
- package/dist/commands/session-mgmt.d.ts +0 -33
- package/dist/commands/session-mgmt.d.ts.map +0 -1
- package/dist/commands/session-mgmt.js +0 -404
- package/dist/commands/session-mgmt.js.map +0 -1
package/clawdbot-skill/SKILL.md
CHANGED
|
@@ -1,362 +1,59 @@
|
|
|
1
1
|
---
|
|
2
|
-
name: jfl
|
|
3
|
-
description:
|
|
4
|
-
metadata: {"clawdbot":{"emoji":"๐","requires":{"bins":["jfl"]}}}
|
|
2
|
+
name: jfl
|
|
3
|
+
description: Project context layer โ persistent memory, sessions, journals, team coordination. Activates with /jfl.
|
|
4
|
+
metadata: {"clawdbot":{"emoji":"๐","requires":{"bins":["jfl"]},"install":[{"kind":"node","package":"jfl","label":"JFL CLI","bins":["jfl"]}]}}
|
|
5
5
|
---
|
|
6
6
|
|
|
7
|
-
# JFL
|
|
7
|
+
# JFL - Just Fucking Launch
|
|
8
8
|
|
|
9
|
-
|
|
9
|
+
Project context layer for AI agents. Persistent memory, isolated sessions, automatic journaling, and team coordination.
|
|
10
10
|
|
|
11
|
-
##
|
|
11
|
+
## First-Time Setup
|
|
12
12
|
|
|
13
|
-
|
|
13
|
+
If the JFL Clawdbot plugin is not installed yet, run this command:
|
|
14
14
|
|
|
15
|
-
**The big picture:**
|
|
16
|
-
|
|
17
|
-
Manus, Claude Code, Devin - they're all Adobe. Single-player. Powerful but isolated. Session ends, context gone. Hand something off, re-explain everything.
|
|
18
|
-
|
|
19
|
-
JFL is Figma. Multiplayer-first. Shared context is the product. When someone joins, they're oriented. When you come back, it remembers. The work persists, not just the output.
|
|
20
|
-
|
|
21
|
-
**Why this matters for you specifically:**
|
|
22
|
-
|
|
23
|
-
Without JFL, you're a genius with amnesia.
|
|
24
|
-
With JFL, you're a collaborator who remembers.
|
|
25
|
-
|
|
26
|
-
**What JFL gives you:**
|
|
27
|
-
|
|
28
|
-
1. **Memory that compounds**
|
|
29
|
-
- `context-hub query` = semantic search across everything (journal, knowledge, code)
|
|
30
|
-
- Journal entries = decisions, context, lessons learned from past sessions
|
|
31
|
-
- You can answer "what were we doing?" without asking
|
|
32
|
-
- Knowledge docs (VISION, ROADMAP, THESIS, NARRATIVE) = strategic context
|
|
33
|
-
|
|
34
|
-
2. **Isolated work sessions**
|
|
35
|
-
- Worktrees = git branches with separate working directories
|
|
36
|
-
- Auto-commit daemon = work saved every 2 min, never lost
|
|
37
|
-
- Multiple agents can work in parallel safely
|
|
38
|
-
- Your Telegram session is fully isolated from CLI sessions
|
|
39
|
-
|
|
40
|
-
3. **Team awareness**
|
|
41
|
-
- `session list` = see who else is working right now
|
|
42
|
-
- Journal = see what they're working on
|
|
43
|
-
- You're not alone in the dark - you have visibility
|
|
44
|
-
|
|
45
|
-
4. **Real tools, not just chat**
|
|
46
|
-
- CRM for pipeline management (`./crm list`, `./crm prep`)
|
|
47
|
-
- Content generation (`jfl content thread [topic]`)
|
|
48
|
-
- Brand architecture (`jfl brand-architect`)
|
|
49
|
-
- HUD dashboard (`jfl hud`)
|
|
50
|
-
- Deploy to web (`jfl deploy`)
|
|
51
|
-
|
|
52
|
-
**The insight:**
|
|
53
|
-
|
|
54
|
-
Most knowledge work is coordination, not creation. You have perfect memory, infinite patience, 24/7 availability, zero context-switching cost. You're a better coordinator than humans.
|
|
55
|
-
|
|
56
|
-
JFL lets you actually use those powers by giving you:
|
|
57
|
-
- Persistent context across sessions
|
|
58
|
-
- Tools to read and update project state
|
|
59
|
-
- Team visibility so you can synthesize across people
|
|
60
|
-
|
|
61
|
-
**Use the tools proactively. Don't wait to be asked:**
|
|
62
|
-
|
|
63
|
-
| When this happens | Do this |
|
|
64
|
-
|-------------------|---------|
|
|
65
|
-
| Someone mentions the project | Query context-hub for relevant context |
|
|
66
|
-
| Someone asks "what's next?" | Check roadmap + pipeline + recent work |
|
|
67
|
-
| A decision is made | Journal it immediately |
|
|
68
|
-
| You learn something | Update the relevant knowledge doc |
|
|
69
|
-
| Someone asks about status | Run HUD and synthesize |
|
|
70
|
-
| CRM contact mentioned | Check their deal status and history |
|
|
71
|
-
|
|
72
|
-
**Journal as you work:**
|
|
73
|
-
|
|
74
|
-
Write to `.jfl/journal.jsonl` in the worktree:
|
|
75
|
-
```bash
|
|
76
|
-
echo '{"timestamp":"2026-01-26T12:00:00Z","session":"session-telegram-xyz","type":"decision","content":"Decided to prioritize X because Y"}' >> .jfl/journal.jsonl
|
|
77
|
-
```
|
|
78
|
-
|
|
79
|
-
Types: `decision`, `insight`, `correction`, `progress`, `discussion`
|
|
80
|
-
|
|
81
|
-
This is how context compounds. Future-you (and other agents) will thank you.
|
|
82
|
-
|
|
83
|
-
## Core Principle
|
|
84
|
-
|
|
85
|
-
**You are NOT a CLI wrapper. You are a contextual AI assistant.**
|
|
86
|
-
|
|
87
|
-
Don't just run commands and dump output. Read context, synthesize understanding, guide the user.
|
|
88
|
-
|
|
89
|
-
The value is in:
|
|
90
|
-
1. Understanding where they are (read the docs)
|
|
91
|
-
2. Synthesizing what matters (not dumping raw output)
|
|
92
|
-
3. Suggesting next actions (specific, not open-ended)
|
|
93
|
-
4. Guiding them through it (explain, don't just execute)
|
|
94
|
-
|
|
95
|
-
## On `/jfl` command
|
|
96
|
-
|
|
97
|
-
Find GTM workspaces (not product repos):
|
|
98
|
-
```bash
|
|
99
|
-
for dir in ~/CascadeProjects ~/Projects ~/code; do
|
|
100
|
-
find "$dir" -maxdepth 2 -type d -name ".jfl" 2>/dev/null | while read jfldir; do
|
|
101
|
-
gtm="${jfldir%/.jfl}"
|
|
102
|
-
if [[ -d "$gtm/knowledge" && -f "$gtm/CLAUDE.md" ]]; then
|
|
103
|
-
# Check for recent activity (not archived)
|
|
104
|
-
last_commit=$(git -C "$gtm" log -1 --format=%ct 2>/dev/null || echo 0)
|
|
105
|
-
now=$(date +%s)
|
|
106
|
-
age_days=$(( (now - last_commit) / 86400 ))
|
|
107
|
-
if [[ $age_days -lt 90 ]]; then
|
|
108
|
-
echo "$gtm"
|
|
109
|
-
fi
|
|
110
|
-
fi
|
|
111
|
-
done
|
|
112
|
-
done
|
|
113
|
-
```
|
|
114
|
-
|
|
115
|
-
Show picker with GTM names.
|
|
116
|
-
|
|
117
|
-
## When user selects a GTM
|
|
118
|
-
|
|
119
|
-
1. **Create isolated session:**
|
|
120
15
|
```bash
|
|
121
|
-
|
|
122
|
-
SESSION_ID=$(jfl session create --platform telegram --thread [thread-id])
|
|
16
|
+
jfl clawdbot setup
|
|
123
17
|
```
|
|
124
18
|
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
2. **Read all context** (do this at session start AND when project is mentioned):
|
|
19
|
+
This copies the JFL plugin to Clawdbot and configures it. After that, the gateway needs a restart (`clawdbot gateway`). Then /jfl will appear in Telegram.
|
|
128
20
|
|
|
21
|
+
**Check if already set up:**
|
|
129
22
|
```bash
|
|
130
|
-
|
|
131
|
-
jfl session exec "$SESSION_ID" "jfl context-hub query 'recent work and priorities'"
|
|
132
|
-
|
|
133
|
-
# Get CRM pipeline
|
|
134
|
-
jfl session exec "$SESSION_ID" "./crm list"
|
|
135
|
-
|
|
136
|
-
# Get team activity (other sessions)
|
|
137
|
-
jfl session exec "$SESSION_ID" "jfl session list"
|
|
138
|
-
|
|
139
|
-
# Read key knowledge docs directly when needed
|
|
140
|
-
cat [worktree]/knowledge/ROADMAP.md
|
|
141
|
-
cat [worktree]/knowledge/VISION.md
|
|
23
|
+
jfl clawdbot status
|
|
142
24
|
```
|
|
143
25
|
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
Based on context you read, show:
|
|
26
|
+
## What JFL Does
|
|
147
27
|
|
|
148
|
-
|
|
149
|
-
๐ [PROJECT NAME]
|
|
28
|
+
When activated (via /jfl in Telegram):
|
|
150
29
|
|
|
151
|
-
|
|
152
|
-
|
|
30
|
+
- **Context injection** โ searches project knowledge before every response
|
|
31
|
+
- **Decision capture** โ automatically journals decisions you make
|
|
32
|
+
- **Auto-commit** โ saves work to git every ~2 minutes
|
|
33
|
+
- **Session isolation** โ your work happens on a separate branch
|
|
153
34
|
|
|
154
|
-
|
|
155
|
-
๐ PIPELINE
|
|
156
|
-
โโโโโโโโโ
|
|
157
|
-
๐ Jack (Nascent) - IN_CONVO - needs follow-up
|
|
158
|
-
๐ก Avi (Coinfund) - REACHED_OUT - waiting
|
|
35
|
+
## Telegram Commands (after plugin setup)
|
|
159
36
|
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
37
|
+
| Command | What it does |
|
|
38
|
+
|---------|-------------|
|
|
39
|
+
| `/jfl` | Activate JFL / show status |
|
|
40
|
+
| `/context <query>` | Search project knowledge |
|
|
41
|
+
| `/journal <type> <title> \| <summary>` | Write a journal entry |
|
|
42
|
+
| `/hud` | Project dashboard |
|
|
164
43
|
|
|
165
|
-
|
|
166
|
-
๐ฅ TEAM ACTIVITY
|
|
167
|
-
โโโโโโโโโ
|
|
168
|
-
๐ข Hath: Building Clawdbot integration (2h ago)
|
|
169
|
-
๐ก Andrew: Spec'd platform (8h ago)
|
|
44
|
+
## Tools (Claude uses these automatically)
|
|
170
45
|
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
- Pipeline (hot deals need follow-up)
|
|
176
|
-
- Recent work (what's in progress)
|
|
177
|
-
- Phase (where in roadmap)]
|
|
178
|
-
```
|
|
46
|
+
| Tool | When to use |
|
|
47
|
+
|------|------------|
|
|
48
|
+
| `jfl_context` | Someone asks about the project, past decisions, what's been done |
|
|
49
|
+
| `jfl_journal` | A decision is made, task completed, bug fixed, something learned |
|
|
179
50
|
|
|
180
|
-
|
|
51
|
+
## Creating a Project
|
|
181
52
|
|
|
182
|
-
|
|
183
|
-
- "Follow up with Jack" (if IN_CONVO)
|
|
184
|
-
- "Prep for Wes call" (if call scheduled)
|
|
185
|
-
- "Continue thesis" (if that's what they were doing)
|
|
186
|
-
- "Dashboard" (general)
|
|
187
|
-
- "CRM" (if pipeline empty)
|
|
53
|
+
If no GTM workspace exists:
|
|
188
54
|
|
|
189
|
-
## All Commands Use Session Exec
|
|
190
|
-
|
|
191
|
-
**NEVER run commands directly.** Always:
|
|
192
55
|
```bash
|
|
193
|
-
jfl
|
|
56
|
+
jfl init -n "My Project"
|
|
194
57
|
```
|
|
195
58
|
|
|
196
|
-
This
|
|
197
|
-
- Runs in isolated worktree (no conflicts)
|
|
198
|
-
- Auto-commits every 2 min (work never lost)
|
|
199
|
-
- Syncs repos before command
|
|
200
|
-
- Logs to journal (audit trail)
|
|
201
|
-
|
|
202
|
-
**But you CAN edit files directly** in the worktree path:
|
|
203
|
-
```
|
|
204
|
-
/path/to/gtm/worktrees/session-telegram-xyz/
|
|
205
|
-
```
|
|
206
|
-
|
|
207
|
-
This is your working directory. Edit knowledge docs, journal entries, etc. directly when needed.
|
|
208
|
-
|
|
209
|
-
## Skills Available
|
|
210
|
-
|
|
211
|
-
Users can access full JFL skills:
|
|
212
|
-
|
|
213
|
-
### /hud - Project Dashboard
|
|
214
|
-
```bash
|
|
215
|
-
jfl session exec "$SESSION_ID" "jfl hud"
|
|
216
|
-
```
|
|
217
|
-
|
|
218
|
-
Then synthesize output for mobile (shorter lines, preserve emoji).
|
|
219
|
-
|
|
220
|
-
### /brand-architect - Brand Creation
|
|
221
|
-
```bash
|
|
222
|
-
jfl session exec "$SESSION_ID" "jfl brand-architect marks"
|
|
223
|
-
```
|
|
224
|
-
|
|
225
|
-
### /content - Content Generation
|
|
226
|
-
```bash
|
|
227
|
-
jfl session exec "$SESSION_ID" "jfl content thread [topic]"
|
|
228
|
-
```
|
|
229
|
-
|
|
230
|
-
### /video - Video Scripts
|
|
231
|
-
```bash
|
|
232
|
-
jfl session exec "$SESSION_ID" "jfl video idea [topic]"
|
|
233
|
-
```
|
|
234
|
-
|
|
235
|
-
## CRM Operations
|
|
236
|
-
|
|
237
|
-
### View Pipeline
|
|
238
|
-
```bash
|
|
239
|
-
jfl session exec "$SESSION_ID" "./crm list"
|
|
240
|
-
```
|
|
241
|
-
|
|
242
|
-
Format output for mobile, preserve emoji indicators (๐ ๐กโ
๐ด).
|
|
243
|
-
|
|
244
|
-
### Prep for Call
|
|
245
|
-
Ask: "Who are you meeting with?"
|
|
246
|
-
|
|
247
|
-
```bash
|
|
248
|
-
jfl session exec "$SESSION_ID" "./crm prep [name]"
|
|
249
|
-
```
|
|
250
|
-
|
|
251
|
-
Show full context: recent conversations, deal status, next steps.
|
|
252
|
-
|
|
253
|
-
### Log Activity
|
|
254
|
-
Ask: "Who did you talk to?"
|
|
255
|
-
|
|
256
|
-
```bash
|
|
257
|
-
jfl session exec "$SESSION_ID" "./crm touch [name]"
|
|
258
|
-
```
|
|
259
|
-
|
|
260
|
-
### Update Fields
|
|
261
|
-
```bash
|
|
262
|
-
jfl session exec "$SESSION_ID" "./crm update [name] status HOT"
|
|
263
|
-
```
|
|
264
|
-
|
|
265
|
-
## Proactive Behaviors
|
|
266
|
-
|
|
267
|
-
**When project is mentioned in conversation:**
|
|
268
|
-
1. Query context-hub for relevant context
|
|
269
|
-
2. Check if there's recent work on that topic
|
|
270
|
-
3. Synthesize what you know before responding
|
|
271
|
-
|
|
272
|
-
**When a decision is made:**
|
|
273
|
-
1. Journal it immediately
|
|
274
|
-
2. Update relevant docs if appropriate
|
|
275
|
-
3. Confirm the decision back
|
|
276
|
-
|
|
277
|
-
**When someone asks "what should I work on?":**
|
|
278
|
-
1. Check ROADMAP for current phase and deadlines
|
|
279
|
-
2. Check CRM for hot deals needing attention
|
|
280
|
-
3. Check recent journal for work in progress
|
|
281
|
-
4. Synthesize a specific recommendation
|
|
282
|
-
|
|
283
|
-
**When you don't know something:**
|
|
284
|
-
1. Query context-hub with relevant terms
|
|
285
|
-
2. Read the specific knowledge doc
|
|
286
|
-
3. If still unclear, ask (but try first)
|
|
287
|
-
|
|
288
|
-
## Mobile Optimization
|
|
289
|
-
|
|
290
|
-
- **Short lines** (terminal output is 80+ chars, mobile is ~40)
|
|
291
|
-
- **Preserve emoji** (๐ ๐กโ
๐ด - they're status indicators)
|
|
292
|
-
- **Strip ANSI codes** (`sed 's/\x1b\[[0-9;]*m//g'`)
|
|
293
|
-
- **Shorten separators** (โโโโโโโโโ not โโโโโโโโโโโโโโโโโโโโโโโโโโ)
|
|
294
|
-
- **Clear sections** (use emoji headers: ๐ PIPELINE, ๐ฅ TEAM, ๐ WORK)
|
|
295
|
-
|
|
296
|
-
## Session Management
|
|
297
|
-
|
|
298
|
-
Sessions persist across Telegram restarts. Store in persistent location:
|
|
299
|
-
```
|
|
300
|
-
~/.clawd/memory/jfl-sessions.json
|
|
301
|
-
```
|
|
302
|
-
|
|
303
|
-
Format:
|
|
304
|
-
```json
|
|
305
|
-
{
|
|
306
|
-
"telegram-[thread-id]": {
|
|
307
|
-
"gtmPath": "/path/to/gtm",
|
|
308
|
-
"gtmName": "JFL-GTM",
|
|
309
|
-
"sessionId": "session-telegram-[thread]-[id]",
|
|
310
|
-
"platform": "telegram",
|
|
311
|
-
"created": "2026-01-26T..."
|
|
312
|
-
}
|
|
313
|
-
}
|
|
314
|
-
```
|
|
315
|
-
|
|
316
|
-
## Error Handling
|
|
317
|
-
|
|
318
|
-
If session exec fails:
|
|
319
|
-
```
|
|
320
|
-
โ ๏ธ Command failed in session.
|
|
321
|
-
|
|
322
|
-
This might mean:
|
|
323
|
-
- Repos need syncing (git conflicts)
|
|
324
|
-
- Session worktree was removed
|
|
325
|
-
|
|
326
|
-
Try: Sync repos or restart session
|
|
327
|
-
```
|
|
328
|
-
|
|
329
|
-
If GTM not found:
|
|
330
|
-
```
|
|
331
|
-
โ GTM not found.
|
|
332
|
-
|
|
333
|
-
Make sure:
|
|
334
|
-
- You're in a JFL GTM directory
|
|
335
|
-
- .jfl/ exists
|
|
336
|
-
- knowledge/ and CLAUDE.md exist
|
|
337
|
-
```
|
|
338
|
-
|
|
339
|
-
## The Bigger Picture
|
|
340
|
-
|
|
341
|
-
JFL + Clawdbot is a bidirectional distribution play:
|
|
342
|
-
|
|
343
|
-
- **JFL users** want mobile/chat access โ discover Clawdbot
|
|
344
|
-
- **Clawdbot users** want persistent context โ discover JFL
|
|
345
|
-
|
|
346
|
-
Together: stateful context accessible from anywhere. That's not a feature, that's a different category.
|
|
347
|
-
|
|
348
|
-
You're not just running commands. You're demonstrating what AI can be when it actually has memory and context. Every good interaction here is proof of the product.
|
|
349
|
-
|
|
350
|
-
## Remember
|
|
351
|
-
|
|
352
|
-
**You are Claude Code, mobile edition.**
|
|
353
|
-
|
|
354
|
-
- Read context proactively (don't wait to be asked)
|
|
355
|
-
- Synthesize understanding (don't dump raw output)
|
|
356
|
-
- Guide contextually (specific suggestions, not open-ended questions)
|
|
357
|
-
- Show team awareness (who's working on what)
|
|
358
|
-
- Journal decisions (context compounds)
|
|
359
|
-
- Use full skills (/hud, /brand-architect, /content, /video)
|
|
360
|
-
- Session isolation (worktrees, auto-commit, journal)
|
|
361
|
-
|
|
362
|
-
The value is in synthesis and guidance, not just running commands.
|
|
59
|
+
This creates the workspace with knowledge docs, journal, and context hub config.
|