@agent-native/core 0.22.44 → 0.23.0

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.
Files changed (114) hide show
  1. package/dist/a2a/artifact-response.js +1 -1
  2. package/dist/a2a/artifact-response.js.map +1 -1
  3. package/dist/agent/production-agent.d.ts.map +1 -1
  4. package/dist/agent/production-agent.js +12 -4
  5. package/dist/agent/production-agent.js.map +1 -1
  6. package/dist/cli/app-skill.d.ts +139 -0
  7. package/dist/cli/app-skill.d.ts.map +1 -0
  8. package/dist/cli/app-skill.js +960 -0
  9. package/dist/cli/app-skill.js.map +1 -0
  10. package/dist/cli/create.d.ts.map +1 -1
  11. package/dist/cli/create.js +13 -4
  12. package/dist/cli/create.js.map +1 -1
  13. package/dist/cli/index.js +24 -0
  14. package/dist/cli/index.js.map +1 -1
  15. package/dist/cli/skills.d.ts +39 -0
  16. package/dist/cli/skills.d.ts.map +1 -0
  17. package/dist/cli/skills.js +363 -0
  18. package/dist/cli/skills.js.map +1 -0
  19. package/dist/cli/templates-meta.d.ts.map +1 -1
  20. package/dist/cli/templates-meta.js +9 -6
  21. package/dist/cli/templates-meta.js.map +1 -1
  22. package/dist/cli/workspace-dev.d.ts.map +1 -1
  23. package/dist/cli/workspace-dev.js +2 -0
  24. package/dist/cli/workspace-dev.js.map +1 -1
  25. package/dist/client/AgentPanel.d.ts +2 -0
  26. package/dist/client/AgentPanel.d.ts.map +1 -1
  27. package/dist/client/AgentPanel.js +2 -2
  28. package/dist/client/AgentPanel.js.map +1 -1
  29. package/dist/client/AssistantChat.d.ts +9 -0
  30. package/dist/client/AssistantChat.d.ts.map +1 -1
  31. package/dist/client/AssistantChat.js +15 -7
  32. package/dist/client/AssistantChat.js.map +1 -1
  33. package/dist/client/MultiTabAssistantChat.d.ts.map +1 -1
  34. package/dist/client/MultiTabAssistantChat.js +15 -0
  35. package/dist/client/MultiTabAssistantChat.js.map +1 -1
  36. package/dist/client/index.d.ts +1 -1
  37. package/dist/client/index.d.ts.map +1 -1
  38. package/dist/client/index.js.map +1 -1
  39. package/dist/client/use-chat-threads.d.ts +5 -1
  40. package/dist/client/use-chat-threads.d.ts.map +1 -1
  41. package/dist/client/use-chat-threads.js +14 -3
  42. package/dist/client/use-chat-threads.js.map +1 -1
  43. package/dist/collab/client.d.ts.map +1 -1
  44. package/dist/collab/client.js +20 -1
  45. package/dist/collab/client.js.map +1 -1
  46. package/dist/collab/routes.d.ts.map +1 -1
  47. package/dist/collab/routes.js +16 -2
  48. package/dist/collab/routes.js.map +1 -1
  49. package/dist/collab/storage.d.ts +8 -0
  50. package/dist/collab/storage.d.ts.map +1 -1
  51. package/dist/collab/storage.js +55 -7
  52. package/dist/collab/storage.js.map +1 -1
  53. package/dist/collab/ydoc-manager.d.ts.map +1 -1
  54. package/dist/collab/ydoc-manager.js +121 -69
  55. package/dist/collab/ydoc-manager.js.map +1 -1
  56. package/dist/deploy/workspace-deploy.js +6 -0
  57. package/dist/deploy/workspace-deploy.js.map +1 -1
  58. package/dist/mcp-client/index.d.ts +1 -1
  59. package/dist/mcp-client/index.d.ts.map +1 -1
  60. package/dist/mcp-client/index.js +1 -1
  61. package/dist/mcp-client/index.js.map +1 -1
  62. package/dist/mcp-client/routes.d.ts +1 -0
  63. package/dist/mcp-client/routes.d.ts.map +1 -1
  64. package/dist/mcp-client/routes.js +52 -0
  65. package/dist/mcp-client/routes.js.map +1 -1
  66. package/dist/mcp-client/workspace-servers.d.ts +15 -0
  67. package/dist/mcp-client/workspace-servers.d.ts.map +1 -0
  68. package/dist/mcp-client/workspace-servers.js +297 -0
  69. package/dist/mcp-client/workspace-servers.js.map +1 -0
  70. package/dist/resources/handlers.d.ts.map +1 -1
  71. package/dist/resources/handlers.js +38 -25
  72. package/dist/resources/handlers.js.map +1 -1
  73. package/dist/resources/store.d.ts +11 -3
  74. package/dist/resources/store.d.ts.map +1 -1
  75. package/dist/resources/store.js +220 -9
  76. package/dist/resources/store.js.map +1 -1
  77. package/dist/scripts/call-agent.js +1 -1
  78. package/dist/scripts/call-agent.js.map +1 -1
  79. package/dist/server/agent-chat-plugin.d.ts.map +1 -1
  80. package/dist/server/agent-chat-plugin.js +21 -6
  81. package/dist/server/agent-chat-plugin.js.map +1 -1
  82. package/dist/server/agent-discovery.d.ts.map +1 -1
  83. package/dist/server/agent-discovery.js +34 -9
  84. package/dist/server/agent-discovery.js.map +1 -1
  85. package/dist/server/auth-marketing.d.ts.map +1 -1
  86. package/dist/server/auth-marketing.js +8 -5
  87. package/dist/server/auth-marketing.js.map +1 -1
  88. package/dist/templates/default/AGENTS.md +12 -4
  89. package/dist/templates/default/DEVELOPING.md +7 -5
  90. package/dist/templates/workspace-core/AGENTS.md +7 -0
  91. package/dist/templates/workspace-root/AGENTS.md +6 -0
  92. package/docs/content/creating-templates.md +14 -9
  93. package/docs/content/database.md +44 -17
  94. package/docs/content/deployment.md +15 -7
  95. package/docs/content/dispatch.md +7 -1
  96. package/docs/content/embedding-sdk.md +79 -0
  97. package/docs/content/key-concepts.md +15 -17
  98. package/docs/content/mcp-clients.md +30 -0
  99. package/docs/content/multi-app-workspace.md +3 -2
  100. package/docs/content/multi-tenancy.md +4 -4
  101. package/docs/content/server.md +10 -7
  102. package/docs/content/skills-guide.md +75 -0
  103. package/docs/content/template-analytics.md +1 -1
  104. package/docs/content/template-assets.md +130 -0
  105. package/docs/content/template-dispatch.md +3 -2
  106. package/docs/content/template-slides.md +2 -2
  107. package/docs/content/workspace-management.md +2 -2
  108. package/docs/content/workspace.md +11 -9
  109. package/package.json +1 -1
  110. package/src/templates/default/AGENTS.md +12 -4
  111. package/src/templates/default/DEVELOPING.md +7 -5
  112. package/src/templates/workspace-core/AGENTS.md +7 -0
  113. package/src/templates/workspace-root/AGENTS.md +6 -0
  114. package/docs/content/template-images.md +0 -55
@@ -1,5 +1,6 @@
1
1
  import { getDbExec, isPostgres, intType, retryOnDdlRace, } from "../db/client.js";
2
2
  import { emitResourceChange, emitResourceDelete } from "./emitter.js";
3
+ import { getRequestOrgId, getRequestUserEmail, } from "../server/request-context.js";
3
4
  import crypto from "crypto";
4
5
  export const SHARED_OWNER = "__shared__";
5
6
  export const WORKSPACE_OWNER = "__workspace__";
@@ -8,6 +9,8 @@ let _lastScratchCleanupAt = 0;
8
9
  const AGENT_SCRATCH_TTL_MS = 24 * 60 * 60 * 1000;
9
10
  const SCRATCH_CLEANUP_INTERVAL_MS = 60 * 1000;
10
11
  const RESOURCE_META_SELECT = "id, path, owner, mime_type, size, created_at, updated_at, created_by, visibility, thread_id, run_id, expires_at, metadata";
