experimental-agent 0.0.2 → 0.0.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.
Files changed (57) hide show
  1. package/README.md +13 -2
  2. package/dist/agent-workflow.d.mts +11 -3
  3. package/dist/agent-workflow.d.ts +11 -3
  4. package/dist/agent-workflow.js +1921 -1144
  5. package/dist/agent-workflow.mjs +7 -3
  6. package/dist/chunk-3ODWQVIA.mjs +12 -0
  7. package/dist/chunk-64THY7Y7.mjs +155 -0
  8. package/dist/chunk-GSRJYPWF.mjs +284 -0
  9. package/dist/chunk-HJGPUEFC.mjs +42 -0
  10. package/dist/chunk-JEE2FQ4O.mjs +844 -0
  11. package/dist/chunk-TQRCSTCF.mjs +103 -0
  12. package/dist/chunk-UFVWOC5L.mjs +79 -0
  13. package/dist/chunk-VBLZWXVE.mjs +318 -0
  14. package/dist/chunk-ZASQBPOI.mjs +2057 -0
  15. package/dist/{types-DPXFq_r6.d.ts → client-BlSrVoPI.d.mts} +868 -31
  16. package/dist/{types-DPXFq_r6.d.mts → client-BlSrVoPI.d.ts} +868 -31
  17. package/dist/client-SREKHM6I.mjs +15 -0
  18. package/dist/client.d.mts +37 -0
  19. package/dist/client.d.ts +37 -0
  20. package/dist/client.js +58 -0
  21. package/dist/client.mjs +30 -0
  22. package/dist/{client-HUG4HT5L.mjs → handler-36FM5H35.mjs} +4 -5
  23. package/dist/index.d.mts +3 -4
  24. package/dist/index.d.ts +3 -4
  25. package/dist/index.js +3102 -1438
  26. package/dist/index.mjs +720 -147
  27. package/dist/lifecycle-workflow.d.mts +3 -10
  28. package/dist/lifecycle-workflow.d.ts +3 -10
  29. package/dist/lifecycle-workflow.js +170 -1246
  30. package/dist/lifecycle-workflow.mjs +5 -41
  31. package/dist/local-fs-handlers-P4WGW3QY.mjs +235 -0
  32. package/dist/next/loader.d.mts +14 -0
  33. package/dist/next/loader.d.ts +14 -0
  34. package/dist/next/loader.js +206 -0
  35. package/dist/next/loader.mjs +103 -0
  36. package/dist/next.d.mts +34 -0
  37. package/dist/next.d.ts +34 -0
  38. package/dist/next.js +329 -0
  39. package/dist/next.mjs +224 -0
  40. package/dist/process-manager-JAKAXROL.mjs +10 -0
  41. package/dist/{client-4Y3UPWFR.mjs → sandbox-QAPGBVYM.mjs} +4 -3
  42. package/dist/storage-Q376OZH3.mjs +20 -0
  43. package/dist/{vercel-2CFDMEHB.mjs → vercel-LLXAHKVJ.mjs} +3 -1
  44. package/dist/vercel-sdk-VHKEX2GQ.mjs +8 -0
  45. package/package.json +32 -19
  46. package/dist/chunk-24DJSI7C.mjs +0 -374
  47. package/dist/chunk-4RGMKC2M.mjs +0 -755
  48. package/dist/chunk-6ICYKNCC.mjs +0 -284
  49. package/dist/chunk-PGYYQ3WZ.mjs +0 -1088
  50. package/dist/client-BBpD9kKL.d.ts +0 -193
  51. package/dist/client-BGJViybU.d.mts +0 -193
  52. package/dist/lifecycle-workflow-steps-HHN46ZAD.mjs +0 -20
  53. package/dist/local-BYPFRMLZ.mjs +0 -282
  54. package/dist/process-manager-H2HF6G4G.mjs +0 -153
  55. package/dist/sandbox-BFA4ECEQ.mjs +0 -10
  56. package/dist/storage-2U2QFNWI.mjs +0 -27
  57. /package/dist/{chunk-36X6L7SK.mjs → chunk-TAXLUVIC.mjs} +0 -0
