experimental-agent 0.8.0-alpha.2 → 0.8.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.
- package/dist/chunk-5N2UOGXY.mjs +123 -0
- package/dist/chunk-HPBAZJLN.mjs +242 -0
- package/dist/{chunk-EH4L2CPW.mjs → chunk-HVZTAMAX.mjs} +2 -10
- package/dist/{client-DIanpEQ_.d.ts → client-BY6gceox.d.ts} +0 -6
- package/dist/{client-PuttJd6O.d.mts → client-BaItaOx5.d.mts} +0 -6
- package/dist/{framework-DH4Z1NLV.d.ts → framework-DSe3sdP_.d.ts} +5 -0
- package/dist/{framework-c9fvEy0o.d.mts → framework-VPUsYNMf.d.mts} +5 -0
- package/dist/framework-runtime.d.mts +3 -3
- package/dist/framework-runtime.d.ts +3 -3
- package/dist/framework-runtime.js +33 -15
- package/dist/framework-runtime.mjs +33 -7
- package/dist/framework.d.mts +4 -4
- package/dist/framework.d.ts +4 -4
- package/dist/framework.js +45 -2
- package/dist/framework.mjs +1 -1
- package/dist/index.d.mts +2 -2
- package/dist/index.d.ts +2 -2
- package/dist/index.js +2 -10
- package/dist/index.mjs +1 -1
- package/dist/next/agents.d.mts +1 -1
- package/dist/next/agents.d.ts +1 -1
- package/dist/next/agents.js +45 -2
- package/dist/next/agents.mjs +2 -2
- package/dist/next/loader.js +2 -2
- package/dist/next/loader.mjs +1 -1
- package/dist/next.js +5 -3
- package/dist/next.mjs +5 -3
- package/dist/react.d.mts +1 -1
- package/dist/react.d.ts +1 -1
- package/dist/{resolve-BZ26gcyj.d.ts → resolve-DCys_2es.d.ts} +17 -4
- package/dist/{resolve-Cma6YFgx.d.mts → resolve-YlI7Dugf.d.mts} +17 -4
- package/package.json +13 -13
- package/dist/chunk-DO4HKPHR.mjs +0 -199
- package/dist/chunk-LMYEJDMD.mjs +0 -123
package/dist/index.mjs
CHANGED
package/dist/next/agents.d.mts
CHANGED
package/dist/next/agents.d.ts
CHANGED
package/dist/next/agents.js
CHANGED
|
@@ -64,6 +64,20 @@ function inlineEntry(opts) {
|
|
|
64
64
|
});
|
|
65
65
|
parts.push(` import: () => import(${JSON.stringify(relativePath)})`);
|
|
66
66
|
}
|
|
67
|
+
if (opts.agent.tools.length > 0) {
|
|
68
|
+
const toolLines = opts.agent.tools.map((tool) => {
|
|
69
|
+
const rel = relativeImportPath({
|
|
70
|
+
from: opts.outputDir,
|
|
71
|
+
to: tool.importPath
|
|
72
|
+
});
|
|
73
|
+
return ` ${JSON.stringify(tool.name)}: () => import(${JSON.stringify(rel)})`;
|
|
74
|
+
});
|
|
75
|
+
parts.push(` imports: {
|
|
76
|
+
tools: {
|
|
77
|
+
${toolLines.join(",\n")}
|
|
78
|
+
}
|
|
79
|
+
}`);
|
|
80
|
+
}
|
|
67
81
|
return ` ${JSON.stringify(opts.agent.name)}: {
|
|
68
82
|
${parts.join(",\n")}
|
|
69
83
|
},`;
|
|
@@ -174,10 +188,39 @@ function getSystemPrompt(agentDir) {
|
|
|
174
188
|
}
|
|
175
189
|
return parts.length > 0 ? parts.join("\n\n") : void 0;
|
|
176
190
|
}
|
|
191
|
+
function getTools(agentDir) {
|
|
192
|
+
const toolsDir = path2.join(agentDir, "tools");
|
|
193
|
+
const entries = listDir(toolsDir);
|
|
194
|
+
const tools = [];
|
|
195
|
+
for (const entry of entries.sort()) {
|
|
196
|
+
const absolutePath = path2.join(toolsDir, entry);
|
|
197
|
+
if (isDirectory(absolutePath)) {
|
|
198
|
+
const indexFile = findIndexFile(absolutePath);
|
|
199
|
+
if (indexFile) {
|
|
200
|
+
tools.push({ name: entry, importPath: indexFile });
|
|
201
|
+
}
|
|
202
|
+
} else if (TS_EXT.test(entry)) {
|
|
203
|
+
const name = entry.replace(TS_EXT, "");
|
|
204
|
+
tools.push({ name, importPath: absolutePath });
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
return tools;
|
|
208
|
+
}
|
|
209
|
+
function findIndexFile(dir) {
|
|
210
|
+
const extensions = [".ts", ".js", ".mts", ".mjs"];
|
|
211
|
+
for (const ext of extensions) {
|
|
212
|
+
const candidate = path2.join(dir, `index${ext}`);
|
|
213
|
+
if (fileExists(candidate)) {
|
|
214
|
+
return candidate;
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
return null;
|
|
218
|
+
}
|
|
177
219
|
function scanAgent(agentDir) {
|
|
178
220
|
const { skills, tsSkillImportPaths } = getSkills(agentDir.absolutePath);
|
|
179
221
|
const systemPrompt = getSystemPrompt(agentDir.absolutePath);
|
|
180
|
-
|
|
222
|
+
const tools = getTools(agentDir.absolutePath);
|
|
223
|
+
return { ...agentDir, skills, systemPrompt, tsSkillImportPaths, tools };
|
|
181
224
|
}
|
|
182
225
|
function findAgentsRoot(cwd, userDefinedAgentsDir) {
|
|
183
226
|
if (userDefinedAgentsDir) {
|
|
@@ -361,4 +404,4 @@ function withAgents(config, agentsConfig = {}) {
|
|
|
361
404
|
0 && (module.exports = {
|
|
362
405
|
withAgents
|
|
363
406
|
});
|
|
364
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/framework-next/agents-plugin.ts", "../../src/framework/generate.ts", "../../src/framework/scan.ts", "../../src/framework/framework.ts", "../../src/framework-next/next.ts"],
  "sourcesContent": ["import { Framework } from \"../framework/framework\";\nimport { Next, type NextConfigInput } from \"./next\";\n\nexport type { NextConfigInput, WithAgentsConfig } from \"./next\";\n\n/**\n * Next.js config wrapper that discovers agents on the filesystem and\n * generates the route handler + registry files needed to serve them.\n *\n * Call this in `next.config.ts`:\n *\n * @example\n * ```ts\n * import { withAgents } from \"experimental-agent/next/agents\";\n *\n * export default withAgents({ reactStrictMode: true });\n * ```\n *\n * Debug logs:\n * ```ts\n * import { withAgents } from \"experimental-agent/next/agents\";\n *\n * export default withAgents({ reactStrictMode: true }, { debug: true });\n * ```\n */\nexport function withAgents(\n  config: NextConfigInput,\n  agentsConfig: Pick<\n    ConstructorParameters<typeof Framework>[0],\n    \"agentsDir\" | \"debug\"\n  > = {}\n): NextConfigInput {\n  const framework = new Framework(agentsConfig);\n  const next = new Next(framework);\n  next.writeFiles();\n\n  return config;\n}\n", "import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport type { ScannedAgent } from \"./scan\";\n\nconst TS_IMPORT_EXT = /\\.(ts|mts)$/;\nexport function generateRegistry(opts: {\n  agents: ScannedAgent[];\n  outputDir: string;\n}): string {\n  const entries = opts.agents.map((agent) =>\n    inlineEntry({ agent, outputDir: opts.outputDir })\n  );\n\n  return [\n    \"// Auto-generated by withAgents - do not edit\",\n    'import type { AgentRegistry } from \"experimental-agent/framework\";',\n    \"\",\n    \"export const agents = {\",\n    ...entries,\n    \"} satisfies AgentRegistry;\",\n    \"\",\n  ].join(\"\\n\");\n}\n\nfunction inlineEntry(opts: {\n  agent: ScannedAgent;\n  outputDir: string;\n}): string {\n  const config = buildConfig(opts.agent);\n  const configStr = JSON.stringify(config, null, 2)\n    .split(\"\\n\")\n    .map((line, i) => (i === 0 ? line : `      ${line}`))\n    .join(\"\\n\");\n\n  const parts = [`    config: ${configStr}`];\n\n  if (opts.agent.hasAgentConfig) {\n    const configPath = findAgentConfigPath(opts.agent.absolutePath);\n    const relativePath = relativeImportPath({\n      from: opts.outputDir,\n      to: configPath,\n    });\n    parts.push(`    import: () => import(${JSON.stringify(relativePath)})`);\n  }\n\n  return `  ${JSON.stringify(opts.agent.name)}: {\\n${parts.join(\",\\n\")}\\n  },`;\n}\n\nfunction buildConfig(agent: ScannedAgent): Record<string, unknown> {\n  const config: Record<string, unknown> = {};\n\n  if (agent.systemPrompt) {\n    config.system = agent.systemPrompt;\n  }\n\n  if (agent.skills.length > 0) {\n    config.skills = agent.skills;\n  }\n\n  return config;\n}\n\nfunction findAgentConfigPath(agentDir: string): string {\n  const extensions = [\".ts\", \".js\", \".mts\", \".mjs\"];\n  for (const ext of extensions) {\n    const candidate = path.join(agentDir, `agent${ext}`);\n    if (fs.existsSync(candidate)) {\n      return candidate;\n    }\n  }\n  return path.join(agentDir, \"agent\");\n}\n\nfunction relativeImportPath(opts: { from: string; to: string }): string {\n  let rel = path.relative(opts.from, opts.to).replace(/\\\\/g, \"/\");\n  rel = rel.replace(TS_IMPORT_EXT, \"\");\n  if (!rel.startsWith(\".\")) {\n    rel = `./${rel}`;\n  }\n  return rel;\n}\n\n", "import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport type { HostSkillInput, SkillInput } from \"../skills/types\";\n\nexport type AgentDir = {\n  name: string;\n  absolutePath: string;\n  hasAgentConfig: boolean;\n};\n\nexport type ScannedAgent = AgentDir & {\n  skills: SkillInput[];\n  systemPrompt: string | undefined;\n  tsSkillImportPaths: string[];\n};\n\nconst AGENT_CONFIG_FILES = [\"agent.ts\", \"agent.js\", \"agent.mts\", \"agent.mjs\"];\nconst MD_EXT = /\\.md$/;\nconst TS_EXT = /\\.(ts|js|mts|mjs)$/;\n\nexport function listDir(dir: string): string[] {\n  if (!fs.existsSync(dir)) {\n    return [];\n  }\n  return fs.readdirSync(dir);\n}\n\nexport function readFile(filePath: string): string {\n  return fs.readFileSync(filePath, \"utf-8\");\n}\n\nexport function fileExists(filePath: string): boolean {\n  return fs.existsSync(filePath);\n}\n\nexport function isDirectory(filePath: string): boolean {\n  return fs.existsSync(filePath) && fs.statSync(filePath).isDirectory();\n}\n\nexport function discoverAgentDirs(agentsRoot: string): AgentDir[] {\n  const entries = listDir(agentsRoot);\n  const dirs: AgentDir[] = [];\n\n  for (const entry of entries) {\n    const absolutePath = path.join(agentsRoot, entry);\n    if (!isDirectory(absolutePath)) {\n      continue;\n    }\n    if (entry.startsWith(\".\")) {\n      continue;\n    }\n\n    dirs.push({\n      name: entry,\n      absolutePath,\n      hasAgentConfig: hasAgentConfig(absolutePath),\n    });\n  }\n\n  return dirs;\n}\n\nexport function hasAgentConfig(agentDir: string): boolean {\n  return AGENT_CONFIG_FILES.some((f) => fileExists(path.join(agentDir, f)));\n}\n\nexport function getSkills(agentDir: string): {\n  skills: SkillInput[];\n  tsSkillImportPaths: string[];\n} {\n  const skillsDir = path.join(agentDir, \"skills\");\n  const entries = listDir(skillsDir);\n  const skills: SkillInput[] = [];\n  const tsSkillImportPaths: string[] = [];\n\n  for (const entry of entries.sort()) {\n    const absolutePath = path.join(skillsDir, entry);\n\n    if (MD_EXT.test(entry)) {\n      skills.push({\n        type: \"host\",\n        path: absolutePath,\n      } satisfies HostSkillInput);\n    } else if (TS_EXT.test(entry)) {\n      tsSkillImportPaths.push(absolutePath);\n    }\n  }\n\n  return { skills, tsSkillImportPaths };\n}\n\nexport function getSystemPrompt(agentDir: string): string | undefined {\n  const systemDir = path.join(agentDir, \"system\");\n  const entries = listDir(systemDir);\n  const mdFiles = entries.filter((e) => MD_EXT.test(e)).sort();\n\n  if (mdFiles.length === 0) {\n    return undefined;\n  }\n\n  const parts: string[] = [];\n  for (const file of mdFiles) {\n    const content = readFile(path.join(systemDir, file)).trim();\n    if (content) {\n      parts.push(content);\n    }\n  }\n\n  return parts.length > 0 ? parts.join(\"\\n\\n\") : undefined;\n}\n\nexport function scanAgent(agentDir: AgentDir): ScannedAgent {\n  const { skills, tsSkillImportPaths } = getSkills(agentDir.absolutePath);\n  const systemPrompt = getSystemPrompt(agentDir.absolutePath);\n\n  return { ...agentDir, skills, systemPrompt, tsSkillImportPaths };\n}\n\nexport function findAgentsRoot(\n  cwd: string,\n  userDefinedAgentsDir: string | undefined\n): string | null {\n  if (userDefinedAgentsDir) {\n    return path.resolve(cwd, userDefinedAgentsDir);\n  }\n  const candidates = [\n    path.join(cwd, \"src\", \"agents\"),\n    path.join(cwd, \"agents\"),\n  ];\n\n  for (const candidate of candidates) {\n    if (isDirectory(candidate)) {\n      return candidate;\n    }\n  }\n\n  return null;\n}\n", "import { generateRegistry } from \"./generate\";\nimport type { ScannedAgent } from \"./scan\";\nimport { discoverAgentDirs, findAgentsRoot, scanAgent } from \"./scan\";\n\n/**\n * Framework-agnostic core for filesystem-based agent discovery and\n * registry code generation. Adapters like {@link Next} receive a\n * `Framework` instance and use it to scan agents and produce registry\n * source code.\n */\nexport class Framework {\n  readonly cwd: string;\n  readonly agentsDir: string | undefined;\n  readonly log: (...args: unknown[]) => void;\n\n  constructor(opts: {\n    /**\n     * Project root directory.\n     * @defaultValue `process.cwd()`\n     */\n    cwd?: string;\n    /**\n     * Path to the agents directory, relative to `cwd`.\n     * When omitted, auto-detected as the first existing directory\n     * among `src/agents` and `agents`.\n     */\n    agentsDir?: string;\n    /** Enable verbose logging to stdout. */\n    debug?: boolean;\n  }) {\n    this.cwd = opts.cwd ?? process.cwd();\n    this.agentsDir = opts.agentsDir;\n    this.log = opts.debug\n      ? console.log.bind(console, \"[Framework]\")\n      : () => undefined;\n  }\n\n  /**\n   * Scan the agents directory and return metadata for every agent found.\n   * Each subfolder inside the agents directory becomes one agent.\n   * Returns an empty array when no agents directory exists.\n   */\n  discoverAgents(): ScannedAgent[] {\n    const root = findAgentsRoot(this.cwd, this.agentsDir);\n    if (!root) {\n      return [];\n    }\n    const dirs = discoverAgentDirs(root);\n    return dirs.map(scanAgent);\n  }\n\n  /**\n   * Generate the TypeScript source for an agent registry module.\n   *\n   * @param opts.agents - Scanned agents to include in the registry.\n   * @param opts.outputDir - Directory where the registry file will be written\n   *   (used to compute relative import paths to each agent's config module).\n   * @returns The full source text of the generated `_registry.ts` file.\n   */\n  generateRegistrySource = generateRegistry;\n}\n", "import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport type { NextConfig } from \"next\";\nimport type { Framework } from \"../framework/framework\";\n\n/** A Next.js config object or async config function. */\nexport type NextConfigInput =\n  | NextConfig\n  | ((\n      phase: string,\n      ctx: { defaultConfig: NextConfig }\n    ) => Promise<NextConfig>);\n\n/** Options for {@link withAgents}. */\nexport type WithAgentsConfig = {\n  /**\n   * Path to the agents directory, relative to the project root.\n   * When omitted, auto-detected as the first existing directory\n   * among `src/agents` and `agents`.\n   */\n  agentsDir?: string;\n  /** Enable verbose logging to stdout. */\n  debug?: boolean;\n};\n\n/**\n * Next.js adapter for filesystem-based agent routing.\n *\n * Receives a {@link Framework} instance (composition) and uses it to\n * discover agents, generate a registry, and write the Next.js route\n * handler files that serve them.\n *\n * Most users should use the {@link withAgents} helper instead of\n * constructing this class directly.\n *\n * @example\n * ```ts\n * import { Framework } from \"experimental-agent/framework\";\n * import { Next } from \"experimental-agent/next/agents\";\n *\n * const framework = new Framework({ cwd: process.cwd() });\n * new Next(framework).generate();\n * ```\n */\nexport class Next {\n  constructor(private readonly framework: Framework) {}\n\n  private get appDir(): string {\n    const cwd = this.framework.cwd;\n    const srcAppDir = path.join(cwd, \"src\", \"app\");\n    const rootAppDir = path.join(cwd, \"app\");\n\n    if (this.hasAppLayout(srcAppDir)) {\n      return \"src/app\";\n    }\n    if (this.hasAppLayout(rootAppDir)) {\n      return \"app\";\n    }\n    if (fs.existsSync(srcAppDir)) {\n      return \"src/app\";\n    }\n    return \"app\";\n  }\n\n  generateNextRouteHandlerSource(opts: { registryImportPath: string }): string {\n    return `// Auto-generated by withAgents - do not edit\n// @ts-nocheck\n// biome-ignore format, lint, lint/style, lint/suspicious, lint/complexity, lint/performance, lint/security, lint/correctness, lint/strict\n// prettier-ignore\n\nimport { runtime } from \"experimental-agent/framework-runtime\";\nimport { handleRequest } from \"experimental-agent\";\nimport { agents } from ${JSON.stringify(opts.registryImportPath)};\n\nasync function workflow(agent, sessionId, ...args) {\n  \"use workflow\";\n  return agent.session(sessionId).send(...args);\n}\n\nasync function handler(\n  req: Request,\n  ctx: { params: Promise<{ agent: string; path?: string[] }> }\n) {\n  const params = await ctx.params;\n  const name = params.agent;\n  const instance = await runtime.resolveAgent({ name, agents });\n\n  if (!instance) {\n    const available = Object.keys(agents).join(\", \");\n    const body =\n      \\`Agent \"\\${name}\" not found.\\\\n\\\\n\\` +\n      \\`Available agents: \\${available}\\\\n\\\\n\\` +\n      \\`hint: each folder inside agents/ becomes an agent.\\\\n\\` +\n      \\`      Create agents/\\${name}/ to add this agent.\\\\n\\`;\n    return new Response(body, { status: 404 });\n  }\n\n  return handleRequest(instance, { basePath: \\`/.well-known/agents/\\${name}\\`, workflow }).fetch(req);\n}\n\nexport const GET = handler;\nexport const POST = handler;\n`;\n  }\n\n  /**\n   * Pure codegen step: scan agents and return the generated source\n   * strings without touching the filesystem. Useful for adapters that\n   * need to control where and how files are written.\n   *\n   * Returns `null` when no agents are found.\n   */\n  filesToWrite(): {\n    registrySource: string;\n    routeSource: string;\n    dir: string;\n  } | null {\n    const agents = this.framework.discoverAgents();\n\n    if (agents.length === 0) {\n      return null;\n    }\n\n    this.framework.log(\n      \"discovered agents:\",\n      agents.map((a) => a.name)\n    );\n\n    const dir = path.join(\n      this.framework.cwd,\n      this.appDir,\n      \".well-known\",\n      \"agents\",\n      \"[agent]\",\n      \"[[...path]]\"\n    );\n\n    const registrySource = this.framework.generateRegistrySource({\n      agents,\n      outputDir: dir,\n    });\n    const routeSource = this.generateNextRouteHandlerSource({\n      registryImportPath: \"./_registry\",\n    });\n\n    return { registrySource, routeSource, dir };\n  }\n\n  /**\n   * Scan for agents, generate source, and write the `_registry.ts` and\n   * `route.ts` files into the Next.js app directory.\n   */\n  writeFiles(): void {\n    const filesToWrite = this.filesToWrite();\n\n    if (!filesToWrite) {\n      console.warn(\"[withAgents] No agents found\");\n      return;\n    }\n\n    const { registrySource, routeSource, dir } = filesToWrite;\n\n    fs.mkdirSync(dir, { recursive: true });\n    fs.writeFileSync(path.join(dir, \"_registry.ts\"), registrySource);\n    fs.writeFileSync(path.join(dir, \"route.ts\"), routeSource);\n\n    const gitignorePath = path.join(dir, \".gitignore\");\n    if (!fs.existsSync(gitignorePath)) {\n      fs.writeFileSync(gitignorePath, \"*\\n\");\n    }\n  }\n\n  private hasAppLayout(dir: string): boolean {\n    return [\"layout.tsx\", \"layout.js\", \"layout.jsx\"].some((f) =>\n      fs.existsSync(path.join(dir, f))\n    );\n  }\n}\n"],
  "mappings": "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",
  "names": ["fs", "path", "fs", "path"]
}

|
|
407
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/framework-next/agents-plugin.ts", "../../src/framework/generate.ts", "../../src/framework/scan.ts", "../../src/framework/framework.ts", "../../src/framework-next/next.ts"],
  "sourcesContent": ["import { Framework } from \"../framework/framework\";\nimport { Next, type NextConfigInput } from \"./next\";\n\nexport type { NextConfigInput, WithAgentsConfig } from \"./next\";\n\n/**\n * Next.js config wrapper that discovers agents on the filesystem and\n * generates the route handler + registry files needed to serve them.\n *\n * Call this in `next.config.ts`:\n *\n * @example\n * ```ts\n * import { withAgents } from \"experimental-agent/next/agents\";\n *\n * export default withAgents({ reactStrictMode: true });\n * ```\n *\n * Debug logs:\n * ```ts\n * import { withAgents } from \"experimental-agent/next/agents\";\n *\n * export default withAgents({ reactStrictMode: true }, { debug: true });\n * ```\n */\nexport function withAgents(\n  config: NextConfigInput,\n  agentsConfig: Pick<\n    ConstructorParameters<typeof Framework>[0],\n    \"agentsDir\" | \"debug\"\n  > = {}\n): NextConfigInput {\n  const framework = new Framework(agentsConfig);\n  const next = new Next(framework);\n  next.writeFiles();\n\n  return config;\n}\n", "import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport type { ScannedAgent } from \"./scan\";\n\nconst TS_IMPORT_EXT = /\\.(ts|mts)$/;\nexport function generateRegistry(opts: {\n  agents: ScannedAgent[];\n  outputDir: string;\n}): string {\n  const entries = opts.agents.map((agent) =>\n    inlineEntry({ agent, outputDir: opts.outputDir })\n  );\n\n  return [\n    \"// Auto-generated by withAgents - do not edit\",\n    'import type { AgentRegistry } from \"experimental-agent/framework\";',\n    \"\",\n    \"export const agents = {\",\n    ...entries,\n    \"} satisfies AgentRegistry;\",\n    \"\",\n  ].join(\"\\n\");\n}\n\nfunction inlineEntry(opts: {\n  agent: ScannedAgent;\n  outputDir: string;\n}): string {\n  const config = buildConfig(opts.agent);\n  const configStr = JSON.stringify(config, null, 2)\n    .split(\"\\n\")\n    .map((line, i) => (i === 0 ? line : `      ${line}`))\n    .join(\"\\n\");\n\n  const parts = [`    config: ${configStr}`];\n\n  if (opts.agent.hasAgentConfig) {\n    const configPath = findAgentConfigPath(opts.agent.absolutePath);\n    const relativePath = relativeImportPath({\n      from: opts.outputDir,\n      to: configPath,\n    });\n    parts.push(`    import: () => import(${JSON.stringify(relativePath)})`);\n  }\n\n  if (opts.agent.tools.length > 0) {\n    const toolLines = opts.agent.tools.map((tool) => {\n      const rel = relativeImportPath({\n        from: opts.outputDir,\n        to: tool.importPath,\n      });\n      return `        ${JSON.stringify(tool.name)}: () => import(${JSON.stringify(rel)})`;\n    });\n    parts.push(`    imports: {\\n      tools: {\\n${toolLines.join(\",\\n\")}\\n      }\\n    }`);\n  }\n\n  return `  ${JSON.stringify(opts.agent.name)}: {\\n${parts.join(\",\\n\")}\\n  },`;\n}\n\nfunction buildConfig(agent: ScannedAgent): Record<string, unknown> {\n  const config: Record<string, unknown> = {};\n\n  if (agent.systemPrompt) {\n    config.system = agent.systemPrompt;\n  }\n\n  if (agent.skills.length > 0) {\n    config.skills = agent.skills;\n  }\n\n  return config;\n}\n\nfunction findAgentConfigPath(agentDir: string): string {\n  const extensions = [\".ts\", \".js\", \".mts\", \".mjs\"];\n  for (const ext of extensions) {\n    const candidate = path.join(agentDir, `agent${ext}`);\n    if (fs.existsSync(candidate)) {\n      return candidate;\n    }\n  }\n  return path.join(agentDir, \"agent\");\n}\n\nfunction relativeImportPath(opts: { from: string; to: string }): string {\n  let rel = path.relative(opts.from, opts.to).replace(/\\\\/g, \"/\");\n  rel = rel.replace(TS_IMPORT_EXT, \"\");\n  if (!rel.startsWith(\".\")) {\n    rel = `./${rel}`;\n  }\n  return rel;\n}\n\n", "import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport type { HostSkillInput, SkillInput } from \"../skills/types\";\n\nexport type AgentDir = {\n  name: string;\n  absolutePath: string;\n  hasAgentConfig: boolean;\n};\n\nexport type ScannedTool = {\n  name: string;\n  importPath: string;\n};\n\nexport type ScannedAgent = AgentDir & {\n  skills: SkillInput[];\n  systemPrompt: string | undefined;\n  tsSkillImportPaths: string[];\n  tools: ScannedTool[];\n};\n\nconst AGENT_CONFIG_FILES = [\"agent.ts\", \"agent.js\", \"agent.mts\", \"agent.mjs\"];\nconst MD_EXT = /\\.md$/;\nconst TS_EXT = /\\.(ts|js|mts|mjs)$/;\n\nexport function listDir(dir: string): string[] {\n  if (!fs.existsSync(dir)) {\n    return [];\n  }\n  return fs.readdirSync(dir);\n}\n\nexport function readFile(filePath: string): string {\n  return fs.readFileSync(filePath, \"utf-8\");\n}\n\nexport function fileExists(filePath: string): boolean {\n  return fs.existsSync(filePath);\n}\n\nexport function isDirectory(filePath: string): boolean {\n  return fs.existsSync(filePath) && fs.statSync(filePath).isDirectory();\n}\n\nexport function discoverAgentDirs(agentsRoot: string): AgentDir[] {\n  const entries = listDir(agentsRoot);\n  const dirs: AgentDir[] = [];\n\n  for (const entry of entries) {\n    const absolutePath = path.join(agentsRoot, entry);\n    if (!isDirectory(absolutePath)) {\n      continue;\n    }\n    if (entry.startsWith(\".\")) {\n      continue;\n    }\n\n    dirs.push({\n      name: entry,\n      absolutePath,\n      hasAgentConfig: hasAgentConfig(absolutePath),\n    });\n  }\n\n  return dirs;\n}\n\nexport function hasAgentConfig(agentDir: string): boolean {\n  return AGENT_CONFIG_FILES.some((f) => fileExists(path.join(agentDir, f)));\n}\n\nexport function getSkills(agentDir: string): {\n  skills: SkillInput[];\n  tsSkillImportPaths: string[];\n} {\n  const skillsDir = path.join(agentDir, \"skills\");\n  const entries = listDir(skillsDir);\n  const skills: SkillInput[] = [];\n  const tsSkillImportPaths: string[] = [];\n\n  for (const entry of entries.sort()) {\n    const absolutePath = path.join(skillsDir, entry);\n\n    if (MD_EXT.test(entry)) {\n      skills.push({\n        type: \"host\",\n        path: absolutePath,\n      } satisfies HostSkillInput);\n    } else if (TS_EXT.test(entry)) {\n      tsSkillImportPaths.push(absolutePath);\n    }\n  }\n\n  return { skills, tsSkillImportPaths };\n}\n\nexport function getSystemPrompt(agentDir: string): string | undefined {\n  const systemDir = path.join(agentDir, \"system\");\n  const entries = listDir(systemDir);\n  const mdFiles = entries.filter((e) => MD_EXT.test(e)).sort();\n\n  if (mdFiles.length === 0) {\n    return undefined;\n  }\n\n  const parts: string[] = [];\n  for (const file of mdFiles) {\n    const content = readFile(path.join(systemDir, file)).trim();\n    if (content) {\n      parts.push(content);\n    }\n  }\n\n  return parts.length > 0 ? parts.join(\"\\n\\n\") : undefined;\n}\n\nexport function getTools(agentDir: string): ScannedTool[] {\n  const toolsDir = path.join(agentDir, \"tools\");\n  const entries = listDir(toolsDir);\n  const tools: ScannedTool[] = [];\n\n  for (const entry of entries.sort()) {\n    const absolutePath = path.join(toolsDir, entry);\n\n    if (isDirectory(absolutePath)) {\n      const indexFile = findIndexFile(absolutePath);\n      if (indexFile) {\n        tools.push({ name: entry, importPath: indexFile });\n      }\n    } else if (TS_EXT.test(entry)) {\n      const name = entry.replace(TS_EXT, \"\");\n      tools.push({ name, importPath: absolutePath });\n    }\n  }\n\n  return tools;\n}\n\nfunction findIndexFile(dir: string): string | null {\n  const extensions = [\".ts\", \".js\", \".mts\", \".mjs\"];\n  for (const ext of extensions) {\n    const candidate = path.join(dir, `index${ext}`);\n    if (fileExists(candidate)) {\n      return candidate;\n    }\n  }\n  return null;\n}\n\nexport function scanAgent(agentDir: AgentDir): ScannedAgent {\n  const { skills, tsSkillImportPaths } = getSkills(agentDir.absolutePath);\n  const systemPrompt = getSystemPrompt(agentDir.absolutePath);\n  const tools = getTools(agentDir.absolutePath);\n\n  return { ...agentDir, skills, systemPrompt, tsSkillImportPaths, tools };\n}\n\nexport function findAgentsRoot(\n  cwd: string,\n  userDefinedAgentsDir: string | undefined\n): string | null {\n  if (userDefinedAgentsDir) {\n    return path.resolve(cwd, userDefinedAgentsDir);\n  }\n  const candidates = [\n    path.join(cwd, \"src\", \"agents\"),\n    path.join(cwd, \"agents\"),\n  ];\n\n  for (const candidate of candidates) {\n    if (isDirectory(candidate)) {\n      return candidate;\n    }\n  }\n\n  return null;\n}\n", "import { generateRegistry } from \"./generate\";\nimport type { ScannedAgent } from \"./scan\";\nimport { discoverAgentDirs, findAgentsRoot, scanAgent } from \"./scan\";\n\n/**\n * Framework-agnostic core for filesystem-based agent discovery and\n * registry code generation. Adapters like {@link Next} receive a\n * `Framework` instance and use it to scan agents and produce registry\n * source code.\n */\nexport class Framework {\n  readonly cwd: string;\n  readonly agentsDir: string | undefined;\n  readonly log: (...args: unknown[]) => void;\n\n  constructor(opts: {\n    /**\n     * Project root directory.\n     * @defaultValue `process.cwd()`\n     */\n    cwd?: string;\n    /**\n     * Path to the agents directory, relative to `cwd`.\n     * When omitted, auto-detected as the first existing directory\n     * among `src/agents` and `agents`.\n     */\n    agentsDir?: string;\n    /** Enable verbose logging to stdout. */\n    debug?: boolean;\n  }) {\n    this.cwd = opts.cwd ?? process.cwd();\n    this.agentsDir = opts.agentsDir;\n    this.log = opts.debug\n      ? console.log.bind(console, \"[Framework]\")\n      : () => undefined;\n  }\n\n  /**\n   * Scan the agents directory and return metadata for every agent found.\n   * Each subfolder inside the agents directory becomes one agent.\n   * Returns an empty array when no agents directory exists.\n   */\n  discoverAgents(): ScannedAgent[] {\n    const root = findAgentsRoot(this.cwd, this.agentsDir);\n    if (!root) {\n      return [];\n    }\n    const dirs = discoverAgentDirs(root);\n    return dirs.map(scanAgent);\n  }\n\n  /**\n   * Generate the TypeScript source for an agent registry module.\n   *\n   * @param opts.agents - Scanned agents to include in the registry.\n   * @param opts.outputDir - Directory where the registry file will be written\n   *   (used to compute relative import paths to each agent's config module).\n   * @returns The full source text of the generated `_registry.ts` file.\n   */\n  generateRegistrySource = generateRegistry;\n}\n", "import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport type { NextConfig } from \"next\";\nimport type { Framework } from \"../framework/framework\";\n\n/** A Next.js config object or async config function. */\nexport type NextConfigInput =\n  | NextConfig\n  | ((\n      phase: string,\n      ctx: { defaultConfig: NextConfig }\n    ) => Promise<NextConfig>);\n\n/** Options for {@link withAgents}. */\nexport type WithAgentsConfig = {\n  /**\n   * Path to the agents directory, relative to the project root.\n   * When omitted, auto-detected as the first existing directory\n   * among `src/agents` and `agents`.\n   */\n  agentsDir?: string;\n  /** Enable verbose logging to stdout. */\n  debug?: boolean;\n};\n\n/**\n * Next.js adapter for filesystem-based agent routing.\n *\n * Receives a {@link Framework} instance (composition) and uses it to\n * discover agents, generate a registry, and write the Next.js route\n * handler files that serve them.\n *\n * Most users should use the {@link withAgents} helper instead of\n * constructing this class directly.\n *\n * @example\n * ```ts\n * import { Framework } from \"experimental-agent/framework\";\n * import { Next } from \"experimental-agent/next/agents\";\n *\n * const framework = new Framework({ cwd: process.cwd() });\n * new Next(framework).generate();\n * ```\n */\nexport class Next {\n  constructor(private readonly framework: Framework) {}\n\n  get appDir(): string {\n    const cwd = this.framework.cwd;\n    const srcAppDir = path.join(cwd, \"src\", \"app\");\n    const rootAppDir = path.join(cwd, \"app\");\n\n    if (this.hasAppLayout(srcAppDir)) {\n      return \"src/app\";\n    }\n    if (this.hasAppLayout(rootAppDir)) {\n      return \"app\";\n    }\n    if (fs.existsSync(srcAppDir)) {\n      return \"src/app\";\n    }\n    return \"app\";\n  }\n\n  generateNextRouteHandlerSource(opts: { registryImportPath: string }): string {\n    return `// Auto-generated by withAgents - do not edit\n// @ts-nocheck\n// biome-ignore format, lint, lint/style, lint/suspicious, lint/complexity, lint/performance, lint/security, lint/correctness, lint/strict\n// prettier-ignore\n\nimport { runtime } from \"experimental-agent/framework-runtime\";\nimport { handleRequest } from \"experimental-agent\";\nimport { agents } from ${JSON.stringify(opts.registryImportPath)};\n\nasync function workflow(agent, sessionId, ...args) {\n  \"use workflow\";\n  return agent.session(sessionId).send(...args);\n}\n\nasync function handler(\n  req: Request,\n  ctx: { params: Promise<{ agent: string; path?: string[] }> }\n) {\n  const params = await ctx.params;\n  const name = params.agent;\n  const instance = await runtime.resolveAgent({ name, agents });\n\n  if (!instance) {\n    const available = Object.keys(agents).join(\", \");\n    const body =\n      \\`Agent \"\\${name}\" not found.\\\\n\\\\n\\` +\n      \\`Available agents: \\${available}\\\\n\\\\n\\` +\n      \\`hint: each folder inside agents/ becomes an agent.\\\\n\\` +\n      \\`      Create agents/\\${name}/ to add this agent.\\\\n\\`;\n    return new Response(body, { status: 404 });\n  }\n\n  return handleRequest(instance, { basePath: \\`/.well-known/agents/\\${name}\\`, workflow }).fetch(req);\n}\n\nexport const GET = handler;\nexport const POST = handler;\n`;\n  }\n\n  /**\n   * Pure codegen step: scan agents and return the generated source\n   * strings without touching the filesystem. Useful for adapters that\n   * need to control where and how files are written.\n   *\n   * Returns `null` when no agents are found.\n   */\n  filesToWrite(): {\n    registrySource: string;\n    routeSource: string;\n    dir: string;\n  } | null {\n    const agents = this.framework.discoverAgents();\n\n    if (agents.length === 0) {\n      return null;\n    }\n\n    this.framework.log(\n      \"discovered agents:\",\n      agents.map((a) => a.name)\n    );\n\n    const dir = path.join(\n      this.framework.cwd,\n      this.appDir,\n      \".well-known\",\n      \"agents\",\n      \"[agent]\",\n      \"[[...path]]\"\n    );\n\n    const registrySource = this.framework.generateRegistrySource({\n      agents,\n      outputDir: dir,\n    });\n    const routeSource = this.generateNextRouteHandlerSource({\n      registryImportPath: \"./_registry\",\n    });\n\n    return { registrySource, routeSource, dir };\n  }\n\n  /**\n   * Scan for agents, generate source, and write the `_registry.ts` and\n   * `route.ts` files into the Next.js app directory.\n   */\n  writeFiles(): void {\n    const filesToWrite = this.filesToWrite();\n\n    if (!filesToWrite) {\n      console.warn(\"[withAgents] No agents found\");\n      return;\n    }\n\n    const { registrySource, routeSource, dir } = filesToWrite;\n\n    fs.mkdirSync(dir, { recursive: true });\n    fs.writeFileSync(path.join(dir, \"_registry.ts\"), registrySource);\n    fs.writeFileSync(path.join(dir, \"route.ts\"), routeSource);\n\n    const gitignorePath = path.join(dir, \".gitignore\");\n    if (!fs.existsSync(gitignorePath)) {\n      fs.writeFileSync(gitignorePath, \"*\\n\");\n    }\n  }\n\n  private hasAppLayout(dir: string): boolean {\n    return [\"layout.tsx\", \"layout.js\", \"layout.jsx\"].some((f) =>\n      fs.existsSync(path.join(dir, f))\n    );\n  }\n}\n"],
  "mappings": "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",
  "names": ["fs", "path", "fs", "path"]
}

|
package/dist/next/agents.mjs
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
Framework
|
|
3
|
-
} from "../chunk-
|
|
3
|
+
} from "../chunk-HPBAZJLN.mjs";
|
|
4
4
|
import "../chunk-BJTO5JO5.mjs";
|
|
5
5
|
|
|
6
6
|
// src/framework-next/next.ts
|
|
@@ -134,4 +134,4 @@ function withAgents(config, agentsConfig = {}) {
|
|
|
134
134
|
export {
|
|
135
135
|
withAgents
|
|
136
136
|
};
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/framework-next/next.ts", "../../src/framework-next/agents-plugin.ts"],
  "sourcesContent": ["import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport type { NextConfig } from \"next\";\nimport type { Framework } from \"../framework/framework\";\n\n/** A Next.js config object or async config function. */\nexport type NextConfigInput =\n  | NextConfig\n  | ((\n      phase: string,\n      ctx: { defaultConfig: NextConfig }\n    ) => Promise<NextConfig>);\n\n/** Options for {@link withAgents}. */\nexport type WithAgentsConfig = {\n  /**\n   * Path to the agents directory, relative to the project root.\n   * When omitted, auto-detected as the first existing directory\n   * among `src/agents` and `agents`.\n   */\n  agentsDir?: string;\n  /** Enable verbose logging to stdout. */\n  debug?: boolean;\n};\n\n/**\n * Next.js adapter for filesystem-based agent routing.\n *\n * Receives a {@link Framework} instance (composition) and uses it to\n * discover agents, generate a registry, and write the Next.js route\n * handler files that serve them.\n *\n * Most users should use the {@link withAgents} helper instead of\n * constructing this class directly.\n *\n * @example\n * ```ts\n * import { Framework } from \"experimental-agent/framework\";\n * import { Next } from \"experimental-agent/next/agents\";\n *\n * const framework = new Framework({ cwd: process.cwd() });\n * new Next(framework).generate();\n * ```\n */\nexport class Next {\n  constructor(private readonly framework: Framework) {}\n\n  private get appDir(): string {\n    const cwd = this.framework.cwd;\n    const srcAppDir = path.join(cwd, \"src\", \"app\");\n    const rootAppDir = path.join(cwd, \"app\");\n\n    if (this.hasAppLayout(srcAppDir)) {\n      return \"src/app\";\n    }\n    if (this.hasAppLayout(rootAppDir)) {\n      return \"app\";\n    }\n    if (fs.existsSync(srcAppDir)) {\n      return \"src/app\";\n    }\n    return \"app\";\n  }\n\n  generateNextRouteHandlerSource(opts: { registryImportPath: string }): string {\n    return `// Auto-generated by withAgents - do not edit\n// @ts-nocheck\n// biome-ignore format, lint, lint/style, lint/suspicious, lint/complexity, lint/performance, lint/security, lint/correctness, lint/strict\n// prettier-ignore\n\nimport { runtime } from \"experimental-agent/framework-runtime\";\nimport { handleRequest } from \"experimental-agent\";\nimport { agents } from ${JSON.stringify(opts.registryImportPath)};\n\nasync function workflow(agent, sessionId, ...args) {\n  \"use workflow\";\n  return agent.session(sessionId).send(...args);\n}\n\nasync function handler(\n  req: Request,\n  ctx: { params: Promise<{ agent: string; path?: string[] }> }\n) {\n  const params = await ctx.params;\n  const name = params.agent;\n  const instance = await runtime.resolveAgent({ name, agents });\n\n  if (!instance) {\n    const available = Object.keys(agents).join(\", \");\n    const body =\n      \\`Agent \"\\${name}\" not found.\\\\n\\\\n\\` +\n      \\`Available agents: \\${available}\\\\n\\\\n\\` +\n      \\`hint: each folder inside agents/ becomes an agent.\\\\n\\` +\n      \\`      Create agents/\\${name}/ to add this agent.\\\\n\\`;\n    return new Response(body, { status: 404 });\n  }\n\n  return handleRequest(instance, { basePath: \\`/.well-known/agents/\\${name}\\`, workflow }).fetch(req);\n}\n\nexport const GET = handler;\nexport const POST = handler;\n`;\n  }\n\n  /**\n   * Pure codegen step: scan agents and return the generated source\n   * strings without touching the filesystem. Useful for adapters that\n   * need to control where and how files are written.\n   *\n   * Returns `null` when no agents are found.\n   */\n  filesToWrite(): {\n    registrySource: string;\n    routeSource: string;\n    dir: string;\n  } | null {\n    const agents = this.framework.discoverAgents();\n\n    if (agents.length === 0) {\n      return null;\n    }\n\n    this.framework.log(\n      \"discovered agents:\",\n      agents.map((a) => a.name)\n    );\n\n    const dir = path.join(\n      this.framework.cwd,\n      this.appDir,\n      \".well-known\",\n      \"agents\",\n      \"[agent]\",\n      \"[[...path]]\"\n    );\n\n    const registrySource = this.framework.generateRegistrySource({\n      agents,\n      outputDir: dir,\n    });\n    const routeSource = this.generateNextRouteHandlerSource({\n      registryImportPath: \"./_registry\",\n    });\n\n    return { registrySource, routeSource, dir };\n  }\n\n  /**\n   * Scan for agents, generate source, and write the `_registry.ts` and\n   * `route.ts` files into the Next.js app directory.\n   */\n  writeFiles(): void {\n    const filesToWrite = this.filesToWrite();\n\n    if (!filesToWrite) {\n      console.warn(\"[withAgents] No agents found\");\n      return;\n    }\n\n    const { registrySource, routeSource, dir } = filesToWrite;\n\n    fs.mkdirSync(dir, { recursive: true });\n    fs.writeFileSync(path.join(dir, \"_registry.ts\"), registrySource);\n    fs.writeFileSync(path.join(dir, \"route.ts\"), routeSource);\n\n    const gitignorePath = path.join(dir, \".gitignore\");\n    if (!fs.existsSync(gitignorePath)) {\n      fs.writeFileSync(gitignorePath, \"*\\n\");\n    }\n  }\n\n  private hasAppLayout(dir: string): boolean {\n    return [\"layout.tsx\", \"layout.js\", \"layout.jsx\"].some((f) =>\n      fs.existsSync(path.join(dir, f))\n    );\n  }\n}\n", "import { Framework } from \"../framework/framework\";\nimport { Next, type NextConfigInput } from \"./next\";\n\nexport type { NextConfigInput, WithAgentsConfig } from \"./next\";\n\n/**\n * Next.js config wrapper that discovers agents on the filesystem and\n * generates the route handler + registry files needed to serve them.\n *\n * Call this in `next.config.ts`:\n *\n * @example\n * ```ts\n * import { withAgents } from \"experimental-agent/next/agents\";\n *\n * export default withAgents({ reactStrictMode: true });\n * ```\n *\n * Debug logs:\n * ```ts\n * import { withAgents } from \"experimental-agent/next/agents\";\n *\n * export default withAgents({ reactStrictMode: true }, { debug: true });\n * ```\n */\nexport function withAgents(\n  config: NextConfigInput,\n  agentsConfig: Pick<\n    ConstructorParameters<typeof Framework>[0],\n    \"agentsDir\" | \"debug\"\n  > = {}\n): NextConfigInput {\n  const framework = new Framework(agentsConfig);\n  const next = new Next(framework);\n  next.writeFiles();\n\n  return config;\n}\n"],
  "mappings": ";;;;;;AAAA,YAAY,QAAQ;AACpB,YAAY,UAAU;AA2Cf,IAAM,OAAN,MAAW;AAAA,EAChB,YAA6B,WAAsB;AAAtB;AAAA,EAAuB;AAAA,EAEpD,IAAY,SAAiB;AAC3B,UAAM,MAAM,KAAK,UAAU;AAC3B,UAAM,YAAiB,UAAK,KAAK,OAAO,KAAK;AAC7C,UAAM,aAAkB,UAAK,KAAK,KAAK;AAEvC,QAAI,KAAK,aAAa,SAAS,GAAG;AAChC,aAAO;AAAA,IACT;AACA,QAAI,KAAK,aAAa,UAAU,GAAG;AACjC,aAAO;AAAA,IACT;AACA,QAAO,cAAW,SAAS,GAAG;AAC5B,aAAO;AAAA,IACT;AACA,WAAO;AAAA,EACT;AAAA,EAEA,+BAA+B,MAA8C;AAC3E,WAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,yBAOc,KAAK,UAAU,KAAK,kBAAkB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA+B9D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,eAIS;AACP,UAAM,SAAS,KAAK,UAAU,eAAe;AAE7C,QAAI,OAAO,WAAW,GAAG;AACvB,aAAO;AAAA,IACT;AAEA,SAAK,UAAU;AAAA,MACb;AAAA,MACA,OAAO,IAAI,CAAC,MAAM,EAAE,IAAI;AAAA,IAC1B;AAEA,UAAM,MAAW;AAAA,MACf,KAAK,UAAU;AAAA,MACf,KAAK;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAEA,UAAM,iBAAiB,KAAK,UAAU,uBAAuB;AAAA,MAC3D;AAAA,MACA,WAAW;AAAA,IACb,CAAC;AACD,UAAM,cAAc,KAAK,+BAA+B;AAAA,MACtD,oBAAoB;AAAA,IACtB,CAAC;AAED,WAAO,EAAE,gBAAgB,aAAa,IAAI;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,aAAmB;AACjB,UAAM,eAAe,KAAK,aAAa;AAEvC,QAAI,CAAC,cAAc;AACjB,cAAQ,KAAK,8BAA8B;AAC3C;AAAA,IACF;AAEA,UAAM,EAAE,gBAAgB,aAAa,IAAI,IAAI;AAE7C,IAAG,aAAU,KAAK,EAAE,WAAW,KAAK,CAAC;AACrC,IAAG,iBAAmB,UAAK,KAAK,cAAc,GAAG,cAAc;AAC/D,IAAG,iBAAmB,UAAK,KAAK,UAAU,GAAG,WAAW;AAExD,UAAM,gBAAqB,UAAK,KAAK,YAAY;AACjD,QAAI,CAAI,cAAW,aAAa,GAAG;AACjC,MAAG,iBAAc,eAAe,KAAK;AAAA,IACvC;AAAA,EACF;AAAA,EAEQ,aAAa,KAAsB;AACzC,WAAO,CAAC,cAAc,aAAa,YAAY,EAAE;AAAA,MAAK,CAAC,MAClD,cAAgB,UAAK,KAAK,CAAC,CAAC;AAAA,IACjC;AAAA,EACF;AACF;;;ACxJO,SAAS,WACd,QACA,eAGI,CAAC,GACY;AACjB,QAAM,YAAY,IAAI,UAAU,YAAY;AAC5C,QAAM,OAAO,IAAI,KAAK,SAAS;AAC/B,OAAK,WAAW;AAEhB,SAAO;AACT;",
  "names": []
}

|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/framework-next/next.ts", "../../src/framework-next/agents-plugin.ts"],
  "sourcesContent": ["import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport type { NextConfig } from \"next\";\nimport type { Framework } from \"../framework/framework\";\n\n/** A Next.js config object or async config function. */\nexport type NextConfigInput =\n  | NextConfig\n  | ((\n      phase: string,\n      ctx: { defaultConfig: NextConfig }\n    ) => Promise<NextConfig>);\n\n/** Options for {@link withAgents}. */\nexport type WithAgentsConfig = {\n  /**\n   * Path to the agents directory, relative to the project root.\n   * When omitted, auto-detected as the first existing directory\n   * among `src/agents` and `agents`.\n   */\n  agentsDir?: string;\n  /** Enable verbose logging to stdout. */\n  debug?: boolean;\n};\n\n/**\n * Next.js adapter for filesystem-based agent routing.\n *\n * Receives a {@link Framework} instance (composition) and uses it to\n * discover agents, generate a registry, and write the Next.js route\n * handler files that serve them.\n *\n * Most users should use the {@link withAgents} helper instead of\n * constructing this class directly.\n *\n * @example\n * ```ts\n * import { Framework } from \"experimental-agent/framework\";\n * import { Next } from \"experimental-agent/next/agents\";\n *\n * const framework = new Framework({ cwd: process.cwd() });\n * new Next(framework).generate();\n * ```\n */\nexport class Next {\n  constructor(private readonly framework: Framework) {}\n\n  get appDir(): string {\n    const cwd = this.framework.cwd;\n    const srcAppDir = path.join(cwd, \"src\", \"app\");\n    const rootAppDir = path.join(cwd, \"app\");\n\n    if (this.hasAppLayout(srcAppDir)) {\n      return \"src/app\";\n    }\n    if (this.hasAppLayout(rootAppDir)) {\n      return \"app\";\n    }\n    if (fs.existsSync(srcAppDir)) {\n      return \"src/app\";\n    }\n    return \"app\";\n  }\n\n  generateNextRouteHandlerSource(opts: { registryImportPath: string }): string {\n    return `// Auto-generated by withAgents - do not edit\n// @ts-nocheck\n// biome-ignore format, lint, lint/style, lint/suspicious, lint/complexity, lint/performance, lint/security, lint/correctness, lint/strict\n// prettier-ignore\n\nimport { runtime } from \"experimental-agent/framework-runtime\";\nimport { handleRequest } from \"experimental-agent\";\nimport { agents } from ${JSON.stringify(opts.registryImportPath)};\n\nasync function workflow(agent, sessionId, ...args) {\n  \"use workflow\";\n  return agent.session(sessionId).send(...args);\n}\n\nasync function handler(\n  req: Request,\n  ctx: { params: Promise<{ agent: string; path?: string[] }> }\n) {\n  const params = await ctx.params;\n  const name = params.agent;\n  const instance = await runtime.resolveAgent({ name, agents });\n\n  if (!instance) {\n    const available = Object.keys(agents).join(\", \");\n    const body =\n      \\`Agent \"\\${name}\" not found.\\\\n\\\\n\\` +\n      \\`Available agents: \\${available}\\\\n\\\\n\\` +\n      \\`hint: each folder inside agents/ becomes an agent.\\\\n\\` +\n      \\`      Create agents/\\${name}/ to add this agent.\\\\n\\`;\n    return new Response(body, { status: 404 });\n  }\n\n  return handleRequest(instance, { basePath: \\`/.well-known/agents/\\${name}\\`, workflow }).fetch(req);\n}\n\nexport const GET = handler;\nexport const POST = handler;\n`;\n  }\n\n  /**\n   * Pure codegen step: scan agents and return the generated source\n   * strings without touching the filesystem. Useful for adapters that\n   * need to control where and how files are written.\n   *\n   * Returns `null` when no agents are found.\n   */\n  filesToWrite(): {\n    registrySource: string;\n    routeSource: string;\n    dir: string;\n  } | null {\n    const agents = this.framework.discoverAgents();\n\n    if (agents.length === 0) {\n      return null;\n    }\n\n    this.framework.log(\n      \"discovered agents:\",\n      agents.map((a) => a.name)\n    );\n\n    const dir = path.join(\n      this.framework.cwd,\n      this.appDir,\n      \".well-known\",\n      \"agents\",\n      \"[agent]\",\n      \"[[...path]]\"\n    );\n\n    const registrySource = this.framework.generateRegistrySource({\n      agents,\n      outputDir: dir,\n    });\n    const routeSource = this.generateNextRouteHandlerSource({\n      registryImportPath: \"./_registry\",\n    });\n\n    return { registrySource, routeSource, dir };\n  }\n\n  /**\n   * Scan for agents, generate source, and write the `_registry.ts` and\n   * `route.ts` files into the Next.js app directory.\n   */\n  writeFiles(): void {\n    const filesToWrite = this.filesToWrite();\n\n    if (!filesToWrite) {\n      console.warn(\"[withAgents] No agents found\");\n      return;\n    }\n\n    const { registrySource, routeSource, dir } = filesToWrite;\n\n    fs.mkdirSync(dir, { recursive: true });\n    fs.writeFileSync(path.join(dir, \"_registry.ts\"), registrySource);\n    fs.writeFileSync(path.join(dir, \"route.ts\"), routeSource);\n\n    const gitignorePath = path.join(dir, \".gitignore\");\n    if (!fs.existsSync(gitignorePath)) {\n      fs.writeFileSync(gitignorePath, \"*\\n\");\n    }\n  }\n\n  private hasAppLayout(dir: string): boolean {\n    return [\"layout.tsx\", \"layout.js\", \"layout.jsx\"].some((f) =>\n      fs.existsSync(path.join(dir, f))\n    );\n  }\n}\n", "import { Framework } from \"../framework/framework\";\nimport { Next, type NextConfigInput } from \"./next\";\n\nexport type { NextConfigInput, WithAgentsConfig } from \"./next\";\n\n/**\n * Next.js config wrapper that discovers agents on the filesystem and\n * generates the route handler + registry files needed to serve them.\n *\n * Call this in `next.config.ts`:\n *\n * @example\n * ```ts\n * import { withAgents } from \"experimental-agent/next/agents\";\n *\n * export default withAgents({ reactStrictMode: true });\n * ```\n *\n * Debug logs:\n * ```ts\n * import { withAgents } from \"experimental-agent/next/agents\";\n *\n * export default withAgents({ reactStrictMode: true }, { debug: true });\n * ```\n */\nexport function withAgents(\n  config: NextConfigInput,\n  agentsConfig: Pick<\n    ConstructorParameters<typeof Framework>[0],\n    \"agentsDir\" | \"debug\"\n  > = {}\n): NextConfigInput {\n  const framework = new Framework(agentsConfig);\n  const next = new Next(framework);\n  next.writeFiles();\n\n  return config;\n}\n"],
  "mappings": ";;;;;;AAAA,YAAY,QAAQ;AACpB,YAAY,UAAU;AA2Cf,IAAM,OAAN,MAAW;AAAA,EAChB,YAA6B,WAAsB;AAAtB;AAAA,EAAuB;AAAA,EAEpD,IAAI,SAAiB;AACnB,UAAM,MAAM,KAAK,UAAU;AAC3B,UAAM,YAAiB,UAAK,KAAK,OAAO,KAAK;AAC7C,UAAM,aAAkB,UAAK,KAAK,KAAK;AAEvC,QAAI,KAAK,aAAa,SAAS,GAAG;AAChC,aAAO;AAAA,IACT;AACA,QAAI,KAAK,aAAa,UAAU,GAAG;AACjC,aAAO;AAAA,IACT;AACA,QAAO,cAAW,SAAS,GAAG;AAC5B,aAAO;AAAA,IACT;AACA,WAAO;AAAA,EACT;AAAA,EAEA,+BAA+B,MAA8C;AAC3E,WAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,yBAOc,KAAK,UAAU,KAAK,kBAAkB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA+B9D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,eAIS;AACP,UAAM,SAAS,KAAK,UAAU,eAAe;AAE7C,QAAI,OAAO,WAAW,GAAG;AACvB,aAAO;AAAA,IACT;AAEA,SAAK,UAAU;AAAA,MACb;AAAA,MACA,OAAO,IAAI,CAAC,MAAM,EAAE,IAAI;AAAA,IAC1B;AAEA,UAAM,MAAW;AAAA,MACf,KAAK,UAAU;AAAA,MACf,KAAK;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAEA,UAAM,iBAAiB,KAAK,UAAU,uBAAuB;AAAA,MAC3D;AAAA,MACA,WAAW;AAAA,IACb,CAAC;AACD,UAAM,cAAc,KAAK,+BAA+B;AAAA,MACtD,oBAAoB;AAAA,IACtB,CAAC;AAED,WAAO,EAAE,gBAAgB,aAAa,IAAI;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,aAAmB;AACjB,UAAM,eAAe,KAAK,aAAa;AAEvC,QAAI,CAAC,cAAc;AACjB,cAAQ,KAAK,8BAA8B;AAC3C;AAAA,IACF;AAEA,UAAM,EAAE,gBAAgB,aAAa,IAAI,IAAI;AAE7C,IAAG,aAAU,KAAK,EAAE,WAAW,KAAK,CAAC;AACrC,IAAG,iBAAmB,UAAK,KAAK,cAAc,GAAG,cAAc;AAC/D,IAAG,iBAAmB,UAAK,KAAK,UAAU,GAAG,WAAW;AAExD,UAAM,gBAAqB,UAAK,KAAK,YAAY;AACjD,QAAI,CAAI,cAAW,aAAa,GAAG;AACjC,MAAG,iBAAc,eAAe,KAAK;AAAA,IACvC;AAAA,EACF;AAAA,EAEQ,aAAa,KAAsB;AACzC,WAAO,CAAC,cAAc,aAAa,YAAY,EAAE;AAAA,MAAK,CAAC,MAClD,cAAgB,UAAK,KAAK,CAAC,CAAC;AAAA,IACjC;AAAA,EACF;AACF;;;ACxJO,SAAS,WACd,QACA,eAGI,CAAC,GACY;AACjB,QAAM,YAAY,IAAI,UAAU,YAAY;AAC5C,QAAM,OAAO,IAAI,KAAK,SAAS;AAC/B,OAAK,WAAW;AAEhB,SAAO;AACT;",
  "names": []
}

|
package/dist/next/loader.js
CHANGED
|
@@ -39,7 +39,7 @@ var import_core = require("@swc/core");
|
|
|
39
39
|
// package.json
|
|
40
40
|
var package_default = {
|
|
41
41
|
name: "experimental-agent",
|
|
42
|
-
version: "0.8.0
|
|
42
|
+
version: "0.8.0",
|
|
43
43
|
main: "./dist/index.js",
|
|
44
44
|
module: "./dist/index.mjs",
|
|
45
45
|
types: "./dist/index.d.ts",
|
|
@@ -259,4 +259,4 @@ function findAgentExports(ast) {
|
|
|
259
259
|
}
|
|
260
260
|
return exports2;
|
|
261
261
|
}
|
|
262
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/next/loader.ts", "../../package.json"],
  "sourcesContent": ["import * as path from \"node:path\";\nimport { type Module, parseSync } from \"@swc/core\";\nimport pkg from \"../../package.json\";\n\ntype LoaderOptions = {\n  debug?: boolean;\n  appDir?: string;\n};\n\ntype LoaderContext = {\n  resourcePath: string;\n  getOptions(): LoaderOptions;\n};\n\nconst PACKAGE_NAME = pkg.name;\nconst AGENT_PROTOCOL_VERSION = \"v1\";\nconst TYPESCRIPT_EXT_REGEX = /\\.(ts|tsx|mts|cts)$/;\n\n/**\n * Webpack/Turbopack loader that wires up agent.rpc by requiring steps.js\n * at the END of the file. Using require() avoids import hoisting issues.\n */\nexport default function agentRpcLoader(\n  this: LoaderContext,\n  source: string\n): string {\n  const { debug, appDir: appDirOption } = this.getOptions();\n  const log = debug\n    ? (...args: unknown[]) => console.log(\"[agent-loader]\", ...args)\n    : () => undefined;\n\n  log(\"processing:\", this.resourcePath);\n\n  if (!source.includes(PACKAGE_NAME)) {\n    log(\"skipping - no package name\");\n    return source;\n  }\n\n  const filename = this.resourcePath;\n  const isTypeScript = TYPESCRIPT_EXT_REGEX.test(filename);\n\n  let ast: Module;\n  try {\n    ast = parseSync(source, {\n      syntax: isTypeScript ? \"typescript\" : \"ecmascript\",\n      tsx: filename.endsWith(\".tsx\"),\n      jsx: filename.endsWith(\".jsx\"),\n    });\n  } catch {\n    return source;\n  }\n\n  const agentExports = findAgentExports(ast);\n  if (agentExports.length === 0) {\n    log(\"skipping - no agent exports\");\n    return source;\n  }\n\n  log(\"found agent exports:\", agentExports);\n\n  const fileDir = path.dirname(filename);\n\n  let appDir: string;\n  if (appDirOption) {\n    appDir = appDirOption;\n  } else {\n    const srcIndex = filename.lastIndexOf(`${path.sep}src${path.sep}`);\n    if (srcIndex !== -1) {\n      const srcDir = filename.substring(0, srcIndex + 4);\n      appDir = path.join(srcDir, \"app\");\n    } else {\n      const appSep = `${path.sep}app${path.sep}`;\n      const appIndex = filename.lastIndexOf(appSep);\n      if (appIndex !== -1) {\n        appDir = filename.substring(0, appIndex + appSep.length - 1);\n      } else {\n        log(\"skipping - no src/ or app/ dir found\");\n        return source;\n      }\n    }\n  }\n\n  const stepsPath = path.join(\n    appDir,\n    \".well-known\",\n    \"agent\",\n    AGENT_PROTOCOL_VERSION,\n    \"steps.js\"\n  );\n  let relativePath = path.relative(fileDir, stepsPath).replace(/\\\\/g, \"/\");\n\n  if (!(relativePath.startsWith(\"./\") || relativePath.startsWith(\"../\"))) {\n    relativePath = `./${relativePath}`;\n  }\n\n  const initCalls = agentExports\n    .map((name) => {\n      const initName = `__init${name[0].toUpperCase()}${name.slice(1)}`;\n      return `${initName}(${name});`;\n    })\n    .join(\"\\n\");\n\n  const initImports = agentExports\n    .map((name) => `__init${name[0].toUpperCase()}${name.slice(1)}`)\n    .join(\", \");\n\n  log(\"injecting init calls for:\", agentExports);\n  return `${source}\nimport { ${initImports} } from \"${relativePath}\";\n${initCalls}`;\n}\n\nfunction findAgentExports(ast: Module): string[] {\n  let agentLocalName: string | null = null;\n\n  for (const item of ast.body) {\n    if (\n      item.type === \"ImportDeclaration\" &&\n      item.source.value === PACKAGE_NAME\n    ) {\n      for (const specifier of item.specifiers) {\n        if (specifier.type === \"ImportSpecifier\") {\n          const imported =\n            specifier.imported?.type === \"Identifier\"\n              ? specifier.imported.value\n              : specifier.local.value;\n\n          if (imported === \"agent\") {\n            agentLocalName = specifier.local.value;\n            break;\n          }\n        }\n      }\n    }\n  }\n\n  if (!agentLocalName) {\n    return [];\n  }\n\n  const exports: string[] = [];\n\n  for (const item of ast.body) {\n    if (item.type === \"ExportDeclaration\" && item.declaration) {\n      const decl = item.declaration;\n      if (decl.type === \"VariableDeclaration\") {\n        for (const declarator of decl.declarations) {\n          if (\n            declarator.id.type === \"Identifier\" &&\n            declarator.init?.type === \"CallExpression\" &&\n            declarator.init.callee.type === \"Identifier\" &&\n            declarator.init.callee.value === agentLocalName\n          ) {\n            exports.push(declarator.id.value);\n          }\n        }\n      }\n    }\n  }\n\n  return exports;\n}\n", "{\n  \"name\": \"experimental-agent\",\n  \"version\": \"0.8.0-alpha.1\",\n  \"main\": \"./dist/index.js\",\n  \"module\": \"./dist/index.mjs\",\n  \"types\": \"./dist/index.d.ts\",\n  \"sideEffects\": true,\n  \"license\": \"MIT\",\n  \"files\": [\n    \"dist/**\"\n  ],\n  \"exports\": {\n    \".\": {\n      \"types\": \"./dist/index.d.ts\",\n      \"import\": \"./dist/index.mjs\",\n      \"require\": \"./dist/index.js\"\n    },\n    \"./storage\": {\n      \"types\": \"./dist/storage.d.ts\",\n      \"import\": \"./dist/storage.mjs\",\n      \"require\": \"./dist/storage.js\"\n    },\n    \"./sandbox\": {\n      \"types\": \"./dist/sandbox.d.ts\",\n      \"import\": \"./dist/sandbox.mjs\",\n      \"require\": \"./dist/sandbox.js\"\n    },\n    \"./next\": {\n      \"types\": \"./dist/next.d.ts\",\n      \"import\": \"./dist/next.mjs\",\n      \"require\": \"./dist/next.js\"\n    },\n    \"./next/loader\": {\n      \"types\": \"./dist/next/loader.d.ts\",\n      \"import\": \"./dist/next/loader.mjs\",\n      \"require\": \"./dist/next/loader.js\"\n    },\n    \"./next/agents\": {\n      \"types\": \"./dist/next/agents.d.ts\",\n      \"import\": \"./dist/next/agents.mjs\",\n      \"require\": \"./dist/next/agents.js\"\n    },\n    \"./framework\": {\n      \"types\": \"./dist/framework.d.ts\",\n      \"import\": \"./dist/framework.mjs\",\n      \"require\": \"./dist/framework.js\"\n    },\n    \"./framework-runtime\": {\n      \"types\": \"./dist/framework-runtime.d.ts\",\n      \"import\": \"./dist/framework-runtime.mjs\",\n      \"require\": \"./dist/framework-runtime.js\"\n    },\n    \"./client\": {\n      \"types\": \"./dist/client.d.ts\",\n      \"import\": \"./dist/client.mjs\",\n      \"require\": \"./dist/client.js\"\n    },\n    \"./lifecycle-workflow\": {\n      \"types\": \"./dist/lifecycle-workflow.d.ts\",\n      \"import\": \"./dist/lifecycle-workflow.mjs\",\n      \"require\": \"./dist/lifecycle-workflow.js\"\n    },\n    \"./lifecycle-workflow-steps\": {\n      \"types\": \"./dist/lifecycle-workflow-steps.d.ts\",\n      \"import\": \"./dist/lifecycle-workflow-steps.mjs\",\n      \"require\": \"./dist/lifecycle-workflow-steps.js\"\n    },\n    \"./react\": {\n      \"types\": \"./dist/react.d.ts\",\n      \"import\": \"./dist/react.mjs\",\n      \"require\": \"./dist/react.js\"\n    }\n  },\n  \"scripts\": {\n    \"build\": \"tsup\",\n    \"dev\": \"tsup --watch\",\n    \"clean\": \"rm -rf .turbo && rm -rf node_modules && rm -rf dist\",\n    \"release\": \"pnpm build && npm publish\",\n    \"typecheck\": \"tsc --noEmit\",\n    \"test\": \"vitest run\",\n    \"test:watch\": \"vitest\"\n  },\n  \"dependencies\": {\n    \"@elysiajs/openapi\": \"^1.4.14\",\n    \"@swc/core\": \"^1.10.0\",\n    \"@tanstack/react-query\": \"^5.90.21\",\n    \"@vercel/kv2\": \"^0.0.18\",\n    \"@vercel/oidc\": \"^3.1.0\",\n    \"@vercel/sandbox\": \"1.7.1\",\n    \"@workflow/serde\": \"4.1.0-beta.2\",\n    \"better-all\": \"^0.0.5\",\n    \"elysia\": \"^1.4.25\",\n    \"errore\": \"^0.14.0\",\n    \"fast-deep-equal\": \"^3.1.3\",\n    \"ulid\": \"^3.0.2\",\n    \"zod\": \"^4.3.6\"\n  },\n  \"devDependencies\": {\n    \"@agent/tsconfig\": \"workspace:*\",\n    \"@ai-sdk/react\": \"^3.0.88\",\n    \"@types/node\": \"^20.11.24\",\n    \"@types/react\": \"^19.2.14\",\n    \"dotenv\": \"^17.2.3\",\n    \"next\": \"^16.0.0\",\n    \"react\": \"^19.2.4\",\n    \"tsup\": \"^8.0.2\",\n    \"typescript\": \"5.5.4\",\n    \"vitest\": \"^3.0.0\",\n    \"workflow\": \"4.2.0-beta.70\"\n  },\n  \"peerDependencies\": {\n    \"ai\": \"^6.0.0\"\n  },\n  \"publishConfig\": {\n    \"access\": \"public\"\n  }\n}\n"],
  "mappings": "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",
  "names": ["exports"]
}

|
|
262
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/next/loader.ts", "../../package.json"],
  "sourcesContent": ["import * as path from \"node:path\";\nimport { type Module, parseSync } from \"@swc/core\";\nimport pkg from \"../../package.json\";\n\ntype LoaderOptions = {\n  debug?: boolean;\n  appDir?: string;\n};\n\ntype LoaderContext = {\n  resourcePath: string;\n  getOptions(): LoaderOptions;\n};\n\nconst PACKAGE_NAME = pkg.name;\nconst AGENT_PROTOCOL_VERSION = \"v1\";\nconst TYPESCRIPT_EXT_REGEX = /\\.(ts|tsx|mts|cts)$/;\n\n/**\n * Webpack/Turbopack loader that wires up agent.rpc by requiring steps.js\n * at the END of the file. Using require() avoids import hoisting issues.\n */\nexport default function agentRpcLoader(\n  this: LoaderContext,\n  source: string\n): string {\n  const { debug, appDir: appDirOption } = this.getOptions();\n  const log = debug\n    ? (...args: unknown[]) => console.log(\"[agent-loader]\", ...args)\n    : () => undefined;\n\n  log(\"processing:\", this.resourcePath);\n\n  if (!source.includes(PACKAGE_NAME)) {\n    log(\"skipping - no package name\");\n    return source;\n  }\n\n  const filename = this.resourcePath;\n  const isTypeScript = TYPESCRIPT_EXT_REGEX.test(filename);\n\n  let ast: Module;\n  try {\n    ast = parseSync(source, {\n      syntax: isTypeScript ? \"typescript\" : \"ecmascript\",\n      tsx: filename.endsWith(\".tsx\"),\n      jsx: filename.endsWith(\".jsx\"),\n    });\n  } catch {\n    return source;\n  }\n\n  const agentExports = findAgentExports(ast);\n  if (agentExports.length === 0) {\n    log(\"skipping - no agent exports\");\n    return source;\n  }\n\n  log(\"found agent exports:\", agentExports);\n\n  const fileDir = path.dirname(filename);\n\n  let appDir: string;\n  if (appDirOption) {\n    appDir = appDirOption;\n  } else {\n    const srcIndex = filename.lastIndexOf(`${path.sep}src${path.sep}`);\n    if (srcIndex !== -1) {\n      const srcDir = filename.substring(0, srcIndex + 4);\n      appDir = path.join(srcDir, \"app\");\n    } else {\n      const appSep = `${path.sep}app${path.sep}`;\n      const appIndex = filename.lastIndexOf(appSep);\n      if (appIndex !== -1) {\n        appDir = filename.substring(0, appIndex + appSep.length - 1);\n      } else {\n        log(\"skipping - no src/ or app/ dir found\");\n        return source;\n      }\n    }\n  }\n\n  const stepsPath = path.join(\n    appDir,\n    \".well-known\",\n    \"agent\",\n    AGENT_PROTOCOL_VERSION,\n    \"steps.js\"\n  );\n  let relativePath = path.relative(fileDir, stepsPath).replace(/\\\\/g, \"/\");\n\n  if (!(relativePath.startsWith(\"./\") || relativePath.startsWith(\"../\"))) {\n    relativePath = `./${relativePath}`;\n  }\n\n  const initCalls = agentExports\n    .map((name) => {\n      const initName = `__init${name[0].toUpperCase()}${name.slice(1)}`;\n      return `${initName}(${name});`;\n    })\n    .join(\"\\n\");\n\n  const initImports = agentExports\n    .map((name) => `__init${name[0].toUpperCase()}${name.slice(1)}`)\n    .join(\", \");\n\n  log(\"injecting init calls for:\", agentExports);\n  return `${source}\nimport { ${initImports} } from \"${relativePath}\";\n${initCalls}`;\n}\n\nfunction findAgentExports(ast: Module): string[] {\n  let agentLocalName: string | null = null;\n\n  for (const item of ast.body) {\n    if (\n      item.type === \"ImportDeclaration\" &&\n      item.source.value === PACKAGE_NAME\n    ) {\n      for (const specifier of item.specifiers) {\n        if (specifier.type === \"ImportSpecifier\") {\n          const imported =\n            specifier.imported?.type === \"Identifier\"\n              ? specifier.imported.value\n              : specifier.local.value;\n\n          if (imported === \"agent\") {\n            agentLocalName = specifier.local.value;\n            break;\n          }\n        }\n      }\n    }\n  }\n\n  if (!agentLocalName) {\n    return [];\n  }\n\n  const exports: string[] = [];\n\n  for (const item of ast.body) {\n    if (item.type === \"ExportDeclaration\" && item.declaration) {\n      const decl = item.declaration;\n      if (decl.type === \"VariableDeclaration\") {\n        for (const declarator of decl.declarations) {\n          if (\n            declarator.id.type === \"Identifier\" &&\n            declarator.init?.type === \"CallExpression\" &&\n            declarator.init.callee.type === \"Identifier\" &&\n            declarator.init.callee.value === agentLocalName\n          ) {\n            exports.push(declarator.id.value);\n          }\n        }\n      }\n    }\n  }\n\n  return exports;\n}\n", "{\n  \"name\": \"experimental-agent\",\n  \"version\": \"0.8.0\",\n  \"main\": \"./dist/index.js\",\n  \"module\": \"./dist/index.mjs\",\n  \"types\": \"./dist/index.d.ts\",\n  \"sideEffects\": true,\n  \"license\": \"MIT\",\n  \"files\": [\n    \"dist/**\"\n  ],\n  \"exports\": {\n    \".\": {\n      \"types\": \"./dist/index.d.ts\",\n      \"import\": \"./dist/index.mjs\",\n      \"require\": \"./dist/index.js\"\n    },\n    \"./storage\": {\n      \"types\": \"./dist/storage.d.ts\",\n      \"import\": \"./dist/storage.mjs\",\n      \"require\": \"./dist/storage.js\"\n    },\n    \"./sandbox\": {\n      \"types\": \"./dist/sandbox.d.ts\",\n      \"import\": \"./dist/sandbox.mjs\",\n      \"require\": \"./dist/sandbox.js\"\n    },\n    \"./next\": {\n      \"types\": \"./dist/next.d.ts\",\n      \"import\": \"./dist/next.mjs\",\n      \"require\": \"./dist/next.js\"\n    },\n    \"./next/loader\": {\n      \"types\": \"./dist/next/loader.d.ts\",\n      \"import\": \"./dist/next/loader.mjs\",\n      \"require\": \"./dist/next/loader.js\"\n    },\n    \"./next/agents\": {\n      \"types\": \"./dist/next/agents.d.ts\",\n      \"import\": \"./dist/next/agents.mjs\",\n      \"require\": \"./dist/next/agents.js\"\n    },\n    \"./framework\": {\n      \"types\": \"./dist/framework.d.ts\",\n      \"import\": \"./dist/framework.mjs\",\n      \"require\": \"./dist/framework.js\"\n    },\n    \"./framework-runtime\": {\n      \"types\": \"./dist/framework-runtime.d.ts\",\n      \"import\": \"./dist/framework-runtime.mjs\",\n      \"require\": \"./dist/framework-runtime.js\"\n    },\n    \"./client\": {\n      \"types\": \"./dist/client.d.ts\",\n      \"import\": \"./dist/client.mjs\",\n      \"require\": \"./dist/client.js\"\n    },\n    \"./lifecycle-workflow\": {\n      \"types\": \"./dist/lifecycle-workflow.d.ts\",\n      \"import\": \"./dist/lifecycle-workflow.mjs\",\n      \"require\": \"./dist/lifecycle-workflow.js\"\n    },\n    \"./lifecycle-workflow-steps\": {\n      \"types\": \"./dist/lifecycle-workflow-steps.d.ts\",\n      \"import\": \"./dist/lifecycle-workflow-steps.mjs\",\n      \"require\": \"./dist/lifecycle-workflow-steps.js\"\n    },\n    \"./react\": {\n      \"types\": \"./dist/react.d.ts\",\n      \"import\": \"./dist/react.mjs\",\n      \"require\": \"./dist/react.js\"\n    }\n  },\n  \"scripts\": {\n    \"build\": \"tsup\",\n    \"dev\": \"tsup --watch\",\n    \"clean\": \"rm -rf .turbo && rm -rf node_modules && rm -rf dist\",\n    \"release\": \"pnpm build && npm publish\",\n    \"typecheck\": \"tsc --noEmit\",\n    \"test\": \"vitest run\",\n    \"test:watch\": \"vitest\"\n  },\n  \"dependencies\": {\n    \"@elysiajs/openapi\": \"^1.4.14\",\n    \"@swc/core\": \"^1.10.0\",\n    \"@tanstack/react-query\": \"^5.90.21\",\n    \"@vercel/kv2\": \"^0.0.18\",\n    \"@vercel/oidc\": \"^3.1.0\",\n    \"@vercel/sandbox\": \"1.7.1\",\n    \"@workflow/serde\": \"4.1.0-beta.2\",\n    \"better-all\": \"^0.0.5\",\n    \"elysia\": \"^1.4.25\",\n    \"errore\": \"^0.14.0\",\n    \"fast-deep-equal\": \"^3.1.3\",\n    \"ulid\": \"^3.0.2\",\n    \"zod\": \"^4.3.6\"\n  },\n  \"devDependencies\": {\n    \"@agent/tsconfig\": \"workspace:*\",\n    \"@ai-sdk/react\": \"^3.0.88\",\n    \"@types/node\": \"^20.11.24\",\n    \"@types/react\": \"^19.2.14\",\n    \"dotenv\": \"^17.2.3\",\n    \"next\": \"^16.0.0\",\n    \"react\": \"^19.2.4\",\n    \"tsup\": \"^8.0.2\",\n    \"typescript\": \"5.5.4\",\n    \"vitest\": \"^3.0.0\",\n    \"workflow\": \"4.2.0-beta.70\"\n  },\n  \"peerDependencies\": {\n    \"ai\": \"^6.0.0\"\n  },\n  \"publishConfig\": {\n    \"access\": \"public\"\n  }\n}\n"],
  "mappings": "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",
  "names": ["exports"]
}

