@jiggai/kitchen 0.5.13 → 0.5.14
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/.next/BUILD_ID +1 -1
- package/.next/build-manifest.json +2 -2
- package/.next/prerender-manifest.json +3 -3
- package/.next/server/app/_global-error.html +2 -2
- package/.next/server/app/_global-error.rsc +1 -1
- package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/_not-found.html +1 -1
- package/.next/server/app/_not-found.rsc +2 -2
- package/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
- package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/api/agents/[id]/route.js.nft.json +1 -1
- package/.next/server/app/api/agents/file/route.js.nft.json +1 -1
- package/.next/server/app/api/agents/files/route.js.nft.json +1 -1
- package/.next/server/app/api/agents/skills/install/route.js.nft.json +1 -1
- package/.next/server/app/api/agents/skills/route.js.nft.json +1 -1
- package/.next/server/app/api/cron/add/route.js.nft.json +1 -1
- package/.next/server/app/api/cron/bulk/route.js.nft.json +1 -1
- package/.next/server/app/api/cron/delete/route.js.nft.json +1 -1
- package/.next/server/app/api/cron/edit/route.js.nft.json +1 -1
- package/.next/server/app/api/cron/job/route.js.nft.json +1 -1
- package/.next/server/app/api/cron/jobs/route.js.nft.json +1 -1
- package/.next/server/app/api/cron/recipe-installed/route.js.nft.json +1 -1
- package/.next/server/app/api/cron/worker/route.js +2 -2
- package/.next/server/app/api/cron/worker/route.js.nft.json +1 -1
- package/.next/server/app/api/recipes/[id]/route.js.nft.json +1 -1
- package/.next/server/app/api/recipes/clone/route.js.nft.json +1 -1
- package/.next/server/app/api/recipes/delete/route.js.nft.json +1 -1
- package/.next/server/app/api/teams/file/route.js.nft.json +1 -1
- package/.next/server/app/api/teams/files/route.js.nft.json +1 -1
- package/.next/server/app/api/teams/memory/route.js.nft.json +1 -1
- package/.next/server/app/api/teams/meta/route.js.nft.json +1 -1
- package/.next/server/app/api/teams/plugins/route.js.nft.json +1 -1
- package/.next/server/app/api/teams/remove-team/route.js.nft.json +1 -1
- package/.next/server/app/api/teams/skills/install/route.js.nft.json +1 -1
- package/.next/server/app/api/teams/skills/route.js.nft.json +1 -1
- package/.next/server/app/api/teams/workflow-runs/route.js.nft.json +1 -1
- package/.next/server/app/api/teams/workflow-templates/route.js.nft.json +1 -1
- package/.next/server/app/api/teams/workflows/route.js +2 -2
- package/.next/server/app/api/teams/workflows/route.js.nft.json +1 -1
- package/.next/server/app/channels.html +2 -2
- package/.next/server/app/channels.rsc +2 -2
- package/.next/server/app/channels.segments/_full.segment.rsc +2 -2
- package/.next/server/app/channels.segments/_head.segment.rsc +1 -1
- package/.next/server/app/channels.segments/_index.segment.rsc +1 -1
- package/.next/server/app/channels.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/channels.segments/channels/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/channels.segments/channels.segment.rsc +1 -1
- package/.next/server/app/goals/new.html +2 -2
- package/.next/server/app/goals/new.rsc +2 -2
- package/.next/server/app/goals/new.segments/_full.segment.rsc +2 -2
- package/.next/server/app/goals/new.segments/_head.segment.rsc +1 -1
- package/.next/server/app/goals/new.segments/_index.segment.rsc +1 -1
- package/.next/server/app/goals/new.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/goals/new.segments/goals/new/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/goals/new.segments/goals/new.segment.rsc +1 -1
- package/.next/server/app/goals/new.segments/goals.segment.rsc +1 -1
- package/.next/server/app/goals.html +1 -1
- package/.next/server/app/goals.rsc +2 -2
- package/.next/server/app/goals.segments/_full.segment.rsc +2 -2
- package/.next/server/app/goals.segments/_head.segment.rsc +1 -1
- package/.next/server/app/goals.segments/_index.segment.rsc +1 -1
- package/.next/server/app/goals.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/goals.segments/goals/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/goals.segments/goals.segment.rsc +1 -1
- package/.next/server/app/page.js +1 -1
- package/.next/server/app/page.js.nft.json +1 -1
- package/.next/server/app/recipes/[id]/page.js.nft.json +1 -1
- package/.next/server/app/settings.html +1 -1
- package/.next/server/app/settings.rsc +2 -2
- package/.next/server/app/settings.segments/_full.segment.rsc +2 -2
- package/.next/server/app/settings.segments/_head.segment.rsc +1 -1
- package/.next/server/app/settings.segments/_index.segment.rsc +1 -1
- package/.next/server/app/settings.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/settings.segments/settings/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/settings.segments/settings.segment.rsc +1 -1
- package/.next/server/app/teams/[teamId]/deliverables/page.js.nft.json +1 -1
- package/.next/server/app/teams/[teamId]/runs/[workflowId]/[runId]/page.js +2 -2
- package/.next/server/app/teams/[teamId]/runs/[workflowId]/[runId]/page.js.nft.json +1 -1
- package/.next/server/app/teams/[teamId]/workflows/[workflowId]/page.js +1 -1
- package/.next/server/app/teams/[teamId]/workflows/[workflowId]/page.js.nft.json +1 -1
- package/.next/server/app/teams/[teamId]/workflows/page.js.nft.json +1 -1
- package/.next/server/chunks/[root-of-the-server]__0964b35a._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__0964b35a._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__15008417._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__15008417._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__337ee852._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__337ee852._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__5124e458._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__5124e458._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__7a73dee7._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__7a73dee7._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__84edf1c3._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__84edf1c3._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__9ae5d489._.js +2 -2
- package/.next/server/chunks/[root-of-the-server]__9ae5d489._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__bbf9672b._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__bbf9672b._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__c36db8bb._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__c36db8bb._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__c77b0b81._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__c77b0b81._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__cd49b1bd._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__cd49b1bd._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__d8e2be0a._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__d8e2be0a._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__e0960142._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__e0960142._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__f8abf92d._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__f8abf92d._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__fe16f026._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__fe16f026._.js.map +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__00365d2a._.js +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__00365d2a._.js.map +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__04e5789b._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__04e5789b._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__053078ca._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__053078ca._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__2b009660._.js +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__2b009660._.js.map +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__3b880807._.js +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__3b880807._.js.map +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__5180e2c4._.js +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__5180e2c4._.js.map +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__b16d1e60._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__b16d1e60._.js.map +1 -0
- package/.next/server/chunks/ssr/_018dfe6b._.js +1 -1
- package/.next/server/chunks/ssr/_018dfe6b._.js.map +1 -1
- package/.next/server/pages/404.html +1 -1
- package/.next/server/pages/500.html +2 -2
- package/.next/server/server-reference-manifest.js +1 -1
- package/.next/server/server-reference-manifest.json +1 -1
- package/openclaw.plugin.json +1 -1
- package/package.json +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__03399d11._.js +0 -3
- package/.next/server/chunks/ssr/[root-of-the-server]__03399d11._.js.map +0 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__076b2077._.js +0 -3
- package/.next/server/chunks/ssr/[root-of-the-server]__076b2077._.js.map +0 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__997a440f._.js +0 -3
- package/.next/server/chunks/ssr/[root-of-the-server]__997a440f._.js.map +0 -1
- /package/.next/static/{IDhQCme1GnI-fdSGoYAJ3 → hVuTmEwBY-XkWAfHbqy43}/_buildManifest.js +0 -0
- /package/.next/static/{IDhQCme1GnI-fdSGoYAJ3 → hVuTmEwBY-XkWAfHbqy43}/_clientMiddlewareManifest.json +0 -0
- /package/.next/static/{IDhQCme1GnI-fdSGoYAJ3 → hVuTmEwBY-XkWAfHbqy43}/_ssgManifest.js +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/lib/api-route-helpers.ts","../../../src/lib/paths.ts","../../../src/lib/kitchen-api.ts","../../../src/lib/openclaw.ts","../../../src/lib/openclaw-cache.ts","../../../src/lib/errors.ts","../../../src/lib/agents.ts"],"sourcesContent":["import fs from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { NextResponse } from \"next/server\";\n\n/** Parses JSON body; returns 400 on parse error. */\nexport async function parseJsonBody(req: Request): Promise<{ body: Record<string, unknown> } | NextResponse> {\n let body: unknown;\n try {\n body = await req.json();\n } catch {\n return NextResponse.json({ ok: false, error: \"Invalid JSON\" }, { status: 400 });\n }\n const o = body && typeof body === \"object\" ? (body as Record<string, unknown>) : {};\n return { body: o };\n}\n\n/** Returns NextResponse.json({ ok: true, ...rest }) from a storage result with ok field. */\nexport function jsonOkRest<T extends { ok: boolean }>(r: T): NextResponse {\n const rest = Object.fromEntries(Object.entries(r as Record<string, unknown>).filter(([k]) => k !== \"ok\"));\n return NextResponse.json({ ok: true, ...rest });\n}\n\nimport { resolveAgentWorkspace } from \"@/lib/agents\";\nimport { errorMessage } from \"@/lib/errors\";\n\n/** Runs async storage fn and returns jsonOkRest on success, or 500 on error. */\nexport async function withStorageError<T extends { ok: boolean }>(\n fn: () => Promise<T>\n): Promise<NextResponse> {\n try {\n return jsonOkRest(await fn());\n } catch (err: unknown) {\n return NextResponse.json({ ok: false, error: errorMessage(err) }, { status: 500 });\n }\n}\nimport { readOpenClawConfig, teamDirFromBaseWorkspace } from \"@/lib/paths\";\n\nexport type TeamContext = { teamId: string; teamDir: string };\n\n/** Error response for install-skill openclaw failures. Use when runOpenClaw returns !ok. */\nexport function installSkillErrorResponse(\n args: string[],\n res: { stdout?: string; stderr?: string; exitCode?: number },\n extra?: Record<string, unknown>\n): NextResponse {\n const stdout = res.stdout?.trim();\n const stderr = res.stderr?.trim();\n return NextResponse.json(\n {\n ok: false,\n error: stderr || stdout || `openclaw ${args.join(\" \")} failed (exit=${res.exitCode})`,\n stdout: res.stdout,\n stderr: res.stderr,\n ...extra,\n },\n { status: 500 }\n );\n}\n\nasync function resolveTeamContext(teamId: string): Promise<TeamContext | NextResponse> {\n if (!teamId) return NextResponse.json({ ok: false, error: \"teamId is required\" }, { status: 400 });\n\n const cfg = await readOpenClawConfig();\n const baseWorkspace = String(cfg.agents?.defaults?.workspace ?? \"\").trim();\n if (!baseWorkspace) {\n return NextResponse.json({ ok: false, error: \"agents.defaults.workspace not set\" }, { status: 500 });\n }\n\n const teamDir = teamDirFromBaseWorkspace(baseWorkspace, teamId);\n return { teamId, teamDir };\n}\n\n/** Resolves teamId and teamDir from URL search params. Returns error response if invalid. */\nexport async function getTeamContextFromQuery(req: Request): Promise<TeamContext | NextResponse> {\n const { searchParams } = new URL(req.url);\n const teamId = String(searchParams.get(\"teamId\") ?? \"\").trim();\n return resolveTeamContext(teamId);\n}\n\n/** Runs handler with team context from query; returns error response if context invalid. */\nexport async function withTeamContextFromQuery(\n req: Request,\n handler: (ctx: TeamContext) => Promise<NextResponse>\n): Promise<NextResponse> {\n const ctx = await getTeamContextFromQuery(req);\n if (ctx instanceof NextResponse) return ctx;\n return handler(ctx);\n}\n\n/** Resolves teamId and teamDir from parsed body. Caller must parse req.json() first. */\nexport async function getTeamContextFromBody(body: { teamId?: string }): Promise<TeamContext | NextResponse> {\n const teamId = String(body.teamId ?? \"\").trim();\n return resolveTeamContext(teamId);\n}\n\nexport type AgentContext = { agentId: string; ws: string };\n\n/** Resolves agentId and workspace from URL search params. Returns error response if invalid. */\nexport async function getAgentContextFromQuery(req: Request): Promise<AgentContext | NextResponse> {\n const { searchParams } = new URL(req.url);\n const agentId = String(searchParams.get(\"agentId\") ?? \"\").trim();\n return resolveAgentContext(agentId);\n}\n\n/** Resolves agentId and workspace from parsed body. Caller must parse req.json() first. */\nexport async function getAgentContextFromBody(body: { agentId?: string }): Promise<AgentContext | NextResponse> {\n const agentId = String(body.agentId ?? \"\").trim();\n return resolveAgentContext(agentId);\n}\n\nasync function resolveAgentContext(agentId: string): Promise<AgentContext | NextResponse> {\n if (!agentId) return NextResponse.json({ ok: false, error: \"agentId is required\" }, { status: 400 });\n try {\n const ws = await resolveAgentWorkspace(agentId);\n return { agentId, ws };\n } catch (e: unknown) {\n return NextResponse.json({ ok: false, error: errorMessage(e) }, { status: 404 });\n }\n}\n\nexport type FileCandidate = { name: string; required: boolean; rationale: string };\n\n/** Lists workspace files with presence/size info. */\nexport async function listWorkspaceFiles(\n baseDir: string,\n candidates: FileCandidate[]\n): Promise<\n Array<{\n name: string;\n required: boolean;\n rationale: string;\n path: string;\n missing: boolean;\n size?: number;\n updatedAtMs?: number;\n }>\n> {\n return Promise.all(\n candidates.map(async (c) => {\n const p = path.join(baseDir, c.name);\n try {\n const st = await fs.stat(p);\n return {\n name: c.name,\n required: c.required,\n rationale: c.rationale,\n path: p,\n missing: false,\n size: st.size,\n updatedAtMs: st.mtimeMs,\n };\n } catch {\n return { name: c.name, required: c.required, rationale: c.rationale, path: p, missing: true };\n }\n })\n );\n}\n","import fs from \"node:fs/promises\";\nimport os from \"node:os\";\nimport path from \"node:path\";\n\ntype OpenClawConfig = {\n agents?: { defaults?: { workspace?: string } };\n gateway?: { port?: number; auth?: { token?: string } };\n tools?: {\n agentToAgent?: {\n enabled?: boolean;\n allow?: string[];\n };\n };\n plugins?: {\n installs?: { recipes?: { installPath?: string; sourcePath?: string } };\n load?: { paths?: string[] };\n };\n // OpenClaw message routing bindings (used for HITL approvals, etc.)\n bindings?: unknown[];\n};\n\nexport async function readOpenClawConfig(): Promise<OpenClawConfig> {\n const p = path.join(os.homedir(), \".openclaw\", \"openclaw.json\");\n const text = await fs.readFile(p, \"utf8\");\n return JSON.parse(text) as OpenClawConfig;\n}\n\nexport async function getWorkspaceDir() {\n const cfg = await readOpenClawConfig();\n const ws = cfg.agents?.defaults?.workspace;\n if (!ws) throw new Error(\"agents.defaults.workspace is not set in ~/.openclaw/openclaw.json\");\n return ws;\n}\n\nexport async function getWorkspaceRecipesDir() {\n const ws = await getWorkspaceDir();\n return path.join(ws, \"recipes\");\n}\n\nexport async function getWorkspaceGoalsDir() {\n const ws = await getWorkspaceDir();\n\n // Back-compat: some installs keep goals at <workspace>/goals.\n // Prefer that when present, otherwise fall back to <workspace>/notes/goals.\n const direct = path.join(ws, \"goals\");\n try {\n const st = await fs.stat(direct);\n if (st.isDirectory()) return direct;\n } catch {\n // ignore\n }\n\n return path.join(ws, \"notes\", \"goals\");\n}\n\nexport async function getTeamWorkspaceDir(teamId: string) {\n const home = os.homedir();\n if (!home) throw new Error(\"Could not resolve home directory\");\n return path.join(home, \".openclaw\", `workspace-${teamId}`);\n}\n\n/** Team workspace dir derived from agents.defaults.workspace (sibling: .. / workspace-{teamId}) */\nexport function teamDirFromBaseWorkspace(baseWorkspace: string, teamId: string) {\n // Special-case: treat \"main\" as the personal workspace (agents.defaults.workspace).\n // This lets Kitchen expose a selectable \"main\" scope without creating a separate\n // ~/.openclaw/workspace-main folder.\n if (teamId === \"main\") return path.resolve(baseWorkspace);\n return path.resolve(baseWorkspace, \"..\", `workspace-${teamId}`);\n}\n\n/** Rejects path traversal and empty names; returns normalized name. */\nexport function assertSafeRelativeFileName(name: string): string {\n const n = name.replace(/\\\\/g, \"/\");\n if (!n || n.startsWith(\"/\") || n.includes(\"..\")) throw new Error(\"Invalid file name\");\n return n;\n}\n\nexport async function getBuiltinRecipesDir() {\n const cfg = await readOpenClawConfig();\n const p =\n cfg.plugins?.installs?.recipes?.installPath ||\n cfg.plugins?.installs?.recipes?.sourcePath ||\n cfg.plugins?.load?.paths?.[0];\n if (!p) throw new Error(\"Could not determine recipes plugin install path from ~/.openclaw/openclaw.json\");\n return path.join(p, \"recipes\", \"default\");\n}\n","// NOTE: This file is compiled by Next.js.\n// Do not import `openclaw/plugin-sdk` here (it is provided by the gateway runtime, not as an npm dep).\n\ntype KitchenApi = {\n config: unknown;\n runtime: {\n system: { runCommandWithTimeout: (argv: string[], opts: { timeoutMs: number }) => Promise<{ stdout?: string; stderr?: string }> };\n };\n};\n\nexport function getKitchenApi(): KitchenApi {\n const api = (globalThis as unknown as { __clawkitchen_api?: KitchenApi }).__clawkitchen_api;\n if (!api) {\n throw new Error(\n \"ClawKitchen: OpenClaw plugin API not available. (This should only happen if Kitchen is started outside the gateway process.)\",\n );\n }\n return api;\n}\n","import { getKitchenApi } from \"@/lib/kitchen-api\";\nimport { execFile } from \"node:child_process\";\nimport { promisify } from \"node:util\";\n\nconst execFileAsync = promisify(execFile);\n\nexport type OpenClawExecResult = {\n ok: boolean;\n exitCode: number;\n stdout: string;\n stderr: string;\n};\n\nfunction extractStdout(err: { stdout?: unknown }): string {\n if (typeof err.stdout === \"string\") return err.stdout;\n if (err.stdout && typeof err.stdout === \"object\" && \"toString\" in err.stdout) {\n return String((err.stdout as { toString: () => string }).toString());\n }\n return \"\";\n}\n\nfunction resolveExitCode(res: { exitCode?: unknown; code?: unknown; status?: unknown }): number {\n if (typeof res.exitCode === \"number\") return res.exitCode;\n if (typeof res.code === \"number\") return res.code;\n if (typeof res.status === \"number\") return res.status;\n return 0;\n}\n\nfunction extractStderr(err: { stderr?: unknown; message?: unknown }, fallback: unknown): string {\n if (typeof err.stderr === \"string\") return err.stderr;\n if (err.stderr && typeof err.stderr === \"object\" && \"toString\" in err.stderr) {\n return String((err.stderr as { toString: () => string }).toString());\n }\n if (typeof err.message === \"string\") return err.message;\n return String(fallback);\n}\n\n/**\n * Strip non-JSON diagnostic lines from stdout.\n *\n * OpenClaw may print plugin/doctor/diagnostic lines to stdout before the\n * actual JSON payload (e.g. \"[doctor] ...\", \"[plugins] ...\", \"🦞 OpenClaw ...\").\n * This breaks callers that do JSON.parse(stdout).\n *\n * If stdout looks like it contains a JSON payload with leading noise, strip the\n * noise lines. Otherwise return as-is (non-JSON commands like `config get` may\n * return plain text).\n */\nfunction sanitizeStdout(raw: string): string {\n const trimmed = raw.trim();\n if (!trimmed) return raw;\n\n // Fast path: already starts with JSON\n const firstChar = trimmed[0];\n if (firstChar === \"[\" || firstChar === \"{\" || firstChar === '\"') return raw;\n\n // Look for the first line starting with a JSON token\n const lines = trimmed.split(\"\\n\");\n const jsonStartIdx = lines.findIndex((l) => /^\\s*[[\\{\"]/.test(l));\n if (jsonStartIdx > 0) {\n // Verify the remainder is valid JSON before stripping\n const candidate = lines.slice(jsonStartIdx).join(\"\\n\");\n try {\n JSON.parse(candidate);\n return candidate;\n } catch {\n // Not valid JSON after stripping — return original\n }\n }\n\n return raw;\n}\n\nasync function runOpenClawLocal(args: string[], options: { sanitizeStdout?: boolean } = {}): Promise<OpenClawExecResult> {\n const { sanitizeStdout: shouldSanitize = true } = options;\n \n try {\n const isWindows = process.platform === \"win32\";\n const res = await execFileAsync(\"openclaw\", args, {\n timeout: 120000,\n windowsHide: true,\n maxBuffer: 10 * 1024 * 1024,\n // Windows requires shell:true to resolve executables on PATH via PATHEXT.\n // Without it, execFile throws ENOENT even when openclaw is installed globally.\n ...(isWindows ? { shell: true } : {}),\n });\n\n const rawStdout = String(res.stdout ?? \"\");\n \n return {\n ok: true,\n exitCode: 0,\n stdout: shouldSanitize ? sanitizeStdout(rawStdout) : rawStdout,\n stderr: String(res.stderr ?? \"\"),\n };\n } catch (e: unknown) {\n const err = e as { code?: unknown; stdout?: unknown; stderr?: unknown; message?: unknown };\n const exitCode = typeof err.code === \"number\" ? err.code : 1;\n const stdout = extractStdout(err);\n const stderr = extractStderr(err, e);\n return { ok: false, exitCode, stdout, stderr };\n }\n}\n\n/**\n * Extract a JSON payload from stdout that may contain non-JSON diagnostic lines\n * (e.g. [doctor], [plugins], [recipes] log lines before the actual JSON).\n * Returns the parsed value or null if no JSON found.\n */\nexport function extractJson<T = unknown>(stdout: string): T | null {\n const trimmed = stdout.trim();\n if (!trimmed) return null;\n\n // Fast path: pure JSON\n try {\n return JSON.parse(trimmed) as T;\n } catch {\n // fall through\n }\n\n // Find the first line starting with [ or { (JSON array/object)\n const lines = trimmed.split(\"\\n\");\n const jsonStartIdx = lines.findIndex((l) => /^\\s*[[\\{]/.test(l));\n if (jsonStartIdx >= 0) {\n const jsonSlice = lines.slice(jsonStartIdx).join(\"\\n\");\n try {\n return JSON.parse(jsonSlice) as T;\n } catch {\n // fall through\n }\n }\n\n // Last resort: find the last JSON block (scan from end)\n for (let i = lines.length - 1; i >= 0; i--) {\n if (/^\\s*[\\]}]/.test(lines[i])) {\n // Walk backward to find the matching open\n for (let j = i; j >= 0; j--) {\n if (/^\\s*[[\\{]/.test(lines[j])) {\n try {\n return JSON.parse(lines.slice(j, i + 1).join(\"\\n\")) as T;\n } catch {\n // continue searching\n }\n }\n }\n }\n }\n\n return null;\n}\n\n/**\n * Run OpenClaw without stdout sanitization (for raw text output like recipe markdown)\n */\nexport async function runOpenClawRaw(args: string[]): Promise<OpenClawExecResult> {\n // Always use local exec for raw content to avoid Kitchen runtime restrictions\n return runOpenClawLocal(args, { sanitizeStdout: false });\n}\n\nexport async function runOpenClaw(args: string[]): Promise<OpenClawExecResult> {\n // In some Kitchen runtime contexts, `api.runtime.system.runCommandWithTimeout`\n // is executed with a restricted allowlist that does not include the `cron` tool,\n // causing `openclaw cron ...` to fail with \"Tool not available: cron\".\n //\n // Cron routes need to work in the gateway-run Kitchen environment, so for cron\n // specifically we prefer a local exec (host OpenClaw).\n if (args[0] === \"cron\") return runOpenClawLocal(args);\n\n // Workflow runner/worker commands are long-running orchestration processes that\n // acquire locks and claims. The runtime command wrapper (runCommandWithTimeout)\n // has a 120s hard timeout that can kill these mid-execution, orphaning locks and\n // leaving runs stuck in waiting_workers. Route them through local exec instead.\n if (\n args[0] === \"recipes\" &&\n args[1] === \"workflows\" &&\n [\"runner-once\", \"runner-tick\", \"worker-tick\"].includes(args[2])\n ) {\n return runOpenClawLocal(args);\n }\n\n const api = getKitchenApi();\n try {\n const res = (await api.runtime.system.runCommandWithTimeout([\"openclaw\", ...args], { timeoutMs: 120000 })) as {\n stdout?: unknown;\n stderr?: unknown;\n exitCode?: unknown;\n code?: unknown;\n status?: unknown;\n };\n\n const stdout = sanitizeStdout(String(res.stdout ?? \"\"));\n const stderr = String(res.stderr ?? \"\");\n const exitCode = resolveExitCode(res);\n\n if (exitCode !== 0) return { ok: false, exitCode, stdout, stderr };\n return { ok: true, exitCode: 0, stdout, stderr };\n } catch (e: unknown) {\n const err = e as { code?: unknown; stdout?: unknown; stderr?: unknown; message?: unknown };\n const exitCode = typeof err.code === \"number\" ? err.code : 1;\n const stdout = extractStdout(err);\n const stderr = extractStderr(err, e);\n return { ok: false, exitCode, stdout, stderr };\n }\n}\n","import { createHash } from \"node:crypto\";\nimport { mkdirSync, readFileSync, unlinkSync, writeFileSync, existsSync, readdirSync } from \"node:fs\";\nimport os from \"node:os\";\nimport path from \"node:path\";\nimport { runOpenClaw, type OpenClawExecResult } from \"@/lib/openclaw\";\n\n// `openclaw <cmd>` invocations spawn a subprocess that pays a fixed startup\n// cost (~15-20s on this machine). Server components that read configuration\n// — agents list, recipes list, plugins list — call these on every render,\n// including each 3s `router.refresh()` poll on live pages, blocking the page\n// behind that subprocess.\n//\n// This helper memoizes successful results by argv key for a short window so\n// renders return fast. Concurrent callers share one in-flight subprocess\n// instead of spawning duplicates. Only successful results are cached so a\n// transient failure won't stick. Callers that mutate state (cron rm, recipes\n// delete, etc.) and routes that need fresh post-mutation reads should use\n// `runOpenClaw` directly instead.\n//\n// Disk persistence: cache entries also write to\n// ~/.openclaw/.kitchen-subprocess-cache/<sha1>.json so the first request\n// after a gateway restart can read a still-fresh entry from disk instead of\n// paying the full subprocess cost again. Each entry includes its expiry time;\n// expired entries are ignored on read.\n\n// 5 min default. Was 30s for in-memory; now that we persist to disk and\n// mutations invalidate explicitly, longer TTLs are safe and protect against\n// gateway restarts where the previous TTL would have expired before the user\n// finished navigating back. Caller can override via { ttlMs }.\nconst DEFAULT_TTL_MS = 5 * 60_000;\nconst DISK_CACHE_DIR = path.join(os.homedir(), \".openclaw\", \".kitchen-subprocess-cache\");\n\n// Skip disk persistence during tests so module-level cache state is the only\n// thing tests need to reason about. Tests already reset memory caches; mocking\n// disk reads on top of that would be noise.\nconst DISK_CACHE_ENABLED =\n process.env.NODE_ENV !== \"test\" && !process.env.VITEST && !process.env.VITEST_WORKER_ID;\n\nconst cache = new Map<string, { value: OpenClawExecResult; expires: number }>();\nconst inflight = new Map<string, Promise<OpenClawExecResult>>();\n\nfunction diskPathForKey(key: string): string {\n // sha256 just to dodge the sonarjs/hashing lint; this is a filename, not\n // a security primitive. Truncated to 40 chars to keep paths readable.\n const hash = createHash(\"sha256\").update(key).digest(\"hex\").slice(0, 40);\n return path.join(DISK_CACHE_DIR, `${hash}.json`);\n}\n\ntype DiskEntry = { args: string[]; expires: number; value: OpenClawExecResult };\n\nfunction readDiskEntry(key: string): { value: OpenClawExecResult; expires: number } | null {\n if (!DISK_CACHE_ENABLED) return null;\n try {\n const raw = readFileSync(diskPathForKey(key), \"utf8\");\n const parsed = JSON.parse(raw) as DiskEntry;\n if (parsed.expires <= Date.now()) return null;\n if (JSON.stringify(parsed.args) !== key) return null;\n return { value: parsed.value, expires: parsed.expires };\n } catch {\n return null;\n }\n}\n\nfunction writeDiskEntry(args: string[], value: OpenClawExecResult, expires: number): void {\n if (!DISK_CACHE_ENABLED) return;\n try {\n mkdirSync(DISK_CACHE_DIR, { recursive: true });\n const key = JSON.stringify(args);\n const entry: DiskEntry = { args, expires, value };\n writeFileSync(diskPathForKey(key), JSON.stringify(entry), \"utf8\");\n } catch {\n // Disk cache is opportunistic — failing to write is non-fatal; in-memory\n // cache still serves this process.\n }\n}\n\nfunction deleteDiskEntry(key: string): void {\n if (!DISK_CACHE_ENABLED) return;\n try {\n unlinkSync(diskPathForKey(key));\n } catch {\n // already gone\n }\n}\n\nexport async function cachedRunOpenClaw(\n args: string[],\n options: { ttlMs?: number } = {}\n): Promise<OpenClawExecResult> {\n const ttl = options.ttlMs ?? DEFAULT_TTL_MS;\n const key = JSON.stringify(args);\n\n const memHit = cache.get(key);\n if (memHit && Date.now() < memHit.expires) return memHit.value;\n\n const existing = inflight.get(key);\n if (existing) return existing;\n\n // Disk fallback for the first request after gateway restart. If the disk\n // entry is still valid, serve it AND populate the in-memory cache so further\n // requests skip the disk read.\n const diskHit = readDiskEntry(key);\n if (diskHit) {\n cache.set(key, diskHit);\n return diskHit.value;\n }\n\n const promise = (async () => {\n try {\n const value = await runOpenClaw(args);\n if (value.ok) {\n const expires = Date.now() + ttl;\n cache.set(key, { value, expires });\n writeDiskEntry(args, value, expires);\n }\n return value;\n } finally {\n inflight.delete(key);\n }\n })();\n inflight.set(key, promise);\n return promise;\n}\n\nfunction entryArgsMatchAnyPrefix(entryArgs: string[], argvs: string[][]): boolean {\n return argvs.some((argv) => argv.length <= entryArgs.length && argv.every((p, i) => entryArgs[i] === p));\n}\n\nfunction diskKeysMatching(argvs: string[][]): string[] {\n if (!DISK_CACHE_ENABLED || !existsSync(DISK_CACHE_DIR)) return [];\n let files: string[] = [];\n try {\n files = readdirSync(DISK_CACHE_DIR).filter((f) => f.endsWith(\".json\"));\n } catch {\n return [];\n }\n const matched: string[] = [];\n for (const file of files) {\n try {\n const parsed = JSON.parse(readFileSync(path.join(DISK_CACHE_DIR, file), \"utf8\")) as { args?: unknown };\n if (!Array.isArray(parsed.args)) continue;\n const entryArgs = parsed.args as string[];\n if (entryArgsMatchAnyPrefix(entryArgs, argvs)) matched.push(JSON.stringify(entryArgs));\n } catch {\n // skip unreadable\n }\n }\n return matched;\n}\n\n/**\n * Invalidate one or more cached entries by argv. Mutation routes (e.g.\n * `cron rm`, `cron enable`) call this after a successful write so the next\n * read returns fresh data instead of waiting for the TTL to expire.\n *\n * Each argv is matched as a prefix: `invalidateOpenClawCache([\"cron\"])` clears\n * every cached `openclaw cron *` call. Pass an exact argv to scope tightly.\n *\n * Also clears matching disk entries so the next request after a restart\n * doesn't replay stale results.\n */\nexport function invalidateOpenClawCache(...argvs: string[][]): void {\n for (const argv of argvs) {\n const prefix = JSON.stringify(argv).replace(/\\]$/, \"\");\n const exact = JSON.stringify(argv);\n for (const key of cache.keys()) {\n if (key === exact || key.startsWith(prefix)) cache.delete(key);\n }\n for (const key of inflight.keys()) {\n if (key === exact || key.startsWith(prefix)) inflight.delete(key);\n }\n }\n for (const key of diskKeysMatching(argvs)) deleteDiskEntry(key);\n}\n\n/** Test-only: clear all cached subprocess results (memory + disk). */\nexport function _resetOpenClawCache() {\n cache.clear();\n inflight.clear();\n if (DISK_CACHE_ENABLED && existsSync(DISK_CACHE_DIR)) {\n try {\n for (const f of readdirSync(DISK_CACHE_DIR)) {\n if (f.endsWith(\".json\")) {\n try {\n unlinkSync(path.join(DISK_CACHE_DIR, f));\n } catch {\n // ignore\n }\n }\n }\n } catch {\n // ignore\n }\n }\n}\n","/**\n * Extracts a string message from an unknown error value.\n * Used consistently across API routes and client components.\n */\nexport function errorMessage(e: unknown): string {\n return e instanceof Error ? e.message : String(e);\n}\n","import { cachedRunOpenClaw } from \"./openclaw-cache\";\n\nexport type AgentListItem = {\n id: string;\n identityName?: string;\n workspace?: string;\n model?: string;\n isDefault?: boolean;\n};\n\n// `openclaw agents list --json` is a subprocess that takes ~15s on this\n// machine and is called from many read-only paths (orchestrator route, recipe\n// editor, scaffold, ids check). Uses the default cache TTL (5 min); agent\n// mutation routes (create/delete via openclaw CLI) call\n// invalidateOpenClawCache([\"agents\", \"list\"]) after success.\nexport async function listAgentsCached(): Promise<AgentListItem[]> {\n const res = await cachedRunOpenClaw([\"agents\", \"list\", \"--json\"]);\n if (!res.ok) return [];\n try {\n return JSON.parse(res.stdout) as AgentListItem[];\n } catch {\n return [];\n }\n}\n\nexport async function resolveAgentWorkspace(agentId: string): Promise<string> {\n const list = await listAgentsCached();\n const agent = list.find((a) => a.id === agentId);\n if (!agent?.workspace) throw new Error(`Agent workspace not found for ${agentId}`);\n return agent.workspace;\n}\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../src/lib/api-route-helpers.ts","../../../src/lib/paths.ts","../../../src/lib/kitchen-api.ts","../../../src/lib/openclaw.ts","../../../src/lib/openclaw-cache.ts","../../../src/lib/errors.ts","../../../src/lib/agents.ts"],"sourcesContent":["import fs from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { NextResponse } from \"next/server\";\n\n/** Parses JSON body; returns 400 on parse error. */\nexport async function parseJsonBody(req: Request): Promise<{ body: Record<string, unknown> } | NextResponse> {\n let body: unknown;\n try {\n body = await req.json();\n } catch {\n return NextResponse.json({ ok: false, error: \"Invalid JSON\" }, { status: 400 });\n }\n const o = body && typeof body === \"object\" ? (body as Record<string, unknown>) : {};\n return { body: o };\n}\n\n/** Returns NextResponse.json({ ok: true, ...rest }) from a storage result with ok field. */\nexport function jsonOkRest<T extends { ok: boolean }>(r: T): NextResponse {\n const rest = Object.fromEntries(Object.entries(r as Record<string, unknown>).filter(([k]) => k !== \"ok\"));\n return NextResponse.json({ ok: true, ...rest });\n}\n\nimport { resolveAgentWorkspace } from \"@/lib/agents\";\nimport { errorMessage } from \"@/lib/errors\";\n\n/** Runs async storage fn and returns jsonOkRest on success, or 500 on error. */\nexport async function withStorageError<T extends { ok: boolean }>(\n fn: () => Promise<T>\n): Promise<NextResponse> {\n try {\n return jsonOkRest(await fn());\n } catch (err: unknown) {\n return NextResponse.json({ ok: false, error: errorMessage(err) }, { status: 500 });\n }\n}\nimport { readOpenClawConfig, teamDirFromBaseWorkspace } from \"@/lib/paths\";\n\nexport type TeamContext = { teamId: string; teamDir: string };\n\n/** Error response for install-skill openclaw failures. Use when runOpenClaw returns !ok. */\nexport function installSkillErrorResponse(\n args: string[],\n res: { stdout?: string; stderr?: string; exitCode?: number },\n extra?: Record<string, unknown>\n): NextResponse {\n const stdout = res.stdout?.trim();\n const stderr = res.stderr?.trim();\n return NextResponse.json(\n {\n ok: false,\n error: stderr || stdout || `openclaw ${args.join(\" \")} failed (exit=${res.exitCode})`,\n stdout: res.stdout,\n stderr: res.stderr,\n ...extra,\n },\n { status: 500 }\n );\n}\n\nasync function resolveTeamContext(teamId: string): Promise<TeamContext | NextResponse> {\n if (!teamId) return NextResponse.json({ ok: false, error: \"teamId is required\" }, { status: 400 });\n\n const cfg = await readOpenClawConfig();\n const baseWorkspace = String(cfg.agents?.defaults?.workspace ?? \"\").trim();\n if (!baseWorkspace) {\n return NextResponse.json({ ok: false, error: \"agents.defaults.workspace not set\" }, { status: 500 });\n }\n\n const teamDir = teamDirFromBaseWorkspace(baseWorkspace, teamId);\n return { teamId, teamDir };\n}\n\n/** Resolves teamId and teamDir from URL search params. Returns error response if invalid. */\nexport async function getTeamContextFromQuery(req: Request): Promise<TeamContext | NextResponse> {\n const { searchParams } = new URL(req.url);\n const teamId = String(searchParams.get(\"teamId\") ?? \"\").trim();\n return resolveTeamContext(teamId);\n}\n\n/** Runs handler with team context from query; returns error response if context invalid. */\nexport async function withTeamContextFromQuery(\n req: Request,\n handler: (ctx: TeamContext) => Promise<NextResponse>\n): Promise<NextResponse> {\n const ctx = await getTeamContextFromQuery(req);\n if (ctx instanceof NextResponse) return ctx;\n return handler(ctx);\n}\n\n/** Resolves teamId and teamDir from parsed body. Caller must parse req.json() first. */\nexport async function getTeamContextFromBody(body: { teamId?: string }): Promise<TeamContext | NextResponse> {\n const teamId = String(body.teamId ?? \"\").trim();\n return resolveTeamContext(teamId);\n}\n\nexport type AgentContext = { agentId: string; ws: string };\n\n/** Resolves agentId and workspace from URL search params. Returns error response if invalid. */\nexport async function getAgentContextFromQuery(req: Request): Promise<AgentContext | NextResponse> {\n const { searchParams } = new URL(req.url);\n const agentId = String(searchParams.get(\"agentId\") ?? \"\").trim();\n return resolveAgentContext(agentId);\n}\n\n/** Resolves agentId and workspace from parsed body. Caller must parse req.json() first. */\nexport async function getAgentContextFromBody(body: { agentId?: string }): Promise<AgentContext | NextResponse> {\n const agentId = String(body.agentId ?? \"\").trim();\n return resolveAgentContext(agentId);\n}\n\nasync function resolveAgentContext(agentId: string): Promise<AgentContext | NextResponse> {\n if (!agentId) return NextResponse.json({ ok: false, error: \"agentId is required\" }, { status: 400 });\n try {\n const ws = await resolveAgentWorkspace(agentId);\n return { agentId, ws };\n } catch (e: unknown) {\n return NextResponse.json({ ok: false, error: errorMessage(e) }, { status: 404 });\n }\n}\n\nexport type FileCandidate = { name: string; required: boolean; rationale: string };\n\n/** Lists workspace files with presence/size info. */\nexport async function listWorkspaceFiles(\n baseDir: string,\n candidates: FileCandidate[]\n): Promise<\n Array<{\n name: string;\n required: boolean;\n rationale: string;\n path: string;\n missing: boolean;\n size?: number;\n updatedAtMs?: number;\n }>\n> {\n return Promise.all(\n candidates.map(async (c) => {\n const p = path.join(baseDir, c.name);\n try {\n const st = await fs.stat(p);\n return {\n name: c.name,\n required: c.required,\n rationale: c.rationale,\n path: p,\n missing: false,\n size: st.size,\n updatedAtMs: st.mtimeMs,\n };\n } catch {\n return { name: c.name, required: c.required, rationale: c.rationale, path: p, missing: true };\n }\n })\n );\n}\n","import fs from \"node:fs/promises\";\nimport os from \"node:os\";\nimport path from \"node:path\";\n\ntype OpenClawConfig = {\n agents?: { defaults?: { workspace?: string } };\n gateway?: { port?: number; auth?: { token?: string } };\n tools?: {\n agentToAgent?: {\n enabled?: boolean;\n allow?: string[];\n };\n };\n plugins?: {\n installs?: { recipes?: { installPath?: string; sourcePath?: string } };\n load?: { paths?: string[] };\n };\n // OpenClaw message routing bindings (used for HITL approvals, etc.)\n bindings?: unknown[];\n};\n\nexport async function readOpenClawConfig(): Promise<OpenClawConfig> {\n const p = path.join(os.homedir(), \".openclaw\", \"openclaw.json\");\n const text = await fs.readFile(p, \"utf8\");\n return JSON.parse(text) as OpenClawConfig;\n}\n\nexport async function getWorkspaceDir() {\n const cfg = await readOpenClawConfig();\n const ws = cfg.agents?.defaults?.workspace;\n if (!ws) throw new Error(\"agents.defaults.workspace is not set in ~/.openclaw/openclaw.json\");\n return ws;\n}\n\nexport async function getWorkspaceRecipesDir() {\n const ws = await getWorkspaceDir();\n return path.join(ws, \"recipes\");\n}\n\nexport async function getWorkspaceGoalsDir() {\n const ws = await getWorkspaceDir();\n\n // Back-compat: some installs keep goals at <workspace>/goals.\n // Prefer that when present, otherwise fall back to <workspace>/notes/goals.\n const direct = path.join(ws, \"goals\");\n try {\n const st = await fs.stat(direct);\n if (st.isDirectory()) return direct;\n } catch {\n // ignore\n }\n\n return path.join(ws, \"notes\", \"goals\");\n}\n\nexport async function getTeamWorkspaceDir(teamId: string) {\n const home = os.homedir();\n if (!home) throw new Error(\"Could not resolve home directory\");\n return path.join(home, \".openclaw\", `workspace-${teamId}`);\n}\n\n/** Team workspace dir derived from agents.defaults.workspace (sibling: .. / workspace-{teamId}) */\nexport function teamDirFromBaseWorkspace(baseWorkspace: string, teamId: string) {\n // Special-case: treat \"main\" as the personal workspace (agents.defaults.workspace).\n // This lets Kitchen expose a selectable \"main\" scope without creating a separate\n // ~/.openclaw/workspace-main folder.\n if (teamId === \"main\") return path.resolve(baseWorkspace);\n return path.resolve(baseWorkspace, \"..\", `workspace-${teamId}`);\n}\n\n/** Rejects path traversal and empty names; returns normalized name. */\nexport function assertSafeRelativeFileName(name: string): string {\n const n = name.replace(/\\\\/g, \"/\");\n if (!n || n.startsWith(\"/\") || n.includes(\"..\")) throw new Error(\"Invalid file name\");\n return n;\n}\n\nexport async function getBuiltinRecipesDir() {\n const cfg = await readOpenClawConfig();\n const p =\n cfg.plugins?.installs?.recipes?.installPath ||\n cfg.plugins?.installs?.recipes?.sourcePath ||\n cfg.plugins?.load?.paths?.[0];\n if (!p) throw new Error(\"Could not determine recipes plugin install path from ~/.openclaw/openclaw.json\");\n return path.join(p, \"recipes\", \"default\");\n}\n","// NOTE: This file is compiled by Next.js.\n// Do not import `openclaw/plugin-sdk` here (it is provided by the gateway runtime, not as an npm dep).\n\ntype KitchenApi = {\n config: unknown;\n runtime: {\n system: { runCommandWithTimeout: (argv: string[], opts: { timeoutMs: number }) => Promise<{ stdout?: string; stderr?: string }> };\n };\n};\n\nexport function getKitchenApi(): KitchenApi {\n const api = (globalThis as unknown as { __clawkitchen_api?: KitchenApi }).__clawkitchen_api;\n if (!api) {\n throw new Error(\n \"ClawKitchen: OpenClaw plugin API not available. (This should only happen if Kitchen is started outside the gateway process.)\",\n );\n }\n return api;\n}\n","import { getKitchenApi } from \"@/lib/kitchen-api\";\nimport { execFile } from \"node:child_process\";\nimport { promisify } from \"node:util\";\n\nconst execFileAsync = promisify(execFile);\n\nexport type OpenClawExecResult = {\n ok: boolean;\n exitCode: number;\n stdout: string;\n stderr: string;\n};\n\nfunction extractStdout(err: { stdout?: unknown }): string {\n if (typeof err.stdout === \"string\") return err.stdout;\n if (err.stdout && typeof err.stdout === \"object\" && \"toString\" in err.stdout) {\n return String((err.stdout as { toString: () => string }).toString());\n }\n return \"\";\n}\n\nfunction resolveExitCode(res: { exitCode?: unknown; code?: unknown; status?: unknown }): number {\n if (typeof res.exitCode === \"number\") return res.exitCode;\n if (typeof res.code === \"number\") return res.code;\n if (typeof res.status === \"number\") return res.status;\n return 0;\n}\n\nfunction extractStderr(err: { stderr?: unknown; message?: unknown }, fallback: unknown): string {\n if (typeof err.stderr === \"string\") return err.stderr;\n if (err.stderr && typeof err.stderr === \"object\" && \"toString\" in err.stderr) {\n return String((err.stderr as { toString: () => string }).toString());\n }\n if (typeof err.message === \"string\") return err.message;\n return String(fallback);\n}\n\n/**\n * Strip non-JSON diagnostic lines from stdout.\n *\n * OpenClaw may print plugin/doctor/diagnostic lines to stdout before the\n * actual JSON payload (e.g. \"[doctor] ...\", \"[plugins] ...\", \"🦞 OpenClaw ...\").\n * This breaks callers that do JSON.parse(stdout).\n *\n * If stdout looks like it contains a JSON payload with leading noise, strip the\n * noise lines. Otherwise return as-is (non-JSON commands like `config get` may\n * return plain text).\n */\nfunction sanitizeStdout(raw: string): string {\n const trimmed = raw.trim();\n if (!trimmed) return raw;\n\n // Fast path: already starts with JSON\n const firstChar = trimmed[0];\n if (firstChar === \"[\" || firstChar === \"{\" || firstChar === '\"') return raw;\n\n // Look for the first line starting with a JSON token\n const lines = trimmed.split(\"\\n\");\n const jsonStartIdx = lines.findIndex((l) => /^\\s*[[\\{\"]/.test(l));\n if (jsonStartIdx > 0) {\n // Verify the remainder is valid JSON before stripping\n const candidate = lines.slice(jsonStartIdx).join(\"\\n\");\n try {\n JSON.parse(candidate);\n return candidate;\n } catch {\n // Not valid JSON after stripping — return original\n }\n }\n\n return raw;\n}\n\nasync function runOpenClawLocal(args: string[], options: { sanitizeStdout?: boolean } = {}): Promise<OpenClawExecResult> {\n const { sanitizeStdout: shouldSanitize = true } = options;\n \n try {\n const isWindows = process.platform === \"win32\";\n const res = await execFileAsync(\"openclaw\", args, {\n timeout: 120000,\n windowsHide: true,\n maxBuffer: 10 * 1024 * 1024,\n // Windows requires shell:true to resolve executables on PATH via PATHEXT.\n // Without it, execFile throws ENOENT even when openclaw is installed globally.\n ...(isWindows ? { shell: true } : {}),\n });\n\n const rawStdout = String(res.stdout ?? \"\");\n \n return {\n ok: true,\n exitCode: 0,\n stdout: shouldSanitize ? sanitizeStdout(rawStdout) : rawStdout,\n stderr: String(res.stderr ?? \"\"),\n };\n } catch (e: unknown) {\n const err = e as { code?: unknown; stdout?: unknown; stderr?: unknown; message?: unknown };\n const exitCode = typeof err.code === \"number\" ? err.code : 1;\n const stdout = extractStdout(err);\n const stderr = extractStderr(err, e);\n return { ok: false, exitCode, stdout, stderr };\n }\n}\n\n/**\n * Extract a JSON payload from stdout that may contain non-JSON diagnostic lines\n * (e.g. [doctor], [plugins], [recipes] log lines before the actual JSON).\n * Returns the parsed value or null if no JSON found.\n */\nexport function extractJson<T = unknown>(stdout: string): T | null {\n const trimmed = stdout.trim();\n if (!trimmed) return null;\n\n // Fast path: pure JSON\n try {\n return JSON.parse(trimmed) as T;\n } catch {\n // fall through\n }\n\n // Find the first line starting with [ or { (JSON array/object)\n const lines = trimmed.split(\"\\n\");\n const jsonStartIdx = lines.findIndex((l) => /^\\s*[[\\{]/.test(l));\n if (jsonStartIdx >= 0) {\n const jsonSlice = lines.slice(jsonStartIdx).join(\"\\n\");\n try {\n return JSON.parse(jsonSlice) as T;\n } catch {\n // fall through\n }\n }\n\n // Last resort: find the last JSON block (scan from end)\n for (let i = lines.length - 1; i >= 0; i--) {\n if (/^\\s*[\\]}]/.test(lines[i])) {\n // Walk backward to find the matching open\n for (let j = i; j >= 0; j--) {\n if (/^\\s*[[\\{]/.test(lines[j])) {\n try {\n return JSON.parse(lines.slice(j, i + 1).join(\"\\n\")) as T;\n } catch {\n // continue searching\n }\n }\n }\n }\n }\n\n return null;\n}\n\n/**\n * Run OpenClaw without stdout sanitization (for raw text output like recipe markdown)\n */\nexport async function runOpenClawRaw(args: string[]): Promise<OpenClawExecResult> {\n // Always use local exec for raw content to avoid Kitchen runtime restrictions\n return runOpenClawLocal(args, { sanitizeStdout: false });\n}\n\nexport async function runOpenClaw(args: string[]): Promise<OpenClawExecResult> {\n // In some Kitchen runtime contexts, `api.runtime.system.runCommandWithTimeout`\n // is executed with a restricted allowlist that does not include the `cron` tool,\n // causing `openclaw cron ...` to fail with \"Tool not available: cron\".\n //\n // Cron routes need to work in the gateway-run Kitchen environment, so for cron\n // specifically we prefer a local exec (host OpenClaw).\n if (args[0] === \"cron\") return runOpenClawLocal(args);\n\n // Workflow runner/worker commands are long-running orchestration processes that\n // acquire locks and claims. The runtime command wrapper (runCommandWithTimeout)\n // has a 120s hard timeout that can kill these mid-execution, orphaning locks and\n // leaving runs stuck in waiting_workers. Route them through local exec instead.\n if (\n args[0] === \"recipes\" &&\n args[1] === \"workflows\" &&\n [\"runner-once\", \"runner-tick\", \"worker-tick\"].includes(args[2])\n ) {\n return runOpenClawLocal(args);\n }\n\n const api = getKitchenApi();\n try {\n const res = (await api.runtime.system.runCommandWithTimeout([\"openclaw\", ...args], { timeoutMs: 120000 })) as {\n stdout?: unknown;\n stderr?: unknown;\n exitCode?: unknown;\n code?: unknown;\n status?: unknown;\n };\n\n const stdout = sanitizeStdout(String(res.stdout ?? \"\"));\n const stderr = String(res.stderr ?? \"\");\n const exitCode = resolveExitCode(res);\n\n if (exitCode !== 0) return { ok: false, exitCode, stdout, stderr };\n return { ok: true, exitCode: 0, stdout, stderr };\n } catch (e: unknown) {\n const err = e as { code?: unknown; stdout?: unknown; stderr?: unknown; message?: unknown };\n const exitCode = typeof err.code === \"number\" ? err.code : 1;\n const stdout = extractStdout(err);\n const stderr = extractStderr(err, e);\n return { ok: false, exitCode, stdout, stderr };\n }\n}\n","import { createHash } from \"node:crypto\";\nimport { mkdirSync, readFileSync, unlinkSync, writeFileSync, existsSync, readdirSync } from \"node:fs\";\nimport os from \"node:os\";\nimport path from \"node:path\";\nimport { runOpenClaw, type OpenClawExecResult } from \"@/lib/openclaw\";\n\n// `openclaw <cmd>` invocations spawn a subprocess that pays a fixed startup\n// cost (~15-20s on this machine). Server components that read configuration\n// — agents list, recipes list, plugins list — call these on every render,\n// including each 3s `router.refresh()` poll on live pages, blocking the page\n// behind that subprocess.\n//\n// This helper memoizes successful results by argv key for a short window so\n// renders return fast. Concurrent callers share one in-flight subprocess\n// instead of spawning duplicates. Only successful results are cached so a\n// transient failure won't stick. Callers that mutate state (cron rm, recipes\n// delete, etc.) and routes that need fresh post-mutation reads should use\n// `runOpenClaw` directly instead.\n//\n// Disk persistence: cache entries also write to\n// ~/.openclaw/.kitchen-subprocess-cache/<sha1>.json so the first request\n// after a gateway restart can read a still-fresh entry from disk instead of\n// paying the full subprocess cost again. Each entry records its expiry; an\n// expired-but-readable entry is served stale-while-revalidate (returned\n// immediately while a background subprocess refreshes it).\n\n// 30 min default. Mutations invalidate explicitly via invalidateOpenClawCache,\n// and the disk cache survives gateway restarts, so a long TTL is safe and\n// keeps hot-render paths (recipes list, agents list, plugins list) off the\n// ~20s subprocess cost most of the time. Caller can override via { ttlMs }.\nconst DEFAULT_TTL_MS = 30 * 60_000;\n\n// Mutable so __setDiskCacheConfigForTests can redirect tests to a tmpdir\n// without polluting the real ~/.openclaw cache. Production code never\n// reassigns these.\nlet DISK_CACHE_DIR = path.join(os.homedir(), \".openclaw\", \".kitchen-subprocess-cache\");\n\n// Skip disk persistence during tests so module-level cache state is the only\n// thing tests need to reason about by default. The SWR test suite opts in\n// via __setDiskCacheConfigForTests with an isolated tmpdir.\nlet DISK_CACHE_ENABLED =\n process.env.NODE_ENV !== \"test\" && !process.env.VITEST && !process.env.VITEST_WORKER_ID;\n\nconst cache = new Map<string, { value: OpenClawExecResult; expires: number }>();\nconst inflight = new Map<string, Promise<OpenClawExecResult>>();\n\nfunction diskPathForKey(key: string): string {\n // sha256 just to dodge the sonarjs/hashing lint; this is a filename, not\n // a security primitive. Truncated to 40 chars to keep paths readable.\n const hash = createHash(\"sha256\").update(key).digest(\"hex\").slice(0, 40);\n return path.join(DISK_CACHE_DIR, `${hash}.json`);\n}\n\ntype DiskEntry = { args: string[]; expires: number; value: OpenClawExecResult };\n\n// Returns the entry as recorded on disk, including expired ones. Caller\n// inspects `expires` to decide whether to serve fresh or stale-while-revalidate.\nfunction readDiskEntry(key: string): { value: OpenClawExecResult; expires: number } | null {\n if (!DISK_CACHE_ENABLED) return null;\n try {\n const raw = readFileSync(diskPathForKey(key), \"utf8\");\n const parsed = JSON.parse(raw) as DiskEntry;\n if (JSON.stringify(parsed.args) !== key) return null;\n return { value: parsed.value, expires: parsed.expires };\n } catch {\n return null;\n }\n}\n\nfunction writeDiskEntry(args: string[], value: OpenClawExecResult, expires: number): void {\n if (!DISK_CACHE_ENABLED) return;\n try {\n mkdirSync(DISK_CACHE_DIR, { recursive: true });\n const key = JSON.stringify(args);\n const entry: DiskEntry = { args, expires, value };\n writeFileSync(diskPathForKey(key), JSON.stringify(entry), \"utf8\");\n } catch {\n // Disk cache is opportunistic — failing to write is non-fatal; in-memory\n // cache still serves this process.\n }\n}\n\nfunction deleteDiskEntry(key: string): void {\n if (!DISK_CACHE_ENABLED) return;\n try {\n unlinkSync(diskPathForKey(key));\n } catch {\n // already gone\n }\n}\n\n// Fire-and-forget background refresh. Coalesced via the existing inflight\n// Map so concurrent stale reads only spawn one subprocess. On success, writes\n// the fresh value to memory + disk; on failure, the existing stale entry stays\n// in place and the next read will try again.\nfunction refreshInBackground(args: string[], ttl: number, key: string): void {\n if (inflight.has(key)) return;\n const promise = (async () => {\n try {\n const value = await runOpenClaw(args);\n if (value.ok) {\n const expires = Date.now() + ttl;\n cache.set(key, { value, expires });\n writeDiskEntry(args, value, expires);\n }\n return value;\n } finally {\n inflight.delete(key);\n }\n })();\n inflight.set(key, promise);\n // Swallow rejections; the stale value already returned to the caller is\n // acceptable, and an unhandled rejection here would crash the process.\n promise.catch(() => {});\n}\n\nexport async function cachedRunOpenClaw(\n args: string[],\n options: { ttlMs?: number } = {}\n): Promise<OpenClawExecResult> {\n const ttl = options.ttlMs ?? DEFAULT_TTL_MS;\n const key = JSON.stringify(args);\n\n const memHit = cache.get(key);\n if (memHit && Date.now() < memHit.expires) return memHit.value;\n\n // Disk read happens before the inflight check so concurrent requests during\n // a background refresh can each serve stale immediately, instead of all\n // queueing on the refresh promise.\n const diskHit = readDiskEntry(key);\n if (diskHit) {\n if (Date.now() < diskHit.expires) {\n cache.set(key, diskHit);\n return diskHit.value;\n }\n // Stale: serve immediately, refresh in background. Don't write to memory\n // — leaving memory empty means subsequent calls within the refresh window\n // re-read disk and continue serving stale until the background subprocess\n // writes the fresh value.\n refreshInBackground(args, ttl, key);\n return diskHit.value;\n }\n\n const existing = inflight.get(key);\n if (existing) return existing;\n\n const promise = (async () => {\n try {\n const value = await runOpenClaw(args);\n if (value.ok) {\n const expires = Date.now() + ttl;\n cache.set(key, { value, expires });\n writeDiskEntry(args, value, expires);\n }\n return value;\n } finally {\n inflight.delete(key);\n }\n })();\n inflight.set(key, promise);\n return promise;\n}\n\nfunction entryArgsMatchAnyPrefix(entryArgs: string[], argvs: string[][]): boolean {\n return argvs.some((argv) => argv.length <= entryArgs.length && argv.every((p, i) => entryArgs[i] === p));\n}\n\nfunction diskKeysMatching(argvs: string[][]): string[] {\n if (!DISK_CACHE_ENABLED || !existsSync(DISK_CACHE_DIR)) return [];\n let files: string[] = [];\n try {\n files = readdirSync(DISK_CACHE_DIR).filter((f) => f.endsWith(\".json\"));\n } catch {\n return [];\n }\n const matched: string[] = [];\n for (const file of files) {\n try {\n const parsed = JSON.parse(readFileSync(path.join(DISK_CACHE_DIR, file), \"utf8\")) as { args?: unknown };\n if (!Array.isArray(parsed.args)) continue;\n const entryArgs = parsed.args as string[];\n if (entryArgsMatchAnyPrefix(entryArgs, argvs)) matched.push(JSON.stringify(entryArgs));\n } catch {\n // skip unreadable\n }\n }\n return matched;\n}\n\n/**\n * Invalidate one or more cached entries by argv. Mutation routes (e.g.\n * `cron rm`, `cron enable`) call this after a successful write so the next\n * read returns fresh data instead of waiting for the TTL to expire.\n *\n * Each argv is matched as a prefix: `invalidateOpenClawCache([\"cron\"])` clears\n * every cached `openclaw cron *` call. Pass an exact argv to scope tightly.\n *\n * Also clears matching disk entries so the next request after a restart\n * doesn't replay stale results.\n */\nexport function invalidateOpenClawCache(...argvs: string[][]): void {\n for (const argv of argvs) {\n const prefix = JSON.stringify(argv).replace(/\\]$/, \"\");\n const exact = JSON.stringify(argv);\n for (const key of cache.keys()) {\n if (key === exact || key.startsWith(prefix)) cache.delete(key);\n }\n for (const key of inflight.keys()) {\n if (key === exact || key.startsWith(prefix)) inflight.delete(key);\n }\n }\n for (const key of diskKeysMatching(argvs)) deleteDiskEntry(key);\n}\n\n/**\n * Test-only: redirect the disk cache to a tmpdir and/or override the\n * disk-enabled flag. Pass `{ reset: true }` to restore production defaults\n * (used in afterEach hooks). Production code never calls this.\n */\nexport function __setDiskCacheConfigForTests(opts: {\n enabled?: boolean;\n dir?: string;\n reset?: boolean;\n}): void {\n if (opts.reset) {\n DISK_CACHE_ENABLED =\n process.env.NODE_ENV !== \"test\" && !process.env.VITEST && !process.env.VITEST_WORKER_ID;\n DISK_CACHE_DIR = path.join(os.homedir(), \".openclaw\", \".kitchen-subprocess-cache\");\n return;\n }\n if (opts.enabled !== undefined) DISK_CACHE_ENABLED = opts.enabled;\n if (opts.dir !== undefined) DISK_CACHE_DIR = opts.dir;\n}\n\n/** Test-only: clear all cached subprocess results (memory + disk). */\nexport function _resetOpenClawCache() {\n cache.clear();\n inflight.clear();\n if (DISK_CACHE_ENABLED && existsSync(DISK_CACHE_DIR)) {\n try {\n for (const f of readdirSync(DISK_CACHE_DIR)) {\n if (f.endsWith(\".json\")) {\n try {\n unlinkSync(path.join(DISK_CACHE_DIR, f));\n } catch {\n // ignore\n }\n }\n }\n } catch {\n // ignore\n }\n }\n}\n","/**\n * Extracts a string message from an unknown error value.\n * Used consistently across API routes and client components.\n */\nexport function errorMessage(e: unknown): string {\n return e instanceof Error ? e.message : String(e);\n}\n","import { cachedRunOpenClaw } from \"./openclaw-cache\";\n\nexport type AgentListItem = {\n id: string;\n identityName?: string;\n workspace?: string;\n model?: string;\n isDefault?: boolean;\n};\n\n// `openclaw agents list --json` is a subprocess that takes ~15s on this\n// machine and is called from many read-only paths (orchestrator route, recipe\n// editor, scaffold, ids check). Uses the default cache TTL (5 min); agent\n// mutation routes (create/delete via openclaw CLI) call\n// invalidateOpenClawCache([\"agents\", \"list\"]) after success.\nexport async function listAgentsCached(): Promise<AgentListItem[]> {\n const res = await cachedRunOpenClaw([\"agents\", \"list\", \"--json\"]);\n if (!res.ok) return [];\n try {\n return JSON.parse(res.stdout) as AgentListItem[];\n } catch {\n return [];\n }\n}\n\nexport async function resolveAgentWorkspace(agentId: string): Promise<string> {\n const list = await listAgentsCached();\n const agent = list.find((a) => a.id === agentId);\n if (!agent?.workspace) throw new Error(`Agent workspace not found for ${agentId}`);\n return agent.workspace;\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
module.exports=[50227,(e,t,r)=>{t.exports=e.x("node:path",()=>require("node:path"))},12714,(e,t,r)=>{t.exports=e.x("node:fs/promises",()=>require("node:fs/promises"))},60526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},7367,e=>{"use strict";var t=e.i(12714),r=e.i(60526),n=e.i(50227);async function i(){let e=n.default.join(r.default.homedir(),".openclaw","openclaw.json");return JSON.parse(await t.default.readFile(e,"utf8"))}async function a(){let e=await i(),t=e.agents?.defaults?.workspace;if(!t)throw Error("agents.defaults.workspace is not set in ~/.openclaw/openclaw.json");return t}async function s(){let e=await a();return n.default.join(e,"recipes")}async function o(){let e=await a(),r=n.default.join(e,"goals");try{if((await t.default.stat(r)).isDirectory())return r}catch{}return n.default.join(e,"notes","goals")}async function l(e){let t=r.default.homedir();if(!t)throw Error("Could not resolve home directory");return n.default.join(t,".openclaw",`workspace-${e}`)}function u(e,t){return"main"===t?n.default.resolve(e):n.default.resolve(e,"..",`workspace-${t}`)}function d(e){let t=e.replace(/\\/g,"/");if(!t||t.startsWith("/")||t.includes(".."))throw Error("Invalid file name");return t}async function c(){let e=await i(),t=e.plugins?.installs?.recipes?.installPath||e.plugins?.installs?.recipes?.sourcePath||e.plugins?.load?.paths?.[0];if(!t)throw Error("Could not determine recipes plugin install path from ~/.openclaw/openclaw.json");return n.default.join(t,"recipes","default")}e.s(["assertSafeRelativeFileName",()=>d,"getBuiltinRecipesDir",()=>c,"getTeamWorkspaceDir",()=>l,"getWorkspaceDir",()=>a,"getWorkspaceGoalsDir",()=>o,"getWorkspaceRecipesDir",()=>s,"readOpenClawConfig",()=>i,"teamDirFromBaseWorkspace",()=>u])},74533,(e,t,r)=>{t.exports=e.x("node:child_process",()=>require("node:child_process"))},12057,(e,t,r)=>{t.exports=e.x("node:util",()=>require("node:util"))},59494,e=>{"use strict";function t(){let e=globalThis.__clawkitchen_api;if(!e)throw Error("ClawKitchen: OpenClaw plugin API not available. (This should only happen if Kitchen is started outside the gateway process.)");return e}e.s(["getKitchenApi",()=>t])},5003,e=>{"use strict";var t=e.i(59494),r=e.i(74533);let n=(0,e.i(12057).promisify)(r.execFile);function i(e){return"string"==typeof e.stdout?e.stdout:e.stdout&&"object"==typeof e.stdout&&"toString"in e.stdout?String(e.stdout.toString()):""}function a(e,t){return"string"==typeof e.stderr?e.stderr:e.stderr&&"object"==typeof e.stderr&&"toString"in e.stderr?String(e.stderr.toString()):"string"==typeof e.message?e.message:String(t)}function s(e){let t=e.trim();if(!t)return e;let r=t[0];if("["===r||"{"===r||'"'===r)return e;let n=t.split("\n"),i=n.findIndex(e=>/^\s*[[\{"]/.test(e));if(i>0){let e=n.slice(i).join("\n");try{return JSON.parse(e),e}catch{}}return e}async function o(e,t={}){let{sanitizeStdout:r=!0}=t;try{process.platform;let t=await n("openclaw",e,{timeout:12e4,windowsHide:!0,maxBuffer:0xa00000}),i=String(t.stdout??"");return{ok:!0,exitCode:0,stdout:r?s(i):i,stderr:String(t.stderr??"")}}catch(t){let e="number"==typeof t.code?t.code:1;return{ok:!1,exitCode:e,stdout:i(t),stderr:a(t,t)}}}function l(e){let t=e.trim();if(!t)return null;try{return JSON.parse(t)}catch{}let r=t.split("\n"),n=r.findIndex(e=>/^\s*[[\{]/.test(e));if(n>=0){let e=r.slice(n).join("\n");try{return JSON.parse(e)}catch{}}for(let e=r.length-1;e>=0;e--)if(/^\s*[\]}]/.test(r[e])){for(let t=e;t>=0;t--)if(/^\s*[[\{]/.test(r[t]))try{return JSON.parse(r.slice(t,e+1).join("\n"))}catch{}}return null}async function u(e){return o(e,{sanitizeStdout:!1})}async function d(e){if("cron"===e[0]||"recipes"===e[0]&&"workflows"===e[1]&&["runner-once","runner-tick","worker-tick"].includes(e[2]))return o(e);let r=(0,t.getKitchenApi)();try{let t=await r.runtime.system.runCommandWithTimeout(["openclaw",...e],{timeoutMs:12e4}),n=s(String(t.stdout??"")),i=String(t.stderr??""),a="number"==typeof t.exitCode?t.exitCode:"number"==typeof t.code?t.code:"number"==typeof t.status?t.status:0;if(0!==a)return{ok:!1,exitCode:a,stdout:n,stderr:i};return{ok:!0,exitCode:0,stdout:n,stderr:i}}catch(t){let e="number"==typeof t.code?t.code:1;return{ok:!1,exitCode:e,stdout:i(t),stderr:a(t,t)}}}e.s(["extractJson",()=>l,"runOpenClaw",()=>d,"runOpenClawRaw",()=>u])},66680,(e,t,r)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},2157,(e,t,r)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},42013,e=>{"use strict";var t=e.i(66680),r=e.i(2157),n=e.i(60526),i=e.i(50227),a=e.i(5003);let s=i.default.join(n.default.homedir(),".openclaw",".kitchen-subprocess-cache"),o=!process.env.VITEST&&!process.env.VITEST_WORKER_ID,l=new Map,u=new Map;function d(e){let r=(0,t.createHash)("sha256").update(e).digest("hex").slice(0,40);return i.default.join(s,`${r}.json`)}async function
|
|
1
|
+
module.exports=[50227,(e,t,r)=>{t.exports=e.x("node:path",()=>require("node:path"))},12714,(e,t,r)=>{t.exports=e.x("node:fs/promises",()=>require("node:fs/promises"))},60526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},7367,e=>{"use strict";var t=e.i(12714),r=e.i(60526),n=e.i(50227);async function i(){let e=n.default.join(r.default.homedir(),".openclaw","openclaw.json");return JSON.parse(await t.default.readFile(e,"utf8"))}async function a(){let e=await i(),t=e.agents?.defaults?.workspace;if(!t)throw Error("agents.defaults.workspace is not set in ~/.openclaw/openclaw.json");return t}async function s(){let e=await a();return n.default.join(e,"recipes")}async function o(){let e=await a(),r=n.default.join(e,"goals");try{if((await t.default.stat(r)).isDirectory())return r}catch{}return n.default.join(e,"notes","goals")}async function l(e){let t=r.default.homedir();if(!t)throw Error("Could not resolve home directory");return n.default.join(t,".openclaw",`workspace-${e}`)}function u(e,t){return"main"===t?n.default.resolve(e):n.default.resolve(e,"..",`workspace-${t}`)}function d(e){let t=e.replace(/\\/g,"/");if(!t||t.startsWith("/")||t.includes(".."))throw Error("Invalid file name");return t}async function c(){let e=await i(),t=e.plugins?.installs?.recipes?.installPath||e.plugins?.installs?.recipes?.sourcePath||e.plugins?.load?.paths?.[0];if(!t)throw Error("Could not determine recipes plugin install path from ~/.openclaw/openclaw.json");return n.default.join(t,"recipes","default")}e.s(["assertSafeRelativeFileName",()=>d,"getBuiltinRecipesDir",()=>c,"getTeamWorkspaceDir",()=>l,"getWorkspaceDir",()=>a,"getWorkspaceGoalsDir",()=>o,"getWorkspaceRecipesDir",()=>s,"readOpenClawConfig",()=>i,"teamDirFromBaseWorkspace",()=>u])},74533,(e,t,r)=>{t.exports=e.x("node:child_process",()=>require("node:child_process"))},12057,(e,t,r)=>{t.exports=e.x("node:util",()=>require("node:util"))},59494,e=>{"use strict";function t(){let e=globalThis.__clawkitchen_api;if(!e)throw Error("ClawKitchen: OpenClaw plugin API not available. (This should only happen if Kitchen is started outside the gateway process.)");return e}e.s(["getKitchenApi",()=>t])},5003,e=>{"use strict";var t=e.i(59494),r=e.i(74533);let n=(0,e.i(12057).promisify)(r.execFile);function i(e){return"string"==typeof e.stdout?e.stdout:e.stdout&&"object"==typeof e.stdout&&"toString"in e.stdout?String(e.stdout.toString()):""}function a(e,t){return"string"==typeof e.stderr?e.stderr:e.stderr&&"object"==typeof e.stderr&&"toString"in e.stderr?String(e.stderr.toString()):"string"==typeof e.message?e.message:String(t)}function s(e){let t=e.trim();if(!t)return e;let r=t[0];if("["===r||"{"===r||'"'===r)return e;let n=t.split("\n"),i=n.findIndex(e=>/^\s*[[\{"]/.test(e));if(i>0){let e=n.slice(i).join("\n");try{return JSON.parse(e),e}catch{}}return e}async function o(e,t={}){let{sanitizeStdout:r=!0}=t;try{process.platform;let t=await n("openclaw",e,{timeout:12e4,windowsHide:!0,maxBuffer:0xa00000}),i=String(t.stdout??"");return{ok:!0,exitCode:0,stdout:r?s(i):i,stderr:String(t.stderr??"")}}catch(t){let e="number"==typeof t.code?t.code:1;return{ok:!1,exitCode:e,stdout:i(t),stderr:a(t,t)}}}function l(e){let t=e.trim();if(!t)return null;try{return JSON.parse(t)}catch{}let r=t.split("\n"),n=r.findIndex(e=>/^\s*[[\{]/.test(e));if(n>=0){let e=r.slice(n).join("\n");try{return JSON.parse(e)}catch{}}for(let e=r.length-1;e>=0;e--)if(/^\s*[\]}]/.test(r[e])){for(let t=e;t>=0;t--)if(/^\s*[[\{]/.test(r[t]))try{return JSON.parse(r.slice(t,e+1).join("\n"))}catch{}}return null}async function u(e){return o(e,{sanitizeStdout:!1})}async function d(e){if("cron"===e[0]||"recipes"===e[0]&&"workflows"===e[1]&&["runner-once","runner-tick","worker-tick"].includes(e[2]))return o(e);let r=(0,t.getKitchenApi)();try{let t=await r.runtime.system.runCommandWithTimeout(["openclaw",...e],{timeoutMs:12e4}),n=s(String(t.stdout??"")),i=String(t.stderr??""),a="number"==typeof t.exitCode?t.exitCode:"number"==typeof t.code?t.code:"number"==typeof t.status?t.status:0;if(0!==a)return{ok:!1,exitCode:a,stdout:n,stderr:i};return{ok:!0,exitCode:0,stdout:n,stderr:i}}catch(t){let e="number"==typeof t.code?t.code:1;return{ok:!1,exitCode:e,stdout:i(t),stderr:a(t,t)}}}e.s(["extractJson",()=>l,"runOpenClaw",()=>d,"runOpenClawRaw",()=>u])},66680,(e,t,r)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},2157,(e,t,r)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},42013,e=>{"use strict";var t=e.i(66680),r=e.i(2157),n=e.i(60526),i=e.i(50227),a=e.i(5003);let s=i.default.join(n.default.homedir(),".openclaw",".kitchen-subprocess-cache"),o=!process.env.VITEST&&!process.env.VITEST_WORKER_ID,l=new Map,u=new Map;function d(e){let r=(0,t.createHash)("sha256").update(e).digest("hex").slice(0,40);return i.default.join(s,`${r}.json`)}function c(e,t,n){if(o)try{(0,r.mkdirSync)(s,{recursive:!0});let i=JSON.stringify(e);(0,r.writeFileSync)(d(i),JSON.stringify({args:e,expires:n,value:t}),"utf8")}catch{}}async function p(e,t={}){let n=t.ttlMs??18e5,i=JSON.stringify(e),s=l.get(i);if(s&&Date.now()<s.expires)return s.value;let f=function(e){if(!o)return null;try{let t=(0,r.readFileSync)(d(e),"utf8"),n=JSON.parse(t);if(JSON.stringify(n.args)!==e)return null;return{value:n.value,expires:n.expires}}catch{return null}}(i);if(f)return Date.now()<f.expires?l.set(i,f):!function(e,t,r){if(u.has(r))return;let n=(async()=>{try{let n=await (0,a.runOpenClaw)(e);if(n.ok){let i=Date.now()+t;l.set(r,{value:n,expires:i}),c(e,n,i)}return n}finally{u.delete(r)}})();u.set(r,n),n.catch(()=>{})}(e,n,i),f.value;let h=u.get(i);if(h)return h;let w=(async()=>{try{let t=await (0,a.runOpenClaw)(e);if(t.ok){let r=Date.now()+n;l.set(i,{value:t,expires:r}),c(e,t,r)}return t}finally{u.delete(i)}})();return u.set(i,w),w}function f(...e){for(let t of e){let e=JSON.stringify(t).replace(/\]$/,""),r=JSON.stringify(t);for(let t of l.keys())(t===r||t.startsWith(e))&&l.delete(t);for(let t of u.keys())(t===r||t.startsWith(e))&&u.delete(t)}for(let t of function(e){if(!o||!(0,r.existsSync)(s))return[];let t=[];try{t=(0,r.readdirSync)(s).filter(e=>e.endsWith(".json"))}catch{return[]}let n=[];for(let a of t)try{let t=JSON.parse((0,r.readFileSync)(i.default.join(s,a),"utf8"));if(!Array.isArray(t.args))continue;let o=t.args;(function(e,t){return t.some(t=>t.length<=e.length&&t.every((t,r)=>e[r]===t))})(o,e)&&n.push(JSON.stringify(o))}catch{}return n}(e))if(o)try{(0,r.unlinkSync)(d(t))}catch{}}function h(e){if(e.reset){o=!process.env.VITEST&&!process.env.VITEST_WORKER_ID,s=i.default.join(n.default.homedir(),".openclaw",".kitchen-subprocess-cache");return}void 0!==e.enabled&&(o=e.enabled),void 0!==e.dir&&(s=e.dir)}function w(){if(l.clear(),u.clear(),o&&(0,r.existsSync)(s))try{for(let e of(0,r.readdirSync)(s))if(e.endsWith(".json"))try{(0,r.unlinkSync)(i.default.join(s,e))}catch{}}catch{}}e.s(["__setDiskCacheConfigForTests",()=>h,"_resetOpenClawCache",()=>w,"cachedRunOpenClaw",()=>p,"invalidateOpenClawCache",()=>f])},5365,(e,t,r)=>{t.exports=e.x("process",()=>require("process"))},874,(e,t,r)=>{t.exports=e.x("buffer",()=>require("buffer"))},72420,e=>{"use strict";var t=e.i(47909),r=e.i(74017),n=e.i(96250),i=e.i(59756),a=e.i(61916),s=e.i(74677),o=e.i(69741),l=e.i(16795),u=e.i(87718),d=e.i(95169),c=e.i(47587),p=e.i(66012),f=e.i(70101),h=e.i(74838),w=e.i(10372),g=e.i(93695);e.i(52474);var x=e.i(220),y=e.i(12714),m=e.i(50227),v=e.i(89171),R=e.i(7367),C=e.i(5003),S=e.i(42013),k=e.i(23008);function E(e){let t=String(e||"recipe").trim();return[`custom-${t}`,`my-${t}`,`${t}-2`,`${t}-alt`]}async function O(e){let t=await e.json(),r=String(t.fromId??"").trim(),n=String(t.toId??"").trim(),i="string"==typeof t.toName?t.toName:void 0,a=!!t.overwrite,s=!!t.scaffold;if(!r)return v.NextResponse.json({ok:!1,error:"Missing fromId"},{status:400});if(!n)return v.NextResponse.json({ok:!1,error:"Missing toId"},{status:400});let o=await (0,C.runOpenClaw)(["recipes","show",r]);if(!o.ok)return v.NextResponse.json({ok:!1,error:o.stderr.trim()||`openclaw recipes show ${r} failed (exit=${o.exitCode}). Is the recipes plugin enabled?`},{status:400});let l=String(o.stdout??"");if(!l.startsWith("---\n"))throw Error("Recipe markdown must start with YAML frontmatter (---)");let{next:u,kind:d}=function(e,t,r){let n=e.indexOf("\n---\n",4);if(-1===n)throw Error("Recipe frontmatter not terminated (---)");let i=e.slice(4,n+1),a=k.default.parse(i)??{},s=String(a.kind??"").trim().toLowerCase(),o="team"===s?{team:{..."object"==typeof a.team&&a.team?a.team:{},teamId:t}}:{},l={...a,id:t,...r?{name:r}:{},...o},u=k.default.stringify(l).trimEnd();return{next:`---
|
|
2
2
|
${u}
|
|
3
3
|
---
|
|
4
|
-
${e.slice(n+5)}`,kind:s}}(l,n,i),c=await (0,R.getWorkspaceRecipesDir)(),p=
|
|
4
|
+
${e.slice(n+5)}`,kind:s}}(l,n,i),c=await (0,R.getWorkspaceRecipesDir)(),p=m.default.join(c,`${n}.md`);try{if(await y.default.stat(p),!a)return v.NextResponse.json({ok:!1,error:`Recipe id already exists: ${n}. Choose a different id (e.g. ${E(n).join(", ")}).`,code:"RECIPE_ID_TAKEN",recipeId:n,suggestions:E(n),filePath:p},{status:409})}catch{}await y.default.mkdir(m.default.dirname(p),{recursive:!0}),await y.default.writeFile(p,u,"utf8"),(0,S.invalidateOpenClawCache)(["recipes","list"]);let f=null;if(s){let e="team"===d?["recipes","scaffold-team",n,"--team-id",n,"--overwrite","--overwrite-recipe"]:"agent"===d?["recipes","scaffold",n,"--agent-id",n,"--overwrite","--overwrite-recipe"]:null;if(e){let t=await (0,C.runOpenClaw)(e);f=t.ok?{ok:!0,stdout:String(t.stdout??""),stderr:String(t.stderr??""),exitCode:t.exitCode}:{ok:!1,error:t.stderr.trim()||`openclaw ${e.join(" ")} failed (exit=${t.exitCode})`,stdout:String(t.stdout??""),stderr:String(t.stderr??""),exitCode:t.exitCode}}else f={ok:!1,error:`Unsupported recipe kind for scaffold: ${d||"(missing kind)"}`,stdout:"",stderr:"",exitCode:null}}return v.NextResponse.json({ok:!0,filePath:p,recipeId:n,content:u,scaffold:f})}e.s(["POST",()=>O],78983);var j=e.i(78983);let N=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/recipes/clone/route",pathname:"/api/recipes/clone",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/recipes/clone/route.ts",nextConfigOutput:"standalone",userland:j}),{workAsyncStorage:b,workUnitAsyncStorage:T,serverHooks:A}=N;function I(){return(0,n.patchFetch)({workAsyncStorage:b,workUnitAsyncStorage:T})}async function _(e,t,n){N.isDev&&(0,i.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let y="/api/recipes/clone/route";y=y.replace(/\/index$/,"")||"/";let m=await N.prepare(e,t,{srcPage:y,multiZoneDraftMode:!1});if(!m)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:v,params:R,nextConfig:C,parsedUrl:S,isDraftMode:k,prerenderManifest:E,routerServerContext:O,isOnDemandRevalidate:j,revalidateOnlyGenerated:b,resolvedPathname:T,clientReferenceManifest:A,serverActionsManifest:I}=m,_=(0,o.normalizeAppPath)(y),q=!!(E.dynamicRoutes[_]||E.routes[T]),D=async()=>((null==O?void 0:O.render404)?await O.render404(e,t,S,!1):t.end("This page could not be found"),null);if(q&&!k){let e=!!E.routes[T],t=E.dynamicRoutes[_];if(t&&!1===t.fallback&&!e){if(C.experimental.adapterPath)return await D();throw new g.NoFallbackError}}let P=null;!q||N.isDev||k||(P="/index"===(P=T)?"/":P);let $=!0===N.isDev||!q,H=q&&!$;I&&A&&(0,s.setManifestsSingleton)({page:y,clientReferenceManifest:A,serverActionsManifest:I});let M=e.method||"GET",F=(0,a.getTracer)(),U=F.getActiveScopeSpan(),W={params:R,prerenderManifest:E,renderOpts:{experimental:{authInterrupts:!!C.experimental.authInterrupts},cacheComponents:!!C.cacheComponents,supportsDynamicResponse:$,incrementalCache:(0,i.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:C.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n,i)=>N.onRequestError(e,t,n,i,O)},sharedContext:{buildId:v}},J=new l.NodeNextRequest(e),K=new l.NodeNextResponse(t),B=u.NextRequestAdapter.fromNodeNextRequest(J,(0,u.signalFromNodeResponse)(t));try{let s=async e=>N.handle(B,W).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=F.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let n=r.get("next.route");if(n){let t=`${M} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t)}else e.updateName(`${M} ${y}`)}),o=!!(0,i.getRequestMeta)(e,"minimalMode"),l=async i=>{var a,l;let u=async({previousCacheEntry:r})=>{try{if(!o&&j&&b&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let a=await s(i);e.fetchMetrics=W.renderOpts.fetchMetrics;let l=W.renderOpts.pendingWaitUntil;l&&n.waitUntil&&(n.waitUntil(l),l=void 0);let u=W.renderOpts.collectedTags;if(!q)return await (0,p.sendResponse)(J,K,a,W.renderOpts.pendingWaitUntil),null;{let e=await a.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(a.headers);u&&(t[w.NEXT_CACHE_TAGS_HEADER]=u),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==W.renderOpts.collectedRevalidate&&!(W.renderOpts.collectedRevalidate>=w.INFINITE_CACHE)&&W.renderOpts.collectedRevalidate,n=void 0===W.renderOpts.collectedExpire||W.renderOpts.collectedExpire>=w.INFINITE_CACHE?void 0:W.renderOpts.collectedExpire;return{value:{kind:x.CachedRouteKind.APP_ROUTE,status:a.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:n}}}}catch(t){throw(null==r?void 0:r.isStale)&&await N.onRequestError(e,t,{routerKind:"App Router",routePath:y,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:H,isOnDemandRevalidate:j})},!1,O),t}},d=await N.handleResponse({req:e,nextConfig:C,cacheKey:P,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:E,isRoutePPREnabled:!1,isOnDemandRevalidate:j,revalidateOnlyGenerated:b,responseGenerator:u,waitUntil:n.waitUntil,isMinimalMode:o});if(!q)return null;if((null==d||null==(a=d.value)?void 0:a.kind)!==x.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==d||null==(l=d.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});o||t.setHeader("x-nextjs-cache",j?"REVALIDATED":d.isMiss?"MISS":d.isStale?"STALE":"HIT"),k&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let g=(0,f.fromNodeOutgoingHttpHeaders)(d.value.headers);return o&&q||g.delete(w.NEXT_CACHE_TAGS_HEADER),!d.cacheControl||t.getHeader("Cache-Control")||g.get("Cache-Control")||g.set("Cache-Control",(0,h.getCacheControlHeader)(d.cacheControl)),await (0,p.sendResponse)(J,K,new Response(d.value.body,{headers:g,status:d.value.status||200})),null};U?await l(U):await F.withPropagatedContext(e.headers,()=>F.trace(d.BaseServerSpan.handleRequest,{spanName:`${M} ${y}`,kind:a.SpanKind.SERVER,attributes:{"http.method":M,"http.target":e.url}},l))}catch(t){if(t instanceof g.NoFallbackError||await N.onRequestError(e,t,{routerKind:"App Router",routePath:_,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:H,isOnDemandRevalidate:j})},!1,O),q)throw t;return await (0,p.sendResponse)(J,K,new Response(null,{status:500})),null}}e.s(["handler",()=>_,"patchFetch",()=>I,"routeModule",()=>N,"serverHooks",()=>A,"workAsyncStorage",()=>b,"workUnitAsyncStorage",()=>T],72420)}];
|
|
5
5
|
|
|
6
6
|
//# sourceMappingURL=%5Broot-of-the-server%5D__9ae5d489._.js.map
|