12
+ const DISPATCH_WORKSPACE_RESOURCE_ID_PREFIX = "dispatch-workspace-resource:";
13
+ const DISPATCH_WORKSPACE_RESOURCE_METADATA_SOURCE = "dispatch-workspace-resource";
11
14
  const DEFAULT_LEARNINGS_SHARED_MD = `# Learnings
12
15
 
13
16
  User preferences, corrections, and patterns. The agent reads this at the start of every conversation.
@@ -245,6 +248,178 @@ function scratchFilterSql(options) {
245
248
  ? ""
246
249
  : " AND (visibility IS NULL OR visibility != 'agent_scratch')";
247
250
  }
251
+ function normalizeWorkspaceAppId(value) {
252
+ if (typeof value !== "string")
253
+ return null;
254
+ const trimmed = value.trim();
255
+ if (!trimmed)
256
+ return null;
257
+ const candidate = trimmed.replace(/^\/+/, "").split("/")[0] ?? "";
258
+ if (!/^[a-z0-9][a-z0-9-]{0,127}$/.test(candidate))
259
+ return null;
260
+ return candidate;
261
+ }
262
+ function workspaceAppIdFromBasePath(value) {
263
+ if (typeof value !== "string")
264
+ return null;
265
+ return normalizeWorkspaceAppId(value);
266
+ }
267
+ function currentWorkspaceAppId(explicit) {
268
+ return (normalizeWorkspaceAppId(explicit) ??
269
+ normalizeWorkspaceAppId(process.env.AGENT_NATIVE_WORKSPACE_APP_ID) ??
270
+ normalizeWorkspaceAppId(process.env.APP_NAME) ??
271
+ normalizeWorkspaceAppId(process.env.AGENT_APP) ??
272
+ workspaceAppIdFromBasePath(process.env.APP_BASE_PATH) ??
273
+ workspaceAppIdFromBasePath(process.env.VITE_APP_BASE_PATH));
274
+ }
275
+ function requestScopedResourceIdentity(options) {
276
+ const userEmail = options?.userEmail ?? getRequestUserEmail() ?? null;
277
+ const orgId = options?.orgId ?? getRequestOrgId() ?? null;
278
+ return { userEmail, orgId };
279
+ }
280
+ function workspaceResourceMimeType(path) {
281
+ return path.endsWith(".json") ? "application/json" : "text/markdown";
282
+ }
283
+ function syntheticWorkspaceResourceId(resourceId) {
284
+ return `${DISPATCH_WORKSPACE_RESOURCE_ID_PREFIX}${resourceId}`;
285
+ }
286
+ function physicalWorkspaceResourceId(id) {
287
+ return id.startsWith(DISPATCH_WORKSPACE_RESOURCE_ID_PREFIX)
288
+ ? id.slice(DISPATCH_WORKSPACE_RESOURCE_ID_PREFIX.length)
289
+ : null;
290
+ }
291
+ function rowToGrantedWorkspaceResource(row) {
292
+ const content = String(row.content ?? "");
293
+ const path = String(row.path ?? "");
294
+ return {
295
+ id: syntheticWorkspaceResourceId(String(row.id)),
296
+ path,
297
+ owner: WORKSPACE_OWNER,
298
+ content,
299
+ mimeType: workspaceResourceMimeType(path),
300
+ size: Buffer.byteLength(content, "utf8"),
301
+ createdAt: Number(row.created_at ?? Date.now()),
302
+ updatedAt: Number(row.updated_at ?? Date.now()),
303
+ createdBy: "system",
304
+ visibility: "workspace",
305
+ threadId: null,
306
+ runId: null,
307
+ expiresAt: null,
308
+ metadata: JSON.stringify({
309
+ source: DISPATCH_WORKSPACE_RESOURCE_METADATA_SOURCE,
310
+ resourceId: String(row.id),
311
+ grantId: row.grant_id ? String(row.grant_id) : null,
312
+ kind: row.kind ?? null,
313
+ name: row.name ?? null,
314
+ description: row.description ?? null,
315
+ scope: "selected",
316
+ appId: row.app_id ?? null,
317
+ updatedAt: Number(row.updated_at ?? Date.now()),
318
+ }),
319
+ };
320
+ }
321
+ function mergeResourceMetas(primary, inherited) {
322
+ const seen = new Set(primary.map((resource) => resource.path));
323
+ const merged = [...primary];
324
+ for (const resource of inherited) {
325
+ if (seen.has(resource.path))
326
+ continue;
327
+ seen.add(resource.path);
328
+ merged.push(resource);
329
+ }
330
+ return merged;
331
+ }
332
+ async function selectGrantedWorkspaceResourceRows(input) {
333
+ const appId = currentWorkspaceAppId(input.workspaceAppId);
334
+ const { userEmail, orgId } = requestScopedResourceIdentity(input);
335
+ if (!appId || (!userEmail && !orgId))
336
+ return [];
337
+ const conditions = ["wr.scope = ?", "wg.status = ?", "wg.app_id = ?"];
338
+ const args = ["selected", "active", appId];
339
+ if (input.resourceId) {
340
+ conditions.push("wr.id = ?");
341
+ args.push(input.resourceId);
342
+ }
343
+ if (input.path) {
344
+ conditions.push("wr.path = ?");
345
+ args.push(input.path);
346
+ }
347
+ if (input.pathPrefix) {
348
+ conditions.push("wr.path LIKE ?");
349
+ args.push(`${input.pathPrefix}%`);
350
+ }
351
+ if (orgId) {
352
+ conditions.push("wr.org_id = ?", "wg.org_id = ?");
353
+ args.push(orgId, orgId);
354
+ }
355
+ else if (userEmail) {
356
+ conditions.push("wr.owner_email = ?", "wr.org_id IS NULL", "wg.owner_email = ?", "wg.org_id IS NULL");
357
+ args.push(userEmail, userEmail);
358
+ }
359
+ const client = getDbExec();
360
+ const { rows } = await client.execute({
361
+ sql: `
362
+ SELECT
363
+ wr.id,
364
+ wr.kind,
365
+ wr.name,
366
+ wr.description,
367
+ wr.path,
368
+ wr.content,
369
+ wr.created_at,
370
+ wr.updated_at,
371
+ wg.id AS grant_id,
372
+ wg.app_id AS app_id
373
+ FROM workspace_resources wr
374
+ INNER JOIN workspace_resource_grants wg ON wg.resource_id = wr.id
375
+ WHERE ${conditions.join(" AND ")}
376
+ ORDER BY wr.updated_at DESC
377
+ `,
378
+ args,
379
+ });
380
+ return rows;
381
+ }
382
+ async function grantedWorkspaceResources(input) {
383
+ try {
384
+ const rows = await selectGrantedWorkspaceResourceRows(input);
385
+ return rows.map(rowToGrantedWorkspaceResource);
386
+ }
387
+ catch {
388
+ // Dispatch workspace-resource tables are optional for standalone apps.
389
+ return [];
390
+ }
391
+ }
392
+ async function grantedWorkspaceResourceById(id, options) {
393
+ const resourceId = physicalWorkspaceResourceId(id);
394
+ if (!resourceId)
395
+ return null;
396
+ try {
397
+ const rows = await selectGrantedWorkspaceResourceRows({
398
+ resourceId,
399
+ workspaceAppId: options?.workspaceAppId,
400
+ userEmail: options?.userEmail,
401
+ orgId: options?.orgId,
402
+ });
403
+ return rows[0] ? rowToGrantedWorkspaceResource(rows[0]) : null;
404
+ }
405
+ catch {
406
+ return null;
407
+ }
408
+ }
409
+ async function grantedWorkspaceResourceByPath(path, options) {
410
+ try {
411
+ const rows = await selectGrantedWorkspaceResourceRows({
412
+ path,
413
+ workspaceAppId: options?.workspaceAppId,
414
+ userEmail: options?.userEmail,
415
+ orgId: options?.orgId,
416
+ });
417
+ return rows[0] ? rowToGrantedWorkspaceResource(rows[0]) : null;
418
+ }
419
+ catch {
420
+ return null;
421
+ }
422
+ }
248
423
  async function cleanupExpiredAgentScratchResources(client) {
249
424
  const now = Date.now();
250
425
  if (now - _lastScratchCleanupAt < SCRATCH_CLEANUP_INTERVAL_MS)
@@ -540,7 +715,7 @@ function resourceToMeta(resource) {
540
715
  const { content: _content, ...meta } = resource;
541
716
  return meta;
542
717
  }
543
- export async function resourceGet(id) {
718
+ export async function resourceGet(id, options) {
544
719
  await ensureTable();
545
720
  const client = getDbExec();
546
721
  await cleanupExpiredAgentScratchResources(client);
@@ -549,10 +724,10 @@ export async function resourceGet(id) {
549
724
  args: [id],
550
725
  });
551
726
  if (rows.length === 0)
552
- return null;
727
+ return grantedWorkspaceResourceById(id, options);
553
728
  return rowToResource(rows[0]);
554
729
  }
555
- export async function resourceGetByPath(owner, path) {
730
+ export async function resourceGetByPath(owner, path, options) {
556
731
  await ensureTable();
557
732
  const client = getDbExec();
558
733
  await cleanupExpiredAgentScratchResources(client);
@@ -560,6 +735,9 @@ export async function resourceGetByPath(owner, path) {
560
735
  sql: `SELECT * FROM resources WHERE owner = ? AND path = ?`,
561
736
  args: [owner, path],
562
737
  });
738
+ if (rows.length === 0 && owner === WORKSPACE_OWNER) {
739
+ return grantedWorkspaceResourceByPath(path, options);
740
+ }
563
741
  if (rows.length === 0)
564
742
  return null;
565
743
  return rowToResource(rows[0]);
@@ -692,13 +870,30 @@ export async function resourceList(owner, pathPrefix, options) {
692
870
  sql: `SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ? AND path LIKE ?${visibilitySql}`,
693
871
  args: [owner, pathPrefix + "%"],
694
872
  });
695
- return rows.map(rowToMeta);
873
+ const resources = rows.map(rowToMeta);
874
+ if (owner !== WORKSPACE_OWNER)
875
+ return resources;
876
+ const granted = await grantedWorkspaceResources({
877
+ pathPrefix,
878
+ workspaceAppId: options?.workspaceAppId,
879
+ userEmail: options?.userEmail,
880
+ orgId: options?.orgId,
881
+ });
882
+ return mergeResourceMetas(resources, granted.map(resourceToMeta));
696
883
  }
697
884
  const { rows } = await client.execute({
698
885
  sql: `SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ?${visibilitySql}`,
699
886
  args: [owner],
700
887
  });
701
- return rows.map(rowToMeta);
888
+ const resources = rows.map(rowToMeta);
889
+ if (owner !== WORKSPACE_OWNER)
890
+ return resources;
891
+ const granted = await grantedWorkspaceResources({
892
+ workspaceAppId: options?.workspaceAppId,
893
+ userEmail: options?.userEmail,
894
+ orgId: options?.orgId,
895
+ });
896
+ return mergeResourceMetas(resources, granted.map(resourceToMeta));
702
897
  }
703
898
  export async function resourceListAccessible(userEmail, pathPrefix, options) {
704
899
  await ensureTable();
@@ -721,7 +916,14 @@ export async function resourceListAccessible(userEmail, pathPrefix, options) {
721
916
  pathPrefix + "%",
722
917
  ],
723
918
  });
724
- return rows.map(rowToMeta);
919
+ const resources = rows.map(rowToMeta);
920
+ const granted = await grantedWorkspaceResources({
921
+ pathPrefix,
922
+ workspaceAppId: options?.workspaceAppId,
923
+ userEmail,
924
+ orgId: options?.orgId,
925
+ });
926
+ return mergeResourceMetas(resources, granted.map(resourceToMeta));
725
927
  }
726
928
  const { rows } = await client.execute({
727
929
  sql: `SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ?${visibilitySql}