|
package/dist/next/loader.mjs
CHANGED
package/dist/next.js
CHANGED
|
@@ -40,7 +40,7 @@ var path = __toESM(require("path"));
|
|
|
40
40
|
// package.json
|
|
41
41
|
var package_default = {
|
|
42
42
|
name: "experimental-agent",
|
|
43
|
-
version: "0.8.0
|
|
43
|
+
version: "0.8.0",
|
|
44
44
|
main: "./dist/index.js",
|
|
45
45
|
module: "./dist/index.mjs",
|
|
46
46
|
types: "./dist/index.d.ts",
|
|
@@ -207,7 +207,9 @@ function detectAgents(cwd, debug) {
|
|
|
207
207
|
const content = fs.readFileSync(fullPath, "utf-8");
|
|
208
208
|
if (content.includes(PACKAGE_NAME) && content.includes("agent(")) {
|
|
209
209
|
const stripped = content.replace(/\/\/.*$/gm, "").replace(/\/\*[\s\S]*?\*\//g, "");
|
|
210
|
-
const exportMatches =
|
|
210
|
+
const exportMatches = Array.from(
|
|
211
|
+
stripped.matchAll(AGENT_EXPORT_REGEX)
|
|
212
|
+
);
|
|
211
213
|
const seen = /* @__PURE__ */ new Set();
|
|
212
214
|
for (const match of exportMatches) {
|
|
213
215
|
if (seen.has(match[1])) {
|
|
@@ -393,4 +395,4 @@ function withAgent(configOrFn, agentConfig) {
|
|
|
393
395
|
0 && (module.exports = {
|
|
394
396
|
withAgent
|
|
395
397
|
});
|
|
396
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/next/index.ts", "../package.json"],
  "sourcesContent": ["import * as crypto from \"node:crypto\";\nimport * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport type { NextConfig } from \"next\";\nimport pkg from \"../../package.json\";\n\nexport type WithAgentConfig = {\n  /** Enable debug logging for the Next.js loader (agent detection, file generation). */\n  debug?: boolean;\n};\n\nconst PACKAGE_NAME = pkg.name;\nconst AGENT_PROTOCOL_VERSION = \"v1\";\nconst FILE_EXT_REGEX = /\\.(ts|tsx|js|jsx)$/;\nconst AGENT_EXPORT_REGEX = /export\\s+const\\s+(\\w+)\\s*=\\s*agent\\s*\\(/g;\nconst DEFAULT_WORKFLOW_DIRS = [\"pages\", \"app\", \"src/pages\", \"src/app\"];\n\ntype DetectedAgent = {\n  exportName: string;\n  filePath: string;\n  /** Unique identifier: exportName or exportName_hash if duplicates exist */\n  uniqueId: string;\n};\n\nfunction shortHash(str: string): string {\n  let hash = 0;\n  for (let i = 0; i < str.length; i++) {\n    const char = str.charCodeAt(i);\n    // biome-ignore lint/suspicious/noBitwiseOperators: intentional hash computation\n    hash = (hash << 5) - hash + char;\n    // biome-ignore lint/suspicious/noBitwiseOperators: convert to 32-bit integer\n    hash &= hash;\n  }\n  return Math.abs(hash).toString(36).slice(0, 6);\n}\n\nfunction hasNextAppLayout(dir: string): boolean {\n  return [\"layout.tsx\", \"layout.ts\", \"layout.js\", \"layout.jsx\"].some((f) =>\n    fs.existsSync(path.join(dir, f))\n  );\n}\n\n/**\n * Detects whether the project uses src/app or app directory structure\n * by checking which directory contains a Next.js layout file.\n * Returns the app directory path relative to cwd.\n */\nfunction getAppDir(cwd: string): string {\n  const srcAppDir = path.join(cwd, \"src\", \"app\");\n  const rootAppDir = path.join(cwd, \"app\");\n\n  if (hasNextAppLayout(srcAppDir)) {\n    return \"src/app\";\n  }\n  if (hasNextAppLayout(rootAppDir)) {\n    return \"app\";\n  }\n\n  /**\n   * Fallback when neither directory has a layout file yet\n   * (e.g. fresh project). Prefer src/app if the directory exists.\n   */\n  if (fs.existsSync(srcAppDir)) {\n    return \"src/app\";\n  }\n  return \"app\";\n}\n\n/**\n * Scans for agent exports in the project.\n */\nfunction detectAgents(cwd: string, debug: boolean): DetectedAgent[] {\n  const agents: DetectedAgent[] = [];\n\n  const dirsToScan = [path.join(cwd, \"src\"), cwd];\n\n  function scanDir(dir: string) {\n    if (!fs.existsSync(dir)) {\n      return;\n    }\n\n    const entries = fs.readdirSync(dir, { withFileTypes: true });\n    for (const entry of entries) {\n      const fullPath = path.join(dir, entry.name);\n      if (\n        entry.isDirectory() &&\n        !entry.name.startsWith(\".\") &&\n        entry.name !== \"node_modules\" &&\n        entry.name !== \"src\"\n      ) {\n        scanDir(fullPath);\n      } else if (entry.isFile() && FILE_EXT_REGEX.test(entry.name)) {\n        try {\n          const content = fs.readFileSync(fullPath, \"utf-8\");\n          if (content.includes(PACKAGE_NAME) && content.includes(\"agent(\")) {\n            // Strip single-line comments and block comments to avoid\n            // matching commented-out agent exports\n            const stripped = content\n              .replace(/\\/\\/.*$/gm, \"\")\n              .replace(/\\/\\*[\\s\\S]*?\\*\\//g, \"\");\n            const exportMatches = stripped.matchAll(AGENT_EXPORT_REGEX);\n            const seen = new Set<string>();\n            for (const match of exportMatches) {\n              if (seen.has(match[1])) {\n                continue;\n              }\n              seen.add(match[1]);\n              agents.push({\n                exportName: match[1],\n                filePath: fullPath,\n                uniqueId: \"\", // Will be set after all agents are found\n              });\n              if (debug) {\n                console.log(\n                  `[withAgent] Found agent: ${match[1]} in ${fullPath}`\n                );\n              }\n            }\n          }\n        } catch {\n          // Ignore read errors\n        }\n      }\n    }\n  }\n\n  for (const dir of dirsToScan) {\n    scanDir(dir);\n  }\n\n  // Assign unique IDs - add hash suffix if duplicate export names exist\n  const nameCounts = new Map<string, number>();\n  for (const agent of agents) {\n    nameCounts.set(\n      agent.exportName,\n      (nameCounts.get(agent.exportName) || 0) + 1\n    );\n  }\n\n  for (const agent of agents) {\n    const count = nameCounts.get(agent.exportName) ?? 0;\n    if (count > 1) {\n      agent.uniqueId = `${agent.exportName}_${shortHash(agent.filePath)}`;\n    } else {\n      agent.uniqueId = agent.exportName;\n    }\n  }\n\n  return agents;\n}\n\n/**\n * Generates all agent files in .well-known/agent/v1/:\n * - steps.js: RPC step functions with \"use step\"\n * - route.js: triggers workflow discovery\n */\nfunction generateAgentFiles(\n  agents: DetectedAgent[],\n  outputDir: string,\n  _cwd: string,\n  debug: boolean\n): void {\n  if (agents.length === 0) {\n    if (debug) {\n      console.log(\"[withAgent] No agents found, skipping generation\");\n    }\n    return;\n  }\n\n  if (!fs.existsSync(outputDir)) {\n    fs.mkdirSync(outputDir, { recursive: true });\n  }\n\n  /**\n   * Generate step functions that use dynamic import.\n   * Dynamic import ensures the agent module loads (including loader-injected init)\n   * when the step runs in workflow context, avoiding the \"not initialized\" error.\n   *\n   * Uses uniqueId for function names to handle duplicate export names across files.\n   */\n  const rpcFunctions = agents\n    .map((a) => {\n      // Calculate relative path from steps.js to the agent file\n      let agentRelPath = path\n        .relative(outputDir, a.filePath)\n        .replace(/\\\\/g, \"/\");\n\n      if (!agentRelPath.startsWith(\".\")) {\n        agentRelPath = `./${agentRelPath}`;\n      }\n\n      return `\nexport const ${a.uniqueId}Rpc = async (params) => {\n  \"use step\";\n  const { ${a.exportName} } = await import(\"${agentRelPath}\");\n  const res = await ${a.exportName}.handler(params);\n  if (res instanceof Response) {\n    return res.json();\n  }\n  return res;\n};`;\n    })\n    .join(\"\\n\");\n\n  /**\n   * Init functions wire up agent.rpc in the main app context.\n   * Uses exportName for the function name (loader matches by export name),\n   * but references uniqueId for the Rpc function.\n   */\n  const initFunctions = agents\n    .map(\n      (a) => `\nexport function __init${a.exportName[0].toUpperCase()}${a.exportName.slice(\n        1\n      )}(agent) {\n  agent.rpc = ${a.uniqueId}Rpc;\n}`\n    )\n    .join(\"\\n\");\n\n  const stepsContent = `// Auto-generated by withAgent - do not edit\n${rpcFunctions}\n${initFunctions}\n`;\n\n  const stepsPath = path.join(outputDir, \"steps.js\");\n  fs.writeFileSync(stepsPath, stepsContent);\n\n  /**\n   * Generate route.js that imports steps.js.\n   * This ensures workflow discovers the \"use step\" functions.\n   * No actual handler needed - storage RPC uses the step function directly.\n   */\n  const routeContent = `// Auto-generated by withAgent - triggers workflow discovery\nimport \"./steps.js\";\nexport function GET() {\n  return new Response(\"ok\");\n}\n`;\n\n  const routePath = path.join(outputDir, \"route.js\");\n  fs.writeFileSync(routePath, routeContent);\n\n  // Add .gitignore\n  const gitignorePath = path.join(outputDir, \".gitignore\");\n  if (!fs.existsSync(gitignorePath)) {\n    fs.writeFileSync(gitignorePath, \"*\\n\");\n  }\n\n  if (debug) {\n    console.log(`[withAgent] Generated agent files at ${outputDir}`);\n  }\n}\n\ntype TurbopackLoader =\n  | string\n  | { loader: string; options?: Record<string, unknown> };\n\ntype TurbopackRule = {\n  loaders?: TurbopackLoader[];\n  condition?: {\n    all?: unknown[];\n    any?: unknown[];\n    path?: RegExp;\n    content?: RegExp;\n    not?: unknown;\n  };\n};\n\ntype WorkflowConfigFn = (\n  phase: string,\n  ctx: { defaultConfig: NextConfig }\n) => Promise<NextConfig>;\n\ntype NextConfigInput =\n  | NextConfig\n  | ((\n      phase: string,\n      ctx: { defaultConfig: NextConfig }\n    ) => Promise<NextConfig>);\n\n/**\n * Next.js plugin that configures agent support.\n *\n * - Detects agents and generates RPC steps with \"use step\" in .well-known/agent/v1/\n * - Generates AGENT_SECRET for secure RPC calls\n * - Wraps withWorkflow for workflow support\n *\n * @example\n * ```ts\n * // next.config.ts\n * import { withAgent } from \"experimental-agent/next\";\n *\n * // Option 1: withAgent handles everything (recommended)\n * export default withAgent({});\n *\n * // Option 2: Compose with other plugins\n * export default withAgent(withSomeOtherPlugin({}));\n * ```\n */\nexport function withAgent(\n  configOrFn: NextConfigInput,\n  agentConfig?: WithAgentConfig\n): WorkflowConfigFn {\n  const debug = agentConfig?.debug ?? false;\n  const cwd = process.cwd();\n\n  // Detect app directory structure (src/app vs app)\n  const appDir = getAppDir(cwd);\n  const agentDir = `${appDir}/.well-known/agent/${AGENT_PROTOCOL_VERSION}`;\n\n  // Detect agents and generate files FIRST (before workflow discovers them)\n  const agents = detectAgents(cwd, debug);\n  const outputDir = path.join(cwd, agentDir);\n  generateAgentFiles(agents, outputDir, cwd, debug);\n\n  const agentFilePaths = agents.map((a) => a.filePath);\n  const loaderPath = require.resolve(\"./next/loader\");\n  const absoluteAppDir = path.join(cwd, appDir);\n  const loaderOptions = { appDir: absoluteAppDir, debug };\n\n  if (debug) {\n    console.log(\"[withAgent] loader path:\", loaderPath);\n    console.log(\"[withAgent] agent files:\", agentFilePaths);\n    console.log(\"[withAgent] agent dir:\", agentDir);\n  }\n\n  // Build regex to match agent file paths\n  const agentPathRegex =\n    agentFilePaths.length > 0\n      ? new RegExp(\n          `${agentFilePaths\n            .map((p) =>\n              path\n                .relative(cwd, p)\n                .replace(/\\\\/g, \"/\")\n                .replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\")\n            )\n            .join(\"|\")}$`\n        )\n      : null;\n\n  /**\n   * Always pass through withWorkflow - it handles both NextConfig and async functions.\n   * This ensures workflow is always configured, regardless of what the user passed.\n   */\n  let withWorkflow: (\n    config: NextConfigInput,\n    options?: { workflows?: { dirs?: string[] } }\n  ) => WorkflowConfigFn;\n  try {\n    withWorkflow = require(\"workflow/next\").withWorkflow;\n  } catch {\n    console.warn(\n      \"[withAgent] workflow/next not found. Make sure workflow is installed.\"\n    );\n    return typeof configOrFn === \"function\"\n      ? configOrFn\n      : async () => configOrFn;\n  }\n\n  const baseConfigFn = withWorkflow(configOrFn, {\n    workflows: {\n      dirs: [...DEFAULT_WORKFLOW_DIRS, agentDir],\n    },\n  });\n\n  /**\n   * Return a wrapper that runs AFTER workflow processes, then adds our loader.\n   * This is necessary because workflow overwrites turbopack rules - we need to\n   * modify them after workflow is done.\n   */\n  return async (phase, ctx) => {\n    const nextConfig = await baseConfigFn(phase, ctx);\n\n    // Set up AGENT_SECRET if not already set\n    if (!process.env.AGENT_SECRET) {\n      nextConfig.env = {\n        ...nextConfig.env,\n        AGENT_SECRET: crypto.randomUUID(),\n      };\n      if (debug) {\n        console.log(\"[withAgent] Generated AGENT_SECRET\");\n      }\n    }\n\n    if (!agentPathRegex || agentFilePaths.length === 0) {\n      return nextConfig;\n    }\n\n    // Modify turbopack rules to include our loader for agent files\n    const rules = (nextConfig.turbopack?.rules || {}) as Record<\n      string,\n      TurbopackRule\n    >;\n\n    for (const key of [\"*.ts\", \"*.tsx\", \"*.js\", \"*.jsx\"]) {\n      const existingRule = rules[key];\n      if (!existingRule) {\n        continue;\n      }\n\n      /**\n       * Workflow's rule has: condition.all = [{ not: path }, { content: /use step|.../ }]\n       * We want: run loader if workflow's conditions match OR it's an agent file.\n       * So we wrap in: condition.any = [existingCondition, { path: agentPathRegex }]\n       */\n      rules[key] = {\n        ...existingRule,\n        loaders: [\n          { loader: loaderPath, options: loaderOptions },\n          ...(existingRule.loaders || []),\n        ],\n        condition: {\n          any: [existingRule.condition, { path: agentPathRegex }],\n        },\n      };\n    }\n\n    // Also configure webpack for non-turbopack builds\n    const existingWebpack = nextConfig.webpack;\n    nextConfig.webpack = (webpackConfig, context) => {\n      webpackConfig.module.rules.push({\n        test: (resourcePath: string) => agentFilePaths.includes(resourcePath),\n        use: [{ loader: loaderPath, options: loaderOptions }],\n      });\n      return existingWebpack?.(webpackConfig, context) ?? webpackConfig;\n    };\n\n    if (debug) {\n      console.log(\"[withAgent] Added agent loader to turbopack rules\");\n    }\n\n    return nextConfig;\n  };\n}\n", "{\n  \"name\": \"experimental-agent\",\n  \"version\": \"0.8.0-alpha.1\",\n  \"main\": \"./dist/index.js\",\n  \"module\": \"./dist/index.mjs\",\n  \"types\": \"./dist/index.d.ts\",\n  \"sideEffects\": true,\n  \"license\": \"MIT\",\n  \"files\": [\n    \"dist/**\"\n  ],\n  \"exports\": {\n    \".\": {\n      \"types\": \"./dist/index.d.ts\",\n      \"import\": \"./dist/index.mjs\",\n      \"require\": \"./dist/index.js\"\n    },\n    \"./storage\": {\n      \"types\": \"./dist/storage.d.ts\",\n      \"import\": \"./dist/storage.mjs\",\n      \"require\": \"./dist/storage.js\"\n    },\n    \"./sandbox\": {\n      \"types\": \"./dist/sandbox.d.ts\",\n      \"import\": \"./dist/sandbox.mjs\",\n      \"require\": \"./dist/sandbox.js\"\n    },\n    \"./next\": {\n      \"types\": \"./dist/next.d.ts\",\n      \"import\": \"./dist/next.mjs\",\n      \"require\": \"./dist/next.js\"\n    },\n    \"./next/loader\": {\n      \"types\": \"./dist/next/loader.d.ts\",\n      \"import\": \"./dist/next/loader.mjs\",\n      \"require\": \"./dist/next/loader.js\"\n    },\n    \"./next/agents\": {\n      \"types\": \"./dist/next/agents.d.ts\",\n      \"import\": \"./dist/next/agents.mjs\",\n      \"require\": \"./dist/next/agents.js\"\n    },\n    \"./framework\": {\n      \"types\": \"./dist/framework.d.ts\",\n      \"import\": \"./dist/framework.mjs\",\n      \"require\": \"./dist/framework.js\"\n    },\n    \"./framework-runtime\": {\n      \"types\": \"./dist/framework-runtime.d.ts\",\n      \"import\": \"./dist/framework-runtime.mjs\",\n      \"require\": \"./dist/framework-runtime.js\"\n    },\n    \"./client\": {\n      \"types\": \"./dist/client.d.ts\",\n      \"import\": \"./dist/client.mjs\",\n      \"require\": \"./dist/client.js\"\n    },\n    \"./lifecycle-workflow\": {\n      \"types\": \"./dist/lifecycle-workflow.d.ts\",\n      \"import\": \"./dist/lifecycle-workflow.mjs\",\n      \"require\": \"./dist/lifecycle-workflow.js\"\n    },\n    \"./lifecycle-workflow-steps\": {\n      \"types\": \"./dist/lifecycle-workflow-steps.d.ts\",\n      \"import\": \"./dist/lifecycle-workflow-steps.mjs\",\n      \"require\": \"./dist/lifecycle-workflow-steps.js\"\n    },\n    \"./react\": {\n      \"types\": \"./dist/react.d.ts\",\n      \"import\": \"./dist/react.mjs\",\n      \"require\": \"./dist/react.js\"\n    }\n  },\n  \"scripts\": {\n    \"build\": \"tsup\",\n    \"dev\": \"tsup --watch\",\n    \"clean\": \"rm -rf .turbo && rm -rf node_modules && rm -rf dist\",\n    \"release\": \"pnpm build && npm publish\",\n    \"typecheck\": \"tsc --noEmit\",\n    \"test\": \"vitest run\",\n    \"test:watch\": \"vitest\"\n  },\n  \"dependencies\": {\n    \"@elysiajs/openapi\": \"^1.4.14\",\n    \"@swc/core\": \"^1.10.0\",\n    \"@tanstack/react-query\": \"^5.90.21\",\n    \"@vercel/kv2\": \"^0.0.18\",\n    \"@vercel/oidc\": \"^3.1.0\",\n    \"@vercel/sandbox\": \"1.7.1\",\n    \"@workflow/serde\": \"4.1.0-beta.2\",\n    \"better-all\": \"^0.0.5\",\n    \"elysia\": \"^1.4.25\",\n    \"errore\": \"^0.14.0\",\n    \"fast-deep-equal\": \"^3.1.3\",\n    \"ulid\": \"^3.0.2\",\n    \"zod\": \"^4.3.6\"\n  },\n  \"devDependencies\": {\n    \"@agent/tsconfig\": \"workspace:*\",\n    \"@ai-sdk/react\": \"^3.0.88\",\n    \"@types/node\": \"^20.11.24\",\n    \"@types/react\": \"^19.2.14\",\n    \"dotenv\": \"^17.2.3\",\n    \"next\": \"^16.0.0\",\n    \"react\": \"^19.2.4\",\n    \"tsup\": \"^8.0.2\",\n    \"typescript\": \"5.5.4\",\n    \"vitest\": \"^3.0.0\",\n    \"workflow\": \"4.2.0-beta.70\"\n  },\n  \"peerDependencies\": {\n    \"ai\": \"^6.0.0\"\n  },\n  \"publishConfig\": {\n    \"access\": \"public\"\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|
|
398
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/next/index.ts", "../package.json"],
  "sourcesContent": ["import * as crypto from \"node:crypto\";\nimport * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport type { NextConfig } from \"next\";\nimport pkg from \"../../package.json\";\n\nexport type WithAgentConfig = {\n  /** Enable debug logging for the Next.js loader (agent detection, file generation). */\n  debug?: boolean;\n};\n\nconst PACKAGE_NAME = pkg.name;\nconst AGENT_PROTOCOL_VERSION = \"v1\";\nconst FILE_EXT_REGEX = /\\.(ts|tsx|js|jsx)$/;\nconst AGENT_EXPORT_REGEX = /export\\s+const\\s+(\\w+)\\s*=\\s*agent\\s*\\(/g;\nconst DEFAULT_WORKFLOW_DIRS = [\"pages\", \"app\", \"src/pages\", \"src/app\"];\n\ntype DetectedAgent = {\n  exportName: string;\n  filePath: string;\n  /** Unique identifier: exportName or exportName_hash if duplicates exist */\n  uniqueId: string;\n};\n\nfunction shortHash(str: string): string {\n  let hash = 0;\n  for (let i = 0; i < str.length; i++) {\n    const char = str.charCodeAt(i);\n    // biome-ignore lint/suspicious/noBitwiseOperators: intentional hash computation\n    hash = (hash << 5) - hash + char;\n    // biome-ignore lint/suspicious/noBitwiseOperators: convert to 32-bit integer\n    hash &= hash;\n  }\n  return Math.abs(hash).toString(36).slice(0, 6);\n}\n\nfunction hasNextAppLayout(dir: string): boolean {\n  return [\"layout.tsx\", \"layout.ts\", \"layout.js\", \"layout.jsx\"].some((f) =>\n    fs.existsSync(path.join(dir, f))\n  );\n}\n\n/**\n * Detects whether the project uses src/app or app directory structure\n * by checking which directory contains a Next.js layout file.\n * Returns the app directory path relative to cwd.\n */\nfunction getAppDir(cwd: string): string {\n  const srcAppDir = path.join(cwd, \"src\", \"app\");\n  const rootAppDir = path.join(cwd, \"app\");\n\n  if (hasNextAppLayout(srcAppDir)) {\n    return \"src/app\";\n  }\n  if (hasNextAppLayout(rootAppDir)) {\n    return \"app\";\n  }\n\n  /**\n   * Fallback when neither directory has a layout file yet\n   * (e.g. fresh project). Prefer src/app if the directory exists.\n   */\n  if (fs.existsSync(srcAppDir)) {\n    return \"src/app\";\n  }\n  return \"app\";\n}\n\n/**\n * Scans for agent exports in the project.\n */\nfunction detectAgents(cwd: string, debug: boolean): DetectedAgent[] {\n  const agents: DetectedAgent[] = [];\n\n  const dirsToScan = [path.join(cwd, \"src\"), cwd];\n\n  function scanDir(dir: string) {\n    if (!fs.existsSync(dir)) {\n      return;\n    }\n\n    const entries = fs.readdirSync(dir, { withFileTypes: true });\n    for (const entry of entries) {\n      const fullPath = path.join(dir, entry.name);\n      if (\n        entry.isDirectory() &&\n        !entry.name.startsWith(\".\") &&\n        entry.name !== \"node_modules\" &&\n        entry.name !== \"src\"\n      ) {\n        scanDir(fullPath);\n      } else if (entry.isFile() && FILE_EXT_REGEX.test(entry.name)) {\n        try {\n          const content = fs.readFileSync(fullPath, \"utf-8\");\n          if (content.includes(PACKAGE_NAME) && content.includes(\"agent(\")) {\n            // Strip single-line comments and block comments to avoid\n            // matching commented-out agent exports\n            const stripped = content\n              .replace(/\\/\\/.*$/gm, \"\")\n              .replace(/\\/\\*[\\s\\S]*?\\*\\//g, \"\");\n            const exportMatches = Array.from(\n              stripped.matchAll(AGENT_EXPORT_REGEX)\n            );\n            const seen = new Set<string>();\n            for (const match of exportMatches) {\n              if (seen.has(match[1])) {\n                continue;\n              }\n              seen.add(match[1]);\n              agents.push({\n                exportName: match[1],\n                filePath: fullPath,\n                uniqueId: \"\", // Will be set after all agents are found\n              });\n              if (debug) {\n                console.log(\n                  `[withAgent] Found agent: ${match[1]} in ${fullPath}`\n                );\n              }\n            }\n          }\n        } catch {\n          // Ignore read errors\n        }\n      }\n    }\n  }\n\n  for (const dir of dirsToScan) {\n    scanDir(dir);\n  }\n\n  // Assign unique IDs - add hash suffix if duplicate export names exist\n  const nameCounts = new Map<string, number>();\n  for (const agent of agents) {\n    nameCounts.set(\n      agent.exportName,\n      (nameCounts.get(agent.exportName) || 0) + 1\n    );\n  }\n\n  for (const agent of agents) {\n    const count = nameCounts.get(agent.exportName) ?? 0;\n    if (count > 1) {\n      agent.uniqueId = `${agent.exportName}_${shortHash(agent.filePath)}`;\n    } else {\n      agent.uniqueId = agent.exportName;\n    }\n  }\n\n  return agents;\n}\n\n/**\n * Generates all agent files in .well-known/agent/v1/:\n * - steps.js: RPC step functions with \"use step\"\n * - route.js: triggers workflow discovery\n */\nfunction generateAgentFiles(\n  agents: DetectedAgent[],\n  outputDir: string,\n  _cwd: string,\n  debug: boolean\n): void {\n  if (agents.length === 0) {\n    if (debug) {\n      console.log(\"[withAgent] No agents found, skipping generation\");\n    }\n    return;\n  }\n\n  if (!fs.existsSync(outputDir)) {\n    fs.mkdirSync(outputDir, { recursive: true });\n  }\n\n  /**\n   * Generate step functions that use dynamic import.\n   * Dynamic import ensures the agent module loads (including loader-injected init)\n   * when the step runs in workflow context, avoiding the \"not initialized\" error.\n   *\n   * Uses uniqueId for function names to handle duplicate export names across files.\n   */\n  const rpcFunctions = agents\n    .map((a) => {\n      // Calculate relative path from steps.js to the agent file\n      let agentRelPath = path\n        .relative(outputDir, a.filePath)\n        .replace(/\\\\/g, \"/\");\n\n      if (!agentRelPath.startsWith(\".\")) {\n        agentRelPath = `./${agentRelPath}`;\n      }\n\n      return `\nexport const ${a.uniqueId}Rpc = async (params) => {\n  \"use step\";\n  const { ${a.exportName} } = await import(\"${agentRelPath}\");\n  const res = await ${a.exportName}.handler(params);\n  if (res instanceof Response) {\n    return res.json();\n  }\n  return res;\n};`;\n    })\n    .join(\"\\n\");\n\n  /**\n   * Init functions wire up agent.rpc in the main app context.\n   * Uses exportName for the function name (loader matches by export name),\n   * but references uniqueId for the Rpc function.\n   */\n  const initFunctions = agents\n    .map(\n      (a) => `\nexport function __init${a.exportName[0].toUpperCase()}${a.exportName.slice(\n        1\n      )}(agent) {\n  agent.rpc = ${a.uniqueId}Rpc;\n}`\n    )\n    .join(\"\\n\");\n\n  const stepsContent = `// Auto-generated by withAgent - do not edit\n${rpcFunctions}\n${initFunctions}\n`;\n\n  const stepsPath = path.join(outputDir, \"steps.js\");\n  fs.writeFileSync(stepsPath, stepsContent);\n\n  /**\n   * Generate route.js that imports steps.js.\n   * This ensures workflow discovers the \"use step\" functions.\n   * No actual handler needed - storage RPC uses the step function directly.\n   */\n  const routeContent = `// Auto-generated by withAgent - triggers workflow discovery\nimport \"./steps.js\";\nexport function GET() {\n  return new Response(\"ok\");\n}\n`;\n\n  const routePath = path.join(outputDir, \"route.js\");\n  fs.writeFileSync(routePath, routeContent);\n\n  // Add .gitignore\n  const gitignorePath = path.join(outputDir, \".gitignore\");\n  if (!fs.existsSync(gitignorePath)) {\n    fs.writeFileSync(gitignorePath, \"*\\n\");\n  }\n\n  if (debug) {\n    console.log(`[withAgent] Generated agent files at ${outputDir}`);\n  }\n}\n\ntype TurbopackLoader =\n  | string\n  | { loader: string; options?: Record<string, unknown> };\n\ntype TurbopackRule = {\n  loaders?: TurbopackLoader[];\n  condition?: {\n    all?: unknown[];\n    any?: unknown[];\n    path?: RegExp;\n    content?: RegExp;\n    not?: unknown;\n  };\n};\n\ntype WorkflowConfigFn = (\n  phase: string,\n  ctx: { defaultConfig: NextConfig }\n) => Promise<NextConfig>;\n\ntype NextConfigInput =\n  | NextConfig\n  | ((\n      phase: string,\n      ctx: { defaultConfig: NextConfig }\n    ) => Promise<NextConfig>);\n\n/**\n * Next.js plugin that configures agent support.\n *\n * - Detects agents and generates RPC steps with \"use step\" in .well-known/agent/v1/\n * - Generates AGENT_SECRET for secure RPC calls\n * - Wraps withWorkflow for workflow support\n *\n * @example\n * ```ts\n * // next.config.ts\n * import { withAgent } from \"experimental-agent/next\";\n *\n * // Option 1: withAgent handles everything (recommended)\n * export default withAgent({});\n *\n * // Option 2: Compose with other plugins\n * export default withAgent(withSomeOtherPlugin({}));\n * ```\n */\nexport function withAgent(\n  configOrFn: NextConfigInput,\n  agentConfig?: WithAgentConfig\n): WorkflowConfigFn {\n  const debug = agentConfig?.debug ?? false;\n  const cwd = process.cwd();\n\n  // Detect app directory structure (src/app vs app)\n  const appDir = getAppDir(cwd);\n  const agentDir = `${appDir}/.well-known/agent/${AGENT_PROTOCOL_VERSION}`;\n\n  // Detect agents and generate files FIRST (before workflow discovers them)\n  const agents = detectAgents(cwd, debug);\n  const outputDir = path.join(cwd, agentDir);\n  generateAgentFiles(agents, outputDir, cwd, debug);\n\n  const agentFilePaths = agents.map((a) => a.filePath);\n  const loaderPath = require.resolve(\"./next/loader\");\n  const absoluteAppDir = path.join(cwd, appDir);\n  const loaderOptions = { appDir: absoluteAppDir, debug };\n\n  if (debug) {\n    console.log(\"[withAgent] loader path:\", loaderPath);\n    console.log(\"[withAgent] agent files:\", agentFilePaths);\n    console.log(\"[withAgent] agent dir:\", agentDir);\n  }\n\n  // Build regex to match agent file paths\n  const agentPathRegex =\n    agentFilePaths.length > 0\n      ? new RegExp(\n          `${agentFilePaths\n            .map((p) =>\n              path\n                .relative(cwd, p)\n                .replace(/\\\\/g, \"/\")\n                .replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\")\n            )\n            .join(\"|\")}$`\n        )\n      : null;\n\n  /**\n   * Always pass through withWorkflow - it handles both NextConfig and async functions.\n   * This ensures workflow is always configured, regardless of what the user passed.\n   */\n  let withWorkflow: (\n    config: NextConfigInput,\n    options?: { workflows?: { dirs?: string[] } }\n  ) => WorkflowConfigFn;\n  try {\n    withWorkflow = require(\"workflow/next\").withWorkflow;\n  } catch {\n    console.warn(\n      \"[withAgent] workflow/next not found. Make sure workflow is installed.\"\n    );\n    return typeof configOrFn === \"function\"\n      ? configOrFn\n      : async () => configOrFn;\n  }\n\n  const baseConfigFn = withWorkflow(configOrFn, {\n    workflows: {\n      dirs: [...DEFAULT_WORKFLOW_DIRS, agentDir],\n    },\n  });\n\n  /**\n   * Return a wrapper that runs AFTER workflow processes, then adds our loader.\n   * This is necessary because workflow overwrites turbopack rules - we need to\n   * modify them after workflow is done.\n   */\n  return async (phase, ctx) => {\n    const nextConfig = await baseConfigFn(phase, ctx);\n\n    // Set up AGENT_SECRET if not already set\n    if (!process.env.AGENT_SECRET) {\n      nextConfig.env = {\n        ...nextConfig.env,\n        AGENT_SECRET: crypto.randomUUID(),\n      };\n      if (debug) {\n        console.log(\"[withAgent] Generated AGENT_SECRET\");\n      }\n    }\n\n    if (!agentPathRegex || agentFilePaths.length === 0) {\n      return nextConfig;\n    }\n\n    // Modify turbopack rules to include our loader for agent files\n    const rules = (nextConfig.turbopack?.rules || {}) as Record<\n      string,\n      TurbopackRule\n    >;\n\n    for (const key of [\"*.ts\", \"*.tsx\", \"*.js\", \"*.jsx\"]) {\n      const existingRule = rules[key];\n      if (!existingRule) {\n        continue;\n      }\n\n      /**\n       * Workflow's rule has: condition.all = [{ not: path }, { content: /use step|.../ }]\n       * We want: run loader if workflow's conditions match OR it's an agent file.\n       * So we wrap in: condition.any = [existingCondition, { path: agentPathRegex }]\n       */\n      rules[key] = {\n        ...existingRule,\n        loaders: [\n          { loader: loaderPath, options: loaderOptions },\n          ...(existingRule.loaders || []),\n        ],\n        condition: {\n          any: [existingRule.condition, { path: agentPathRegex }],\n        },\n      };\n    }\n\n    // Also configure webpack for non-turbopack builds\n    const existingWebpack = nextConfig.webpack;\n    nextConfig.webpack = (webpackConfig, context) => {\n      webpackConfig.module.rules.push({\n        test: (resourcePath: string) => agentFilePaths.includes(resourcePath),\n        use: [{ loader: loaderPath, options: loaderOptions }],\n      });\n      return existingWebpack?.(webpackConfig, context) ?? webpackConfig;\n    };\n\n    if (debug) {\n      console.log(\"[withAgent] Added agent loader to turbopack rules\");\n    }\n\n    return nextConfig;\n  };\n}\n", "{\n  \"name\": \"experimental-agent\",\n  \"version\": \"0.8.0\",\n  \"main\": \"./dist/index.js\",\n  \"module\": \"./dist/index.mjs\",\n  \"types\": \"./dist/index.d.ts\",\n  \"sideEffects\": true,\n  \"license\": \"MIT\",\n  \"files\": [\n    \"dist/**\"\n  ],\n  \"exports\": {\n    \".\": {\n      \"types\": \"./dist/index.d.ts\",\n      \"import\": \"./dist/index.mjs\",\n      \"require\": \"./dist/index.js\"\n    },\n    \"./storage\": {\n      \"types\": \"./dist/storage.d.ts\",\n      \"import\": \"./dist/storage.mjs\",\n      \"require\": \"./dist/storage.js\"\n    },\n    \"./sandbox\": {\n      \"types\": \"./dist/sandbox.d.ts\",\n      \"import\": \"./dist/sandbox.mjs\",\n      \"require\": \"./dist/sandbox.js\"\n    },\n    \"./next\": {\n      \"types\": \"./dist/next.d.ts\",\n      \"import\": \"./dist/next.mjs\",\n      \"require\": \"./dist/next.js\"\n    },\n    \"./next/loader\": {\n      \"types\": \"./dist/next/loader.d.ts\",\n      \"import\": \"./dist/next/loader.mjs\",\n      \"require\": \"./dist/next/loader.js\"\n    },\n    \"./next/agents\": {\n      \"types\": \"./dist/next/agents.d.ts\",\n      \"import\": \"./dist/next/agents.mjs\",\n      \"require\": \"./dist/next/agents.js\"\n    },\n    \"./framework\": {\n      \"types\": \"./dist/framework.d.ts\",\n      \"import\": \"./dist/framework.mjs\",\n      \"require\": \"./dist/framework.js\"\n    },\n    \"./framework-runtime\": {\n      \"types\": \"./dist/framework-runtime.d.ts\",\n      \"import\": \"./dist/framework-runtime.mjs\",\n      \"require\": \"./dist/framework-runtime.js\"\n    },\n    \"./client\": {\n      \"types\": \"./dist/client.d.ts\",\n      \"import\": \"./dist/client.mjs\",\n      \"require\": \"./dist/client.js\"\n    },\n    \"./lifecycle-workflow\": {\n      \"types\": \"./dist/lifecycle-workflow.d.ts\",\n      \"import\": \"./dist/lifecycle-workflow.mjs\",\n      \"require\": \"./dist/lifecycle-workflow.js\"\n    },\n    \"./lifecycle-workflow-steps\": {\n      \"types\": \"./dist/lifecycle-workflow-steps.d.ts\",\n      \"import\": \"./dist/lifecycle-workflow-steps.mjs\",\n      \"require\": \"./dist/lifecycle-workflow-steps.js\"\n    },\n    \"./react\": {\n      \"types\": \"./dist/react.d.ts\",\n      \"import\": \"./dist/react.mjs\",\n      \"require\": \"./dist/react.js\"\n    }\n  },\n  \"scripts\": {\n    \"build\": \"tsup\",\n    \"dev\": \"tsup --watch\",\n    \"clean\": \"rm -rf .turbo && rm -rf node_modules && rm -rf dist\",\n    \"release\": \"pnpm build && npm publish\",\n    \"typecheck\": \"tsc --noEmit\",\n    \"test\": \"vitest run\",\n    \"test:watch\": \"vitest\"\n  },\n  \"dependencies\": {\n    \"@elysiajs/openapi\": \"^1.4.14\",\n    \"@swc/core\": \"^1.10.0\",\n    \"@tanstack/react-query\": \"^5.90.21\",\n    \"@vercel/kv2\": \"^0.0.18\",\n    \"@vercel/oidc\": \"^3.1.0\",\n    \"@vercel/sandbox\": \"1.7.1\",\n    \"@workflow/serde\": \"4.1.0-beta.2\",\n    \"better-all\": \"^0.0.5\",\n    \"elysia\": \"^1.4.25\",\n    \"errore\": \"^0.14.0\",\n    \"fast-deep-equal\": \"^3.1.3\",\n    \"ulid\": \"^3.0.2\",\n    \"zod\": \"^4.3.6\"\n  },\n  \"devDependencies\": {\n    \"@agent/tsconfig\": \"workspace:*\",\n    \"@ai-sdk/react\": \"^3.0.88\",\n    \"@types/node\": \"^20.11.24\",\n    \"@types/react\": \"^19.2.14\",\n    \"dotenv\": \"^17.2.3\",\n    \"next\": \"^16.0.0\",\n    \"react\": \"^19.2.4\",\n    \"tsup\": \"^8.0.2\",\n    \"typescript\": \"5.5.4\",\n    \"vitest\": \"^3.0.0\",\n    \"workflow\": \"4.2.0-beta.70\"\n  },\n  \"peerDependencies\": {\n    \"ai\": \"^6.0.0\"\n  },\n  \"publishConfig\": {\n    \"access\": \"public\"\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|