package/dist/next.mjs ADDED
@@ -0,0 +1,224 @@
1
+ import {
2
+ package_default
3
+ } from "./chunk-UFVWOC5L.mjs";
4
+ import {
5
+ __require
6
+ } from "./chunk-3ODWQVIA.mjs";
7
+
8
+ // src/next/index.ts
9
+ import * as crypto from "node:crypto";
10
+ import * as fs from "node:fs";
11
+ import * as path from "node:path";
12
+ var PACKAGE_NAME = package_default.name;
13
+ var AGENT_PROTOCOL_VERSION = "v1";
14
+ var FILE_EXT_REGEX = /\.(ts|tsx|js|jsx)$/;
15
+ var AGENT_EXPORT_REGEX = /export\s+const\s+(\w+)\s*=\s*agent\s*\(/g;
16
+ var DEFAULT_WORKFLOW_DIRS = ["pages", "app", "src/pages", "src/app"];
17
+ function shortHash(str) {
18
+ let hash = 0;
19
+ for (let i = 0; i < str.length; i++) {
20
+ const char = str.charCodeAt(i);
21
+ hash = (hash << 5) - hash + char;
22
+ hash &= hash;
23
+ }
24
+ return Math.abs(hash).toString(36).slice(0, 6);
25
+ }
26
+ function getAppDir(cwd) {
27
+ const srcAppDir = path.join(cwd, "src", "app");
28
+ if (fs.existsSync(srcAppDir)) {
29
+ return "src/app";
30
+ }
31
+ return "app";
32
+ }
33
+ function detectAgents(cwd, debug) {
34
+ const agents = [];
35
+ const dirsToScan = [path.join(cwd, "src"), cwd];
36
+ function scanDir(dir) {
37
+ if (!fs.existsSync(dir)) {
38
+ return;
39
+ }
40
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
41
+ for (const entry of entries) {
42
+ const fullPath = path.join(dir, entry.name);
43
+ if (entry.isDirectory() && !entry.name.startsWith(".") && entry.name !== "node_modules" && entry.name !== "src") {
44
+ scanDir(fullPath);
45
+ } else if (entry.isFile() && FILE_EXT_REGEX.test(entry.name)) {
46
+ try {
47
+ const content = fs.readFileSync(fullPath, "utf-8");
48
+ if (content.includes(PACKAGE_NAME) && content.includes("agent(")) {
49
+ const exportMatches = content.matchAll(AGENT_EXPORT_REGEX);
50
+ for (const match of exportMatches) {
51
+ agents.push({
52
+ exportName: match[1],
53
+ filePath: fullPath,
54
+ uniqueId: ""
55
+ // Will be set after all agents are found
56
+ });
57
+ if (debug) {
58
+ console.log(
59
+ `[withAgent] Found agent: ${match[1]} in ${fullPath}`
60
+ );
61
+ }
62
+ }
63
+ }
64
+ } catch {
65
+ }
66
+ }
67
+ }
68
+ }
69
+ for (const dir of dirsToScan) {
70
+ scanDir(dir);
71
+ }
72
+ const nameCounts = /* @__PURE__ */ new Map();
73
+ for (const agent of agents) {
74
+ nameCounts.set(
75
+ agent.exportName,
76
+ (nameCounts.get(agent.exportName) || 0) + 1
77
+ );
78
+ }
79
+ for (const agent of agents) {
80
+ const count = nameCounts.get(agent.exportName) ?? 0;
81
+ if (count > 1) {
82
+ agent.uniqueId = `${agent.exportName}_${shortHash(agent.filePath)}`;
83
+ } else {
84
+ agent.uniqueId = agent.exportName;
85
+ }
86
+ }
87
+ return agents;
88
+ }
89
+ function generateAgentFiles(agents, outputDir, _cwd, debug) {
90
+ if (agents.length === 0) {
91
+ if (debug) {
92
+ console.log("[withAgent] No agents found, skipping generation");
93
+ }
94
+ return;
95
+ }
96
+ if (!fs.existsSync(outputDir)) {
97
+ fs.mkdirSync(outputDir, { recursive: true });
98
+ }
99
+ const rpcFunctions = agents.map((a) => {
100
+ let agentRelPath = path.relative(outputDir, a.filePath).replace(/\\/g, "/");
101
+ if (!agentRelPath.startsWith(".")) {
102
+ agentRelPath = `./${agentRelPath}`;
103
+ }
104
+ return `
105
+ export const ${a.uniqueId}Rpc = async (params) => {
106
+ "use step";
107
+ const { ${a.exportName} } = await import("${agentRelPath}");
108
+ const res = await ${a.exportName}.handler(params);
109
+ if (res instanceof Response) {
110
+ return res.json();
111
+ }
112
+ return res;
113
+ };`;
114
+ }).join("\n");
115
+ const initFunctions = agents.map(
116
+ (a) => `
117
+ export function __init${a.exportName[0].toUpperCase()}${a.exportName.slice(
118
+ 1
119
+ )}(agent) {
120
+ agent.rpc = ${a.uniqueId}Rpc;
121
+ }`
122
+ ).join("\n");
123
+ const stepsContent = `// Auto-generated by withAgent - do not edit
124
+ ${rpcFunctions}
125
+ ${initFunctions}
126
+ `;
127
+ const stepsPath = path.join(outputDir, "steps.js");
128
+ fs.writeFileSync(stepsPath, stepsContent);
129
+ const routeContent = `// Auto-generated by withAgent - triggers workflow discovery
130
+ import "./steps.js";
131
+ export function GET() {
132
+ return new Response("ok");
133
+ }
134
+ `;
135
+ const routePath = path.join(outputDir, "route.js");
136
+ fs.writeFileSync(routePath, routeContent);
137
+ const gitignorePath = path.join(outputDir, ".gitignore");
138
+ if (!fs.existsSync(gitignorePath)) {
139
+ fs.writeFileSync(gitignorePath, "*\n");
140
+ }
141
+ if (debug) {
142
+ console.log(`[withAgent] Generated agent files at ${outputDir}`);
143
+ }
144
+ }
145
+ function withAgent(configOrFn, agentConfig) {
146
+ const debug = agentConfig?.debug ?? false;
147
+ const cwd = process.cwd();
148
+ const appDir = getAppDir(cwd);
149
+ const agentDir = `${appDir}/.well-known/agent/${AGENT_PROTOCOL_VERSION}`;
150
+ const agents = detectAgents(cwd, debug);
151
+ const outputDir = path.join(cwd, agentDir);
152
+ generateAgentFiles(agents, outputDir, cwd, debug);
153
+ const agentFilePaths = agents.map((a) => a.filePath);
154
+ const loaderPath = __require.resolve("./next/loader");
155
+ if (debug) {
156
+ console.log("[withAgent] loader path:", loaderPath);
157
+ console.log("[withAgent] agent files:", agentFilePaths);
158
+ console.log("[withAgent] agent dir:", agentDir);
159
+ }
160
+ const agentPathRegex = agentFilePaths.length > 0 ? new RegExp(
161
+ `${agentFilePaths.map(
162
+ (p) => path.relative(cwd, p).replace(/\\/g, "/").replace(/[.*+?^${}()|[\]\\]/g, "\\$&")
163
+ ).join("|")}$`
164
+ ) : null;
165
+ let withWorkflow;
166
+ try {
167
+ withWorkflow = __require("workflow/next").withWorkflow;
168
+ } catch {
169
+ console.warn(
170
+ "[withAgent] workflow/next not found. Make sure workflow is installed."
171
+ );
172
+ return typeof configOrFn === "function" ? configOrFn : async () => configOrFn;
173
+ }
174
+ const baseConfigFn = withWorkflow(configOrFn, {
175
+ workflows: {
176
+ dirs: [...DEFAULT_WORKFLOW_DIRS, agentDir]
177
+ }
178
+ });
179
+ return async (phase, ctx) => {
180
+ const nextConfig = await baseConfigFn(phase, ctx);
181
+ if (!process.env.AGENT_SECRET) {
182
+ nextConfig.env = {
183
+ ...nextConfig.env,
184
+ AGENT_SECRET: crypto.randomUUID()
185
+ };
186
+ if (debug) {
187
+ console.log("[withAgent] Generated AGENT_SECRET");
188
+ }
189
+ }
190
+ if (!agentPathRegex || agentFilePaths.length === 0) {
191
+ return nextConfig;
192
+ }
193
+ const rules = nextConfig.turbopack?.rules || {};
194
+ for (const key of ["*.ts", "*.tsx", "*.js", "*.jsx"]) {
195
+ const existingRule = rules[key];
196
+ if (!existingRule) {
197
+ continue;
198
+ }
199
+ rules[key] = {
200
+ ...existingRule,
201
+ loaders: [loaderPath, ...existingRule.loaders || []],
202
+ condition: {
203
+ any: [existingRule.condition, { path: agentPathRegex }]
204
+ }
205
+ };
206
+ }
207
+ const existingWebpack = nextConfig.webpack;
208
+ nextConfig.webpack = (webpackConfig, context) => {
209
+ webpackConfig.module.rules.push({
210
+ test: (resourcePath) => agentFilePaths.includes(resourcePath),
211
+ use: [{ loader: loaderPath }]
212
+ });
213
+ return existingWebpack?.(webpackConfig, context) ?? webpackConfig;
214
+ };
215
+ if (debug) {
216
+ console.log("[withAgent] Added agent loader to turbopack rules");
217
+ }
218
+ return nextConfig;
219
+ };
220
+ }
221
+ export {
222
+ withAgent
223
+ };
224
+ //# 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 */\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            const exportMatches = content.matchAll(AGENT_EXPORT_REGEX);\n            for (const match of exportMatches) {\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": []
}