@@ -731,11 +933,20 @@ export async function resourceListAccessible(userEmail, pathPrefix, options) {
731
933
  SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ?${visibilitySql}`,
732
934
  args: [userEmail, SHARED_OWNER, WORKSPACE_OWNER],
733
935
  });
734
- return rows.map(rowToMeta);
936
+ const resources = rows.map(rowToMeta);
937
+ const granted = await grantedWorkspaceResources({
938
+ workspaceAppId: options?.workspaceAppId,
939
+ userEmail,
940
+ orgId: options?.orgId,
941
+ });
942
+ return mergeResourceMetas(resources, granted.map(resourceToMeta));
735
943
  }
736
- export async function resourceEffectiveContext(userEmail, path) {
944
+ export async function resourceEffectiveContext(userEmail, path, options) {
737
945
  await ensureTable();
738
- const workspace = await resourceGetByPath(WORKSPACE_OWNER, path);
946
+ const workspace = await resourceGetByPath(WORKSPACE_OWNER, path, {
947
+ ...options,
948
+ userEmail,
949
+ });
739
950
  const shared = await resourceGetByPath(SHARED_OWNER, path);
740
951
  const personal = await resourceGetByPath(userEmail, path);
741
952
  const effective = personal ?? shared ?? workspace ?? null;
@@ -1 +1 @@
1
- {"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/resources/store.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n getDbExec,\n isPostgres,\n intType,\n retryOnDdlRace,\n type DbExec,\n} from \"../db/client.js\";\nimport { emitResourceChange, emitResourceDelete } from \"./emitter.js\";\nimport type { StoreWriteOptions } from \"../settings/store.js\";\nimport crypto from \"crypto\";\n\nexport const SHARED_OWNER = \"__shared__\";\nexport const WORKSPACE_OWNER = \"__workspace__\";\n\nexport interface Resource {\n id: string;\n path: string;\n owner: string;\n content: string;\n mimeType: string;\n size: number;\n createdAt: number;\n updatedAt: number;\n createdBy: ResourceCreatedBy;\n visibility: ResourceVisibility;\n threadId: string | null;\n runId: string | null;\n expiresAt: number | null;\n metadata: string | null;\n}\n\nexport interface ResourceMeta {\n id: string;\n path: string;\n owner: string;\n mimeType: string;\n size: number;\n createdAt: number;\n updatedAt: number;\n createdBy: ResourceCreatedBy;\n visibility: ResourceVisibility;\n threadId: string | null;\n runId: string | null;\n expiresAt: number | null;\n metadata: string | null;\n}\n\nexport type ResourceCreatedBy = \"user\" | \"agent\" | \"system\";\nexport type ResourceVisibility = \"workspace\" | \"agent_scratch\";\n\nexport interface ResourceWriteOptions extends StoreWriteOptions {\n createdBy?: ResourceCreatedBy;\n visibility?: ResourceVisibility;\n threadId?: string | null;\n runId?: string | null;\n expiresAt?: number | null;\n metadata?: string | Record<string, unknown> | null;\n}\n\nexport interface ResourceListOptions {\n includeAgentScratch?: boolean;\n}\n\nexport type ResourceInheritanceScope = \"workspace\" | \"shared\" | \"personal\";\n\nexport interface EffectiveResourceLayer {\n scope: ResourceInheritanceScope;\n label: string;\n owner: string;\n resource: ResourceMeta | null;\n exists: boolean;\n effective: boolean;\n overridden: boolean;\n canWrite: boolean;\n}\n\nexport interface EffectiveResourceContext {\n path: string;\n effectiveResource: ResourceMeta | null;\n effectiveScope: ResourceInheritanceScope | null;\n layers: EffectiveResourceLayer[];\n}\n\nlet _initPromise: Promise<void> | undefined;\nlet _lastScratchCleanupAt = 0;\n\nconst AGENT_SCRATCH_TTL_MS = 24 * 60 * 60 * 1000;\nconst SCRATCH_CLEANUP_INTERVAL_MS = 60 * 1000;\nconst RESOURCE_META_SELECT =\n \"id, path, owner, mime_type, size, created_at, updated_at, created_by, visibility, thread_id, run_id, expires_at, metadata\";\n\nconst DEFAULT_LEARNINGS_SHARED_MD = `# Learnings\n\nUser preferences, corrections, and patterns. The agent reads this at the start of every conversation.\n\nKeep this file tidy — revise, consolidate, and remove outdated entries. Don't just append forever.\n\n## Preferences\n\n## Corrections\n\n## Patterns\n`;\n\nconst DEFAULT_LEARNINGS_PERSONAL_MD = `# My Learnings\n\nPersonal preferences, corrections, and patterns — only visible to you.\n\n## Preferences\n\n## Corrections\n\n## Patterns\n`;\n\nconst DEFAULT_SKILL_LEARN_MD = `---\nname: learn\ndescription: >-\n Review the conversation and save structured memories for future sessions.\nuser-invocable: true\n---\n\n# Learn\n\nReview the current conversation and save anything worth remembering using the structured memory system.\n\n## Memory types\n\n- **user** — Preferences, role, personal context, contacts\n- **feedback** — Corrections (\"don't do X, do Y instead\"), confirmed approaches\n- **project** — Ongoing work context, decisions, status\n- **reference** — Pointers to external systems, URLs, API details\n\n## Steps\n\n1. Review the conversation for new insights\n2. Check your memory index: \\`resource-read --path memory/MEMORY.md\\`\n3. For each new insight, use \\`save-memory\\` with a descriptive name, type, and content\n4. If updating an existing memory, read it first with \\`resource-read --path memory/<name>.md\\`, then save with merged content\n\n## What NOT to capture\n\n- Things obvious from reading the code\n- Standard language/framework behavior\n- Temporary debugging notes\n- Anything already in AGENTS.md or other skills\n\nKeep one memory per logical topic. Descriptions should be concise — the index is loaded every conversation.\n`;\n\nconst DEFAULT_SKILL_LEARN_SHARED_MD = `---\nname: learn-shared\ndescription: >-\n Update the shared LEARNINGS.md with team-wide preferences, corrections, and\n patterns from this session.\nuser-invocable: true\n---\n\n# Learn (Shared)\n\nReview the current conversation and update the shared \\`LEARNINGS.md\\` resource with anything the whole team should know.\n\n## What to capture\n\n- **Team conventions** — agreed-upon approaches, code style decisions\n- **Technical learnings** — API quirks, library gotchas, surprising behavior\n- **Architectural decisions** — why something is done a certain way\n- **Corrections** — mistakes that any team member's agent should avoid\n\n## What NOT to capture\n\n- Personal preferences (use \\`/learn\\` for those)\n- Things obvious from reading the code\n- Standard language/framework behavior\n\n## Steps\n\n1. Read shared learnings: \\`pnpm action resource-read --path LEARNINGS.md --scope shared\\`\n2. Review the conversation for team-relevant insights\n3. Merge new learnings with existing ones — don't duplicate, refine existing entries\n4. Write back: \\`pnpm action resource-write --path LEARNINGS.md --scope shared --content \"...\"\\`\n\nKeep entries concise — one line per learning, grouped by category (Conventions, Technical, Patterns).\n`;\n\nconst DEFAULT_AGENTS_SHARED_MD = `# Agent Instructions\n\nThis file customizes how the AI agent behaves in this app. Edit it to add your own instructions, preferences, and context.\n\nWorkspace-level resources managed from Dispatch are inherited before this file.\nUse this shared app/organization file to override or narrow those defaults for\nthis app or team.\n\n## What to put here\n\n- **Preferences** — Tone, style, verbosity, response format\n- **Context** — Domain knowledge, terminology, team conventions\n- **Rules** — Things the agent should always/never do\n- **Skills** — Reference skill files for specialized tasks (create them in the \\`skills/\\` folder)\n\n## Skills\n\nYou can create skill files to give the agent specialized knowledge for specific tasks. Create resources under \\`skills/<name>/SKILL.md\\` (e.g., \\`skills/data-analysis/SKILL.md\\`, \\`skills/code-review/SKILL.md\\`) and reference them here:\n\n| Skill | Path | Description |\n|-------|------|-------------|\n| *(add your skills here)* | \\`skills/example/SKILL.md\\` | What this skill teaches the agent |\n\nThe agent will read the relevant skill file when performing that type of task.\n\n## Global instructions\n\nPut always-on guardrails in this shared \\`AGENTS.md\\`. For separate policy files that should also apply every turn, create shared resources under \\`instructions/<name>.md\\`. These are loaded automatically with this file.\n\n## Shared reference resources\n\nPut company, brand, positioning, persona, product, or messaging context in shared resources under paths like \\`context/core-positioning.md\\` or \\`context/brand-guidelines.md\\`. The agent sees an index of shared reference resources and reads the relevant files when a task may depend on them.\n\n## Workspace files\n\nWorkspace resources are for files users intentionally add, edit, or manage. Agents may create hidden \\`agent_scratch\\` resources for temporary working notes, scripts, or intermediate results; only promote those files into workspace visibility when a user explicitly asks to keep them.\n\n## Example\n\n\\`\\`\\`markdown\n## Tone\nBe concise. Lead with the answer. Skip filler.\n\n## Code style\n- Use TypeScript, never JavaScript\n- Prefer named exports\n- Use early returns\n\n## Domain context\nWe sell B2B SaaS. Our customers are enterprise engineering teams.\n\\`\\`\\`\n`;\n\nconst DEFAULT_AGENTS_PERSONAL_MD = `# My Agent Instructions\n\nPersonal agent instructions — only visible to you. Use this for your own contacts, preferences, and context.\n\n## Contacts\n\nAdd people you frequently interact with so the agent can resolve names like \"email my wife\" or \"message John\":\n\n| Name | Email | Notes |\n|------|-------|-------|\n| *(add your contacts here)* | | |\n\n## Preferences\n\n## Context\n\n## Workspace files\n\nFiles you create here are user-facing. Temporary agent working files should stay hidden as \\`agent_scratch\\` unless you ask the agent to keep them.\n`;\n\nasync function migrateDefaultResourcePath({\n client,\n owner,\n fromPath,\n toPath,\n defaultContent,\n}: {\n client: DbExec;\n owner: string;\n fromPath: string;\n toPath: string;\n defaultContent: string;\n}): Promise<void> {\n try {\n const existing = await client.execute({\n sql: `SELECT id, content FROM resources WHERE owner = ? AND path = ?`,\n args: [owner, fromPath],\n });\n const row = existing.rows?.[0] as\n | { id: string; content: string }\n | undefined;\n if (!row || row.content !== defaultContent) return;\n\n const destination = await client.execute({\n sql: `SELECT id FROM resources WHERE owner = ? AND path = ?`,\n args: [owner, toPath],\n });\n if ((destination.rows?.length ?? 0) > 0) return;\n\n await client.execute({\n sql: `UPDATE resources SET path = ?, updated_at = ? WHERE id = ?`,\n args: [toPath, Date.now(), row.id],\n });\n } catch {\n // Best-effort compatibility migration; seeding below still works if it fails.\n }\n}\n\nfunction isDuplicateColumnError(err: unknown): boolean {\n const code = (err as { code?: string })?.code;\n const message = String((err as { message?: unknown })?.message ?? err)\n .toLowerCase()\n .trim();\n return (\n code === \"42701\" ||\n message.includes(\"duplicate column\") ||\n message.includes(\"already exists\")\n );\n}\n\nasync function ensureResourceColumn(\n client: DbExec,\n definition: string,\n): Promise<void> {\n try {\n await retryOnDdlRace(() =>\n client.execute(`ALTER TABLE resources ADD COLUMN ${definition}`),\n );\n } catch (err) {\n if (!isDuplicateColumnError(err)) throw err;\n }\n}\n\nfunction normalizeCreatedBy(value: unknown): ResourceCreatedBy {\n return value === \"agent\" || value === \"system\" || value === \"user\"\n ? value\n : \"user\";\n}\n\nfunction normalizeVisibility(value: unknown): ResourceVisibility {\n return value === \"agent_scratch\" ? \"agent_scratch\" : \"workspace\";\n}\n\nfunction nullableString(value: unknown): string | null {\n return typeof value === \"string\" && value.length > 0 ? value : null;\n}\n\nfunction nullableNumber(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n const parsed = Number(value);\n return Number.isFinite(parsed) ? parsed : null;\n}\n\nfunction hasOption<K extends keyof ResourceWriteOptions>(\n options: ResourceWriteOptions | undefined,\n key: K,\n): boolean {\n return (\n Object.prototype.hasOwnProperty.call(options ?? {}, key) &&\n options?.[key] !== undefined\n );\n}\n\nfunction serializeMetadata(\n value: ResourceWriteOptions[\"metadata\"] | undefined,\n): string | null | undefined {\n if (value === undefined) return undefined;\n if (value === null) return null;\n return typeof value === \"string\" ? value : JSON.stringify(value);\n}\n\nfunction scratchFilterSql(options?: ResourceListOptions): string {\n return options?.includeAgentScratch === true\n ? \"\"\n : \" AND (visibility IS NULL OR visibility != 'agent_scratch')\";\n}\n\nasync function cleanupExpiredAgentScratchResources(\n client: DbExec,\n): Promise<void> {\n const now = Date.now();\n if (now - _lastScratchCleanupAt < SCRATCH_CLEANUP_INTERVAL_MS) return;\n _lastScratchCleanupAt = now;\n await client.execute({\n sql: `DELETE FROM resources WHERE visibility = ? AND expires_at IS NOT NULL AND expires_at <= ?`,\n args: [\"agent_scratch\", now],\n });\n}\n\nasync function ensureTable(): Promise<void> {\n if (!_initPromise) {\n _initPromise = _doEnsureTable().catch((err) => {\n // Don't cache the rejection — let the next caller retry a fresh init.\n _initPromise = undefined;\n throw err;\n });\n }\n return _initPromise;\n}\n\nasync function _doEnsureTable(): Promise<void> {\n const client = getDbExec();\n await retryOnDdlRace(() =>\n client.execute(`\n CREATE TABLE IF NOT EXISTS resources (\n id TEXT PRIMARY KEY,\n path TEXT NOT NULL,\n owner TEXT NOT NULL,\n content TEXT NOT NULL DEFAULT '',\n mime_type TEXT NOT NULL DEFAULT 'text/markdown',\n size ${intType()} NOT NULL DEFAULT 0,\n created_at ${intType()} NOT NULL,\n updated_at ${intType()} NOT NULL,\n created_by TEXT NOT NULL DEFAULT 'user',\n visibility TEXT NOT NULL DEFAULT 'workspace',\n thread_id TEXT,\n run_id TEXT,\n expires_at ${intType()},\n metadata TEXT,\n UNIQUE(path, owner)\n )\n `),\n );\n\n await ensureResourceColumn(client, \"created_by TEXT NOT NULL DEFAULT 'user'\");\n await ensureResourceColumn(\n client,\n \"visibility TEXT NOT NULL DEFAULT 'workspace'\",\n );\n await ensureResourceColumn(client, \"thread_id TEXT\");\n await ensureResourceColumn(client, \"run_id TEXT\");\n await ensureResourceColumn(client, `expires_at ${intType()}`);\n await ensureResourceColumn(client, \"metadata TEXT\");\n\n // Seed default shared resources if they don't exist (INSERT OR IGNORE to avoid race conditions)\n const now = Date.now();\n const seedSql = isPostgres()\n ? `INSERT INTO resources (id, path, owner, content, mime_type, size, created_at, updated_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?) ON CONFLICT (path, owner) DO NOTHING`\n : `INSERT OR IGNORE INTO resources (id, path, owner, content, mime_type, size, created_at, updated_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?)`;\n\n // AGENTS.md — shared agent instructions\n const agentsSize = Buffer.byteLength(DEFAULT_AGENTS_SHARED_MD, \"utf8\");\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"AGENTS.md\",\n SHARED_OWNER,\n DEFAULT_AGENTS_SHARED_MD,\n \"text/markdown\",\n agentsSize,\n now,\n now,\n ],\n });\n\n // LEARNINGS.md — shared learnings (preferences, corrections, patterns)\n const learningsSize = Buffer.byteLength(DEFAULT_LEARNINGS_SHARED_MD, \"utf8\");\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"LEARNINGS.md\",\n SHARED_OWNER,\n DEFAULT_LEARNINGS_SHARED_MD,\n \"text/markdown\",\n learningsSize,\n now,\n now,\n ],\n });\n\n await migrateDefaultResourcePath({\n client,\n owner: SHARED_OWNER,\n fromPath: \"skills/learn-shared.md\",\n toPath: \"skills/learn-shared/SKILL.md\",\n defaultContent: DEFAULT_SKILL_LEARN_SHARED_MD,\n });\n\n // skills/learn-shared/SKILL.md — shared skill for updating shared LEARNINGS.md\n const learnSharedSize = Buffer.byteLength(\n DEFAULT_SKILL_LEARN_SHARED_MD,\n \"utf8\",\n );\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"skills/learn-shared/SKILL.md\",\n SHARED_OWNER,\n DEFAULT_SKILL_LEARN_SHARED_MD,\n \"text/markdown\",\n learnSharedSize,\n now,\n now,\n ],\n });\n\n // Seed built-in agents as shared resources under remote-agents/. ALWAYS\n // use the production URL here, never the env-resolved devUrl. The seed\n // runs once per DB (ON CONFLICT DO NOTHING), so a localhost URL written\n // during a dev run sticks forever — including when that DB is later used\n // by a prod deploy and the override wins over the built-in's prod URL.\n // (Verified problem: `dispatch.agent-native.com` had every remote-agents\n // entry pointing at localhost from an early-seed run, breaking call-agent\n // outbound from Lambda for ~12h before this was caught.)\n try {\n const { getBuiltinAgents, BUILTIN_AGENTS_FOR_SEEDING } =\n await import(\"../server/agent-discovery.js\");\n void getBuiltinAgents; // referenced to keep type-only import alive\n const builtins = BUILTIN_AGENTS_FOR_SEEDING;\n for (const agent of builtins) {\n const agentJson = JSON.stringify(\n {\n id: agent.id,\n name: agent.name,\n description: agent.description,\n url: agent.url, // always prod\n color: agent.color,\n },\n null,\n 2,\n );\n const agentSize = Buffer.byteLength(agentJson, \"utf8\");\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n `remote-agents/${agent.id}.json`,\n SHARED_OWNER,\n agentJson,\n \"application/json\",\n agentSize,\n now,\n now,\n ],\n });\n }\n } catch {\n // Agent discovery not available — skip seeding\n }\n\n // One-time migration: rename legacy agents/*.json (A2A manifests) to\n // remote-agents/*.json so they live in their own folder, separate from\n // custom agents (agents/*.md).\n try {\n const legacy = await client.execute({\n sql: `SELECT id, path FROM resources WHERE path LIKE ? AND path LIKE ?`,\n args: [\"agents/%\", \"%.json\"],\n });\n const rows = (legacy.rows ?? []) as Array<{ id: string; path: string }>;\n for (const row of rows) {\n const newPath = row.path.replace(/^agents\\//, \"remote-agents/\");\n try {\n await client.execute({\n sql: `UPDATE resources SET path = ?, updated_at = ? WHERE id = ?`,\n args: [newPath, Date.now(), row.id],\n });\n } catch {\n // Skip if destination path already exists (unique constraint) —\n // we'll leave the old row in place; readers accept both paths and\n // canonical remote-agents/ entries win when both exist.\n }\n }\n } catch {\n // Migration best-effort\n }\n}\n\nconst _personalSeeded = new Set<string>();\n\n/**\n * Seed personal AGENTS.md and LEARNINGS.md for a user if they don't exist.\n * Called when listing resources or from the agent chat plugin.\n */\nexport async function ensurePersonalDefaults(owner: string): Promise<void> {\n if (\n owner === SHARED_OWNER ||\n owner === WORKSPACE_OWNER ||\n _personalSeeded.has(owner)\n ) {\n return;\n }\n _personalSeeded.add(owner);\n await ensureTable();\n\n const client = getDbExec();\n const now = Date.now();\n const seedSql = isPostgres()\n ? `INSERT INTO resources (id, path, owner, content, mime_type, size, created_at, updated_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?) ON CONFLICT (path, owner) DO NOTHING`\n : `INSERT OR IGNORE INTO resources (id, path, owner, content, mime_type, size, created_at, updated_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?)`;\n\n const agentsSize = Buffer.byteLength(DEFAULT_AGENTS_PERSONAL_MD, \"utf8\");\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"AGENTS.md\",\n owner,\n DEFAULT_AGENTS_PERSONAL_MD,\n \"text/markdown\",\n agentsSize,\n now,\n now,\n ],\n });\n\n const learningsSize = Buffer.byteLength(\n DEFAULT_LEARNINGS_PERSONAL_MD,\n \"utf8\",\n );\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"LEARNINGS.md\",\n owner,\n DEFAULT_LEARNINGS_PERSONAL_MD,\n \"text/markdown\",\n learningsSize,\n now,\n now,\n ],\n });\n\n // memory/MEMORY.md — personal structured memory index\n const memoryIndexContent = \"# Memory Index\\n\";\n const memoryIndexSize = Buffer.byteLength(memoryIndexContent, \"utf8\");\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"memory/MEMORY.md\",\n owner,\n memoryIndexContent,\n \"text/markdown\",\n memoryIndexSize,\n now,\n now,\n ],\n });\n\n await migrateDefaultResourcePath({\n client,\n owner,\n fromPath: \"skills/learn.md\",\n toPath: \"skills/learn/SKILL.md\",\n defaultContent: DEFAULT_SKILL_LEARN_MD,\n });\n\n // skills/learn/SKILL.md — personal skill for updating memory\n const learnSize = Buffer.byteLength(DEFAULT_SKILL_LEARN_MD, \"utf8\");\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"skills/learn/SKILL.md\",\n owner,\n DEFAULT_SKILL_LEARN_MD,\n \"text/markdown\",\n learnSize,\n now,\n now,\n ],\n });\n}\n\nfunction rowToResource(row: any): Resource {\n return {\n id: row.id as string,\n path: row.path as string,\n owner: row.owner as string,\n content: row.content as string,\n mimeType: row.mime_type as string,\n size: Number(row.size),\n createdAt: Number(row.created_at),\n updatedAt: Number(row.updated_at),\n createdBy: normalizeCreatedBy(row.created_by),\n visibility: normalizeVisibility(row.visibility),\n threadId: nullableString(row.thread_id),\n runId: nullableString(row.run_id),\n expiresAt: nullableNumber(row.expires_at),\n metadata: nullableString(row.metadata),\n };\n}\n\nfunction rowToMeta(row: any): ResourceMeta {\n return {\n id: row.id as string,\n path: row.path as string,\n owner: row.owner as string,\n mimeType: row.mime_type as string,\n size: Number(row.size),\n createdAt: Number(row.created_at),\n updatedAt: Number(row.updated_at),\n createdBy: normalizeCreatedBy(row.created_by),\n visibility: normalizeVisibility(row.visibility),\n threadId: nullableString(row.thread_id),\n runId: nullableString(row.run_id),\n expiresAt: nullableNumber(row.expires_at),\n metadata: nullableString(row.metadata),\n };\n}\n\nfunction resourceToMeta(resource: Resource): ResourceMeta {\n const { content: _content, ...meta } = resource;\n return meta;\n}\n\nexport async function resourceGet(id: string): Promise<Resource | null> {\n await ensureTable();\n const client = getDbExec();\n await cleanupExpiredAgentScratchResources(client);\n const { rows } = await client.execute({\n sql: `SELECT * FROM resources WHERE id = ?`,\n args: [id],\n });\n if (rows.length === 0) return null;\n return rowToResource(rows[0]);\n}\n\nexport async function resourceGetByPath(\n owner: string,\n path: string,\n): Promise<Resource | null> {\n await ensureTable();\n const client = getDbExec();\n await cleanupExpiredAgentScratchResources(client);\n const { rows } = await client.execute({\n sql: `SELECT * FROM resources WHERE owner = ? AND path = ?`,\n args: [owner, path],\n });\n if (rows.length === 0) return null;\n return rowToResource(rows[0]);\n}\n\nexport async function resourcePut(\n owner: string,\n path: string,\n content: string,\n mimeType?: string,\n options?: ResourceWriteOptions,\n): Promise<Resource> {\n await ensureTable();\n const client = getDbExec();\n const now = Date.now();\n const size = Buffer.byteLength(content, \"utf8\");\n const mime = mimeType || \"text/markdown\";\n\n // Check for existing resource to preserve ID on upsert\n const { rows: existing } = await client.execute({\n sql: `SELECT id, created_at, created_by, visibility, thread_id, run_id, expires_at, metadata FROM resources WHERE owner = ? AND path = ?`,\n args: [owner, path],\n });\n const existingRow = existing[0] as\n | {\n id: string;\n created_at: number;\n created_by?: string | null;\n visibility?: string | null;\n thread_id?: string | null;\n run_id?: string | null;\n expires_at?: number | null;\n metadata?: string | null;\n }\n | undefined;\n\n const id =\n existing.length > 0 ? (existingRow?.id as string) : crypto.randomUUID();\n const createdAt = existingRow ? Number(existingRow.created_at) : now;\n const createdBy = normalizeCreatedBy(\n hasOption(options, \"createdBy\")\n ? options?.createdBy\n : existingRow?.created_by,\n );\n const visibility = normalizeVisibility(\n hasOption(options, \"visibility\")\n ? options?.visibility\n : existingRow?.visibility,\n );\n const threadId = hasOption(options, \"threadId\")\n ? (options?.threadId ?? null)\n : nullableString(existingRow?.thread_id);\n const runId = hasOption(options, \"runId\")\n ? (options?.runId ?? null)\n : nullableString(existingRow?.run_id);\n let expiresAt = hasOption(options, \"expiresAt\")\n ? (options?.expiresAt ?? null)\n : nullableNumber(existingRow?.expires_at);\n if (visibility === \"agent_scratch\" && expiresAt === null) {\n expiresAt = now + AGENT_SCRATCH_TTL_MS;\n }\n if (visibility === \"workspace\" && !hasOption(options, \"expiresAt\")) {\n expiresAt = null;\n }\n const serializedMetadata = serializeMetadata(options?.metadata);\n const metadata =\n serializedMetadata !== undefined\n ? serializedMetadata\n : nullableString(existingRow?.metadata);\n\n await client.execute({\n sql: isPostgres()\n ? `INSERT INTO resources (id, path, owner, content, mime_type, size, created_at, updated_at, created_by, visibility, thread_id, run_id, expires_at, metadata) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?) ON CONFLICT (path, owner) DO UPDATE SET id=EXCLUDED.id, content=EXCLUDED.content, mime_type=EXCLUDED.mime_type, size=EXCLUDED.size, updated_at=EXCLUDED.updated_at, created_by=EXCLUDED.created_by, visibility=EXCLUDED.visibility, thread_id=EXCLUDED.thread_id, run_id=EXCLUDED.run_id, expires_at=EXCLUDED.expires_at, metadata=EXCLUDED.metadata`\n : `INSERT OR REPLACE INTO resources (id, path, owner, content, mime_type, size, created_at, updated_at, created_by, visibility, thread_id, run_id, expires_at, metadata) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,\n args: [\n id,\n path,\n owner,\n content,\n mime,\n size,\n createdAt,\n now,\n createdBy,\n visibility,\n threadId,\n runId,\n expiresAt,\n metadata,\n ],\n });\n\n emitResourceChange(id, path, owner, options?.requestSource);\n\n return {\n id,\n path,\n owner,\n content,\n mimeType: mime,\n size,\n createdAt,\n updatedAt: now,\n createdBy,\n visibility,\n threadId,\n runId,\n expiresAt,\n metadata,\n };\n}\n\nexport async function resourceDelete(id: string): Promise<boolean> {\n await ensureTable();\n const client = getDbExec();\n\n // Get resource info for emitter before deleting\n const { rows } = await client.execute({\n sql: `SELECT path, owner FROM resources WHERE id = ?`,\n args: [id],\n });\n if (rows.length === 0) return false;\n\n const result = await client.execute({\n sql: `DELETE FROM resources WHERE id = ?`,\n args: [id],\n });\n const deleted = result.rowsAffected > 0;\n if (deleted) {\n emitResourceDelete(id, rows[0].path as string, rows[0].owner as string);\n }\n return deleted;\n}\n\nexport async function resourceDeleteByPath(\n owner: string,\n path: string,\n): Promise<boolean> {\n await ensureTable();\n const client = getDbExec();\n\n // Get resource info for emitter before deleting\n const { rows } = await client.execute({\n sql: `SELECT id FROM resources WHERE owner = ? AND path = ?`,\n args: [owner, path],\n });\n if (rows.length === 0) return false;\n\n const result = await client.execute({\n sql: `DELETE FROM resources WHERE owner = ? AND path = ?`,\n args: [owner, path],\n });\n const deleted = result.rowsAffected > 0;\n if (deleted) {\n emitResourceDelete(rows[0].id as string, path, owner);\n }\n return deleted;\n}\n\nexport async function resourceList(\n owner: string,\n pathPrefix?: string,\n options?: ResourceListOptions,\n): Promise<ResourceMeta[]> {\n await ensureTable();\n const client = getDbExec();\n await cleanupExpiredAgentScratchResources(client);\n const visibilitySql = scratchFilterSql(options);\n\n if (pathPrefix) {\n const { rows } = await client.execute({\n sql: `SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ? AND path LIKE ?${visibilitySql}`,\n args: [owner, pathPrefix + \"%\"],\n });\n return rows.map(rowToMeta);\n }\n\n const { rows } = await client.execute({\n sql: `SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ?${visibilitySql}`,\n args: [owner],\n });\n return rows.map(rowToMeta);\n}\n\nexport async function resourceListAccessible(\n userEmail: string,\n pathPrefix?: string,\n options?: ResourceListOptions,\n): Promise<ResourceMeta[]> {\n await ensureTable();\n const client = getDbExec();\n await cleanupExpiredAgentScratchResources(client);\n const visibilitySql = scratchFilterSql(options);\n\n if (pathPrefix) {\n const { rows } = await client.execute({\n sql: `SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ? AND path LIKE ?${visibilitySql}\n UNION\n SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ? AND path LIKE ?${visibilitySql}\n UNION\n SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ? AND path LIKE ?${visibilitySql}`,\n args: [\n userEmail,\n pathPrefix + \"%\",\n SHARED_OWNER,\n pathPrefix + \"%\",\n WORKSPACE_OWNER,\n pathPrefix + \"%\",\n ],\n });\n return rows.map(rowToMeta);\n }\n\n const { rows } = await client.execute({\n sql: `SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ?${visibilitySql}\n UNION\n SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ?${visibilitySql}\n UNION\n SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ?${visibilitySql}`,\n args: [userEmail, SHARED_OWNER, WORKSPACE_OWNER],\n });\n return rows.map(rowToMeta);\n}\n\nexport async function resourceEffectiveContext(\n userEmail: string,\n path: string,\n): Promise<EffectiveResourceContext> {\n await ensureTable();\n\n const workspace = await resourceGetByPath(WORKSPACE_OWNER, path);\n const shared = await resourceGetByPath(SHARED_OWNER, path);\n const personal = await resourceGetByPath(userEmail, path);\n const effective = personal ?? shared ?? workspace ?? null;\n const effectiveScope: ResourceInheritanceScope | null = personal\n ? \"personal\"\n : shared\n ? \"shared\"\n : workspace\n ? \"workspace\"\n : null;\n\n const layerDefs: Array<{\n scope: ResourceInheritanceScope;\n label: string;\n owner: string;\n resource: Resource | null;\n canWrite: boolean;\n }> = [\n {\n scope: \"workspace\",\n label: \"Workspace default\",\n owner: WORKSPACE_OWNER,\n resource: workspace,\n canWrite: false,\n },\n {\n scope: \"shared\",\n label: \"Organization/app override\",\n owner: SHARED_OWNER,\n resource: shared,\n canWrite: true,\n },\n {\n scope: \"personal\",\n label: \"Personal override\",\n owner: userEmail,\n resource: personal,\n canWrite: true,\n },\n ];\n\n return {\n path,\n effectiveResource: effective ? resourceToMeta(effective) : null,\n effectiveScope,\n layers: layerDefs.map((layer) => ({\n scope: layer.scope,\n label: layer.label,\n owner: layer.owner,\n resource: layer.resource ? resourceToMeta(layer.resource) : null,\n exists: !!layer.resource,\n effective: !!layer.resource && layer.resource.id === effective?.id,\n overridden: !!layer.resource && layer.resource.id !== effective?.id,\n canWrite: layer.canWrite,\n })),\n };\n}\n\n/**\n * List all resources matching a path prefix across ALL owners.\n * Used by the recurring jobs scheduler to find all job resources.\n */\nexport async function resourceListAllOwners(\n pathPrefix: string,\n): Promise<Resource[]> {\n await ensureTable();\n const client = getDbExec();\n const { rows } = await client.execute({\n sql: `SELECT * FROM resources WHERE path LIKE ?`,\n args: [pathPrefix + \"%\"],\n });\n return rows.map(rowToResource);\n}\n\nexport async function resourceMove(\n id: string,\n newPath: string,\n): Promise<boolean> {\n await ensureTable();\n const client = getDbExec();\n const now = Date.now();\n\n // Get current resource info\n const { rows } = await client.execute({\n sql: `SELECT path, owner FROM resources WHERE id = ?`,\n args: [id],\n });\n if (rows.length === 0) return false;\n\n const result = await client.execute({\n sql: `UPDATE resources SET path = ?, updated_at = ? WHERE id = ?`,\n args: [newPath, now, id],\n });\n const moved = result.rowsAffected > 0;\n if (moved) {\n emitResourceChange(id, newPath, rows[0].owner as string);\n }\n return moved;\n}\n"]}
1
+ {"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/resources/store.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n getDbExec,\n isPostgres,\n intType,\n retryOnDdlRace,\n type DbExec,\n} from \"../db/client.js\";\nimport { emitResourceChange, emitResourceDelete } from \"./emitter.js\";\nimport type { StoreWriteOptions } from \"../settings/store.js\";\nimport {\n getRequestOrgId,\n getRequestUserEmail,\n} from \"../server/request-context.js\";\nimport crypto from \"crypto\";\n\nexport const SHARED_OWNER = \"__shared__\";\nexport const WORKSPACE_OWNER = \"__workspace__\";\n\nexport interface Resource {\n id: string;\n path: string;\n owner: string;\n content: string;\n mimeType: string;\n size: number;\n createdAt: number;\n updatedAt: number;\n createdBy: ResourceCreatedBy;\n visibility: ResourceVisibility;\n threadId: string | null;\n runId: string | null;\n expiresAt: number | null;\n metadata: string | null;\n}\n\nexport interface ResourceMeta {\n id: string;\n path: string;\n owner: string;\n mimeType: string;\n size: number;\n createdAt: number;\n updatedAt: number;\n createdBy: ResourceCreatedBy;\n visibility: ResourceVisibility;\n threadId: string | null;\n runId: string | null;\n expiresAt: number | null;\n metadata: string | null;\n}\n\nexport type ResourceCreatedBy = \"user\" | \"agent\" | \"system\";\nexport type ResourceVisibility = \"workspace\" | \"agent_scratch\";\n\nexport interface ResourceWriteOptions extends StoreWriteOptions {\n createdBy?: ResourceCreatedBy;\n visibility?: ResourceVisibility;\n threadId?: string | null;\n runId?: string | null;\n expiresAt?: number | null;\n metadata?: string | Record<string, unknown> | null;\n}\n\nexport interface ResourceListOptions {\n includeAgentScratch?: boolean;\n workspaceAppId?: string | null;\n userEmail?: string | null;\n orgId?: string | null;\n}\n\nexport interface ResourceResolutionOptions {\n workspaceAppId?: string | null;\n userEmail?: string | null;\n orgId?: string | null;\n}\n\nexport type ResourceInheritanceScope = \"workspace\" | \"shared\" | \"personal\";\n\nexport interface EffectiveResourceLayer {\n scope: ResourceInheritanceScope;\n label: string;\n owner: string;\n resource: ResourceMeta | null;\n exists: boolean;\n effective: boolean;\n overridden: boolean;\n canWrite: boolean;\n}\n\nexport interface EffectiveResourceContext {\n path: string;\n effectiveResource: ResourceMeta | null;\n effectiveScope: ResourceInheritanceScope | null;\n layers: EffectiveResourceLayer[];\n}\n\nlet _initPromise: Promise<void> | undefined;\nlet _lastScratchCleanupAt = 0;\n\nconst AGENT_SCRATCH_TTL_MS = 24 * 60 * 60 * 1000;\nconst SCRATCH_CLEANUP_INTERVAL_MS = 60 * 1000;\nconst RESOURCE_META_SELECT =\n \"id, path, owner, mime_type, size, created_at, updated_at, created_by, visibility, thread_id, run_id, expires_at, metadata\";\nconst DISPATCH_WORKSPACE_RESOURCE_ID_PREFIX = \"dispatch-workspace-resource:\";\nconst DISPATCH_WORKSPACE_RESOURCE_METADATA_SOURCE =\n \"dispatch-workspace-resource\";\n\nconst DEFAULT_LEARNINGS_SHARED_MD = `# Learnings\n\nUser preferences, corrections, and patterns. The agent reads this at the start of every conversation.\n\nKeep this file tidy — revise, consolidate, and remove outdated entries. Don't just append forever.\n\n## Preferences\n\n## Corrections\n\n## Patterns\n`;\n\nconst DEFAULT_LEARNINGS_PERSONAL_MD = `# My Learnings\n\nPersonal preferences, corrections, and patterns — only visible to you.\n\n## Preferences\n\n## Corrections\n\n## Patterns\n`;\n\nconst DEFAULT_SKILL_LEARN_MD = `---\nname: learn\ndescription: >-\n Review the conversation and save structured memories for future sessions.\nuser-invocable: true\n---\n\n# Learn\n\nReview the current conversation and save anything worth remembering using the structured memory system.\n\n## Memory types\n\n- **user** — Preferences, role, personal context, contacts\n- **feedback** — Corrections (\"don't do X, do Y instead\"), confirmed approaches\n- **project** — Ongoing work context, decisions, status\n- **reference** — Pointers to external systems, URLs, API details\n\n## Steps\n\n1. Review the conversation for new insights\n2. Check your memory index: \\`resource-read --path memory/MEMORY.md\\`\n3. For each new insight, use \\`save-memory\\` with a descriptive name, type, and content\n4. If updating an existing memory, read it first with \\`resource-read --path memory/<name>.md\\`, then save with merged content\n\n## What NOT to capture\n\n- Things obvious from reading the code\n- Standard language/framework behavior\n- Temporary debugging notes\n- Anything already in AGENTS.md or other skills\n\nKeep one memory per logical topic. Descriptions should be concise — the index is loaded every conversation.\n`;\n\nconst DEFAULT_SKILL_LEARN_SHARED_MD = `---\nname: learn-shared\ndescription: >-\n Update the shared LEARNINGS.md with team-wide preferences, corrections, and\n patterns from this session.\nuser-invocable: true\n---\n\n# Learn (Shared)\n\nReview the current conversation and update the shared \\`LEARNINGS.md\\` resource with anything the whole team should know.\n\n## What to capture\n\n- **Team conventions** — agreed-upon approaches, code style decisions\n- **Technical learnings** — API quirks, library gotchas, surprising behavior\n- **Architectural decisions** — why something is done a certain way\n- **Corrections** — mistakes that any team member's agent should avoid\n\n## What NOT to capture\n\n- Personal preferences (use \\`/learn\\` for those)\n- Things obvious from reading the code\n- Standard language/framework behavior\n\n## Steps\n\n1. Read shared learnings: \\`pnpm action resource-read --path LEARNINGS.md --scope shared\\`\n2. Review the conversation for team-relevant insights\n3. Merge new learnings with existing ones — don't duplicate, refine existing entries\n4. Write back: \\`pnpm action resource-write --path LEARNINGS.md --scope shared --content \"...\"\\`\n\nKeep entries concise — one line per learning, grouped by category (Conventions, Technical, Patterns).\n`;\n\nconst DEFAULT_AGENTS_SHARED_MD = `# Agent Instructions\n\nThis file customizes how the AI agent behaves in this app. Edit it to add your own instructions, preferences, and context.\n\nWorkspace-level resources managed from Dispatch are inherited before this file.\nUse this shared app/organization file to override or narrow those defaults for\nthis app or team.\n\n## What to put here\n\n- **Preferences** — Tone, style, verbosity, response format\n- **Context** — Domain knowledge, terminology, team conventions\n- **Rules** — Things the agent should always/never do\n- **Skills** — Reference skill files for specialized tasks (create them in the \\`skills/\\` folder)\n\n## Skills\n\nYou can create skill files to give the agent specialized knowledge for specific tasks. Create resources under \\`skills/<name>/SKILL.md\\` (e.g., \\`skills/data-analysis/SKILL.md\\`, \\`skills/code-review/SKILL.md\\`) and reference them here:\n\n| Skill | Path | Description |\n|-------|------|-------------|\n| *(add your skills here)* | \\`skills/example/SKILL.md\\` | What this skill teaches the agent |\n\nThe agent will read the relevant skill file when performing that type of task.\n\n## Global instructions\n\nPut always-on guardrails in this shared \\`AGENTS.md\\`. For separate policy files that should also apply every turn, create shared resources under \\`instructions/<name>.md\\`. These are loaded automatically with this file.\n\n## Shared reference resources\n\nPut company, brand, positioning, persona, product, or messaging context in shared resources under paths like \\`context/core-positioning.md\\` or \\`context/brand-guidelines.md\\`. The agent sees an index of shared reference resources and reads the relevant files when a task may depend on them.\n\n## Workspace files\n\nWorkspace resources are for files users intentionally add, edit, or manage. Agents may create hidden \\`agent_scratch\\` resources for temporary working notes, scripts, or intermediate results; only promote those files into workspace visibility when a user explicitly asks to keep them.\n\n## Example\n\n\\`\\`\\`markdown\n## Tone\nBe concise. Lead with the answer. Skip filler.\n\n## Code style\n- Use TypeScript, never JavaScript\n- Prefer named exports\n- Use early returns\n\n## Domain context\nWe sell B2B SaaS. Our customers are enterprise engineering teams.\n\\`\\`\\`\n`;\n\nconst DEFAULT_AGENTS_PERSONAL_MD = `# My Agent Instructions\n\nPersonal agent instructions — only visible to you. Use this for your own contacts, preferences, and context.\n\n## Contacts\n\nAdd people you frequently interact with so the agent can resolve names like \"email my wife\" or \"message John\":\n\n| Name | Email | Notes |\n|------|-------|-------|\n| *(add your contacts here)* | | |\n\n## Preferences\n\n## Context\n\n## Workspace files\n\nFiles you create here are user-facing. Temporary agent working files should stay hidden as \\`agent_scratch\\` unless you ask the agent to keep them.\n`;\n\nasync function migrateDefaultResourcePath({\n client,\n owner,\n fromPath,\n toPath,\n defaultContent,\n}: {\n client: DbExec;\n owner: string;\n fromPath: string;\n toPath: string;\n defaultContent: string;\n}): Promise<void> {\n try {\n const existing = await client.execute({\n sql: `SELECT id, content FROM resources WHERE owner = ? AND path = ?`,\n args: [owner, fromPath],\n });\n const row = existing.rows?.[0] as\n | { id: string; content: string }\n | undefined;\n if (!row || row.content !== defaultContent) return;\n\n const destination = await client.execute({\n sql: `SELECT id FROM resources WHERE owner = ? AND path = ?`,\n args: [owner, toPath],\n });\n if ((destination.rows?.length ?? 0) > 0) return;\n\n await client.execute({\n sql: `UPDATE resources SET path = ?, updated_at = ? WHERE id = ?`,\n args: [toPath, Date.now(), row.id],\n });\n } catch {\n // Best-effort compatibility migration; seeding below still works if it fails.\n }\n}\n\nfunction isDuplicateColumnError(err: unknown): boolean {\n const code = (err as { code?: string })?.code;\n const message = String((err as { message?: unknown })?.message ?? err)\n .toLowerCase()\n .trim();\n return (\n code === \"42701\" ||\n message.includes(\"duplicate column\") ||\n message.includes(\"already exists\")\n );\n}\n\nasync function ensureResourceColumn(\n client: DbExec,\n definition: string,\n): Promise<void> {\n try {\n await retryOnDdlRace(() =>\n client.execute(`ALTER TABLE resources ADD COLUMN ${definition}`),\n );\n } catch (err) {\n if (!isDuplicateColumnError(err)) throw err;\n }\n}\n\nfunction normalizeCreatedBy(value: unknown): ResourceCreatedBy {\n return value === \"agent\" || value === \"system\" || value === \"user\"\n ? value\n : \"user\";\n}\n\nfunction normalizeVisibility(value: unknown): ResourceVisibility {\n return value === \"agent_scratch\" ? \"agent_scratch\" : \"workspace\";\n}\n\nfunction nullableString(value: unknown): string | null {\n return typeof value === \"string\" && value.length > 0 ? value : null;\n}\n\nfunction nullableNumber(value: unknown): number | null {\n if (value === null || value === undefined) return null;\n const parsed = Number(value);\n return Number.isFinite(parsed) ? parsed : null;\n}\n\nfunction hasOption<K extends keyof ResourceWriteOptions>(\n options: ResourceWriteOptions | undefined,\n key: K,\n): boolean {\n return (\n Object.prototype.hasOwnProperty.call(options ?? {}, key) &&\n options?.[key] !== undefined\n );\n}\n\nfunction serializeMetadata(\n value: ResourceWriteOptions[\"metadata\"] | undefined,\n): string | null | undefined {\n if (value === undefined) return undefined;\n if (value === null) return null;\n return typeof value === \"string\" ? value : JSON.stringify(value);\n}\n\nfunction scratchFilterSql(options?: ResourceListOptions): string {\n return options?.includeAgentScratch === true\n ? \"\"\n : \" AND (visibility IS NULL OR visibility != 'agent_scratch')\";\n}\n\nfunction normalizeWorkspaceAppId(value: unknown): string | null {\n if (typeof value !== \"string\") return null;\n const trimmed = value.trim();\n if (!trimmed) return null;\n const candidate = trimmed.replace(/^\\/+/, \"\").split(\"/\")[0] ?? \"\";\n if (!/^[a-z0-9][a-z0-9-]{0,127}$/.test(candidate)) return null;\n return candidate;\n}\n\nfunction workspaceAppIdFromBasePath(value: unknown): string | null {\n if (typeof value !== \"string\") return null;\n return normalizeWorkspaceAppId(value);\n}\n\nfunction currentWorkspaceAppId(explicit?: string | null): string | null {\n return (\n normalizeWorkspaceAppId(explicit) ??\n normalizeWorkspaceAppId(process.env.AGENT_NATIVE_WORKSPACE_APP_ID) ??\n normalizeWorkspaceAppId(process.env.APP_NAME) ??\n normalizeWorkspaceAppId(process.env.AGENT_APP) ??\n workspaceAppIdFromBasePath(process.env.APP_BASE_PATH) ??\n workspaceAppIdFromBasePath(process.env.VITE_APP_BASE_PATH)\n );\n}\n\nfunction requestScopedResourceIdentity(options?: ResourceResolutionOptions): {\n userEmail: string | null;\n orgId: string | null;\n} {\n const userEmail = options?.userEmail ?? getRequestUserEmail() ?? null;\n const orgId = options?.orgId ?? getRequestOrgId() ?? null;\n return { userEmail, orgId };\n}\n\nfunction workspaceResourceMimeType(path: string): string {\n return path.endsWith(\".json\") ? \"application/json\" : \"text/markdown\";\n}\n\nfunction syntheticWorkspaceResourceId(resourceId: string): string {\n return `${DISPATCH_WORKSPACE_RESOURCE_ID_PREFIX}${resourceId}`;\n}\n\nfunction physicalWorkspaceResourceId(id: string): string | null {\n return id.startsWith(DISPATCH_WORKSPACE_RESOURCE_ID_PREFIX)\n ? id.slice(DISPATCH_WORKSPACE_RESOURCE_ID_PREFIX.length)\n : null;\n}\n\nfunction rowToGrantedWorkspaceResource(row: any): Resource {\n const content = String(row.content ?? \"\");\n const path = String(row.path ?? \"\");\n return {\n id: syntheticWorkspaceResourceId(String(row.id)),\n path,\n owner: WORKSPACE_OWNER,\n content,\n mimeType: workspaceResourceMimeType(path),\n size: Buffer.byteLength(content, \"utf8\"),\n createdAt: Number(row.created_at ?? Date.now()),\n updatedAt: Number(row.updated_at ?? Date.now()),\n createdBy: \"system\",\n visibility: \"workspace\",\n threadId: null,\n runId: null,\n expiresAt: null,\n metadata: JSON.stringify({\n source: DISPATCH_WORKSPACE_RESOURCE_METADATA_SOURCE,\n resourceId: String(row.id),\n grantId: row.grant_id ? String(row.grant_id) : null,\n kind: row.kind ?? null,\n name: row.name ?? null,\n description: row.description ?? null,\n scope: \"selected\",\n appId: row.app_id ?? null,\n updatedAt: Number(row.updated_at ?? Date.now()),\n }),\n };\n}\n\nfunction mergeResourceMetas(\n primary: ResourceMeta[],\n inherited: ResourceMeta[],\n): ResourceMeta[] {\n const seen = new Set(primary.map((resource) => resource.path));\n const merged = [...primary];\n for (const resource of inherited) {\n if (seen.has(resource.path)) continue;\n seen.add(resource.path);\n merged.push(resource);\n }\n return merged;\n}\n\nasync function selectGrantedWorkspaceResourceRows(input: {\n resourceId?: string;\n path?: string;\n pathPrefix?: string;\n workspaceAppId?: string | null;\n userEmail?: string | null;\n orgId?: string | null;\n}): Promise<any[]> {\n const appId = currentWorkspaceAppId(input.workspaceAppId);\n const { userEmail, orgId } = requestScopedResourceIdentity(input);\n if (!appId || (!userEmail && !orgId)) return [];\n\n const conditions = [\"wr.scope = ?\", \"wg.status = ?\", \"wg.app_id = ?\"];\n const args: unknown[] = [\"selected\", \"active\", appId];\n\n if (input.resourceId) {\n conditions.push(\"wr.id = ?\");\n args.push(input.resourceId);\n }\n if (input.path) {\n conditions.push(\"wr.path = ?\");\n args.push(input.path);\n }\n if (input.pathPrefix) {\n conditions.push(\"wr.path LIKE ?\");\n args.push(`${input.pathPrefix}%`);\n }\n\n if (orgId) {\n conditions.push(\"wr.org_id = ?\", \"wg.org_id = ?\");\n args.push(orgId, orgId);\n } else if (userEmail) {\n conditions.push(\n \"wr.owner_email = ?\",\n \"wr.org_id IS NULL\",\n \"wg.owner_email = ?\",\n \"wg.org_id IS NULL\",\n );\n args.push(userEmail, userEmail);\n }\n\n const client = getDbExec();\n const { rows } = await client.execute({\n sql: `\n SELECT\n wr.id,\n wr.kind,\n wr.name,\n wr.description,\n wr.path,\n wr.content,\n wr.created_at,\n wr.updated_at,\n wg.id AS grant_id,\n wg.app_id AS app_id\n FROM workspace_resources wr\n INNER JOIN workspace_resource_grants wg ON wg.resource_id = wr.id\n WHERE ${conditions.join(\" AND \")}\n ORDER BY wr.updated_at DESC\n `,\n args,\n });\n return rows;\n}\n\nasync function grantedWorkspaceResources(input: {\n pathPrefix?: string;\n workspaceAppId?: string | null;\n userEmail?: string | null;\n orgId?: string | null;\n}): Promise<Resource[]> {\n try {\n const rows = await selectGrantedWorkspaceResourceRows(input);\n return rows.map(rowToGrantedWorkspaceResource);\n } catch {\n // Dispatch workspace-resource tables are optional for standalone apps.\n return [];\n }\n}\n\nasync function grantedWorkspaceResourceById(\n id: string,\n options?: ResourceResolutionOptions,\n): Promise<Resource | null> {\n const resourceId = physicalWorkspaceResourceId(id);\n if (!resourceId) return null;\n try {\n const rows = await selectGrantedWorkspaceResourceRows({\n resourceId,\n workspaceAppId: options?.workspaceAppId,\n userEmail: options?.userEmail,\n orgId: options?.orgId,\n });\n return rows[0] ? rowToGrantedWorkspaceResource(rows[0]) : null;\n } catch {\n return null;\n }\n}\n\nasync function grantedWorkspaceResourceByPath(\n path: string,\n options?: ResourceResolutionOptions,\n): Promise<Resource | null> {\n try {\n const rows = await selectGrantedWorkspaceResourceRows({\n path,\n workspaceAppId: options?.workspaceAppId,\n userEmail: options?.userEmail,\n orgId: options?.orgId,\n });\n return rows[0] ? rowToGrantedWorkspaceResource(rows[0]) : null;\n } catch {\n return null;\n }\n}\n\nasync function cleanupExpiredAgentScratchResources(\n client: DbExec,\n): Promise<void> {\n const now = Date.now();\n if (now - _lastScratchCleanupAt < SCRATCH_CLEANUP_INTERVAL_MS) return;\n _lastScratchCleanupAt = now;\n await client.execute({\n sql: `DELETE FROM resources WHERE visibility = ? AND expires_at IS NOT NULL AND expires_at <= ?`,\n args: [\"agent_scratch\", now],\n });\n}\n\nasync function ensureTable(): Promise<void> {\n if (!_initPromise) {\n _initPromise = _doEnsureTable().catch((err) => {\n // Don't cache the rejection — let the next caller retry a fresh init.\n _initPromise = undefined;\n throw err;\n });\n }\n return _initPromise;\n}\n\nasync function _doEnsureTable(): Promise<void> {\n const client = getDbExec();\n await retryOnDdlRace(() =>\n client.execute(`\n CREATE TABLE IF NOT EXISTS resources (\n id TEXT PRIMARY KEY,\n path TEXT NOT NULL,\n owner TEXT NOT NULL,\n content TEXT NOT NULL DEFAULT '',\n mime_type TEXT NOT NULL DEFAULT 'text/markdown',\n size ${intType()} NOT NULL DEFAULT 0,\n created_at ${intType()} NOT NULL,\n updated_at ${intType()} NOT NULL,\n created_by TEXT NOT NULL DEFAULT 'user',\n visibility TEXT NOT NULL DEFAULT 'workspace',\n thread_id TEXT,\n run_id TEXT,\n expires_at ${intType()},\n metadata TEXT,\n UNIQUE(path, owner)\n )\n `),\n );\n\n await ensureResourceColumn(client, \"created_by TEXT NOT NULL DEFAULT 'user'\");\n await ensureResourceColumn(\n client,\n \"visibility TEXT NOT NULL DEFAULT 'workspace'\",\n );\n await ensureResourceColumn(client, \"thread_id TEXT\");\n await ensureResourceColumn(client, \"run_id TEXT\");\n await ensureResourceColumn(client, `expires_at ${intType()}`);\n await ensureResourceColumn(client, \"metadata TEXT\");\n\n // Seed default shared resources if they don't exist (INSERT OR IGNORE to avoid race conditions)\n const now = Date.now();\n const seedSql = isPostgres()\n ? `INSERT INTO resources (id, path, owner, content, mime_type, size, created_at, updated_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?) ON CONFLICT (path, owner) DO NOTHING`\n : `INSERT OR IGNORE INTO resources (id, path, owner, content, mime_type, size, created_at, updated_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?)`;\n\n // AGENTS.md — shared agent instructions\n const agentsSize = Buffer.byteLength(DEFAULT_AGENTS_SHARED_MD, \"utf8\");\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"AGENTS.md\",\n SHARED_OWNER,\n DEFAULT_AGENTS_SHARED_MD,\n \"text/markdown\",\n agentsSize,\n now,\n now,\n ],\n });\n\n // LEARNINGS.md — shared learnings (preferences, corrections, patterns)\n const learningsSize = Buffer.byteLength(DEFAULT_LEARNINGS_SHARED_MD, \"utf8\");\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"LEARNINGS.md\",\n SHARED_OWNER,\n DEFAULT_LEARNINGS_SHARED_MD,\n \"text/markdown\",\n learningsSize,\n now,\n now,\n ],\n });\n\n await migrateDefaultResourcePath({\n client,\n owner: SHARED_OWNER,\n fromPath: \"skills/learn-shared.md\",\n toPath: \"skills/learn-shared/SKILL.md\",\n defaultContent: DEFAULT_SKILL_LEARN_SHARED_MD,\n });\n\n // skills/learn-shared/SKILL.md — shared skill for updating shared LEARNINGS.md\n const learnSharedSize = Buffer.byteLength(\n DEFAULT_SKILL_LEARN_SHARED_MD,\n \"utf8\",\n );\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"skills/learn-shared/SKILL.md\",\n SHARED_OWNER,\n DEFAULT_SKILL_LEARN_SHARED_MD,\n \"text/markdown\",\n learnSharedSize,\n now,\n now,\n ],\n });\n\n // Seed built-in agents as shared resources under remote-agents/. ALWAYS\n // use the production URL here, never the env-resolved devUrl. The seed\n // runs once per DB (ON CONFLICT DO NOTHING), so a localhost URL written\n // during a dev run sticks forever — including when that DB is later used\n // by a prod deploy and the override wins over the built-in's prod URL.\n // (Verified problem: `dispatch.agent-native.com` had every remote-agents\n // entry pointing at localhost from an early-seed run, breaking call-agent\n // outbound from Lambda for ~12h before this was caught.)\n try {\n const { getBuiltinAgents, BUILTIN_AGENTS_FOR_SEEDING } =\n await import(\"../server/agent-discovery.js\");\n void getBuiltinAgents; // referenced to keep type-only import alive\n const builtins = BUILTIN_AGENTS_FOR_SEEDING;\n for (const agent of builtins) {\n const agentJson = JSON.stringify(\n {\n id: agent.id,\n name: agent.name,\n description: agent.description,\n url: agent.url, // always prod\n color: agent.color,\n },\n null,\n 2,\n );\n const agentSize = Buffer.byteLength(agentJson, \"utf8\");\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n `remote-agents/${agent.id}.json`,\n SHARED_OWNER,\n agentJson,\n \"application/json\",\n agentSize,\n now,\n now,\n ],\n });\n }\n } catch {\n // Agent discovery not available — skip seeding\n }\n\n // One-time migration: rename legacy agents/*.json (A2A manifests) to\n // remote-agents/*.json so they live in their own folder, separate from\n // custom agents (agents/*.md).\n try {\n const legacy = await client.execute({\n sql: `SELECT id, path FROM resources WHERE path LIKE ? AND path LIKE ?`,\n args: [\"agents/%\", \"%.json\"],\n });\n const rows = (legacy.rows ?? []) as Array<{ id: string; path: string }>;\n for (const row of rows) {\n const newPath = row.path.replace(/^agents\\//, \"remote-agents/\");\n try {\n await client.execute({\n sql: `UPDATE resources SET path = ?, updated_at = ? WHERE id = ?`,\n args: [newPath, Date.now(), row.id],\n });\n } catch {\n // Skip if destination path already exists (unique constraint) —\n // we'll leave the old row in place; readers accept both paths and\n // canonical remote-agents/ entries win when both exist.\n }\n }\n } catch {\n // Migration best-effort\n }\n}\n\nconst _personalSeeded = new Set<string>();\n\n/**\n * Seed personal AGENTS.md and LEARNINGS.md for a user if they don't exist.\n * Called when listing resources or from the agent chat plugin.\n */\nexport async function ensurePersonalDefaults(owner: string): Promise<void> {\n if (\n owner === SHARED_OWNER ||\n owner === WORKSPACE_OWNER ||\n _personalSeeded.has(owner)\n ) {\n return;\n }\n _personalSeeded.add(owner);\n await ensureTable();\n\n const client = getDbExec();\n const now = Date.now();\n const seedSql = isPostgres()\n ? `INSERT INTO resources (id, path, owner, content, mime_type, size, created_at, updated_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?) ON CONFLICT (path, owner) DO NOTHING`\n : `INSERT OR IGNORE INTO resources (id, path, owner, content, mime_type, size, created_at, updated_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?)`;\n\n const agentsSize = Buffer.byteLength(DEFAULT_AGENTS_PERSONAL_MD, \"utf8\");\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"AGENTS.md\",\n owner,\n DEFAULT_AGENTS_PERSONAL_MD,\n \"text/markdown\",\n agentsSize,\n now,\n now,\n ],\n });\n\n const learningsSize = Buffer.byteLength(\n DEFAULT_LEARNINGS_PERSONAL_MD,\n \"utf8\",\n );\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"LEARNINGS.md\",\n owner,\n DEFAULT_LEARNINGS_PERSONAL_MD,\n \"text/markdown\",\n learningsSize,\n now,\n now,\n ],\n });\n\n // memory/MEMORY.md — personal structured memory index\n const memoryIndexContent = \"# Memory Index\\n\";\n const memoryIndexSize = Buffer.byteLength(memoryIndexContent, \"utf8\");\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"memory/MEMORY.md\",\n owner,\n memoryIndexContent,\n \"text/markdown\",\n memoryIndexSize,\n now,\n now,\n ],\n });\n\n await migrateDefaultResourcePath({\n client,\n owner,\n fromPath: \"skills/learn.md\",\n toPath: \"skills/learn/SKILL.md\",\n defaultContent: DEFAULT_SKILL_LEARN_MD,\n });\n\n // skills/learn/SKILL.md — personal skill for updating memory\n const learnSize = Buffer.byteLength(DEFAULT_SKILL_LEARN_MD, \"utf8\");\n await client.execute({\n sql: seedSql,\n args: [\n crypto.randomUUID(),\n \"skills/learn/SKILL.md\",\n owner,\n DEFAULT_SKILL_LEARN_MD,\n \"text/markdown\",\n learnSize,\n now,\n now,\n ],\n });\n}\n\nfunction rowToResource(row: any): Resource {\n return {\n id: row.id as string,\n path: row.path as string,\n owner: row.owner as string,\n content: row.content as string,\n mimeType: row.mime_type as string,\n size: Number(row.size),\n createdAt: Number(row.created_at),\n updatedAt: Number(row.updated_at),\n createdBy: normalizeCreatedBy(row.created_by),\n visibility: normalizeVisibility(row.visibility),\n threadId: nullableString(row.thread_id),\n runId: nullableString(row.run_id),\n expiresAt: nullableNumber(row.expires_at),\n metadata: nullableString(row.metadata),\n };\n}\n\nfunction rowToMeta(row: any): ResourceMeta {\n return {\n id: row.id as string,\n path: row.path as string,\n owner: row.owner as string,\n mimeType: row.mime_type as string,\n size: Number(row.size),\n createdAt: Number(row.created_at),\n updatedAt: Number(row.updated_at),\n createdBy: normalizeCreatedBy(row.created_by),\n visibility: normalizeVisibility(row.visibility),\n threadId: nullableString(row.thread_id),\n runId: nullableString(row.run_id),\n expiresAt: nullableNumber(row.expires_at),\n metadata: nullableString(row.metadata),\n };\n}\n\nfunction resourceToMeta(resource: Resource): ResourceMeta {\n const { content: _content, ...meta } = resource;\n return meta;\n}\n\nexport async function resourceGet(\n id: string,\n options?: ResourceResolutionOptions,\n): Promise<Resource | null> {\n await ensureTable();\n const client = getDbExec();\n await cleanupExpiredAgentScratchResources(client);\n const { rows } = await client.execute({\n sql: `SELECT * FROM resources WHERE id = ?`,\n args: [id],\n });\n if (rows.length === 0) return grantedWorkspaceResourceById(id, options);\n return rowToResource(rows[0]);\n}\n\nexport async function resourceGetByPath(\n owner: string,\n path: string,\n options?: ResourceResolutionOptions,\n): Promise<Resource | null> {\n await ensureTable();\n const client = getDbExec();\n await cleanupExpiredAgentScratchResources(client);\n const { rows } = await client.execute({\n sql: `SELECT * FROM resources WHERE owner = ? AND path = ?`,\n args: [owner, path],\n });\n if (rows.length === 0 && owner === WORKSPACE_OWNER) {\n return grantedWorkspaceResourceByPath(path, options);\n }\n if (rows.length === 0) return null;\n return rowToResource(rows[0]);\n}\n\nexport async function resourcePut(\n owner: string,\n path: string,\n content: string,\n mimeType?: string,\n options?: ResourceWriteOptions,\n): Promise<Resource> {\n await ensureTable();\n const client = getDbExec();\n const now = Date.now();\n const size = Buffer.byteLength(content, \"utf8\");\n const mime = mimeType || \"text/markdown\";\n\n // Check for existing resource to preserve ID on upsert\n const { rows: existing } = await client.execute({\n sql: `SELECT id, created_at, created_by, visibility, thread_id, run_id, expires_at, metadata FROM resources WHERE owner = ? AND path = ?`,\n args: [owner, path],\n });\n const existingRow = existing[0] as\n | {\n id: string;\n created_at: number;\n created_by?: string | null;\n visibility?: string | null;\n thread_id?: string | null;\n run_id?: string | null;\n expires_at?: number | null;\n metadata?: string | null;\n }\n | undefined;\n\n const id =\n existing.length > 0 ? (existingRow?.id as string) : crypto.randomUUID();\n const createdAt = existingRow ? Number(existingRow.created_at) : now;\n const createdBy = normalizeCreatedBy(\n hasOption(options, \"createdBy\")\n ? options?.createdBy\n : existingRow?.created_by,\n );\n const visibility = normalizeVisibility(\n hasOption(options, \"visibility\")\n ? options?.visibility\n : existingRow?.visibility,\n );\n const threadId = hasOption(options, \"threadId\")\n ? (options?.threadId ?? null)\n : nullableString(existingRow?.thread_id);\n const runId = hasOption(options, \"runId\")\n ? (options?.runId ?? null)\n : nullableString(existingRow?.run_id);\n let expiresAt = hasOption(options, \"expiresAt\")\n ? (options?.expiresAt ?? null)\n : nullableNumber(existingRow?.expires_at);\n if (visibility === \"agent_scratch\" && expiresAt === null) {\n expiresAt = now + AGENT_SCRATCH_TTL_MS;\n }\n if (visibility === \"workspace\" && !hasOption(options, \"expiresAt\")) {\n expiresAt = null;\n }\n const serializedMetadata = serializeMetadata(options?.metadata);\n const metadata =\n serializedMetadata !== undefined\n ? serializedMetadata\n : nullableString(existingRow?.metadata);\n\n await client.execute({\n sql: isPostgres()\n ? `INSERT INTO resources (id, path, owner, content, mime_type, size, created_at, updated_at, created_by, visibility, thread_id, run_id, expires_at, metadata) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?) ON CONFLICT (path, owner) DO UPDATE SET id=EXCLUDED.id, content=EXCLUDED.content, mime_type=EXCLUDED.mime_type, size=EXCLUDED.size, updated_at=EXCLUDED.updated_at, created_by=EXCLUDED.created_by, visibility=EXCLUDED.visibility, thread_id=EXCLUDED.thread_id, run_id=EXCLUDED.run_id, expires_at=EXCLUDED.expires_at, metadata=EXCLUDED.metadata`\n : `INSERT OR REPLACE INTO resources (id, path, owner, content, mime_type, size, created_at, updated_at, created_by, visibility, thread_id, run_id, expires_at, metadata) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,\n args: [\n id,\n path,\n owner,\n content,\n mime,\n size,\n createdAt,\n now,\n createdBy,\n visibility,\n threadId,\n runId,\n expiresAt,\n metadata,\n ],\n });\n\n emitResourceChange(id, path, owner, options?.requestSource);\n\n return {\n id,\n path,\n owner,\n content,\n mimeType: mime,\n size,\n createdAt,\n updatedAt: now,\n createdBy,\n visibility,\n threadId,\n runId,\n expiresAt,\n metadata,\n };\n}\n\nexport async function resourceDelete(id: string): Promise<boolean> {\n await ensureTable();\n const client = getDbExec();\n\n // Get resource info for emitter before deleting\n const { rows } = await client.execute({\n sql: `SELECT path, owner FROM resources WHERE id = ?`,\n args: [id],\n });\n if (rows.length === 0) return false;\n\n const result = await client.execute({\n sql: `DELETE FROM resources WHERE id = ?`,\n args: [id],\n });\n const deleted = result.rowsAffected > 0;\n if (deleted) {\n emitResourceDelete(id, rows[0].path as string, rows[0].owner as string);\n }\n return deleted;\n}\n\nexport async function resourceDeleteByPath(\n owner: string,\n path: string,\n): Promise<boolean> {\n await ensureTable();\n const client = getDbExec();\n\n // Get resource info for emitter before deleting\n const { rows } = await client.execute({\n sql: `SELECT id FROM resources WHERE owner = ? AND path = ?`,\n args: [owner, path],\n });\n if (rows.length === 0) return false;\n\n const result = await client.execute({\n sql: `DELETE FROM resources WHERE owner = ? AND path = ?`,\n args: [owner, path],\n });\n const deleted = result.rowsAffected > 0;\n if (deleted) {\n emitResourceDelete(rows[0].id as string, path, owner);\n }\n return deleted;\n}\n\nexport async function resourceList(\n owner: string,\n pathPrefix?: string,\n options?: ResourceListOptions,\n): Promise<ResourceMeta[]> {\n await ensureTable();\n const client = getDbExec();\n await cleanupExpiredAgentScratchResources(client);\n const visibilitySql = scratchFilterSql(options);\n\n if (pathPrefix) {\n const { rows } = await client.execute({\n sql: `SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ? AND path LIKE ?${visibilitySql}`,\n args: [owner, pathPrefix + \"%\"],\n });\n const resources = rows.map(rowToMeta);\n if (owner !== WORKSPACE_OWNER) return resources;\n const granted = await grantedWorkspaceResources({\n pathPrefix,\n workspaceAppId: options?.workspaceAppId,\n userEmail: options?.userEmail,\n orgId: options?.orgId,\n });\n return mergeResourceMetas(resources, granted.map(resourceToMeta));\n }\n\n const { rows } = await client.execute({\n sql: `SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ?${visibilitySql}`,\n args: [owner],\n });\n const resources = rows.map(rowToMeta);\n if (owner !== WORKSPACE_OWNER) return resources;\n const granted = await grantedWorkspaceResources({\n workspaceAppId: options?.workspaceAppId,\n userEmail: options?.userEmail,\n orgId: options?.orgId,\n });\n return mergeResourceMetas(resources, granted.map(resourceToMeta));\n}\n\nexport async function resourceListAccessible(\n userEmail: string,\n pathPrefix?: string,\n options?: ResourceListOptions,\n): Promise<ResourceMeta[]> {\n await ensureTable();\n const client = getDbExec();\n await cleanupExpiredAgentScratchResources(client);\n const visibilitySql = scratchFilterSql(options);\n\n if (pathPrefix) {\n const { rows } = await client.execute({\n sql: `SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ? AND path LIKE ?${visibilitySql}\n UNION\n SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ? AND path LIKE ?${visibilitySql}\n UNION\n SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ? AND path LIKE ?${visibilitySql}`,\n args: [\n userEmail,\n pathPrefix + \"%\",\n SHARED_OWNER,\n pathPrefix + \"%\",\n WORKSPACE_OWNER,\n pathPrefix + \"%\",\n ],\n });\n const resources = rows.map(rowToMeta);\n const granted = await grantedWorkspaceResources({\n pathPrefix,\n workspaceAppId: options?.workspaceAppId,\n userEmail,\n orgId: options?.orgId,\n });\n return mergeResourceMetas(resources, granted.map(resourceToMeta));\n }\n\n const { rows } = await client.execute({\n sql: `SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ?${visibilitySql}\n UNION\n SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ?${visibilitySql}\n UNION\n SELECT ${RESOURCE_META_SELECT} FROM resources WHERE owner = ?${visibilitySql}`,\n args: [userEmail, SHARED_OWNER, WORKSPACE_OWNER],\n });\n const resources = rows.map(rowToMeta);\n const granted = await grantedWorkspaceResources({\n workspaceAppId: options?.workspaceAppId,\n userEmail,\n orgId: options?.orgId,\n });\n return mergeResourceMetas(resources, granted.map(resourceToMeta));\n}\n\nexport async function resourceEffectiveContext(\n userEmail: string,\n path: string,\n options?: ResourceResolutionOptions,\n): Promise<EffectiveResourceContext> {\n await ensureTable();\n\n const workspace = await resourceGetByPath(WORKSPACE_OWNER, path, {\n ...options,\n userEmail,\n });\n const shared = await resourceGetByPath(SHARED_OWNER, path);\n const personal = await resourceGetByPath(userEmail, path);\n const effective = personal ?? shared ?? workspace ?? null;\n const effectiveScope: ResourceInheritanceScope | null = personal\n ? \"personal\"\n : shared\n ? \"shared\"\n : workspace\n ? \"workspace\"\n : null;\n\n const layerDefs: Array<{\n scope: ResourceInheritanceScope;\n label: string;\n owner: string;\n resource: Resource | null;\n canWrite: boolean;\n }> = [\n {\n scope: \"workspace\",\n label: \"Workspace default\",\n owner: WORKSPACE_OWNER,\n resource: workspace,\n canWrite: false,\n },\n {\n scope: \"shared\",\n label: \"Organization/app override\",\n owner: SHARED_OWNER,\n resource: shared,\n canWrite: true,\n },\n {\n scope: \"personal\",\n label: \"Personal override\",\n owner: userEmail,\n resource: personal,\n canWrite: true,\n },\n ];\n\n return {\n path,\n effectiveResource: effective ? resourceToMeta(effective) : null,\n effectiveScope,\n layers: layerDefs.map((layer) => ({\n scope: layer.scope,\n label: layer.label,\n owner: layer.owner,\n resource: layer.resource ? resourceToMeta(layer.resource) : null,\n exists: !!layer.resource,\n effective: !!layer.resource && layer.resource.id === effective?.id,\n overridden: !!layer.resource && layer.resource.id !== effective?.id,\n canWrite: layer.canWrite,\n })),\n };\n}\n\n/**\n * List all resources matching a path prefix across ALL owners.\n * Used by the recurring jobs scheduler to find all job resources.\n */\nexport async function resourceListAllOwners(\n pathPrefix: string,\n): Promise<Resource[]> {\n await ensureTable();\n const client = getDbExec();\n const { rows } = await client.execute({\n sql: `SELECT * FROM resources WHERE path LIKE ?`,\n args: [pathPrefix + \"%\"],\n });\n return rows.map(rowToResource);\n}\n\nexport async function resourceMove(\n id: string,\n newPath: string,\n): Promise<boolean> {\n await ensureTable();\n const client = getDbExec();\n const now = Date.now();\n\n // Get current resource info\n const { rows } = await client.execute({\n sql: `SELECT path, owner FROM resources WHERE id = ?`,\n args: [id],\n });\n if (rows.length === 0) return false;\n\n const result = await client.execute({\n sql: `UPDATE resources SET path = ?, updated_at = ? WHERE id = ?`,\n args: [newPath, now, id],\n });\n const moved = result.rowsAffected > 0;\n if (moved) {\n emitResourceChange(id, newPath, rows[0].owner as string);\n }\n return moved;\n}\n"]}
@@ -46,7 +46,7 @@ function formatDownstreamLlmCredentialFailure(agentName, value) {
46
46
  }
