#!/usr/bin/env node // Inlined — see src/hooks/sdk-guard.ts for canonical version. Kept local // per-hook so tsdown does not emit a shared hashed chunk that would churn // the diff on every rebuild. function isSdkChildContext(payload: unknown): boolean { if (process.env["AGENTMEMORY_SDK_CHILD"] === "1") return true; if (!payload || typeof payload !== "object") return false; return (payload as { entrypoint?: unknown }).entrypoint === "sdk-ts"; } const REST_URL = process.env["AGENTMEMORY_URL"] || "http://localhost:3111"; const SECRET = process.env["AGENTMEMORY_SECRET"] || ""; function authHeaders(): Record { const h: Record = { "Content-Type": "application/json" }; if (SECRET) h["Authorization"] = `Bearer ${SECRET}`; return h; } async function main() { let input = ""; for await (const chunk of process.stdin) { input += chunk; } let data: Record; try { data = JSON.parse(input); } catch { return; } if (isSdkChildContext(data)) { // Do not summarize from inside a Claude Agent SDK child session; // would re-enter agent-sdk provider and loop (see sdk-guard.ts). return; } const sessionId = ((data.session_id || data.sessionId) as string) || "unknown"; fetch(`${REST_URL}/agentmemory/summarize`, { method: "POST", headers: authHeaders(), body: JSON.stringify({ sessionId }), signal: AbortSignal.timeout(120000), }).catch(() => {}); fetch(`${REST_URL}/agentmemory/session/end`, { method: "POST", headers: authHeaders(), body: JSON.stringify({ sessionId }), signal: AbortSignal.timeout(5000), }).catch(() => {}); setTimeout(() => process.exit(0), 1500).unref(); } main();