@@ -0,0 +1,10 @@
1
+ import {
2
+ DEFAULT_WAIT_UNTIL,
3
+ createProcessManager
4
+ } from "./chunk-64THY7Y7.mjs";
5
+ import "./chunk-3ODWQVIA.mjs";
6
+ export {
7
+ DEFAULT_WAIT_UNTIL,
8
+ createProcessManager
9
+ };
10
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFtdLAogICJzb3VyY2VzQ29udGVudCI6IFtdLAogICJtYXBwaW5ncyI6ICIiLAogICJuYW1lcyI6IFtdCn0K
@@ -1,8 +1,9 @@
1
1
  import {
2
2
  getSandbox
3
- } from "./chunk-4RGMKC2M.mjs";
4
- import "./chunk-6ICYKNCC.mjs";
5
- import "./chunk-24DJSI7C.mjs";
3
+ } from "./chunk-JEE2FQ4O.mjs";
4
+ import "./chunk-TQRCSTCF.mjs";
5
+ import "./chunk-HJGPUEFC.mjs";
6
+ import "./chunk-3ODWQVIA.mjs";
6
7
  export {
7
8
  getSandbox
8
9
  };
@@ -0,0 +1,20 @@
1
+ import "./chunk-TAXLUVIC.mjs";
2
+ import {
3
+ STORAGE_RPC_METHODS,
4
+ handleStorageRpc
5
+ } from "./chunk-VBLZWXVE.mjs";
6
+ import {
7
+ DEFAULT_NAMESPACE,
8
+ LOCAL_STORAGE_VERSION,
9
+ getStorage
10
+ } from "./chunk-GSRJYPWF.mjs";
11
+ import "./chunk-HJGPUEFC.mjs";
12
+ import "./chunk-3ODWQVIA.mjs";
13
+ export {
14
+ DEFAULT_NAMESPACE,
15
+ LOCAL_STORAGE_VERSION,
16
+ STORAGE_RPC_METHODS,
17
+ getStorage,
18
+ handleStorageRpc
19
+ };
20
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFtdLAogICJzb3VyY2VzQ29udGVudCI6IFtdLAogICJtYXBwaW5ncyI6ICIiLAogICJuYW1lcyI6IFtdCn0K
@@ -1,3 +1,5 @@
1
+ import "./chunk-3ODWQVIA.mjs";
2
+
1
3
  // src/storage/bindings/vercel.ts