47
47
  export const tool = {
48
48
  description: "Call a DIFFERENT, separately-deployed agent app to ask a question or delegate a task. This is strictly for cross-app A2A communication — for example, asking the mail agent to send an email while you are the calendar agent. NEVER use this to call your own app or perform actions you can do with your own tools. Using call-agent on yourself will fail and waste time. " +
49
- 'For brand-consistent raster image generation, the first-party Images agent is available as agent="images"; use it when another app needs generated heroes, diagrams, product shots, thumbnails, or design imagery, unless the current app has its own image-generation action that already delegates there. ' +
49
+ 'For brand-consistent generated media, the first-party Assets agent is available as agent="assets"; use it when another app needs generated heroes, diagrams, product shots, thumbnails, videos, or design imagery, unless the current app has its own generation action that already delegates there. ' +
50
50
  "IMPORTANT — handling the response: " +
51
51
  "(a) If it contains a URL or ID, copy it VERBATIM into your reply. Do not 'correct' or pluralize the path (e.g. /deck/ → /decks/), normalize casing, or change the slug — any edit breaks the link. " +
52
52
  '(b) If it does NOT contain a URL/ID and the user asked for one, say so explicitly (e.g. "the agent created the deck/image but didn\'t return a link — open the app directly to view it"). NEVER invent a URL, slug, or path — guessing produces broken links that look real. ' +