@automagik/genie 4.260504.18 → 4.260504.19
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/dist/genie.js
CHANGED
|
@@ -868,27 +868,27 @@ ${errCtx.stack}`;d.reject(err)}else d.resolve(msg)}});return sub.requestSubject=
|
|
|
868
868
|
`;for(let row of rows)map2.set(row.claude_session_id,{agentId:row.agent_id,executorId:row.executor_id,team:row.team,wishSlug:row.wish_slug,taskId:row.task_id,role:row.role})}catch{}return workerMapCache={map:map2,expires:Date.now()+WORKER_MAP_TTL_MS},map2}function workerToContext(worker){return{agentId:worker?.agentId??null,team:worker?.team??null,wishSlug:worker?.wishSlug??null,taskId:worker?.taskId??null,lastOffset:0,totalTurns:0}}async function resolveSafeParentId(sql,parentSessionId){if(!parentSessionId)return null;return(await sql`SELECT 1 FROM sessions WHERE id = ${parentSessionId} LIMIT 1`).length>0?parentSessionId:null}async function ensureSession(sql,sessionId,jsonlPath,projectPath,workerMap,opts){let worker=workerMap.get(sessionId),existing=await sql`
|
|
869
869
|
SELECT executor_id, agent_id, team, wish_slug, task_id, role, status, last_ingested_offset, total_turns
|
|
870
870
|
FROM sessions WHERE id = ${sessionId}
|
|
871
|
-
`;if(existing.length>0){let row=existing[0];if(worker
|
|
872
|
-
UPDATE sessions SET
|
|
873
|
-
executor_id = COALESCE(executor_id, ${worker.executorId??null}),
|
|
874
|
-
agent_id = COALESCE(agent_id, ${worker.agentId??null}),
|
|
875
|
-
team = COALESCE(team, ${worker.team??null}),
|
|
876
|
-
wish_slug = COALESCE(wish_slug, ${worker.wishSlug??null}),
|
|
877
|
-
task_id = COALESCE(task_id, ${worker.taskId??null}),
|
|
878
|
-
role = COALESCE(role, ${worker.role??null}),
|
|
879
|
-
status = CASE
|
|
880
|
-
WHEN status = 'orphaned' AND ${worker.agentId??null}::text IS NOT NULL
|
|
881
|
-
THEN 'active'
|
|
882
|
-
ELSE status
|
|
883
|
-
END,
|
|
884
|
-
updated_at = now()
|
|
885
|
-
WHERE id = ${sessionId}
|
|
886
|
-
RETURNING agent_id, team, wish_slug, task_id, last_ingested_offset, total_turns
|
|
887
|
-
`;return{agentId:upgraded.agent_id,team:upgraded.team,wishSlug:upgraded.wish_slug,taskId:upgraded.task_id,lastOffset:upgraded.last_ingested_offset??0,totalTurns:upgraded.total_turns??0}}return{agentId:row.agent_id,team:row.team,wishSlug:row.wish_slug,taskId:row.task_id,lastOffset:row.last_ingested_offset??0,totalTurns:row.total_turns??0}}let parentSessionId=await resolveSafeParentId(sql,opts?.parentSessionId);return await sql`
|
|
871
|
+
`;if(existing.length>0){let row=existing[0];if(shouldUpgradeOrphanedRow(row,worker))return upgradeOrphanedRow(sql,sessionId,worker);return rowToContext(row)}let parentSessionId=await resolveSafeParentId(sql,opts?.parentSessionId);return await sql`
|
|
888
872
|
INSERT INTO sessions (id, agent_id, executor_id, team, wish_slug, task_id, role, project_path, jsonl_path, status, last_ingested_offset, total_turns, parent_session_id, is_subagent, file_size, file_mtime)
|
|
889
873
|
VALUES (${sessionId}, ${worker?.agentId??null}, ${worker?.executorId??null}, ${worker?.team??null}, ${worker?.wishSlug??null}, ${worker?.taskId??null}, ${worker?.role??null}, ${projectPath}, ${jsonlPath}, ${worker?"active":"orphaned"}, 0, 0, ${parentSessionId}, ${opts?.isSubagent??!1}, ${opts?.fileSize??0}, ${opts?.mtime??0})
|
|
890
874
|
ON CONFLICT (id) DO NOTHING
|
|
891
|
-
`,workerToContext(worker)}async function
|
|
875
|
+
`,workerToContext(worker)}function shouldUpgradeOrphanedRow(row,worker){if(worker===void 0)return!1;return row.executor_id===null||row.agent_id===null||row.team===null||row.wish_slug===null||row.task_id===null||row.role===null||row.status==="orphaned"}async function upgradeOrphanedRow(sql,sessionId,worker){let[upgraded]=await sql`
|
|
876
|
+
UPDATE sessions SET
|
|
877
|
+
executor_id = COALESCE(executor_id, ${worker.executorId??null}),
|
|
878
|
+
agent_id = COALESCE(agent_id, ${worker.agentId??null}),
|
|
879
|
+
team = COALESCE(team, ${worker.team??null}),
|
|
880
|
+
wish_slug = COALESCE(wish_slug, ${worker.wishSlug??null}),
|
|
881
|
+
task_id = COALESCE(task_id, ${worker.taskId??null}),
|
|
882
|
+
role = COALESCE(role, ${worker.role??null}),
|
|
883
|
+
status = CASE
|
|
884
|
+
WHEN status = 'orphaned' AND ${worker.agentId??null}::text IS NOT NULL
|
|
885
|
+
THEN 'active'
|
|
886
|
+
ELSE status
|
|
887
|
+
END,
|
|
888
|
+
updated_at = now()
|
|
889
|
+
WHERE id = ${sessionId}
|
|
890
|
+
RETURNING agent_id, team, wish_slug, task_id, last_ingested_offset, total_turns
|
|
891
|
+
`;return{agentId:upgraded.agent_id,team:upgraded.team,wishSlug:upgraded.wish_slug,taskId:upgraded.task_id,lastOffset:upgraded.last_ingested_offset??0,totalTurns:upgraded.total_turns??0}}function rowToContext(row){return{agentId:row.agent_id,team:row.team,wishSlug:row.wish_slug,taskId:row.task_id,lastOffset:row.last_ingested_offset??0,totalTurns:row.total_turns??0}}async function reconcileSubagentParents(sql){let linkResult=await sql`
|
|
892
892
|
UPDATE sessions s
|
|
893
893
|
SET parent_session_id = p.id,
|
|
894
894
|
updated_at = now()
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@automagik/genie",
|
|
3
|
-
"version": "4.260504.
|
|
3
|
+
"version": "4.260504.19",
|
|
4
4
|
"description": "Collaborative terminal toolkit for human + AI workflows. NOTE: the npm distribution is being soft-deprecated — the canonical install is `curl -fsSL https://get.automagik.dev/genie | bash` (cosign + SLSA verified). See https://automagik.dev/genie/security/distribution-sovereignty",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"bin": {
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "genie",
|
|
3
|
-
"version": "4.260504.
|
|
3
|
+
"version": "4.260504.19",
|
|
4
4
|
"description": "Human-AI partnership for Claude Code. Share a terminal, orchestrate workers, evolve together. Brainstorm ideas, turn them into wishes, execute with /work, validate with /review, and ship as one team.",
|
|
5
5
|
"author": {
|
|
6
6
|
"name": "Namastex Labs"
|