2
4
  var VERCEL_STORAGE_URL = "https://agent-sdk-storage-nine.labs.vercel.dev/api/storage";
3
5
  async function getVercelStorageConfig() {
@@ -15,4 +17,4 @@ async function getVercelStorageConfig() {
15
17
  export {
16
18
  getVercelStorageConfig
17
19
  };
18
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL3N0b3JhZ2UvYmluZGluZ3MvdmVyY2VsLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJjb25zdCBWRVJDRUxfU1RPUkFHRV9VUkwgPVxuICBcImh0dHBzOi8vYWdlbnQtc2RrLXN0b3JhZ2UtbmluZS5sYWJzLnZlcmNlbC5kZXYvYXBpL3N0b3JhZ2VcIjtcblxuZXhwb3J0IHR5cGUgVmVyY2VsU3RvcmFnZUNvbmZpZyA9IHtcbiAgdXJsOiBzdHJpbmc7XG4gIGhlYWRlcnM6IFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG59O1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2V0VmVyY2VsU3RvcmFnZUNvbmZpZygpOiBQcm9taXNlPFZlcmNlbFN0b3JhZ2VDb25maWc+IHtcbiAgbGV0IHRva2VuOiBzdHJpbmcgfCBudWxsID0gbnVsbDtcblxuICB0cnkge1xuICAgIGNvbnN0IHsgZ2V0VmVyY2VsT2lkY1Rva2VuIH0gPSBhd2FpdCBpbXBvcnQoXCJAdmVyY2VsL29pZGNcIik7XG4gICAgdG9rZW4gPSBhd2FpdCBnZXRWZXJjZWxPaWRjVG9rZW4oKTtcbiAgfSBjYXRjaCB7XG4gICAgLy8gT0lEQyBub3QgYXZhaWxhYmxlIChsb2NhbCBkZXYsIG5vbi1WZXJjZWwgZW52aXJvbm1lbnQpXG4gIH1cblxuICByZXR1cm4ge1xuICAgIHVybDogVkVSQ0VMX1NUT1JBR0VfVVJMLFxuICAgIGhlYWRlcnM6IHRva2VuID8geyBBdXRob3JpemF0aW9uOiBgQmVhcmVyICR7dG9rZW59YCB9IDoge30sXG4gIH07XG59XG4iXSwKICAibWFwcGluZ3MiOiAiO0FBQUEsSUFBTSxxQkFDSjtBQU9GLGVBQXNCLHlCQUF1RDtBQUMzRSxNQUFJLFFBQXVCO0FBRTNCLE1BQUk7QUFDRixVQUFNLEVBQUUsbUJBQW1CLElBQUksTUFBTSxPQUFPLGNBQWM7QUFDMUQsWUFBUSxNQUFNLG1CQUFtQjtBQUFBLEVBQ25DLFFBQVE7QUFBQSxFQUVSO0FBRUEsU0FBTztBQUFBLElBQ0wsS0FBSztBQUFBLElBQ0wsU0FBUyxRQUFRLEVBQUUsZUFBZSxVQUFVLEtBQUssR0FBRyxJQUFJLENBQUM7QUFBQSxFQUMzRDtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
20
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL3N0b3JhZ2UvYmluZGluZ3MvdmVyY2VsLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJjb25zdCBWRVJDRUxfU1RPUkFHRV9VUkwgPVxuICBcImh0dHBzOi8vYWdlbnQtc2RrLXN0b3JhZ2UtbmluZS5sYWJzLnZlcmNlbC5kZXYvYXBpL3N0b3JhZ2VcIjtcblxuZXhwb3J0IHR5cGUgVmVyY2VsU3RvcmFnZUNvbmZpZyA9IHtcbiAgdXJsOiBzdHJpbmc7XG4gIGhlYWRlcnM6IFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG59O1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2V0VmVyY2VsU3RvcmFnZUNvbmZpZygpOiBQcm9taXNlPFZlcmNlbFN0b3JhZ2VDb25maWc+IHtcbiAgbGV0IHRva2VuOiBzdHJpbmcgfCBudWxsID0gbnVsbDtcblxuICB0cnkge1xuICAgIGNvbnN0IHsgZ2V0VmVyY2VsT2lkY1Rva2VuIH0gPSBhd2FpdCBpbXBvcnQoXCJAdmVyY2VsL29pZGNcIik7XG4gICAgdG9rZW4gPSBhd2FpdCBnZXRWZXJjZWxPaWRjVG9rZW4oKTtcbiAgfSBjYXRjaCB7XG4gICAgLy8gT0lEQyBub3QgYXZhaWxhYmxlIChsb2NhbCBkZXYsIG5vbi1WZXJjZWwgZW52aXJvbm1lbnQpXG4gIH1cblxuICByZXR1cm4ge1xuICAgIHVybDogVkVSQ0VMX1NUT1JBR0VfVVJMLFxuICAgIGhlYWRlcnM6IHRva2VuID8geyBBdXRob3JpemF0aW9uOiBgQmVhcmVyICR7dG9rZW59YCB9IDoge30sXG4gIH07XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7QUFBQSxJQUFNLHFCQUNKO0FBT0YsZUFBc0IseUJBQXVEO0FBQzNFLE1BQUksUUFBdUI7QUFFM0IsTUFBSTtBQUNGLFVBQU0sRUFBRSxtQkFBbUIsSUFBSSxNQUFNLE9BQU8sY0FBYztBQUMxRCxZQUFRLE1BQU0sbUJBQW1CO0FBQUEsRUFDbkMsUUFBUTtBQUFBLEVBRVI7QUFFQSxTQUFPO0FBQUEsSUFDTCxLQUFLO0FBQUEsSUFDTCxTQUFTLFFBQVEsRUFBRSxlQUFlLFVBQVUsS0FBSyxHQUFHLElBQUksQ0FBQztBQUFBLEVBQzNEO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -0,0 +1,8 @@
1
+ import "./chunk-3ODWQVIA.mjs";
2
+
3
+ // src/sandbox/bindings/vercel-sdk.ts
4
+ import { Sandbox } from "sandbox";
5
+ export {
6
+ Sandbox
7
+ };
8
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL3NhbmRib3gvYmluZGluZ3MvdmVyY2VsLXNkay50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiZXhwb3J0IHsgU2FuZGJveCB9IGZyb20gXCJzYW5kYm94XCI7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7QUFBQSxTQUFTLGVBQWU7IiwKICAibmFtZXMiOiBbXQp9Cg==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "experimental-agent",
3
- "version": "0.0.2",
3
+ "version": "0.0.3",
4
4
  "main": "./dist/index.js",
5
5
  "module": "./dist/index.mjs",
6
6
  "types": "./dist/index.d.ts",
@@ -15,46 +15,59 @@
15
15
  "import": "./dist/index.mjs",
16
16
  "require": "./dist/index.js"
17
17
  },
18
- "./workflow": {
19
- "types": "./dist/workflow.d.ts",
20
- "import": "./dist/workflow.mjs",
21
- "require": "./dist/workflow.js"
18
+ "./next": {
19
+ "types": "./dist/next.d.ts",
20
+ "import": "./dist/next.mjs",
21
+ "require": "./dist/next.js"
22
+ },
23
+ "./next/loader": {
24
+ "types": "./dist/next/loader.d.ts",
25
+ "import": "./dist/next/loader.mjs",
26
+ "require": "./dist/next/loader.js"
27
+ },
28
+ "./client": {
29
+ "types": "./dist/client.d.ts",
30
+ "import": "./dist/client.mjs",
31
+ "require": "./dist/client.js"
22
32
  }
23
33
  },
24
- "scripts": {
25
- "build": "tsup",
26
- "dev": "tsup --watch",
27
- "clean": "rm -rf .turbo && rm -rf node_modules && rm -rf dist",
28
- "publish": "pnpm build && npm publish",
29
- "typecheck": "tsc --noEmit",
30
- "test": "vitest run",
31
- "test:watch": "vitest"
32
- },
33
34
  "dependencies": {
34
35
  "@hono/node-server": "^1.19.9",
36
+ "@swc/core": "^1.10.0",
35
37
  "@vercel/oidc": "^3.1.0",
36
38
  "better-all": "^0.0.5",
37
39
  "errore": "^0.8.2",
38
40
  "fast-deep-equal": "^3.1.3",
41
+ "glob": "^11.0.0",
39
42
  "hono": "^4.11.6",
40
43
  "sandbox": "^1.0.18",
41
44
  "ulid": "^3.0.2",
42
45
  "zod": "^4.3.6"
43
46
  },
44
47
  "devDependencies": {
45
- "@agent/tsconfig": "workspace:*",
46
48
  "@types/node": "^20.11.24",
47
- "ai": "^6.0.33",
48
49
  "dotenv": "^17.2.3",
50
+ "next": "^16.0.0",
49
51
  "tsup": "^8.0.2",
50
52
  "type-fest": "^5.4.2",
51
53
  "typescript": "5.5.4",
52
- "vitest": "^3.0.0"
54
+ "vitest": "^3.0.0",
55
+ "@agent/tsconfig": "0.0.0"
53
56
  },
54
57
  "peerDependencies": {
55
- "workflow": "^4.0.1-beta.44"
58
+ "ai": "^6.0.0",
59
+ "workflow": "https://workflow-docs-7evupb64d.vercel.sh/workflow.tgz"
56
60
  },
57
61
  "publishConfig": {
58
62
  "access": "public"
63
+ },
64
+ "scripts": {
65
+ "build": "tsup",
66
+ "dev": "tsup --watch",
67
+ "clean": "rm -rf .turbo && rm -rf node_modules && rm -rf dist",
68
+ "release": "pnpm build && npm publish",
69
+ "typecheck": "tsc --noEmit",
70
+ "test": "vitest run",
71
+ "test:watch": "vitest"
59
72
  }
60
- }
73
+ }