experimental-agent 0.2.0 → 0.2.3

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/index.mjs CHANGED
@@ -3,7 +3,7 @@ import {
3
3
  createSandbox,
4
4
  evictSandbox,
5
5
  getSandbox
6
- } from "./chunk-UCVXI7LW.mjs";
6
+ } from "./chunk-AML2VCQS.mjs";
7
7
  import "./chunk-ZIAHPXOJ.mjs";
8
8
  import "./chunk-TAXLUVIC.mjs";
9
9
  import {
@@ -20,7 +20,7 @@ import {
20
20
  computeSessionUsage,
21
21
  normalizeSkillsDirs,
22
22
  resolveApiUrl
23
- } from "./chunk-OCF5I43X.mjs";
23
+ } from "./chunk-NO7RHGTH.mjs";
24
24
  import {
25
25
  createLogger,
26
26
  setLogAgentName,
@@ -1,4 +1,4 @@
1
- import { J as SandboxLifecycleInput } from './client-CSTexnLF.mjs';
1
+ import { J as SandboxLifecycleInput } from './client-CEeSFGva.mjs';
2
2
  import 'errore';
3
3
  import 'ai';
4
4
  import 'zod';
@@ -1,4 +1,4 @@
1
- import { J as SandboxLifecycleInput } from './client-CSTexnLF.js';
1
+ import { J as SandboxLifecycleInput } from './client-CEeSFGva.js';
2
2
  import 'errore';
3
3
  import 'ai';
4
4
  import 'zod';
@@ -1,5 +1,6 @@
1
1
  type LoaderOptions = {
2
2
  debug?: boolean;
3
+ appDir?: string;
3
4
  };
4
5
  type LoaderContext = {
5
6
  resourcePath: string;
@@ -1,5 +1,6 @@
1
1
  type LoaderOptions = {
2
2
  debug?: boolean;
3
+ appDir?: string;
3
4
  };
4
5
  type LoaderContext = {
5
6
  resourcePath: string;
@@ -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.2.0",
42
+ version: "0.2.3",
43
43
  main: "./dist/index.js",
44
44
  module: "./dist/index.mjs",
45
45
  types: "./dist/index.d.ts",
@@ -112,7 +112,7 @@ var PACKAGE_NAME = package_default.name;
112
112
  var AGENT_PROTOCOL_VERSION = "v1";
113
113
  var TYPESCRIPT_EXT_REGEX = /\.(ts|tsx|mts|cts)$/;
114
114
  function agentRpcLoader(source) {
115
- const { debug } = this.getOptions();
115
+ const { debug, appDir: appDirOption } = this.getOptions();
116
116
  const log = debug ? (...args) => console.log("[agent-loader]", ...args) : () => void 0;
117
117
  log("processing:", this.resourcePath);
118
118
  if (!source.includes(PACKAGE_NAME)) {
@@ -139,18 +139,22 @@ function agentRpcLoader(source) {
139
139
  log("found agent exports:", agentExports);
140
140
  const fileDir = path.dirname(filename);
141
141
  let appDir;
142
- const srcIndex = filename.lastIndexOf(`${path.sep}src${path.sep}`);
143
- if (srcIndex !== -1) {
144
- const srcDir = filename.substring(0, srcIndex + 4);
145
- appDir = path.join(srcDir, "app");
142
+ if (appDirOption) {
143
+ appDir = appDirOption;
146
144
  } else {
147
- const appSep = `${path.sep}app${path.sep}`;
148
- const appIndex = filename.lastIndexOf(appSep);
149
- if (appIndex !== -1) {
150
- appDir = filename.substring(0, appIndex + appSep.length - 1);
145
+ const srcIndex = filename.lastIndexOf(`${path.sep}src${path.sep}`);
146
+ if (srcIndex !== -1) {
147
+ const srcDir = filename.substring(0, srcIndex + 4);
148
+ appDir = path.join(srcDir, "app");
151
149
  } else {
152
- log("skipping - no src/ or app/ dir found");
153
- return source;
150
+ const appSep = `${path.sep}app${path.sep}`;
151
+ const appIndex = filename.lastIndexOf(appSep);
152
+ if (appIndex !== -1) {
153
+ appDir = filename.substring(0, appIndex + appSep.length - 1);
154
+ } else {
155
+ log("skipping - no src/ or app/ dir found");
156
+ return source;
157
+ }
154
158
  }
155
159
  }
156
160
  const stepsPath = path.join(
@@ -207,4 +211,4 @@ function findAgentExports(ast) {
207
211
  }
208
212
  return exports2;
209
213
  }
210
- //# 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};\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 } = 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  // Calculate path to steps.js.\n  // Support both src/ layout (<root>/src/app) and root app/ layout (<root>/app).\n  const fileDir = path.dirname(filename);\n\n  let appDir: string;\n  const srcIndex = filename.lastIndexOf(`${path.sep}src${path.sep}`);\n  if (srcIndex !== -1) {\n    // Project uses src/ layout: resolve app/ relative to src/\n    const srcDir = filename.substring(0, srcIndex + 4);\n    appDir = path.join(srcDir, \"app\");\n  } else {\n    // Project uses root-level app/ layout.\n    // Walk up from the file to find the app/ segment in the path.\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  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  // Import the init function from steps.js and call it for each agent\n  // steps.js no longer imports the agent, so no circular dependency\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.2.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    \"./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    \"./client\": {\n      \"types\": \"./dist/client.d.ts\",\n      \"import\": \"./dist/client.mjs\",\n      \"require\": \"./dist/client.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    \"@swc/core\": \"^1.10.0\",\n    \"@vercel/oidc\": \"^3.1.0\",\n    \"better-all\": \"^0.0.5\",\n    \"errore\": \"^0.8.2\",\n    \"fast-deep-equal\": \"^3.1.3\",\n    \"@vercel/sandbox\": \"1.7.1\",\n    \"ulid\": \"^3.0.2\",\n    \"zod\": \"^4.3.6\"\n  },\n  \"devDependencies\": {\n    \"@agent/tsconfig\": \"workspace:*\",\n    \"@types/node\": \"^20.11.24\",\n    \"dotenv\": \"^17.2.3\",\n    \"next\": \"^16.0.0\",\n    \"tsup\": \"^8.0.2\",\n    \"typescript\": \"5.5.4\",\n    \"vitest\": \"^3.0.0\"\n  },\n  \"peerDependencies\": {\n    \"ai\": \"^6.0.0\",\n    \"workflow\": \"*\"\n  },\n  \"publishConfig\": {\n    \"access\": \"public\"\n  }\n}\n"],
  "mappings": "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",
  "names": ["exports"]
}

214
+ //# 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.2.3\",\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    \"./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    \"./client\": {\n      \"types\": \"./dist/client.d.ts\",\n      \"import\": \"./dist/client.mjs\",\n      \"require\": \"./dist/client.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    \"@swc/core\": \"^1.10.0\",\n    \"@vercel/oidc\": \"^3.1.0\",\n    \"better-all\": \"^0.0.5\",\n    \"errore\": \"^0.8.2\",\n    \"fast-deep-equal\": \"^3.1.3\",\n    \"@vercel/sandbox\": \"1.7.1\",\n    \"ulid\": \"^3.0.2\",\n    \"zod\": \"^4.3.6\"\n  },\n  \"devDependencies\": {\n    \"@agent/tsconfig\": \"workspace:*\",\n    \"@types/node\": \"^20.11.24\",\n    \"dotenv\": \"^17.2.3\",\n    \"next\": \"^16.0.0\",\n    \"tsup\": \"^8.0.2\",\n    \"typescript\": \"5.5.4\",\n    \"vitest\": \"^3.0.0\"\n  },\n  \"peerDependencies\": {\n    \"ai\": \"^6.0.0\",\n    \"workflow\": \"*\"\n  },\n  \"publishConfig\": {\n    \"access\": \"public\"\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,WAAsB;AACtB,kBAAuC;;;ACDvC;AAAA,EACE,MAAQ;AAAA,EACR,SAAW;AAAA,EACX,MAAQ;AAAA,EACR,QAAU;AAAA,EACV,OAAS;AAAA,EACT,aAAe;AAAA,EACf,SAAW;AAAA,EACX,OAAS;AAAA,IACP;AAAA,EACF;AAAA,EACA,SAAW;AAAA,IACT,KAAK;AAAA,MACH,OAAS;AAAA,MACT,QAAU;AAAA,MACV,SAAW;AAAA,IACb;AAAA,IACA,UAAU;AAAA,MACR,OAAS;AAAA,MACT,QAAU;AAAA,MACV,SAAW;AAAA,IACb;AAAA,IACA,iBAAiB;AAAA,MACf,OAAS;AAAA,MACT,QAAU;AAAA,MACV,SAAW;AAAA,IACb;AAAA,IACA,YAAY;AAAA,MACV,OAAS;AAAA,MACT,QAAU;AAAA,MACV,SAAW;AAAA,IACb;AAAA,EACF;AAAA,EACA,SAAW;AAAA,IACT,OAAS;AAAA,IACT,KAAO;AAAA,IACP,OAAS;AAAA,IACT,SAAW;AAAA,IACX,WAAa;AAAA,IACb,MAAQ;AAAA,IACR,cAAc;AAAA,EAChB;AAAA,EACA,cAAgB;AAAA,IACd,aAAa;AAAA,IACb,gBAAgB;AAAA,IAChB,cAAc;AAAA,IACd,QAAU;AAAA,IACV,mBAAmB;AAAA,IACnB,mBAAmB;AAAA,IACnB,MAAQ;AAAA,IACR,KAAO;AAAA,EACT;AAAA,EACA,iBAAmB;AAAA,IACjB,mBAAmB;AAAA,IACnB,eAAe;AAAA,IACf,QAAU;AAAA,IACV,MAAQ;AAAA,IACR,MAAQ;AAAA,IACR,YAAc;AAAA,IACd,QAAU;AAAA,EACZ;AAAA,EACA,kBAAoB;AAAA,IAClB,IAAM;AAAA,IACN,UAAY;AAAA,EACd;AAAA,EACA,eAAiB;AAAA,IACf,QAAU;AAAA,EACZ;AACF;;;ADtDA,IAAM,eAAe,gBAAI;AACzB,IAAM,yBAAyB;AAC/B,IAAM,uBAAuB;AAMd,SAAR,eAEL,QACQ;AACR,QAAM,EAAE,OAAO,QAAQ,aAAa,IAAI,KAAK,WAAW;AACxD,QAAM,MAAM,QACR,IAAI,SAAoB,QAAQ,IAAI,kBAAkB,GAAG,IAAI,IAC7D,MAAM;AAEV,MAAI,eAAe,KAAK,YAAY;AAEpC,MAAI,CAAC,OAAO,SAAS,YAAY,GAAG;AAClC,QAAI,4BAA4B;AAChC,WAAO;AAAA,EACT;AAEA,QAAM,WAAW,KAAK;AACtB,QAAM,eAAe,qBAAqB,KAAK,QAAQ;AAEvD,MAAI;AACJ,MAAI;AACF,cAAM,uBAAU,QAAQ;AAAA,MACtB,QAAQ,eAAe,eAAe;AAAA,MACtC,KAAK,SAAS,SAAS,MAAM;AAAA,MAC7B,KAAK,SAAS,SAAS,MAAM;AAAA,IAC/B,CAAC;AAAA,EACH,QAAQ;AACN,WAAO;AAAA,EACT;AAEA,QAAM,eAAe,iBAAiB,GAAG;AACzC,MAAI,aAAa,WAAW,GAAG;AAC7B,QAAI,6BAA6B;AACjC,WAAO;AAAA,EACT;AAEA,MAAI,wBAAwB,YAAY;AAExC,QAAM,UAAe,aAAQ,QAAQ;AAErC,MAAI;AACJ,MAAI,cAAc;AAChB,aAAS;AAAA,EACX,OAAO;AACL,UAAM,WAAW,SAAS,YAAY,GAAQ,QAAG,MAAW,QAAG,EAAE;AACjE,QAAI,aAAa,IAAI;AACnB,YAAM,SAAS,SAAS,UAAU,GAAG,WAAW,CAAC;AACjD,eAAc,UAAK,QAAQ,KAAK;AAAA,IAClC,OAAO;AACL,YAAM,SAAS,GAAQ,QAAG,MAAW,QAAG;AACxC,YAAM,WAAW,SAAS,YAAY,MAAM;AAC5C,UAAI,aAAa,IAAI;AACnB,iBAAS,SAAS,UAAU,GAAG,WAAW,OAAO,SAAS,CAAC;AAAA,MAC7D,OAAO;AACL,YAAI,sCAAsC;AAC1C,eAAO;AAAA,MACT;AAAA,IACF;AAAA,EACF;AAEA,QAAM,YAAiB;AAAA,IACrB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACA,MAAI,eAAoB,cAAS,SAAS,SAAS,EAAE,QAAQ,OAAO,GAAG;AAEvE,MAAI,EAAE,aAAa,WAAW,IAAI,KAAK,aAAa,WAAW,KAAK,IAAI;AACtE,mBAAe,KAAK,YAAY;AAAA,EAClC;AAEA,QAAM,YAAY,aACf,IAAI,CAAC,SAAS;AACb,UAAM,WAAW,SAAS,KAAK,CAAC,EAAE,YAAY,CAAC,GAAG,KAAK,MAAM,CAAC,CAAC;AAC/D,WAAO,GAAG,QAAQ,IAAI,IAAI;AAAA,EAC5B,CAAC,EACA,KAAK,IAAI;AAEZ,QAAM,cAAc,aACjB,IAAI,CAAC,SAAS,SAAS,KAAK,CAAC,EAAE,YAAY,CAAC,GAAG,KAAK,MAAM,CAAC,CAAC,EAAE,EAC9D,KAAK,IAAI;AAEZ,MAAI,6BAA6B,YAAY;AAC7C,SAAO,GAAG,MAAM;AAAA,WACP,WAAW,YAAY,YAAY;AAAA,EAC5C,SAAS;AACX;AAEA,SAAS,iBAAiB,KAAuB;AAC/C,MAAI,iBAAgC;AAEpC,aAAW,QAAQ,IAAI,MAAM;AAC3B,QACE,KAAK,SAAS,uBACd,KAAK,OAAO,UAAU,cACtB;AACA,iBAAW,aAAa,KAAK,YAAY;AACvC,YAAI,UAAU,SAAS,mBAAmB;AACxC,gBAAM,WACJ,UAAU,UAAU,SAAS,eACzB,UAAU,SAAS,QACnB,UAAU,MAAM;AAEtB,cAAI,aAAa,SAAS;AACxB,6BAAiB,UAAU,MAAM;AACjC;AAAA,UACF;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAEA,MAAI,CAAC,gBAAgB;AACnB,WAAO,CAAC;AAAA,EACV;AAEA,QAAMA,WAAoB,CAAC;AAE3B,aAAW,QAAQ,IAAI,MAAM;AAC3B,QAAI,KAAK,SAAS,uBAAuB,KAAK,aAAa;AACzD,YAAM,OAAO,KAAK;AAClB,UAAI,KAAK,SAAS,uBAAuB;AACvC,mBAAW,cAAc,KAAK,cAAc;AAC1C,cACE,WAAW,GAAG,SAAS,gBACvB,WAAW,MAAM,SAAS,oBAC1B,WAAW,KAAK,OAAO,SAAS,gBAChC,WAAW,KAAK,OAAO,UAAU,gBACjC;AACA,YAAAA,SAAQ,KAAK,WAAW,GAAG,KAAK;AAAA,UAClC;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAEA,SAAOA;AACT;",
  "names": ["exports"]
}

@@ -1,6 +1,6 @@
1
1
  import {
2
2
  package_default
3
- } from "../chunk-GL7Q3MDU.mjs";
3
+ } from "../chunk-7M6UPURS.mjs";
4
4
  import "../chunk-BJTO5JO5.mjs";
5
5
 
6
6
  // src/next/loader.ts
@@ -10,7 +10,7 @@ var PACKAGE_NAME = package_default.name;
10
10
  var AGENT_PROTOCOL_VERSION = "v1";
11
11
  var TYPESCRIPT_EXT_REGEX = /\.(ts|tsx|mts|cts)$/;
12
12
  function agentRpcLoader(source) {
13
- const { debug } = this.getOptions();
13
+ const { debug, appDir: appDirOption } = this.getOptions();
14
14
  const log = debug ? (...args) => console.log("[agent-loader]", ...args) : () => void 0;
15
15
  log("processing:", this.resourcePath);
16
16
  if (!source.includes(PACKAGE_NAME)) {
@@ -37,18 +37,22 @@ function agentRpcLoader(source) {
37
37
  log("found agent exports:", agentExports);
38
38
  const fileDir = path.dirname(filename);
39
39
  let appDir;
40
- const srcIndex = filename.lastIndexOf(`${path.sep}src${path.sep}`);
41
- if (srcIndex !== -1) {
42
- const srcDir = filename.substring(0, srcIndex + 4);
43
- appDir = path.join(srcDir, "app");
40
+ if (appDirOption) {
41
+ appDir = appDirOption;
44
42
  } else {
45
- const appSep = `${path.sep}app${path.sep}`;
46
- const appIndex = filename.lastIndexOf(appSep);
47
- if (appIndex !== -1) {
48
- appDir = filename.substring(0, appIndex + appSep.length - 1);
43
+ const srcIndex = filename.lastIndexOf(`${path.sep}src${path.sep}`);
44
+ if (srcIndex !== -1) {
45
+ const srcDir = filename.substring(0, srcIndex + 4);
46
+ appDir = path.join(srcDir, "app");
49
47
  } else {
50
- log("skipping - no src/ or app/ dir found");
51
- return source;
48
+ const appSep = `${path.sep}app${path.sep}`;
49
+ const appIndex = filename.lastIndexOf(appSep);
50
+ if (appIndex !== -1) {
51
+ appDir = filename.substring(0, appIndex + appSep.length - 1);
52
+ } else {
53
+ log("skipping - no src/ or app/ dir found");
54
+ return source;
55
+ }
52
56
  }
53
57
  }
54
58
  const stepsPath = path.join(
@@ -108,4 +112,4 @@ function findAgentExports(ast) {
108
112
  export {
109
113
  agentRpcLoader as default
110
114
  };
111
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/next/loader.ts"],
  "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};\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 } = 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  // Calculate path to steps.js.\n  // Support both src/ layout (<root>/src/app) and root app/ layout (<root>/app).\n  const fileDir = path.dirname(filename);\n\n  let appDir: string;\n  const srcIndex = filename.lastIndexOf(`${path.sep}src${path.sep}`);\n  if (srcIndex !== -1) {\n    // Project uses src/ layout: resolve app/ relative to src/\n    const srcDir = filename.substring(0, srcIndex + 4);\n    appDir = path.join(srcDir, \"app\");\n  } else {\n    // Project uses root-level app/ layout.\n    // Walk up from the file to find the app/ segment in the path.\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  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  // Import the init function from steps.js and call it for each agent\n  // steps.js no longer imports the agent, so no circular dependency\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"],
  "mappings": "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",
  "names": []
}

115
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/next/loader.ts"],
  "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"],
  "mappings": "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",
  "names": []
}

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.2.0",
43
+ version: "0.2.3",
44
44
  main: "./dist/index.js",
45
45
  module: "./dist/index.mjs",
46
46
  types: "./dist/index.d.ts",
@@ -123,8 +123,20 @@ function shortHash(str) {
123
123
  }
124
124
  return Math.abs(hash).toString(36).slice(0, 6);
125
125
  }
126
+ function hasNextAppLayout(dir) {
127
+ return ["layout.tsx", "layout.ts", "layout.js", "layout.jsx"].some(
128
+ (f) => fs.existsSync(path.join(dir, f))
129
+ );
130
+ }
126
131
  function getAppDir(cwd) {
127
132
  const srcAppDir = path.join(cwd, "src", "app");
133
+ const rootAppDir = path.join(cwd, "app");
134
+ if (hasNextAppLayout(srcAppDir)) {
135
+ return "src/app";
136
+ }
137
+ if (hasNextAppLayout(rootAppDir)) {
138
+ return "app";
139
+ }
128
140
  if (fs.existsSync(srcAppDir)) {
129
141
  return "src/app";
130
142
  }
@@ -258,6 +270,8 @@ function withAgent(configOrFn, agentConfig) {
258
270
  generateAgentFiles(agents, outputDir, cwd, debug);
259
271
  const agentFilePaths = agents.map((a) => a.filePath);
260
272
  const loaderPath = require.resolve("./next/loader");
273
+ const absoluteAppDir = path.join(cwd, appDir);
274
+ const loaderOptions = { appDir: absoluteAppDir, debug };
261
275
  if (debug) {
262
276
  console.log("[withAgent] loader path:", loaderPath);
263
277
  console.log("[withAgent] agent files:", agentFilePaths);
@@ -304,7 +318,7 @@ function withAgent(configOrFn, agentConfig) {
304
318
  }
305
319
  rules[key] = {
306
320
  ...existingRule,
307
- loaders: [loaderPath, ...existingRule.loaders || []],
321
+ loaders: [{ loader: loaderPath, options: loaderOptions }, ...existingRule.loaders || []],
308
322
  condition: {
309
323
  any: [existingRule.condition, { path: agentPathRegex }]
310
324
  }
@@ -314,7 +328,7 @@ function withAgent(configOrFn, agentConfig) {
314
328
  nextConfig.webpack = (webpackConfig, context) => {
315
329
  webpackConfig.module.rules.push({
316
330
  test: (resourcePath) => agentFilePaths.includes(resourcePath),
317
- use: [{ loader: loaderPath }]
331
+ use: [{ loader: loaderPath, options: loaderOptions }]
318
332
  });
319
333
  return existingWebpack?.(webpackConfig, context) ?? webpackConfig;
320
334
  };
@@ -328,4 +342,4 @@ function withAgent(configOrFn, agentConfig) {
328
342
  0 && (module.exports = {
329
343
  withAgent
330
344
  });
331
- //# 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\n/**\n * Detects whether the project uses src/app or app directory structure.\n * Returns the app directory path relative to cwd.\n */\nfunction getAppDir(cwd: string): string {\n  const srcAppDir = path.join(cwd, \"src\", \"app\");\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 TurbopackRule = {\n  loaders?: string[];\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\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: [loaderPath, ...(existingRule.loaders || [])],\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 }],\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.2.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    \"./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    \"./client\": {\n      \"types\": \"./dist/client.d.ts\",\n      \"import\": \"./dist/client.mjs\",\n      \"require\": \"./dist/client.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    \"@swc/core\": \"^1.10.0\",\n    \"@vercel/oidc\": \"^3.1.0\",\n    \"better-all\": \"^0.0.5\",\n    \"errore\": \"^0.8.2\",\n    \"fast-deep-equal\": \"^3.1.3\",\n    \"@vercel/sandbox\": \"1.7.1\",\n    \"ulid\": \"^3.0.2\",\n    \"zod\": \"^4.3.6\"\n  },\n  \"devDependencies\": {\n    \"@agent/tsconfig\": \"workspace:*\",\n    \"@types/node\": \"^20.11.24\",\n    \"dotenv\": \"^17.2.3\",\n    \"next\": \"^16.0.0\",\n    \"tsup\": \"^8.0.2\",\n    \"typescript\": \"5.5.4\",\n    \"vitest\": \"^3.0.0\"\n  },\n  \"peerDependencies\": {\n    \"ai\": \"^6.0.0\",\n    \"workflow\": \"*\"\n  },\n  \"publishConfig\": {\n    \"access\": \"public\"\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

345
+ //# 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 = string | { 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: [{ loader: loaderPath, options: loaderOptions }, ...(existingRule.loaders || [])],\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.2.3\",\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    \"./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    \"./client\": {\n      \"types\": \"./dist/client.d.ts\",\n      \"import\": \"./dist/client.mjs\",\n      \"require\": \"./dist/client.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    \"@swc/core\": \"^1.10.0\",\n    \"@vercel/oidc\": \"^3.1.0\",\n    \"better-all\": \"^0.0.5\",\n    \"errore\": \"^0.8.2\",\n    \"fast-deep-equal\": \"^3.1.3\",\n    \"@vercel/sandbox\": \"1.7.1\",\n    \"ulid\": \"^3.0.2\",\n    \"zod\": \"^4.3.6\"\n  },\n  \"devDependencies\": {\n    \"@agent/tsconfig\": \"workspace:*\",\n    \"@types/node\": \"^20.11.24\",\n    \"dotenv\": \"^17.2.3\",\n    \"next\": \"^16.0.0\",\n    \"tsup\": \"^8.0.2\",\n    \"typescript\": \"5.5.4\",\n    \"vitest\": \"^3.0.0\"\n  },\n  \"peerDependencies\": {\n    \"ai\": \"^6.0.0\",\n    \"workflow\": \"*\"\n  },\n  \"publishConfig\": {\n    \"access\": \"public\"\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

package/dist/next.mjs CHANGED
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  package_default
3
- } from "./chunk-GL7Q3MDU.mjs";
3
+ } from "./chunk-7M6UPURS.mjs";
4
4
  import {
5
5
  __require
6
6
  } from "./chunk-BJTO5JO5.mjs";
@@ -23,8 +23,20 @@ function shortHash(str) {
23
23
  }
24
24
  return Math.abs(hash).toString(36).slice(0, 6);
25
25
  }
26
+ function hasNextAppLayout(dir) {
27
+ return ["layout.tsx", "layout.ts", "layout.js", "layout.jsx"].some(
28
+ (f) => fs.existsSync(path.join(dir, f))
29
+ );
30
+ }
26
31
  function getAppDir(cwd) {
27
32
  const srcAppDir = path.join(cwd, "src", "app");
33
+ const rootAppDir = path.join(cwd, "app");
34
+ if (hasNextAppLayout(srcAppDir)) {
35
+ return "src/app";
36
+ }
37
+ if (hasNextAppLayout(rootAppDir)) {
38
+ return "app";
39
+ }
28
40
  if (fs.existsSync(srcAppDir)) {
29
41
  return "src/app";
30
42
  }
@@ -158,6 +170,8 @@ function withAgent(configOrFn, agentConfig) {
158
170
  generateAgentFiles(agents, outputDir, cwd, debug);
159
171
  const agentFilePaths = agents.map((a) => a.filePath);
160
172
  const loaderPath = __require.resolve("./next/loader");
173
+ const absoluteAppDir = path.join(cwd, appDir);
174
+ const loaderOptions = { appDir: absoluteAppDir, debug };
161
175
  if (debug) {
162
176
  console.log("[withAgent] loader path:", loaderPath);
163
177
  console.log("[withAgent] agent files:", agentFilePaths);
@@ -204,7 +218,7 @@ function withAgent(configOrFn, agentConfig) {
204
218
  }
205
219
  rules[key] = {
206
220
  ...existingRule,
207
- loaders: [loaderPath, ...existingRule.loaders || []],
221
+ loaders: [{ loader: loaderPath, options: loaderOptions }, ...existingRule.loaders || []],
208
222
  condition: {
209
223
  any: [existingRule.condition, { path: agentPathRegex }]
210
224
  }
@@ -214,7 +228,7 @@ function withAgent(configOrFn, agentConfig) {
214
228
  nextConfig.webpack = (webpackConfig, context) => {
215
229
  webpackConfig.module.rules.push({
216
230
  test: (resourcePath) => agentFilePaths.includes(resourcePath),
217
- use: [{ loader: loaderPath }]
231
+ use: [{ loader: loaderPath, options: loaderOptions }]
218
232
  });
219
233
  return existingWebpack?.(webpackConfig, context) ?? webpackConfig;
220
234
  };
@@ -227,4 +241,4 @@ function withAgent(configOrFn, agentConfig) {
227
241
  export {
228
242
  withAgent
229
243
  };
230
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/next/index.ts"],
  "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\n/**\n * Detects whether the project uses src/app or app directory structure.\n * Returns the app directory path relative to cwd.\n */\nfunction getAppDir(cwd: string): string {\n  const srcAppDir = path.join(cwd, \"src\", \"app\");\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 TurbopackRule = {\n  loaders?: string[];\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\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: [loaderPath, ...(existingRule.loaders || [])],\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 }],\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"],
  "mappings": "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",
  "names": []
}

244
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/next/index.ts"],
  "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 = string | { 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: [{ loader: loaderPath, options: loaderOptions }, ...(existingRule.loaders || [])],\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"],
  "mappings": "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",
  "names": []
}
