@elizaos/plugin-openrouter 1.5.10 → 1.5.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -411,6 +411,15 @@ function shouldAutoCleanupImages(runtime) {
411
411
  const setting = getSetting(runtime, "OPENROUTER_AUTO_CLEANUP_IMAGES", "false");
412
412
  return setting?.toLowerCase() === "true";
413
413
  }
414
+ function getToolExecutionMaxSteps(runtime) {
415
+ const setting = getSetting(runtime, "OPENROUTER_TOOL_EXECUTION_MAX_STEPS", "15");
416
+ const value = parseInt(setting || "15", 10);
417
+ if (Number.isNaN(value) || value < 1)
418
+ return 15;
419
+ if (value > 100)
420
+ return 100;
421
+ return value;
422
+ }
414
423
 
415
424
  // src/init.ts
416
425
  function initializeOpenRouter(_config, runtime) {
@@ -450,7 +459,7 @@ function initializeOpenRouter(_config, runtime) {
450
459
 
451
460
  // src/models/text.ts
452
461
  import { logger as logger3, ModelType } from "@elizaos/core";
453
- import { generateText } from "ai";
462
+ import { generateText, stepCountIs } from "ai";
454
463
 
455
464
  // src/providers/openrouter.ts
456
465
  import { createOpenRouter } from "@openrouter/ai-sdk-provider";
@@ -603,7 +612,7 @@ async function generateTextWithModel(runtime, modelType, params) {
603
612
  const openrouter = createOpenRouterProvider(runtime);
604
613
  const modelName = modelType === ModelType.TEXT_SMALL ? getSmallModel(runtime) : getLargeModel(runtime);
605
614
  const modelLabel = modelType === ModelType.TEXT_SMALL ? "TEXT_SMALL" : "TEXT_LARGE";
606
- logger3.log(`[OpenRouter] Generating text with ${modelLabel} model: ${modelName}`);
615
+ logger3.debug(`[OpenRouter] Generating text with ${modelLabel} model: ${modelName}`);
607
616
  const generateParams = {
608
617
  model: openrouter.chat(modelName),
609
618
  prompt,
@@ -616,6 +625,9 @@ async function generateTextWithModel(runtime, modelType, params) {
616
625
  generateParams.maxOutputTokens = resolvedMaxOutput;
617
626
  if (tools) {
618
627
  generateParams.tools = tools;
628
+ const maxSteps = getToolExecutionMaxSteps(runtime);
629
+ generateParams.stopWhen = stepCountIs(maxSteps);
630
+ logger3.debug(`[OpenRouter] Using maxSteps: ${maxSteps} for tool execution`);
619
631
  }
620
632
  if (toolChoice) {
621
633
  generateParams.toolChoice = toolChoice;
@@ -630,12 +642,14 @@ async function generateTextWithModel(runtime, modelType, params) {
630
642
  ...stepResult.toolCalls
631
643
  ];
632
644
  }
633
- if (stepResult.toolResults && stepResult.toolResults.length > 0) {
634
- const decodedToolResults = stepResult.toolResults.map((result) => ({
635
- toolCallId: result.toolCallId,
636
- result: decodeBase64Fields(result.result)
645
+ if (stepResult.content && Array.isArray(stepResult.content)) {
646
+ const toolResultsFromContent = stepResult.content.filter((content) => content.type === "tool-result" && content.output).map((content) => ({
647
+ toolCallId: content.toolCallId,
648
+ result: decodeBase64Fields(content.output)
637
649
  }));
638
- capturedToolResults = [...capturedToolResults, ...decodedToolResults];
650
+ if (toolResultsFromContent.length > 0) {
651
+ capturedToolResults = [...capturedToolResults, ...toolResultsFromContent];
652
+ }
639
653
  }
640
654
  };
641
655
  }
@@ -649,11 +663,12 @@ async function generateTextWithModel(runtime, modelType, params) {
649
663
  if (response.usage) {
650
664
  emitModelUsageEvent(runtime, modelType, prompt, response.usage);
651
665
  }
652
- if (tools && (capturedToolCalls.length > 0 || capturedToolResults.length > 0)) {
666
+ if (tools && response.steps && response.steps.length > 0) {
653
667
  return {
654
668
  text: responseText,
655
669
  toolCalls: capturedToolCalls,
656
670
  toolResults: capturedToolResults,
671
+ steps: response.steps,
657
672
  usage: response.usage,
658
673
  finishReason: response.finishReason
659
674
  };
@@ -682,7 +697,8 @@ async function generateObjectWithModel(runtime, modelType, params) {
682
697
  try {
683
698
  const { object, usage } = await generateObject({
684
699
  model: openrouter.chat(modelName),
685
- output: "no-schema",
700
+ ...params.schema && { schema: params.schema },
701
+ output: params.schema ? "object" : "no-schema",
686
702
  prompt: params.prompt,
687
703
  temperature,
688
704
  experimental_repairText: getJsonRepairFunction()
@@ -965,4 +981,4 @@ export {
965
981
  src_default as default
966
982
  };
967
983
 
968
- //# debugId=BF459D9A02C441C264756E2164756E21
984
+ //# debugId=D932CBC1DE77F50264756E2164756E21
@@ -5,16 +5,16 @@
5
5
  "function assertPath(path){if(typeof path!==\"string\")throw new TypeError(\"Path must be a string. Received \"+JSON.stringify(path))}function normalizeStringPosix(path,allowAboveRoot){var res=\"\",lastSegmentLength=0,lastSlash=-1,dots=0,code;for(var i=0;i<=path.length;++i){if(i<path.length)code=path.charCodeAt(i);else if(code===47)break;else code=47;if(code===47){if(lastSlash===i-1||dots===1);else if(lastSlash!==i-1&&dots===2){if(res.length<2||lastSegmentLength!==2||res.charCodeAt(res.length-1)!==46||res.charCodeAt(res.length-2)!==46){if(res.length>2){var lastSlashIndex=res.lastIndexOf(\"/\");if(lastSlashIndex!==res.length-1){if(lastSlashIndex===-1)res=\"\",lastSegmentLength=0;else res=res.slice(0,lastSlashIndex),lastSegmentLength=res.length-1-res.lastIndexOf(\"/\");lastSlash=i,dots=0;continue}}else if(res.length===2||res.length===1){res=\"\",lastSegmentLength=0,lastSlash=i,dots=0;continue}}if(allowAboveRoot){if(res.length>0)res+=\"/..\";else res=\"..\";lastSegmentLength=2}}else{if(res.length>0)res+=\"/\"+path.slice(lastSlash+1,i);else res=path.slice(lastSlash+1,i);lastSegmentLength=i-lastSlash-1}lastSlash=i,dots=0}else if(code===46&&dots!==-1)++dots;else dots=-1}return res}function _format(sep,pathObject){var dir=pathObject.dir||pathObject.root,base=pathObject.base||(pathObject.name||\"\")+(pathObject.ext||\"\");if(!dir)return base;if(dir===pathObject.root)return dir+base;return dir+sep+base}function resolve(){var resolvedPath=\"\",resolvedAbsolute=!1,cwd;for(var i=arguments.length-1;i>=-1&&!resolvedAbsolute;i--){var path;if(i>=0)path=arguments[i];else{if(cwd===void 0)cwd=process.cwd();path=cwd}if(assertPath(path),path.length===0)continue;resolvedPath=path+\"/\"+resolvedPath,resolvedAbsolute=path.charCodeAt(0)===47}if(resolvedPath=normalizeStringPosix(resolvedPath,!resolvedAbsolute),resolvedAbsolute)if(resolvedPath.length>0)return\"/\"+resolvedPath;else return\"/\";else if(resolvedPath.length>0)return resolvedPath;else return\".\"}function normalize(path){if(assertPath(path),path.length===0)return\".\";var isAbsolute=path.charCodeAt(0)===47,trailingSeparator=path.charCodeAt(path.length-1)===47;if(path=normalizeStringPosix(path,!isAbsolute),path.length===0&&!isAbsolute)path=\".\";if(path.length>0&&trailingSeparator)path+=\"/\";if(isAbsolute)return\"/\"+path;return path}function isAbsolute(path){return assertPath(path),path.length>0&&path.charCodeAt(0)===47}function join(){if(arguments.length===0)return\".\";var joined;for(var i=0;i<arguments.length;++i){var arg=arguments[i];if(assertPath(arg),arg.length>0)if(joined===void 0)joined=arg;else joined+=\"/\"+arg}if(joined===void 0)return\".\";return normalize(joined)}function relative(from,to){if(assertPath(from),assertPath(to),from===to)return\"\";if(from=resolve(from),to=resolve(to),from===to)return\"\";var fromStart=1;for(;fromStart<from.length;++fromStart)if(from.charCodeAt(fromStart)!==47)break;var fromEnd=from.length,fromLen=fromEnd-fromStart,toStart=1;for(;toStart<to.length;++toStart)if(to.charCodeAt(toStart)!==47)break;var toEnd=to.length,toLen=toEnd-toStart,length=fromLen<toLen?fromLen:toLen,lastCommonSep=-1,i=0;for(;i<=length;++i){if(i===length){if(toLen>length){if(to.charCodeAt(toStart+i)===47)return to.slice(toStart+i+1);else if(i===0)return to.slice(toStart+i)}else if(fromLen>length){if(from.charCodeAt(fromStart+i)===47)lastCommonSep=i;else if(i===0)lastCommonSep=0}break}var fromCode=from.charCodeAt(fromStart+i),toCode=to.charCodeAt(toStart+i);if(fromCode!==toCode)break;else if(fromCode===47)lastCommonSep=i}var out=\"\";for(i=fromStart+lastCommonSep+1;i<=fromEnd;++i)if(i===fromEnd||from.charCodeAt(i)===47)if(out.length===0)out+=\"..\";else out+=\"/..\";if(out.length>0)return out+to.slice(toStart+lastCommonSep);else{if(toStart+=lastCommonSep,to.charCodeAt(toStart)===47)++toStart;return to.slice(toStart)}}function _makeLong(path){return path}function dirname(path){if(assertPath(path),path.length===0)return\".\";var code=path.charCodeAt(0),hasRoot=code===47,end=-1,matchedSlash=!0;for(var i=path.length-1;i>=1;--i)if(code=path.charCodeAt(i),code===47){if(!matchedSlash){end=i;break}}else matchedSlash=!1;if(end===-1)return hasRoot?\"/\":\".\";if(hasRoot&&end===1)return\"//\";return path.slice(0,end)}function basename(path,ext){if(ext!==void 0&&typeof ext!==\"string\")throw new TypeError('\"ext\" argument must be a string');assertPath(path);var start=0,end=-1,matchedSlash=!0,i;if(ext!==void 0&&ext.length>0&&ext.length<=path.length){if(ext.length===path.length&&ext===path)return\"\";var extIdx=ext.length-1,firstNonSlashEnd=-1;for(i=path.length-1;i>=0;--i){var code=path.charCodeAt(i);if(code===47){if(!matchedSlash){start=i+1;break}}else{if(firstNonSlashEnd===-1)matchedSlash=!1,firstNonSlashEnd=i+1;if(extIdx>=0)if(code===ext.charCodeAt(extIdx)){if(--extIdx===-1)end=i}else extIdx=-1,end=firstNonSlashEnd}}if(start===end)end=firstNonSlashEnd;else if(end===-1)end=path.length;return path.slice(start,end)}else{for(i=path.length-1;i>=0;--i)if(path.charCodeAt(i)===47){if(!matchedSlash){start=i+1;break}}else if(end===-1)matchedSlash=!1,end=i+1;if(end===-1)return\"\";return path.slice(start,end)}}function extname(path){assertPath(path);var startDot=-1,startPart=0,end=-1,matchedSlash=!0,preDotState=0;for(var i=path.length-1;i>=0;--i){var code=path.charCodeAt(i);if(code===47){if(!matchedSlash){startPart=i+1;break}continue}if(end===-1)matchedSlash=!1,end=i+1;if(code===46){if(startDot===-1)startDot=i;else if(preDotState!==1)preDotState=1}else if(startDot!==-1)preDotState=-1}if(startDot===-1||end===-1||preDotState===0||preDotState===1&&startDot===end-1&&startDot===startPart+1)return\"\";return path.slice(startDot,end)}function format(pathObject){if(pathObject===null||typeof pathObject!==\"object\")throw new TypeError('The \"pathObject\" argument must be of type Object. Received type '+typeof pathObject);return _format(\"/\",pathObject)}function parse(path){assertPath(path);var ret={root:\"\",dir:\"\",base:\"\",ext:\"\",name:\"\"};if(path.length===0)return ret;var code=path.charCodeAt(0),isAbsolute2=code===47,start;if(isAbsolute2)ret.root=\"/\",start=1;else start=0;var startDot=-1,startPart=0,end=-1,matchedSlash=!0,i=path.length-1,preDotState=0;for(;i>=start;--i){if(code=path.charCodeAt(i),code===47){if(!matchedSlash){startPart=i+1;break}continue}if(end===-1)matchedSlash=!1,end=i+1;if(code===46){if(startDot===-1)startDot=i;else if(preDotState!==1)preDotState=1}else if(startDot!==-1)preDotState=-1}if(startDot===-1||end===-1||preDotState===0||preDotState===1&&startDot===end-1&&startDot===startPart+1){if(end!==-1)if(startPart===0&&isAbsolute2)ret.base=ret.name=path.slice(1,end);else ret.base=ret.name=path.slice(startPart,end)}else{if(startPart===0&&isAbsolute2)ret.name=path.slice(1,startDot),ret.base=path.slice(1,end);else ret.name=path.slice(startPart,startDot),ret.base=path.slice(startPart,end);ret.ext=path.slice(startDot,end)}if(startPart>0)ret.dir=path.slice(0,startPart-1);else if(isAbsolute2)ret.dir=\"/\";return ret}var sep=\"/\",delimiter=\":\",posix=((p)=>(p.posix=p,p))({resolve,normalize,isAbsolute,join,relative,_makeLong,dirname,basename,extname,format,parse,sep,delimiter,win32:null,posix:null});var path_default=posix;export{sep,resolve,relative,posix,parse,normalize,join,isAbsolute,format,extname,dirname,delimiter,path_default as default,basename,_makeLong};",
6
6
  "import {\n ModelType,\n type Plugin,\n type IAgentRuntime,\n type GenerateTextParams,\n type ObjectGenerationParams,\n type ImageDescriptionParams,\n type ImageGenerationParams,\n} from \"@elizaos/core\";\nimport type { Tool, ToolChoice } from \"ai\";\nimport { initializeOpenRouter } from \"./init\";\nimport { handleTextSmall, handleTextLarge } from \"./models/text\";\nimport { handleObjectSmall, handleObjectLarge } from \"./models/object\";\nimport { handleImageDescription, handleImageGeneration } from \"./models/image\";\n\n/**\n * Defines the OpenRouter plugin with its name, description, and configuration options.\n * @type {Plugin}\n */\nexport const openrouterPlugin: Plugin = {\n name: \"openrouter\",\n description: \"OpenRouter plugin\",\n config: {\n OPENROUTER_API_KEY: process.env.OPENROUTER_API_KEY,\n OPENROUTER_BASE_URL: process.env.OPENROUTER_BASE_URL,\n OPENROUTER_SMALL_MODEL: process.env.OPENROUTER_SMALL_MODEL,\n OPENROUTER_LARGE_MODEL: process.env.OPENROUTER_LARGE_MODEL,\n OPENROUTER_IMAGE_MODEL: process.env.OPENROUTER_IMAGE_MODEL,\n OPENROUTER_IMAGE_GENERATION_MODEL:\n process.env.OPENROUTER_IMAGE_GENERATION_MODEL,\n OPENROUTER_AUTO_CLEANUP_IMAGES: process.env.OPENROUTER_AUTO_CLEANUP_IMAGES,\n SMALL_MODEL: process.env.SMALL_MODEL,\n LARGE_MODEL: process.env.LARGE_MODEL,\n IMAGE_MODEL: process.env.IMAGE_MODEL,\n IMAGE_GENERATION_MODEL: process.env.IMAGE_GENERATION_MODEL,\n },\n async init(config, runtime) {\n // Note: We intentionally don't await here because ElizaOS expects\n // the init method to return quickly. The initializeOpenRouter function\n // only performs synchronous validation and logging, so it's safe to\n // call without await. This prevents blocking the plugin initialization.\n initializeOpenRouter(config, runtime);\n },\n models: {\n [ModelType.TEXT_SMALL]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n ) => {\n return handleTextSmall(runtime, params);\n },\n [ModelType.TEXT_LARGE]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n ) => {\n return handleTextLarge(runtime, params);\n },\n [ModelType.OBJECT_SMALL]: async (\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n ) => {\n return handleObjectSmall(runtime, params);\n },\n [ModelType.OBJECT_LARGE]: async (\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n ) => {\n return handleObjectLarge(runtime, params);\n },\n [ModelType.IMAGE_DESCRIPTION]: async (\n runtime: IAgentRuntime,\n params: ImageDescriptionParams | string,\n ) => {\n return handleImageDescription(runtime, params);\n },\n [ModelType.IMAGE]: async (\n runtime: IAgentRuntime,\n params: ImageGenerationParams,\n ) => {\n return handleImageGeneration(runtime, params);\n },\n },\n};\n\nexport default openrouterPlugin;\n",
7
7
  "import { logger, type IAgentRuntime } from \"@elizaos/core\";\nimport { fetch } from \"undici\";\nimport { getApiKey, getBaseURL } from \"./utils/config\";\n\n/**\n * Initialize and validate OpenRouter configuration\n * Returns the exact same function that works inline\n */\nexport function initializeOpenRouter(_config: any, runtime: IAgentRuntime) {\n // do check in the background\n (async () => {\n try {\n const isBrowser =\n typeof globalThis !== \"undefined\" && (globalThis as any).document;\n // In browser, skip validation entirely to avoid exposing secrets\n if (isBrowser) {\n return;\n }\n if (!getApiKey(runtime)) {\n logger.warn(\n \"OPENROUTER_API_KEY is not set in environment - OpenRouter functionality will be limited\",\n );\n return;\n }\n try {\n const baseURL = getBaseURL(runtime);\n const response = await fetch(`${baseURL}/models`, {\n headers: { Authorization: `Bearer ${getApiKey(runtime)}` },\n });\n if (!response.ok) {\n logger.warn(\n `OpenRouter API key validation failed: ${response.statusText}`,\n );\n logger.warn(\n \"OpenRouter functionality will be limited until a valid API key is provided\",\n );\n } else {\n logger.log(\"OpenRouter API key validated successfully\");\n }\n } catch (fetchError: unknown) {\n const message =\n fetchError instanceof Error ? fetchError.message : String(fetchError);\n logger.warn(`Error validating OpenRouter API key: ${message}`);\n logger.warn(\n \"OpenRouter functionality will be limited until a valid API key is provided\",\n );\n }\n } catch (error: unknown) {\n const message =\n (error as { errors?: Array<{ message: string }> })?.errors\n ?.map((e) => e.message)\n .join(\", \") ||\n (error instanceof Error ? error.message : String(error));\n logger.warn(\n `OpenRouter plugin configuration issue: ${message} - You need to configure the OPENROUTER_API_KEY in your environment variables`,\n );\n }\n })();\n return;\n}\n",
8
- "import type { IAgentRuntime } from \"@elizaos/core\";\n\n/**\n * Retrieves a configuration setting from the runtime, falling back to environment variables or a default value if not found.\n *\n * @param key - The name of the setting to retrieve.\n * @param defaultValue - The value to return if the setting is not found in the runtime or environment.\n * @returns The resolved setting value, or {@link defaultValue} if not found.\n */\nexport function getSetting(\n runtime: IAgentRuntime,\n key: string,\n defaultValue?: string,\n): string | undefined {\n return runtime.getSetting(key) ?? process.env[key] ?? defaultValue;\n}\n\n/**\n * Retrieves the OpenRouter API base URL from runtime settings, environment variables, or defaults.\n *\n * @returns The resolved base URL for OpenRouter API requests.\n */\nexport function getBaseURL(runtime: IAgentRuntime): string {\n const browserURL = getSetting(runtime, \"OPENROUTER_BROWSER_BASE_URL\");\n if (\n typeof globalThis !== \"undefined\" &&\n (globalThis as any).document &&\n browserURL\n ) {\n return browserURL;\n }\n return (\n getSetting(\n runtime,\n \"OPENROUTER_BASE_URL\",\n \"https://openrouter.ai/api/v1\",\n ) || \"https://openrouter.ai/api/v1\"\n );\n}\n\n/**\n * Helper function to get the API key for OpenRouter\n *\n * @param runtime The runtime context\n * @returns The configured API key\n */\nexport function getApiKey(runtime: IAgentRuntime): string | undefined {\n return getSetting(runtime, \"OPENROUTER_API_KEY\");\n}\n\n/**\n * Helper function to get the small model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured small model name\n */\nexport function getSmallModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_SMALL_MODEL\") ??\n getSetting(runtime, \"SMALL_MODEL\", \"google/gemini-2.0-flash-001\") ??\n \"google/gemini-2.0-flash-001\"\n );\n}\n\n/**\n * Helper function to get the large model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured large model name\n */\nexport function getLargeModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_LARGE_MODEL\") ??\n getSetting(runtime, \"LARGE_MODEL\", \"google/gemini-2.5-flash\") ??\n \"google/gemini-2.5-flash\"\n );\n}\n\n/**\n * Helper function to get the image model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured image model name\n */\nexport function getImageModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_IMAGE_MODEL\") ??\n getSetting(runtime, \"IMAGE_MODEL\", \"x-ai/grok-2-vision-1212\") ??\n \"x-ai/grok-2-vision-1212\"\n );\n}\n\n/**\n * Helper function to get the image generation model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured image generation model name\n */\nexport function getImageGenerationModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_IMAGE_GENERATION_MODEL\") ??\n getSetting(\n runtime,\n \"IMAGE_GENERATION_MODEL\",\n \"google/gemini-2.5-flash-image-preview\",\n ) ??\n \"google/gemini-2.5-flash-image-preview\"\n );\n}\n\n/**\n * Helper function to check if auto cleanup is enabled for generated images\n *\n * @param runtime The runtime context\n * @returns Whether to auto-cleanup generated images (default: false)\n */\nexport function shouldAutoCleanupImages(runtime: IAgentRuntime): boolean {\n const setting = getSetting(\n runtime,\n \"OPENROUTER_AUTO_CLEANUP_IMAGES\",\n \"false\",\n );\n return setting?.toLowerCase() === \"true\";\n}\n",
9
- "import type { GenerateTextParams, IAgentRuntime } from \"@elizaos/core\";\nimport { logger, ModelType } from \"@elizaos/core\";\nimport { generateText } from \"ai\";\nimport type { Tool, ToolChoice } from \"ai\";\n\nimport { createOpenRouterProvider } from \"../providers\";\nimport type { ToolCall, ToolResponse, ToolResult } from \"../types\";\nimport { getSmallModel, getLargeModel } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport { handleEmptyToolResponse, decodeBase64Fields } from \"../utils/helpers\";\n\n/**\n * Common text generation logic for both small and large models\n */\nasync function generateTextWithModel(\n runtime: IAgentRuntime,\n modelType: typeof ModelType.TEXT_SMALL | typeof ModelType.TEXT_LARGE,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n const { prompt, stopSequences = [], tools, toolChoice } = params;\n const temperature = params.temperature ?? 0.7;\n const frequencyPenalty = params.frequencyPenalty ?? 0.7;\n const presencePenalty = params.presencePenalty ?? 0.7;\n // AI SDK v5: prefer maxOutputTokens; keep legacy maxTokens as fallback; default 8192\n const resolvedMaxOutput =\n (params as any).maxOutputTokens ?? (params as any).maxTokens ?? 8192;\n\n const openrouter = createOpenRouterProvider(runtime);\n const modelName =\n modelType === ModelType.TEXT_SMALL\n ? getSmallModel(runtime)\n : getLargeModel(runtime);\n const modelLabel =\n modelType === ModelType.TEXT_SMALL ? \"TEXT_SMALL\" : \"TEXT_LARGE\";\n\n logger.log(\n `[OpenRouter] Generating text with ${modelLabel} model: ${modelName}`,\n );\n\n const generateParams: Parameters<typeof generateText>[0] = {\n model: openrouter.chat(modelName),\n prompt: prompt,\n system: runtime.character.system ?? undefined,\n temperature: temperature,\n frequencyPenalty: frequencyPenalty,\n presencePenalty: presencePenalty,\n stopSequences: stopSequences,\n };\n\n (generateParams as any).maxOutputTokens = resolvedMaxOutput;\n\n // Add tools if provided\n if (tools) {\n (generateParams as any).tools = tools;\n }\n\n // Add toolChoice if provided\n if (toolChoice) {\n (generateParams as any).toolChoice = toolChoice;\n }\n\n // Capture tool results if tools are used\n let capturedToolResults: ToolResult[] = [];\n let capturedToolCalls: ToolCall[] = [];\n\n if (tools) {\n (generateParams as any).onStepFinish = async (stepResult: any) => {\n if (stepResult.toolCalls && stepResult.toolCalls.length > 0) {\n capturedToolCalls = [\n ...capturedToolCalls,\n ...(stepResult.toolCalls as any),\n ];\n }\n if (stepResult.toolResults && stepResult.toolResults.length > 0) {\n const decodedToolResults = (stepResult.toolResults as any[]).map(\n (result: any) => ({\n toolCallId: result.toolCallId,\n result: decodeBase64Fields(result.result),\n }),\n );\n capturedToolResults = [...capturedToolResults, ...decodedToolResults];\n }\n };\n }\n\n const response = await generateText(generateParams);\n\n // Handle cases where tool execution doesn't generate text\n let responseText: string;\n if (\n tools &&\n (!response.text ||\n response.text.trim() === \"\" ||\n response.text === \"Tools executed successfully.\")\n ) {\n responseText = handleEmptyToolResponse(modelLabel);\n } else {\n responseText = response.text;\n }\n\n if (response.usage) {\n emitModelUsageEvent(runtime, modelType, prompt, response.usage);\n }\n\n // If tools were used, return the full response object to access toolCalls and toolResults\n if (\n tools &&\n (capturedToolCalls.length > 0 || capturedToolResults.length > 0)\n ) {\n return {\n text: responseText,\n toolCalls: capturedToolCalls,\n toolResults: capturedToolResults,\n // Include other useful properties\n usage: response.usage,\n finishReason: response.finishReason,\n };\n }\n\n return responseText;\n}\n\n/**\n * TEXT_SMALL model handler\n */\nexport async function handleTextSmall(\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n return generateTextWithModel(runtime, ModelType.TEXT_SMALL, params);\n}\n\n/**\n * TEXT_LARGE model handler\n */\nexport async function handleTextLarge(\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n return generateTextWithModel(runtime, ModelType.TEXT_LARGE, params);\n}\n",
8
+ "import type { IAgentRuntime } from \"@elizaos/core\";\n\n/**\n * Retrieves a configuration setting from the runtime, falling back to environment variables or a default value if not found.\n *\n * @param key - The name of the setting to retrieve.\n * @param defaultValue - The value to return if the setting is not found in the runtime or environment.\n * @returns The resolved setting value, or {@link defaultValue} if not found.\n */\nexport function getSetting(\n runtime: IAgentRuntime,\n key: string,\n defaultValue?: string,\n): string | undefined {\n return runtime.getSetting(key) ?? process.env[key] ?? defaultValue;\n}\n\n/**\n * Retrieves the OpenRouter API base URL from runtime settings, environment variables, or defaults.\n *\n * @returns The resolved base URL for OpenRouter API requests.\n */\nexport function getBaseURL(runtime: IAgentRuntime): string {\n const browserURL = getSetting(runtime, \"OPENROUTER_BROWSER_BASE_URL\");\n if (\n typeof globalThis !== \"undefined\" &&\n (globalThis as any).document &&\n browserURL\n ) {\n return browserURL;\n }\n return (\n getSetting(\n runtime,\n \"OPENROUTER_BASE_URL\",\n \"https://openrouter.ai/api/v1\",\n ) || \"https://openrouter.ai/api/v1\"\n );\n}\n\n/**\n * Helper function to get the API key for OpenRouter\n *\n * @param runtime The runtime context\n * @returns The configured API key\n */\nexport function getApiKey(runtime: IAgentRuntime): string | undefined {\n return getSetting(runtime, \"OPENROUTER_API_KEY\");\n}\n\n/**\n * Helper function to get the small model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured small model name\n */\nexport function getSmallModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_SMALL_MODEL\") ??\n getSetting(runtime, \"SMALL_MODEL\", \"google/gemini-2.0-flash-001\") ??\n \"google/gemini-2.0-flash-001\"\n );\n}\n\n/**\n * Helper function to get the large model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured large model name\n */\nexport function getLargeModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_LARGE_MODEL\") ??\n getSetting(runtime, \"LARGE_MODEL\", \"google/gemini-2.5-flash\") ??\n \"google/gemini-2.5-flash\"\n );\n}\n\n/**\n * Helper function to get the image model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured image model name\n */\nexport function getImageModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_IMAGE_MODEL\") ??\n getSetting(runtime, \"IMAGE_MODEL\", \"x-ai/grok-2-vision-1212\") ??\n \"x-ai/grok-2-vision-1212\"\n );\n}\n\n/**\n * Helper function to get the image generation model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured image generation model name\n */\nexport function getImageGenerationModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_IMAGE_GENERATION_MODEL\") ??\n getSetting(\n runtime,\n \"IMAGE_GENERATION_MODEL\",\n \"google/gemini-2.5-flash-image-preview\",\n ) ??\n \"google/gemini-2.5-flash-image-preview\"\n );\n}\n\n/**\n * Helper function to check if auto cleanup is enabled for generated images\n *\n * @param runtime The runtime context\n * @returns Whether to auto-cleanup generated images (default: false)\n */\nexport function shouldAutoCleanupImages(runtime: IAgentRuntime): boolean {\n const setting = getSetting(\n runtime,\n \"OPENROUTER_AUTO_CLEANUP_IMAGES\",\n \"false\",\n );\n return setting?.toLowerCase() === \"true\";\n}\n\n/**\n * Helper function to get the max steps for tool execution\n *\n * @param runtime The runtime context\n * @returns The maximum number of steps for tool execution (default: 15)\n */\nexport function getToolExecutionMaxSteps(runtime: IAgentRuntime): number {\n const setting = getSetting(\n runtime,\n \"OPENROUTER_TOOL_EXECUTION_MAX_STEPS\",\n \"15\",\n );\n const value = parseInt(setting || \"15\", 10);\n // Ensure valid range (1-100)\n if (Number.isNaN(value) || value < 1) return 15;\n if (value > 100) return 100;\n return value;\n}\n",
9
+ "import type { GenerateTextParams, IAgentRuntime } from \"@elizaos/core\";\nimport { logger, ModelType } from \"@elizaos/core\";\nimport { generateText, stepCountIs } from \"ai\";\nimport type { Tool, ToolChoice } from \"ai\";\n\nimport { createOpenRouterProvider } from \"../providers\";\nimport type { ToolCall, ToolResponse, ToolResult } from \"../types\";\nimport { getSmallModel, getLargeModel, getToolExecutionMaxSteps } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport { handleEmptyToolResponse, decodeBase64Fields } from \"../utils/helpers\";\n\n/**\n * Common text generation logic for both small and large models\n */\nasync function generateTextWithModel(\n runtime: IAgentRuntime,\n modelType: typeof ModelType.TEXT_SMALL | typeof ModelType.TEXT_LARGE,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n const { prompt, stopSequences = [], tools, toolChoice } = params;\n const temperature = params.temperature ?? 0.7;\n const frequencyPenalty = params.frequencyPenalty ?? 0.7;\n const presencePenalty = params.presencePenalty ?? 0.7;\n // AI SDK v5: prefer maxOutputTokens; keep legacy maxTokens as fallback; default 8192\n const resolvedMaxOutput =\n (params as any).maxOutputTokens ?? (params as any).maxTokens ?? 8192;\n\n const openrouter = createOpenRouterProvider(runtime);\n const modelName =\n modelType === ModelType.TEXT_SMALL\n ? getSmallModel(runtime)\n : getLargeModel(runtime);\n const modelLabel =\n modelType === ModelType.TEXT_SMALL ? \"TEXT_SMALL\" : \"TEXT_LARGE\";\n\n logger.debug(\n `[OpenRouter] Generating text with ${modelLabel} model: ${modelName}`,\n );\n\n const generateParams: Parameters<typeof generateText>[0] = {\n model: openrouter.chat(modelName),\n prompt: prompt,\n system: runtime.character.system ?? undefined,\n temperature: temperature,\n frequencyPenalty: frequencyPenalty,\n presencePenalty: presencePenalty,\n stopSequences: stopSequences,\n };\n\n (generateParams as any).maxOutputTokens = resolvedMaxOutput;\n\n // Add tools if provided\n if (tools) {\n (generateParams as any).tools = tools;\n const maxSteps = getToolExecutionMaxSteps(runtime);\n\n (generateParams as any).stopWhen = stepCountIs(maxSteps);\n logger.debug(`[OpenRouter] Using maxSteps: ${maxSteps} for tool execution`);\n }\n\n // Add toolChoice if provided\n if (toolChoice) {\n (generateParams as any).toolChoice = toolChoice;\n }\n\n // Capture tool results if tools are used\n let capturedToolResults: ToolResult[] = [];\n let capturedToolCalls: ToolCall[] = [];\n\n if (tools) {\n (generateParams as any).onStepFinish = async (stepResult: any) => {\n if (stepResult.toolCalls && stepResult.toolCalls.length > 0) {\n capturedToolCalls = [\n ...capturedToolCalls,\n ...(stepResult.toolCalls as any),\n ];\n }\n\n // Extract tool results from content array in steps\n if (stepResult.content && Array.isArray(stepResult.content)) {\n const toolResultsFromContent = stepResult.content\n .filter((content: any) => content.type === 'tool-result' && content.output)\n .map((content: any) => ({\n toolCallId: content.toolCallId,\n result: decodeBase64Fields(content.output),\n }));\n\n if (toolResultsFromContent.length > 0) {\n capturedToolResults = [...capturedToolResults, ...toolResultsFromContent];\n }\n }\n };\n }\n\n const response = await generateText(generateParams);\n\n // Handle cases where tool execution doesn't generate text\n let responseText: string;\n if (\n tools &&\n (!response.text ||\n response.text.trim() === \"\" ||\n response.text === \"Tools executed successfully.\")\n ) {\n responseText = handleEmptyToolResponse(modelLabel);\n } else {\n responseText = response.text;\n }\n\n if (response.usage) {\n emitModelUsageEvent(runtime, modelType, prompt, response.usage);\n }\n\n // If tools were used, return the full response object with steps for proper tool results access\n if (tools && response.steps && response.steps.length > 0) {\n return {\n text: responseText,\n toolCalls: capturedToolCalls,\n toolResults: capturedToolResults,\n steps: response.steps,\n usage: response.usage,\n finishReason: response.finishReason,\n };\n }\n\n return responseText;\n}\n\n/**\n * TEXT_SMALL model handler\n */\nexport async function handleTextSmall(\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n return generateTextWithModel(runtime, ModelType.TEXT_SMALL, params);\n}\n\n/**\n * TEXT_LARGE model handler\n */\nexport async function handleTextLarge(\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n return generateTextWithModel(runtime, ModelType.TEXT_LARGE, params);\n}\n",
10
10
  "import { createOpenRouter } from \"@openrouter/ai-sdk-provider\";\nimport { logger, type IAgentRuntime } from \"@elizaos/core\";\nimport { getApiKey, getBaseURL } from \"../utils/config\";\n\n/**\n * Create an OpenRouter provider instance with proper configuration\n *\n * @param runtime The runtime context\n * @returns Configured OpenRouter provider instance\n */\nexport function createOpenRouterProvider(runtime: IAgentRuntime) {\n const apiKey = getApiKey(runtime);\n const isBrowser =\n typeof globalThis !== \"undefined\" && (globalThis as any).document;\n const baseURL = getBaseURL(runtime);\n // In browser, omit apiKey and rely on proxy baseURL\n return createOpenRouter({\n apiKey: isBrowser ? undefined : apiKey,\n baseURL,\n });\n}\n",
11
- "import {\n EventType,\n type IAgentRuntime,\n type ModelTypeName,\n} from \"@elizaos/core\";\nimport type { LanguageModelUsage } from \"ai\";\n\n/**\n * Emits a model usage event\n */\nexport function emitModelUsageEvent(\n runtime: IAgentRuntime,\n type: ModelTypeName,\n prompt: string,\n usage: LanguageModelUsage,\n) {\n // Never emit the full prompt; truncate to avoid leaking secrets/PII\n const truncatedPrompt =\n typeof prompt === \"string\"\n ? prompt.length > 200\n ? `${prompt.slice(0, 200)}…`\n : prompt\n : \"\";\n // Coalesce optional usage fields to stable numbers\n const inputTokens = Number(usage.inputTokens || 0);\n const outputTokens = Number(usage.outputTokens || 0);\n const totalTokens = Number(\n usage.totalTokens != null ? usage.totalTokens : inputTokens + outputTokens,\n );\n runtime.emitEvent(EventType.MODEL_USED, {\n provider: \"openrouter\",\n type,\n prompt: truncatedPrompt,\n tokens: {\n prompt: inputTokens,\n completion: outputTokens,\n total: totalTokens,\n },\n });\n}\n",
11
+ "import {\n EventType,\n type IAgentRuntime,\n type ModelTypeName,\n} from \"@elizaos/core\";\nimport type { LanguageModelUsage } from \"ai\";\n\n/**\n * Emits a model usage event\n */\nexport function emitModelUsageEvent(\n runtime: IAgentRuntime,\n type: ModelTypeName,\n prompt: string,\n usage: LanguageModelUsage,\n) {\n // Never emit the full prompt; truncate to avoid leaking secrets/PII\n const truncatedPrompt =\n typeof prompt === \"string\"\n ? prompt.length > 200\n ? `${prompt.slice(0, 200)}…`\n : prompt\n : \"\";\n // Coalesce optional usage fields to stable numbers\n const inputTokens = Number((usage as { inputTokens?: number }).inputTokens || 0);\n const outputTokens = Number((usage as { outputTokens?: number }).outputTokens || 0);\n const totalTokens = Number(\n usage.totalTokens != null ? usage.totalTokens : inputTokens + outputTokens,\n );\n runtime.emitEvent(EventType.MODEL_USED, {\n provider: \"openrouter\",\n type,\n prompt: truncatedPrompt,\n tokens: {\n prompt: inputTokens,\n completion: outputTokens,\n total: totalTokens,\n },\n });\n}\n",
12
12
  "import { logger } from \"@elizaos/core\";\nimport { JSONParseError } from \"ai\";\nimport type { GenerateTextResponse, ImageDescriptionResult } from \"../types\";\n\n/**\n * Returns a function to repair JSON text\n */\nexport function getJsonRepairFunction(): (params: {\n text: string;\n error: unknown;\n}) => Promise<string | null> {\n return async ({ text, error }: { text: string; error: unknown }) => {\n try {\n if (error instanceof JSONParseError) {\n const cleanedText = text.replace(/```json\\n|\\n```|```/g, \"\");\n JSON.parse(cleanedText);\n return cleanedText;\n }\n return null;\n } catch (jsonError: unknown) {\n const message =\n jsonError instanceof Error ? jsonError.message : String(jsonError);\n logger.warn(`Failed to repair JSON text: ${message}`);\n return null;\n }\n };\n}\n\n// Re-export for backward compatibility\nexport { emitModelUsageEvent } from \"./events\";\n\n/**\n * Logs response structure for debugging (debug level only)\n */\nexport function logResponseStructure(\n modelType: string,\n response: GenerateTextResponse,\n) {\n // Only log safe, non-sensitive usage fields (avoid raw request bodies)\n const u = (response as any)?.usage;\n const safeUsage =\n u && typeof u === \"object\"\n ? {\n inputTokens: u.inputTokens,\n outputTokens: u.outputTokens,\n totalTokens: u.totalTokens,\n }\n : undefined;\n logger.debug(\n `[${modelType}] Response structure: ${JSON.stringify(\n {\n hasText: !!response.text,\n textLength: response.text?.length || 0,\n hasSteps: !!response.steps,\n stepsCount: response.steps?.length || 0,\n finishReason: response.finishReason,\n usage: safeUsage,\n },\n null,\n 2,\n )}`,\n );\n}\n\n/**\n * Handles cases where tool execution doesn't generate text\n */\nexport function handleEmptyToolResponse(modelType: string): string {\n logger.warn(`[${modelType}] No text generated after tool execution`);\n\n const fallbackText =\n \"I executed the requested action. The tool completed successfully.\";\n logger.warn(`[${modelType}] Using fallback response text`);\n return fallbackText;\n}\n\n/**\n * Parses image description response from text or JSON format\n */\nexport function parseImageDescriptionResponse(\n responseText: string,\n): ImageDescriptionResult {\n // Try to parse as JSON first\n try {\n const jsonResponse = JSON.parse(responseText);\n if (jsonResponse.title && jsonResponse.description) {\n return jsonResponse;\n }\n } catch (e) {\n // If not valid JSON, process as text\n logger.debug(`Parsing as JSON failed, processing as text: ${e}`);\n }\n\n // Extract title and description from text format\n const titleMatch = responseText.match(/title[:\\s]+(.+?)(?:\\n|$)/i);\n const title = titleMatch?.[1]?.trim() || \"Image Analysis\";\n const description = responseText\n .replace(/title[:\\s]+(.+?)(?:\\n|$)/i, \"\")\n .trim();\n\n return { title, description };\n}\n\n/**\n * Handles errors during object generation, including JSON repair attempts\n */\nexport async function handleObjectGenerationError(\n error: unknown,\n): Promise<unknown> {\n if (error instanceof JSONParseError) {\n logger.error(`[generateObject] Failed to parse JSON: ${error.message}`);\n const repairFunction = getJsonRepairFunction();\n const repairedJsonString = await repairFunction({\n text: error.text,\n error,\n });\n\n if (repairedJsonString) {\n try {\n const repairedObject = JSON.parse(repairedJsonString);\n logger.log(\"[generateObject] Successfully repaired JSON.\");\n return repairedObject;\n } catch (repairParseError: unknown) {\n const message =\n repairParseError instanceof Error\n ? repairParseError.message\n : String(repairParseError);\n logger.error(\n `[generateObject] Failed to parse repaired JSON: ${message}`,\n );\n if (repairParseError instanceof Error) throw repairParseError;\n throw Object.assign(new Error(message), { cause: repairParseError });\n }\n } else {\n logger.error(\"[generateObject] JSON repair failed.\");\n throw error;\n }\n } else {\n const message = error instanceof Error ? error.message : String(error);\n logger.error(`[generateObject] Unknown error: ${message}`);\n if (error instanceof Error) throw error;\n throw Object.assign(new Error(message), { cause: error });\n }\n}\n\n/**\n * Quick heuristic to detect if a field likely contains base64 data\n */\nfunction isLikelyBase64(key: string, value: string): boolean {\n // Check key name patterns (expanded base64 field names)\n const base64KeyPattern =\n /^(data|content|body|payload|encoded|b64|base64|document)$/i;\n if (!base64KeyPattern.test(key)) return false;\n\n // Basic format checks\n if (value.length < 20 || value.length > 1024 * 1024) return false; // Size limits\n if (value.length % 4 !== 0) return false; // Invalid base64 length\n if (!/^[A-Za-z0-9+/]*={0,2}$/.test(value)) return false; // Invalid chars\n\n return true;\n}\n\n/**\n * Recursively decodes base64 fields in tool results\n */\nexport function decodeBase64Fields(obj: unknown, depth = 0): unknown {\n // Simple depth protection\n if (depth > 5) return obj;\n if (!obj || typeof obj !== \"object\") return obj;\n if (Array.isArray(obj))\n return obj.map((item) => decodeBase64Fields(item, depth + 1));\n\n const decoded: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(obj)) {\n if (typeof value === \"string\" && isLikelyBase64(key, value)) {\n try {\n decoded[key] = Buffer.from(value, \"base64\").toString(\"utf8\");\n logger.debug(\n `[decodeBase64] Decoded field '${key}' (${value.length} chars)`,\n );\n } catch (error) {\n logger.warn(`[decodeBase64] Failed to decode field '${key}': ${error}`);\n decoded[key] = value; // Keep original if decode fails\n }\n } else if (value && typeof value === \"object\") {\n decoded[key] = decodeBase64Fields(value, depth + 1);\n } else {\n decoded[key] = value;\n }\n }\n return decoded;\n}\n",
13
- "import {\n ModelType,\n logger,\n type IAgentRuntime,\n type ObjectGenerationParams,\n} from \"@elizaos/core\";\nimport { generateObject } from \"ai\";\nimport { createOpenRouterProvider } from \"../providers\";\nimport { getSmallModel, getLargeModel } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport {\n getJsonRepairFunction,\n handleObjectGenerationError,\n} from \"../utils/helpers\";\n\n/**\n * Common object generation logic for both small and large models\n */\nasync function generateObjectWithModel(\n runtime: IAgentRuntime,\n modelType: typeof ModelType.OBJECT_SMALL | typeof ModelType.OBJECT_LARGE,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n const openrouter = createOpenRouterProvider(runtime);\n const modelName =\n modelType === ModelType.OBJECT_SMALL\n ? getSmallModel(runtime)\n : getLargeModel(runtime);\n const modelLabel =\n modelType === ModelType.OBJECT_SMALL ? \"OBJECT_SMALL\" : \"OBJECT_LARGE\";\n\n logger.log(`[OpenRouter] Using ${modelLabel} model: ${modelName}`);\n const temperature = params.temperature ?? 0.7;\n\n try {\n const { object, usage } = await generateObject({\n model: openrouter.chat(modelName),\n output: \"no-schema\",\n prompt: params.prompt,\n temperature: temperature,\n experimental_repairText: getJsonRepairFunction(),\n });\n\n if (usage) {\n emitModelUsageEvent(runtime, modelType, params.prompt, usage);\n }\n return object;\n } catch (error: unknown) {\n return handleObjectGenerationError(error);\n }\n}\n\n/**\n * OBJECT_SMALL model handler\n */\nexport async function handleObjectSmall(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n return generateObjectWithModel(runtime, ModelType.OBJECT_SMALL, params);\n}\n\n/**\n * OBJECT_LARGE model handler\n */\nexport async function handleObjectLarge(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n return generateObjectWithModel(runtime, ModelType.OBJECT_LARGE, params);\n}\n",
13
+ "import {\n ModelType,\n logger,\n type IAgentRuntime,\n type ObjectGenerationParams,\n} from \"@elizaos/core\";\nimport { generateObject } from \"ai\";\nimport { createOpenRouterProvider } from \"../providers\";\nimport { getSmallModel, getLargeModel } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport {\n getJsonRepairFunction,\n handleObjectGenerationError,\n} from \"../utils/helpers\";\n\n/**\n * Common object generation logic for both small and large models\n */\nasync function generateObjectWithModel(\n runtime: IAgentRuntime,\n modelType: typeof ModelType.OBJECT_SMALL | typeof ModelType.OBJECT_LARGE,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n const openrouter = createOpenRouterProvider(runtime);\n const modelName =\n modelType === ModelType.OBJECT_SMALL\n ? getSmallModel(runtime)\n : getLargeModel(runtime);\n const modelLabel =\n modelType === ModelType.OBJECT_SMALL ? \"OBJECT_SMALL\" : \"OBJECT_LARGE\";\n\n logger.log(`[OpenRouter] Using ${modelLabel} model: ${modelName}`);\n const temperature = params.temperature ?? 0.7;\n\n try {\n const { object, usage } = await generateObject({\n model: openrouter.chat(modelName),\n ...(params.schema && { schema: params.schema }),\n output: (params.schema ? \"object\" : \"no-schema\") as any,\n prompt: params.prompt,\n temperature: temperature,\n experimental_repairText: getJsonRepairFunction(),\n });\n\n if (usage) {\n emitModelUsageEvent(runtime, modelType, params.prompt, usage);\n }\n return object;\n } catch (error: unknown) {\n return handleObjectGenerationError(error);\n }\n}\n\n/**\n * OBJECT_SMALL model handler\n */\nexport async function handleObjectSmall(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n return generateObjectWithModel(runtime, ModelType.OBJECT_SMALL, params);\n}\n\n/**\n * OBJECT_LARGE model handler\n */\nexport async function handleObjectLarge(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n return generateObjectWithModel(runtime, ModelType.OBJECT_LARGE, params);\n}\n",
14
14
  "import {\n logger,\n type IAgentRuntime,\n type ImageDescriptionParams,\n type ImageGenerationParams,\n} from \"@elizaos/core\";\nimport { generateText } from \"ai\";\nimport type { OpenRouterImageResponse } from \"../types\";\nimport { createOpenRouterProvider } from \"../providers\";\nimport {\n getApiKey,\n getBaseURL,\n getImageGenerationModel,\n getImageModel,\n shouldAutoCleanupImages,\n} from \"../utils/config\";\nimport { parseImageDescriptionResponse } from \"../utils/helpers\";\nimport { deleteImage, saveBase64Image } from \"../utils/image-storage\";\n\n/**\n * IMAGE_DESCRIPTION model handler\n */\nexport async function handleImageDescription(\n runtime: IAgentRuntime,\n params: ImageDescriptionParams | string,\n): Promise<{ title: string; description: string }> {\n let imageUrl: string;\n let promptText: string | undefined;\n const modelName = getImageModel(runtime);\n logger.log(`[OpenRouter] Using IMAGE_DESCRIPTION model: ${modelName}`);\n const maxOutputTokens = 300;\n\n if (typeof params === \"string\") {\n imageUrl = params;\n promptText =\n \"Please analyze this image and provide a title and detailed description.\";\n } else {\n imageUrl = params.imageUrl;\n promptText =\n params.prompt ||\n \"Please analyze this image and provide a title and detailed description.\";\n }\n\n const openrouter = createOpenRouterProvider(runtime);\n\n const messages = [\n {\n role: \"user\" as const,\n content: [\n { type: \"text\" as const, text: promptText },\n { type: \"image\" as const, image: imageUrl },\n ],\n },\n ];\n\n try {\n const model = openrouter.chat(modelName);\n\n const { text: responseText } = await generateText({\n model: model,\n messages: messages,\n maxOutputTokens: maxOutputTokens,\n });\n\n return parseImageDescriptionResponse(responseText);\n } catch (error: unknown) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error(`Error analyzing image: ${message}`);\n return {\n title: \"Failed to analyze image\",\n description: `Error: ${message}`,\n };\n }\n}\n\n/**\n * IMAGE model handler for image generation\n */\nexport async function handleImageGeneration(\n runtime: IAgentRuntime,\n params: ImageGenerationParams,\n): Promise<{ url: string }[]> {\n const modelName = getImageGenerationModel(runtime);\n logger.log(`[OpenRouter] Using IMAGE_GENERATION model: ${modelName}`);\n const apiKey = getApiKey(runtime);\n\n try {\n const baseUrl = getBaseURL(runtime);\n const isBrowser =\n typeof globalThis !== \"undefined\" && (globalThis as any).document;\n const response = await fetch(`${baseUrl}/chat/completions`, {\n method: \"POST\",\n headers: {\n ...(isBrowser ? {} : { Authorization: `Bearer ${apiKey}` }),\n \"Content-Type\": \"application/json\",\n },\n body: JSON.stringify({\n model: modelName,\n messages: [\n {\n role: \"user\",\n content: params.prompt,\n },\n ],\n modalities: [\"image\", \"text\"],\n }),\n // 60 seconds timeout\n signal: AbortSignal.timeout ? AbortSignal.timeout(60000) : undefined,\n });\n\n if (!response.ok) {\n const errorText = await response.text().catch(() => \"\");\n throw new Error(\n `HTTP ${response.status} ${response.statusText} ${errorText}`,\n );\n }\n\n const result = (await response.json()) as OpenRouterImageResponse;\n\n const images: { url: string; filepath?: string }[] = [];\n const savedPaths: string[] = [];\n\n // Extract images from the response\n if (result.choices?.[0]?.message?.images) {\n for (const [index, image] of result.choices[0].message.images.entries()) {\n const base64Url = image.image_url.url;\n\n // Save image to disk\n const filepath = await saveBase64Image(\n base64Url,\n runtime.agentId,\n index,\n );\n if (filepath) {\n // Return the actual file path for Discord/Telegram compatibility\n logger.log(`[OpenRouter] Returning image with filepath: ${filepath}`);\n images.push({\n url: filepath, // Use actual file path\n });\n savedPaths.push(filepath);\n } else if (!base64Url.startsWith(\"data:\")) {\n // If not base64, return as is (might be a URL)\n images.push({ url: base64Url });\n } else {\n // Failed to save base64 image\n logger.warn(\n `[OpenRouter] Failed to save image ${index + 1}, skipping`,\n );\n }\n }\n }\n\n // Clean up images after a short delay if auto-cleanup is enabled\n if (savedPaths.length > 0 && shouldAutoCleanupImages(runtime)) {\n setTimeout(() => {\n savedPaths.forEach((path) => {\n deleteImage(path);\n });\n }, 30000); // Delete after 30 seconds\n }\n\n if (images.length === 0) {\n throw new Error(\"No images generated in response\");\n }\n\n logger.log(`[OpenRouter] Generated ${images.length} image(s)`);\n return images;\n } catch (error: unknown) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error(`[OpenRouter] Error generating image: ${message}`);\n return [];\n }\n}\n",
15
15
  "import { logger, getGeneratedDir } from \"@elizaos/core\";\n\nfunction isBrowser(): boolean {\n return typeof globalThis !== \"undefined\" && (globalThis as any).document;\n}\n\n// Restrict identifiers to a safe subset to prevent path traversal/FS escape\nfunction sanitizeId(id: string): string {\n const src = (id ?? \"\").toString();\n const normalized = src.normalize(\"NFKC\");\n let safe = normalized.replace(/[^a-zA-Z0-9_-]/g, \"_\");\n safe = safe.replace(/_+/g, \"_\");\n safe = safe.slice(0, 64);\n safe = safe.replace(/^_+|_+$/g, \"\");\n return safe || \"agent\";\n}\n\n// Lightweight base64 decoder that avoids Node Buffer and works in browser/Node\nfunction base64ToBytes(base64: string): Uint8Array {\n // Remove padding\n const cleaned = base64.replace(/\\s+/g, \"\");\n const chars =\n \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\";\n const lookup: number[] = new Array(256).fill(-1);\n for (let i = 0; i < chars.length; i++) lookup[chars.charCodeAt(i)] = i;\n\n const len = cleaned.length;\n let pad = 0;\n if (len >= 2 && cleaned[len - 1] === \"=\") pad++;\n if (len >= 2 && cleaned[len - 2] === \"=\") pad++;\n const outLen = ((len * 3) >> 2) - pad;\n const out = new Uint8Array(outLen);\n\n let o = 0;\n for (let i = 0; i < len; i += 4) {\n const c0 = lookup[cleaned.charCodeAt(i)];\n const c1 = lookup[cleaned.charCodeAt(i + 1)];\n const c2 = lookup[cleaned.charCodeAt(i + 2)];\n const c3 = lookup[cleaned.charCodeAt(i + 3)];\n const n = (c0 << 18) | (c1 << 12) | ((c2 & 63) << 6) | (c3 & 63);\n if (o < outLen) out[o++] = (n >> 16) & 255;\n if (o < outLen) out[o++] = (n >> 8) & 255;\n if (o < outLen) out[o++] = n & 255;\n }\n return out;\n}\n\n/**\n * Save base64 image to disk and return the file path\n */\nexport async function saveBase64Image(\n base64Url: string,\n agentId: string,\n index: number = 0,\n): Promise<string | null> {\n if (isBrowser()) {\n return null;\n }\n // Extract base64 data and extension with MIME type validation\n const m = base64Url.match(\n /^data:(image\\/[a-zA-Z0-9.+-]+);base64,([A-Za-z0-9+/=]+)$/,\n );\n if (!m) return null;\n\n const mime = m[1];\n const base64Data = m[2];\n\n // Whitelist of allowed MIME types mapped to extensions\n const extMap: Record<string, string> = {\n \"image/png\": \"png\",\n \"image/jpeg\": \"jpg\",\n \"image/jpg\": \"jpg\",\n \"image/webp\": \"webp\",\n \"image/gif\": \"gif\",\n \"image/bmp\": \"bmp\",\n \"image/tiff\": \"tiff\",\n };\n\n const extension = extMap[mime];\n if (!extension) return null;\n\n // Use ElizaOS convention: .eliza/data/generated/{agentId}/\n const { join } = await import(\"node:path\");\n const safeAgentId = sanitizeId(agentId);\n const baseDir = join(getGeneratedDir(), safeAgentId);\n\n // Create directory if it doesn't exist\n const { existsSync } = await import(\"node:fs\");\n if (!existsSync(baseDir)) {\n const { mkdir } = await import(\"node:fs/promises\");\n await mkdir(baseDir, { recursive: true });\n }\n\n // Generate filename with timestamp\n const timestamp = Date.now();\n const filename = `image_${timestamp}_${index}.${extension}`;\n const filepath = join(baseDir, filename);\n\n // Save image to disk\n const buffer = base64ToBytes(base64Data);\n const { writeFile } = await import(\"node:fs/promises\");\n await writeFile(filepath, buffer);\n\n logger.info(`[OpenRouter] Saved generated image to ${filepath}`);\n\n // Return only the file path for Discord/Telegram to read\n return filepath;\n}\n\n/**\n * Delete a specific image file\n */\nexport function deleteImage(filepath: string): void {\n if (isBrowser()) {\n return;\n }\n try {\n (async () => {\n const { existsSync, unlinkSync } = await import(\"node:fs\");\n if (existsSync(filepath)) {\n unlinkSync(filepath);\n logger.debug(`[OpenRouter] Deleted image: ${filepath}`);\n }\n })().catch((error) => {\n logger.warn(\n `[OpenRouter] Failed to delete image ${filepath}:`,\n String(error),\n );\n });\n } catch (error) {\n logger.warn(\n `[OpenRouter] Failed to delete image ${filepath}:`,\n String(error),\n );\n }\n}\n"
16
16
  ],
17
- "mappings": "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",
18
- "debugId": "BF459D9A02C441C264756E2164756E21",
17
+ "mappings": "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",
18
+ "debugId": "D932CBC1DE77F50264756E2164756E21",
19
19
  "names": []
20
20
  }
@@ -84,6 +84,15 @@ function shouldAutoCleanupImages(runtime) {
84
84
  const setting = getSetting(runtime, "OPENROUTER_AUTO_CLEANUP_IMAGES", "false");
85
85
  return setting?.toLowerCase() === "true";
86
86
  }
87
+ function getToolExecutionMaxSteps(runtime) {
88
+ const setting = getSetting(runtime, "OPENROUTER_TOOL_EXECUTION_MAX_STEPS", "15");
89
+ const value = parseInt(setting || "15", 10);
90
+ if (Number.isNaN(value) || value < 1)
91
+ return 15;
92
+ if (value > 100)
93
+ return 100;
94
+ return value;
95
+ }
87
96
 
88
97
  // src/init.ts
89
98
  function initializeOpenRouter(_config, runtime) {
@@ -274,7 +283,7 @@ async function generateTextWithModel(runtime, modelType, params) {
274
283
  const openrouter = createOpenRouterProvider(runtime);
275
284
  const modelName = modelType === import_core4.ModelType.TEXT_SMALL ? getSmallModel(runtime) : getLargeModel(runtime);
276
285
  const modelLabel = modelType === import_core4.ModelType.TEXT_SMALL ? "TEXT_SMALL" : "TEXT_LARGE";
277
- import_core4.logger.log(`[OpenRouter] Generating text with ${modelLabel} model: ${modelName}`);
286
+ import_core4.logger.debug(`[OpenRouter] Generating text with ${modelLabel} model: ${modelName}`);
278
287
  const generateParams = {
279
288
  model: openrouter.chat(modelName),
280
289
  prompt,
@@ -287,6 +296,9 @@ async function generateTextWithModel(runtime, modelType, params) {
287
296
  generateParams.maxOutputTokens = resolvedMaxOutput;
288
297
  if (tools) {
289
298
  generateParams.tools = tools;
299
+ const maxSteps = getToolExecutionMaxSteps(runtime);
300
+ generateParams.stopWhen = import_ai2.stepCountIs(maxSteps);
301
+ import_core4.logger.debug(`[OpenRouter] Using maxSteps: ${maxSteps} for tool execution`);
290
302
  }
291
303
  if (toolChoice) {
292
304
  generateParams.toolChoice = toolChoice;
@@ -301,12 +313,14 @@ async function generateTextWithModel(runtime, modelType, params) {
301
313
  ...stepResult.toolCalls
302
314
  ];
303
315
  }
304
- if (stepResult.toolResults && stepResult.toolResults.length > 0) {
305
- const decodedToolResults = stepResult.toolResults.map((result) => ({
306
- toolCallId: result.toolCallId,
307
- result: decodeBase64Fields(result.result)
316
+ if (stepResult.content && Array.isArray(stepResult.content)) {
317
+ const toolResultsFromContent = stepResult.content.filter((content) => content.type === "tool-result" && content.output).map((content) => ({
318
+ toolCallId: content.toolCallId,
319
+ result: decodeBase64Fields(content.output)
308
320
  }));
309
- capturedToolResults = [...capturedToolResults, ...decodedToolResults];
321
+ if (toolResultsFromContent.length > 0) {
322
+ capturedToolResults = [...capturedToolResults, ...toolResultsFromContent];
323
+ }
310
324
  }
311
325
  };
312
326
  }
@@ -320,11 +334,12 @@ async function generateTextWithModel(runtime, modelType, params) {
320
334
  if (response.usage) {
321
335
  emitModelUsageEvent(runtime, modelType, prompt, response.usage);
322
336
  }
323
- if (tools && (capturedToolCalls.length > 0 || capturedToolResults.length > 0)) {
337
+ if (tools && response.steps && response.steps.length > 0) {
324
338
  return {
325
339
  text: responseText,
326
340
  toolCalls: capturedToolCalls,
327
341
  toolResults: capturedToolResults,
342
+ steps: response.steps,
328
343
  usage: response.usage,
329
344
  finishReason: response.finishReason
330
345
  };
@@ -350,7 +365,8 @@ async function generateObjectWithModel(runtime, modelType, params) {
350
365
  try {
351
366
  const { object, usage } = await import_ai3.generateObject({
352
367
  model: openrouter.chat(modelName),
353
- output: "no-schema",
368
+ ...params.schema && { schema: params.schema },
369
+ output: params.schema ? "object" : "no-schema",
354
370
  prompt: params.prompt,
355
371
  temperature,
356
372
  experimental_repairText: getJsonRepairFunction()
@@ -627,4 +643,4 @@ var openrouterPlugin = {
627
643
  };
628
644
  var src_default = openrouterPlugin;
629
645
 
630
- //# debugId=542D5C87F44C9E5B64756E2164756E21
646
+ //# debugId=CE876441FA57CD5464756E2164756E21
@@ -4,16 +4,16 @@
4
4
  "sourcesContent": [
5
5
  "import {\n ModelType,\n type Plugin,\n type IAgentRuntime,\n type GenerateTextParams,\n type ObjectGenerationParams,\n type ImageDescriptionParams,\n type ImageGenerationParams,\n} from \"@elizaos/core\";\nimport type { Tool, ToolChoice } from \"ai\";\nimport { initializeOpenRouter } from \"./init\";\nimport { handleTextSmall, handleTextLarge } from \"./models/text\";\nimport { handleObjectSmall, handleObjectLarge } from \"./models/object\";\nimport { handleImageDescription, handleImageGeneration } from \"./models/image\";\n\n/**\n * Defines the OpenRouter plugin with its name, description, and configuration options.\n * @type {Plugin}\n */\nexport const openrouterPlugin: Plugin = {\n name: \"openrouter\",\n description: \"OpenRouter plugin\",\n config: {\n OPENROUTER_API_KEY: process.env.OPENROUTER_API_KEY,\n OPENROUTER_BASE_URL: process.env.OPENROUTER_BASE_URL,\n OPENROUTER_SMALL_MODEL: process.env.OPENROUTER_SMALL_MODEL,\n OPENROUTER_LARGE_MODEL: process.env.OPENROUTER_LARGE_MODEL,\n OPENROUTER_IMAGE_MODEL: process.env.OPENROUTER_IMAGE_MODEL,\n OPENROUTER_IMAGE_GENERATION_MODEL:\n process.env.OPENROUTER_IMAGE_GENERATION_MODEL,\n OPENROUTER_AUTO_CLEANUP_IMAGES: process.env.OPENROUTER_AUTO_CLEANUP_IMAGES,\n SMALL_MODEL: process.env.SMALL_MODEL,\n LARGE_MODEL: process.env.LARGE_MODEL,\n IMAGE_MODEL: process.env.IMAGE_MODEL,\n IMAGE_GENERATION_MODEL: process.env.IMAGE_GENERATION_MODEL,\n },\n async init(config, runtime) {\n // Note: We intentionally don't await here because ElizaOS expects\n // the init method to return quickly. The initializeOpenRouter function\n // only performs synchronous validation and logging, so it's safe to\n // call without await. This prevents blocking the plugin initialization.\n initializeOpenRouter(config, runtime);\n },\n models: {\n [ModelType.TEXT_SMALL]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n ) => {\n return handleTextSmall(runtime, params);\n },\n [ModelType.TEXT_LARGE]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n ) => {\n return handleTextLarge(runtime, params);\n },\n [ModelType.OBJECT_SMALL]: async (\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n ) => {\n return handleObjectSmall(runtime, params);\n },\n [ModelType.OBJECT_LARGE]: async (\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n ) => {\n return handleObjectLarge(runtime, params);\n },\n [ModelType.IMAGE_DESCRIPTION]: async (\n runtime: IAgentRuntime,\n params: ImageDescriptionParams | string,\n ) => {\n return handleImageDescription(runtime, params);\n },\n [ModelType.IMAGE]: async (\n runtime: IAgentRuntime,\n params: ImageGenerationParams,\n ) => {\n return handleImageGeneration(runtime, params);\n },\n },\n};\n\nexport default openrouterPlugin;\n",
6
6
  "import { logger, type IAgentRuntime } from \"@elizaos/core\";\nimport { fetch } from \"undici\";\nimport { getApiKey, getBaseURL } from \"./utils/config\";\n\n/**\n * Initialize and validate OpenRouter configuration\n * Returns the exact same function that works inline\n */\nexport function initializeOpenRouter(_config: any, runtime: IAgentRuntime) {\n // do check in the background\n (async () => {\n try {\n const isBrowser =\n typeof globalThis !== \"undefined\" && (globalThis as any).document;\n // In browser, skip validation entirely to avoid exposing secrets\n if (isBrowser) {\n return;\n }\n if (!getApiKey(runtime)) {\n logger.warn(\n \"OPENROUTER_API_KEY is not set in environment - OpenRouter functionality will be limited\",\n );\n return;\n }\n try {\n const baseURL = getBaseURL(runtime);\n const response = await fetch(`${baseURL}/models`, {\n headers: { Authorization: `Bearer ${getApiKey(runtime)}` },\n });\n if (!response.ok) {\n logger.warn(\n `OpenRouter API key validation failed: ${response.statusText}`,\n );\n logger.warn(\n \"OpenRouter functionality will be limited until a valid API key is provided\",\n );\n } else {\n logger.log(\"OpenRouter API key validated successfully\");\n }\n } catch (fetchError: unknown) {\n const message =\n fetchError instanceof Error ? fetchError.message : String(fetchError);\n logger.warn(`Error validating OpenRouter API key: ${message}`);\n logger.warn(\n \"OpenRouter functionality will be limited until a valid API key is provided\",\n );\n }\n } catch (error: unknown) {\n const message =\n (error as { errors?: Array<{ message: string }> })?.errors\n ?.map((e) => e.message)\n .join(\", \") ||\n (error instanceof Error ? error.message : String(error));\n logger.warn(\n `OpenRouter plugin configuration issue: ${message} - You need to configure the OPENROUTER_API_KEY in your environment variables`,\n );\n }\n })();\n return;\n}\n",
7
- "import type { IAgentRuntime } from \"@elizaos/core\";\n\n/**\n * Retrieves a configuration setting from the runtime, falling back to environment variables or a default value if not found.\n *\n * @param key - The name of the setting to retrieve.\n * @param defaultValue - The value to return if the setting is not found in the runtime or environment.\n * @returns The resolved setting value, or {@link defaultValue} if not found.\n */\nexport function getSetting(\n runtime: IAgentRuntime,\n key: string,\n defaultValue?: string,\n): string | undefined {\n return runtime.getSetting(key) ?? process.env[key] ?? defaultValue;\n}\n\n/**\n * Retrieves the OpenRouter API base URL from runtime settings, environment variables, or defaults.\n *\n * @returns The resolved base URL for OpenRouter API requests.\n */\nexport function getBaseURL(runtime: IAgentRuntime): string {\n const browserURL = getSetting(runtime, \"OPENROUTER_BROWSER_BASE_URL\");\n if (\n typeof globalThis !== \"undefined\" &&\n (globalThis as any).document &&\n browserURL\n ) {\n return browserURL;\n }\n return (\n getSetting(\n runtime,\n \"OPENROUTER_BASE_URL\",\n \"https://openrouter.ai/api/v1\",\n ) || \"https://openrouter.ai/api/v1\"\n );\n}\n\n/**\n * Helper function to get the API key for OpenRouter\n *\n * @param runtime The runtime context\n * @returns The configured API key\n */\nexport function getApiKey(runtime: IAgentRuntime): string | undefined {\n return getSetting(runtime, \"OPENROUTER_API_KEY\");\n}\n\n/**\n * Helper function to get the small model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured small model name\n */\nexport function getSmallModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_SMALL_MODEL\") ??\n getSetting(runtime, \"SMALL_MODEL\", \"google/gemini-2.0-flash-001\") ??\n \"google/gemini-2.0-flash-001\"\n );\n}\n\n/**\n * Helper function to get the large model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured large model name\n */\nexport function getLargeModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_LARGE_MODEL\") ??\n getSetting(runtime, \"LARGE_MODEL\", \"google/gemini-2.5-flash\") ??\n \"google/gemini-2.5-flash\"\n );\n}\n\n/**\n * Helper function to get the image model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured image model name\n */\nexport function getImageModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_IMAGE_MODEL\") ??\n getSetting(runtime, \"IMAGE_MODEL\", \"x-ai/grok-2-vision-1212\") ??\n \"x-ai/grok-2-vision-1212\"\n );\n}\n\n/**\n * Helper function to get the image generation model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured image generation model name\n */\nexport function getImageGenerationModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_IMAGE_GENERATION_MODEL\") ??\n getSetting(\n runtime,\n \"IMAGE_GENERATION_MODEL\",\n \"google/gemini-2.5-flash-image-preview\",\n ) ??\n \"google/gemini-2.5-flash-image-preview\"\n );\n}\n\n/**\n * Helper function to check if auto cleanup is enabled for generated images\n *\n * @param runtime The runtime context\n * @returns Whether to auto-cleanup generated images (default: false)\n */\nexport function shouldAutoCleanupImages(runtime: IAgentRuntime): boolean {\n const setting = getSetting(\n runtime,\n \"OPENROUTER_AUTO_CLEANUP_IMAGES\",\n \"false\",\n );\n return setting?.toLowerCase() === \"true\";\n}\n",
8
- "import type { GenerateTextParams, IAgentRuntime } from \"@elizaos/core\";\nimport { logger, ModelType } from \"@elizaos/core\";\nimport { generateText } from \"ai\";\nimport type { Tool, ToolChoice } from \"ai\";\n\nimport { createOpenRouterProvider } from \"../providers\";\nimport type { ToolCall, ToolResponse, ToolResult } from \"../types\";\nimport { getSmallModel, getLargeModel } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport { handleEmptyToolResponse, decodeBase64Fields } from \"../utils/helpers\";\n\n/**\n * Common text generation logic for both small and large models\n */\nasync function generateTextWithModel(\n runtime: IAgentRuntime,\n modelType: typeof ModelType.TEXT_SMALL | typeof ModelType.TEXT_LARGE,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n const { prompt, stopSequences = [], tools, toolChoice } = params;\n const temperature = params.temperature ?? 0.7;\n const frequencyPenalty = params.frequencyPenalty ?? 0.7;\n const presencePenalty = params.presencePenalty ?? 0.7;\n // AI SDK v5: prefer maxOutputTokens; keep legacy maxTokens as fallback; default 8192\n const resolvedMaxOutput =\n (params as any).maxOutputTokens ?? (params as any).maxTokens ?? 8192;\n\n const openrouter = createOpenRouterProvider(runtime);\n const modelName =\n modelType === ModelType.TEXT_SMALL\n ? getSmallModel(runtime)\n : getLargeModel(runtime);\n const modelLabel =\n modelType === ModelType.TEXT_SMALL ? \"TEXT_SMALL\" : \"TEXT_LARGE\";\n\n logger.log(\n `[OpenRouter] Generating text with ${modelLabel} model: ${modelName}`,\n );\n\n const generateParams: Parameters<typeof generateText>[0] = {\n model: openrouter.chat(modelName),\n prompt: prompt,\n system: runtime.character.system ?? undefined,\n temperature: temperature,\n frequencyPenalty: frequencyPenalty,\n presencePenalty: presencePenalty,\n stopSequences: stopSequences,\n };\n\n (generateParams as any).maxOutputTokens = resolvedMaxOutput;\n\n // Add tools if provided\n if (tools) {\n (generateParams as any).tools = tools;\n }\n\n // Add toolChoice if provided\n if (toolChoice) {\n (generateParams as any).toolChoice = toolChoice;\n }\n\n // Capture tool results if tools are used\n let capturedToolResults: ToolResult[] = [];\n let capturedToolCalls: ToolCall[] = [];\n\n if (tools) {\n (generateParams as any).onStepFinish = async (stepResult: any) => {\n if (stepResult.toolCalls && stepResult.toolCalls.length > 0) {\n capturedToolCalls = [\n ...capturedToolCalls,\n ...(stepResult.toolCalls as any),\n ];\n }\n if (stepResult.toolResults && stepResult.toolResults.length > 0) {\n const decodedToolResults = (stepResult.toolResults as any[]).map(\n (result: any) => ({\n toolCallId: result.toolCallId,\n result: decodeBase64Fields(result.result),\n }),\n );\n capturedToolResults = [...capturedToolResults, ...decodedToolResults];\n }\n };\n }\n\n const response = await generateText(generateParams);\n\n // Handle cases where tool execution doesn't generate text\n let responseText: string;\n if (\n tools &&\n (!response.text ||\n response.text.trim() === \"\" ||\n response.text === \"Tools executed successfully.\")\n ) {\n responseText = handleEmptyToolResponse(modelLabel);\n } else {\n responseText = response.text;\n }\n\n if (response.usage) {\n emitModelUsageEvent(runtime, modelType, prompt, response.usage);\n }\n\n // If tools were used, return the full response object to access toolCalls and toolResults\n if (\n tools &&\n (capturedToolCalls.length > 0 || capturedToolResults.length > 0)\n ) {\n return {\n text: responseText,\n toolCalls: capturedToolCalls,\n toolResults: capturedToolResults,\n // Include other useful properties\n usage: response.usage,\n finishReason: response.finishReason,\n };\n }\n\n return responseText;\n}\n\n/**\n * TEXT_SMALL model handler\n */\nexport async function handleTextSmall(\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n return generateTextWithModel(runtime, ModelType.TEXT_SMALL, params);\n}\n\n/**\n * TEXT_LARGE model handler\n */\nexport async function handleTextLarge(\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n return generateTextWithModel(runtime, ModelType.TEXT_LARGE, params);\n}\n",
7
+ "import type { IAgentRuntime } from \"@elizaos/core\";\n\n/**\n * Retrieves a configuration setting from the runtime, falling back to environment variables or a default value if not found.\n *\n * @param key - The name of the setting to retrieve.\n * @param defaultValue - The value to return if the setting is not found in the runtime or environment.\n * @returns The resolved setting value, or {@link defaultValue} if not found.\n */\nexport function getSetting(\n runtime: IAgentRuntime,\n key: string,\n defaultValue?: string,\n): string | undefined {\n return runtime.getSetting(key) ?? process.env[key] ?? defaultValue;\n}\n\n/**\n * Retrieves the OpenRouter API base URL from runtime settings, environment variables, or defaults.\n *\n * @returns The resolved base URL for OpenRouter API requests.\n */\nexport function getBaseURL(runtime: IAgentRuntime): string {\n const browserURL = getSetting(runtime, \"OPENROUTER_BROWSER_BASE_URL\");\n if (\n typeof globalThis !== \"undefined\" &&\n (globalThis as any).document &&\n browserURL\n ) {\n return browserURL;\n }\n return (\n getSetting(\n runtime,\n \"OPENROUTER_BASE_URL\",\n \"https://openrouter.ai/api/v1\",\n ) || \"https://openrouter.ai/api/v1\"\n );\n}\n\n/**\n * Helper function to get the API key for OpenRouter\n *\n * @param runtime The runtime context\n * @returns The configured API key\n */\nexport function getApiKey(runtime: IAgentRuntime): string | undefined {\n return getSetting(runtime, \"OPENROUTER_API_KEY\");\n}\n\n/**\n * Helper function to get the small model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured small model name\n */\nexport function getSmallModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_SMALL_MODEL\") ??\n getSetting(runtime, \"SMALL_MODEL\", \"google/gemini-2.0-flash-001\") ??\n \"google/gemini-2.0-flash-001\"\n );\n}\n\n/**\n * Helper function to get the large model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured large model name\n */\nexport function getLargeModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_LARGE_MODEL\") ??\n getSetting(runtime, \"LARGE_MODEL\", \"google/gemini-2.5-flash\") ??\n \"google/gemini-2.5-flash\"\n );\n}\n\n/**\n * Helper function to get the image model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured image model name\n */\nexport function getImageModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_IMAGE_MODEL\") ??\n getSetting(runtime, \"IMAGE_MODEL\", \"x-ai/grok-2-vision-1212\") ??\n \"x-ai/grok-2-vision-1212\"\n );\n}\n\n/**\n * Helper function to get the image generation model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured image generation model name\n */\nexport function getImageGenerationModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_IMAGE_GENERATION_MODEL\") ??\n getSetting(\n runtime,\n \"IMAGE_GENERATION_MODEL\",\n \"google/gemini-2.5-flash-image-preview\",\n ) ??\n \"google/gemini-2.5-flash-image-preview\"\n );\n}\n\n/**\n * Helper function to check if auto cleanup is enabled for generated images\n *\n * @param runtime The runtime context\n * @returns Whether to auto-cleanup generated images (default: false)\n */\nexport function shouldAutoCleanupImages(runtime: IAgentRuntime): boolean {\n const setting = getSetting(\n runtime,\n \"OPENROUTER_AUTO_CLEANUP_IMAGES\",\n \"false\",\n );\n return setting?.toLowerCase() === \"true\";\n}\n\n/**\n * Helper function to get the max steps for tool execution\n *\n * @param runtime The runtime context\n * @returns The maximum number of steps for tool execution (default: 15)\n */\nexport function getToolExecutionMaxSteps(runtime: IAgentRuntime): number {\n const setting = getSetting(\n runtime,\n \"OPENROUTER_TOOL_EXECUTION_MAX_STEPS\",\n \"15\",\n );\n const value = parseInt(setting || \"15\", 10);\n // Ensure valid range (1-100)\n if (Number.isNaN(value) || value < 1) return 15;\n if (value > 100) return 100;\n return value;\n}\n",
8
+ "import type { GenerateTextParams, IAgentRuntime } from \"@elizaos/core\";\nimport { logger, ModelType } from \"@elizaos/core\";\nimport { generateText, stepCountIs } from \"ai\";\nimport type { Tool, ToolChoice } from \"ai\";\n\nimport { createOpenRouterProvider } from \"../providers\";\nimport type { ToolCall, ToolResponse, ToolResult } from \"../types\";\nimport { getSmallModel, getLargeModel, getToolExecutionMaxSteps } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport { handleEmptyToolResponse, decodeBase64Fields } from \"../utils/helpers\";\n\n/**\n * Common text generation logic for both small and large models\n */\nasync function generateTextWithModel(\n runtime: IAgentRuntime,\n modelType: typeof ModelType.TEXT_SMALL | typeof ModelType.TEXT_LARGE,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n const { prompt, stopSequences = [], tools, toolChoice } = params;\n const temperature = params.temperature ?? 0.7;\n const frequencyPenalty = params.frequencyPenalty ?? 0.7;\n const presencePenalty = params.presencePenalty ?? 0.7;\n // AI SDK v5: prefer maxOutputTokens; keep legacy maxTokens as fallback; default 8192\n const resolvedMaxOutput =\n (params as any).maxOutputTokens ?? (params as any).maxTokens ?? 8192;\n\n const openrouter = createOpenRouterProvider(runtime);\n const modelName =\n modelType === ModelType.TEXT_SMALL\n ? getSmallModel(runtime)\n : getLargeModel(runtime);\n const modelLabel =\n modelType === ModelType.TEXT_SMALL ? \"TEXT_SMALL\" : \"TEXT_LARGE\";\n\n logger.debug(\n `[OpenRouter] Generating text with ${modelLabel} model: ${modelName}`,\n );\n\n const generateParams: Parameters<typeof generateText>[0] = {\n model: openrouter.chat(modelName),\n prompt: prompt,\n system: runtime.character.system ?? undefined,\n temperature: temperature,\n frequencyPenalty: frequencyPenalty,\n presencePenalty: presencePenalty,\n stopSequences: stopSequences,\n };\n\n (generateParams as any).maxOutputTokens = resolvedMaxOutput;\n\n // Add tools if provided\n if (tools) {\n (generateParams as any).tools = tools;\n const maxSteps = getToolExecutionMaxSteps(runtime);\n\n (generateParams as any).stopWhen = stepCountIs(maxSteps);\n logger.debug(`[OpenRouter] Using maxSteps: ${maxSteps} for tool execution`);\n }\n\n // Add toolChoice if provided\n if (toolChoice) {\n (generateParams as any).toolChoice = toolChoice;\n }\n\n // Capture tool results if tools are used\n let capturedToolResults: ToolResult[] = [];\n let capturedToolCalls: ToolCall[] = [];\n\n if (tools) {\n (generateParams as any).onStepFinish = async (stepResult: any) => {\n if (stepResult.toolCalls && stepResult.toolCalls.length > 0) {\n capturedToolCalls = [\n ...capturedToolCalls,\n ...(stepResult.toolCalls as any),\n ];\n }\n\n // Extract tool results from content array in steps\n if (stepResult.content && Array.isArray(stepResult.content)) {\n const toolResultsFromContent = stepResult.content\n .filter((content: any) => content.type === 'tool-result' && content.output)\n .map((content: any) => ({\n toolCallId: content.toolCallId,\n result: decodeBase64Fields(content.output),\n }));\n\n if (toolResultsFromContent.length > 0) {\n capturedToolResults = [...capturedToolResults, ...toolResultsFromContent];\n }\n }\n };\n }\n\n const response = await generateText(generateParams);\n\n // Handle cases where tool execution doesn't generate text\n let responseText: string;\n if (\n tools &&\n (!response.text ||\n response.text.trim() === \"\" ||\n response.text === \"Tools executed successfully.\")\n ) {\n responseText = handleEmptyToolResponse(modelLabel);\n } else {\n responseText = response.text;\n }\n\n if (response.usage) {\n emitModelUsageEvent(runtime, modelType, prompt, response.usage);\n }\n\n // If tools were used, return the full response object with steps for proper tool results access\n if (tools && response.steps && response.steps.length > 0) {\n return {\n text: responseText,\n toolCalls: capturedToolCalls,\n toolResults: capturedToolResults,\n steps: response.steps,\n usage: response.usage,\n finishReason: response.finishReason,\n };\n }\n\n return responseText;\n}\n\n/**\n * TEXT_SMALL model handler\n */\nexport async function handleTextSmall(\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n return generateTextWithModel(runtime, ModelType.TEXT_SMALL, params);\n}\n\n/**\n * TEXT_LARGE model handler\n */\nexport async function handleTextLarge(\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n return generateTextWithModel(runtime, ModelType.TEXT_LARGE, params);\n}\n",
9
9
  "import { createOpenRouter } from \"@openrouter/ai-sdk-provider\";\nimport { logger, type IAgentRuntime } from \"@elizaos/core\";\nimport { getApiKey, getBaseURL } from \"../utils/config\";\n\n/**\n * Create an OpenRouter provider instance with proper configuration\n *\n * @param runtime The runtime context\n * @returns Configured OpenRouter provider instance\n */\nexport function createOpenRouterProvider(runtime: IAgentRuntime) {\n const apiKey = getApiKey(runtime);\n const isBrowser =\n typeof globalThis !== \"undefined\" && (globalThis as any).document;\n const baseURL = getBaseURL(runtime);\n // In browser, omit apiKey and rely on proxy baseURL\n return createOpenRouter({\n apiKey: isBrowser ? undefined : apiKey,\n baseURL,\n });\n}\n",
10
- "import {\n EventType,\n type IAgentRuntime,\n type ModelTypeName,\n} from \"@elizaos/core\";\nimport type { LanguageModelUsage } from \"ai\";\n\n/**\n * Emits a model usage event\n */\nexport function emitModelUsageEvent(\n runtime: IAgentRuntime,\n type: ModelTypeName,\n prompt: string,\n usage: LanguageModelUsage,\n) {\n // Never emit the full prompt; truncate to avoid leaking secrets/PII\n const truncatedPrompt =\n typeof prompt === \"string\"\n ? prompt.length > 200\n ? `${prompt.slice(0, 200)}…`\n : prompt\n : \"\";\n // Coalesce optional usage fields to stable numbers\n const inputTokens = Number(usage.inputTokens || 0);\n const outputTokens = Number(usage.outputTokens || 0);\n const totalTokens = Number(\n usage.totalTokens != null ? usage.totalTokens : inputTokens + outputTokens,\n );\n runtime.emitEvent(EventType.MODEL_USED, {\n provider: \"openrouter\",\n type,\n prompt: truncatedPrompt,\n tokens: {\n prompt: inputTokens,\n completion: outputTokens,\n total: totalTokens,\n },\n });\n}\n",
10
+ "import {\n EventType,\n type IAgentRuntime,\n type ModelTypeName,\n} from \"@elizaos/core\";\nimport type { LanguageModelUsage } from \"ai\";\n\n/**\n * Emits a model usage event\n */\nexport function emitModelUsageEvent(\n runtime: IAgentRuntime,\n type: ModelTypeName,\n prompt: string,\n usage: LanguageModelUsage,\n) {\n // Never emit the full prompt; truncate to avoid leaking secrets/PII\n const truncatedPrompt =\n typeof prompt === \"string\"\n ? prompt.length > 200\n ? `${prompt.slice(0, 200)}…`\n : prompt\n : \"\";\n // Coalesce optional usage fields to stable numbers\n const inputTokens = Number((usage as { inputTokens?: number }).inputTokens || 0);\n const outputTokens = Number((usage as { outputTokens?: number }).outputTokens || 0);\n const totalTokens = Number(\n usage.totalTokens != null ? usage.totalTokens : inputTokens + outputTokens,\n );\n runtime.emitEvent(EventType.MODEL_USED, {\n provider: \"openrouter\",\n type,\n prompt: truncatedPrompt,\n tokens: {\n prompt: inputTokens,\n completion: outputTokens,\n total: totalTokens,\n },\n });\n}\n",
11
11
  "import { logger } from \"@elizaos/core\";\nimport { JSONParseError } from \"ai\";\nimport type { GenerateTextResponse, ImageDescriptionResult } from \"../types\";\n\n/**\n * Returns a function to repair JSON text\n */\nexport function getJsonRepairFunction(): (params: {\n text: string;\n error: unknown;\n}) => Promise<string | null> {\n return async ({ text, error }: { text: string; error: unknown }) => {\n try {\n if (error instanceof JSONParseError) {\n const cleanedText = text.replace(/```json\\n|\\n```|```/g, \"\");\n JSON.parse(cleanedText);\n return cleanedText;\n }\n return null;\n } catch (jsonError: unknown) {\n const message =\n jsonError instanceof Error ? jsonError.message : String(jsonError);\n logger.warn(`Failed to repair JSON text: ${message}`);\n return null;\n }\n };\n}\n\n// Re-export for backward compatibility\nexport { emitModelUsageEvent } from \"./events\";\n\n/**\n * Logs response structure for debugging (debug level only)\n */\nexport function logResponseStructure(\n modelType: string,\n response: GenerateTextResponse,\n) {\n // Only log safe, non-sensitive usage fields (avoid raw request bodies)\n const u = (response as any)?.usage;\n const safeUsage =\n u && typeof u === \"object\"\n ? {\n inputTokens: u.inputTokens,\n outputTokens: u.outputTokens,\n totalTokens: u.totalTokens,\n }\n : undefined;\n logger.debug(\n `[${modelType}] Response structure: ${JSON.stringify(\n {\n hasText: !!response.text,\n textLength: response.text?.length || 0,\n hasSteps: !!response.steps,\n stepsCount: response.steps?.length || 0,\n finishReason: response.finishReason,\n usage: safeUsage,\n },\n null,\n 2,\n )}`,\n );\n}\n\n/**\n * Handles cases where tool execution doesn't generate text\n */\nexport function handleEmptyToolResponse(modelType: string): string {\n logger.warn(`[${modelType}] No text generated after tool execution`);\n\n const fallbackText =\n \"I executed the requested action. The tool completed successfully.\";\n logger.warn(`[${modelType}] Using fallback response text`);\n return fallbackText;\n}\n\n/**\n * Parses image description response from text or JSON format\n */\nexport function parseImageDescriptionResponse(\n responseText: string,\n): ImageDescriptionResult {\n // Try to parse as JSON first\n try {\n const jsonResponse = JSON.parse(responseText);\n if (jsonResponse.title && jsonResponse.description) {\n return jsonResponse;\n }\n } catch (e) {\n // If not valid JSON, process as text\n logger.debug(`Parsing as JSON failed, processing as text: ${e}`);\n }\n\n // Extract title and description from text format\n const titleMatch = responseText.match(/title[:\\s]+(.+?)(?:\\n|$)/i);\n const title = titleMatch?.[1]?.trim() || \"Image Analysis\";\n const description = responseText\n .replace(/title[:\\s]+(.+?)(?:\\n|$)/i, \"\")\n .trim();\n\n return { title, description };\n}\n\n/**\n * Handles errors during object generation, including JSON repair attempts\n */\nexport async function handleObjectGenerationError(\n error: unknown,\n): Promise<unknown> {\n if (error instanceof JSONParseError) {\n logger.error(`[generateObject] Failed to parse JSON: ${error.message}`);\n const repairFunction = getJsonRepairFunction();\n const repairedJsonString = await repairFunction({\n text: error.text,\n error,\n });\n\n if (repairedJsonString) {\n try {\n const repairedObject = JSON.parse(repairedJsonString);\n logger.log(\"[generateObject] Successfully repaired JSON.\");\n return repairedObject;\n } catch (repairParseError: unknown) {\n const message =\n repairParseError instanceof Error\n ? repairParseError.message\n : String(repairParseError);\n logger.error(\n `[generateObject] Failed to parse repaired JSON: ${message}`,\n );\n if (repairParseError instanceof Error) throw repairParseError;\n throw Object.assign(new Error(message), { cause: repairParseError });\n }\n } else {\n logger.error(\"[generateObject] JSON repair failed.\");\n throw error;\n }\n } else {\n const message = error instanceof Error ? error.message : String(error);\n logger.error(`[generateObject] Unknown error: ${message}`);\n if (error instanceof Error) throw error;\n throw Object.assign(new Error(message), { cause: error });\n }\n}\n\n/**\n * Quick heuristic to detect if a field likely contains base64 data\n */\nfunction isLikelyBase64(key: string, value: string): boolean {\n // Check key name patterns (expanded base64 field names)\n const base64KeyPattern =\n /^(data|content|body|payload|encoded|b64|base64|document)$/i;\n if (!base64KeyPattern.test(key)) return false;\n\n // Basic format checks\n if (value.length < 20 || value.length > 1024 * 1024) return false; // Size limits\n if (value.length % 4 !== 0) return false; // Invalid base64 length\n if (!/^[A-Za-z0-9+/]*={0,2}$/.test(value)) return false; // Invalid chars\n\n return true;\n}\n\n/**\n * Recursively decodes base64 fields in tool results\n */\nexport function decodeBase64Fields(obj: unknown, depth = 0): unknown {\n // Simple depth protection\n if (depth > 5) return obj;\n if (!obj || typeof obj !== \"object\") return obj;\n if (Array.isArray(obj))\n return obj.map((item) => decodeBase64Fields(item, depth + 1));\n\n const decoded: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(obj)) {\n if (typeof value === \"string\" && isLikelyBase64(key, value)) {\n try {\n decoded[key] = Buffer.from(value, \"base64\").toString(\"utf8\");\n logger.debug(\n `[decodeBase64] Decoded field '${key}' (${value.length} chars)`,\n );\n } catch (error) {\n logger.warn(`[decodeBase64] Failed to decode field '${key}': ${error}`);\n decoded[key] = value; // Keep original if decode fails\n }\n } else if (value && typeof value === \"object\") {\n decoded[key] = decodeBase64Fields(value, depth + 1);\n } else {\n decoded[key] = value;\n }\n }\n return decoded;\n}\n",
12
- "import {\n ModelType,\n logger,\n type IAgentRuntime,\n type ObjectGenerationParams,\n} from \"@elizaos/core\";\nimport { generateObject } from \"ai\";\nimport { createOpenRouterProvider } from \"../providers\";\nimport { getSmallModel, getLargeModel } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport {\n getJsonRepairFunction,\n handleObjectGenerationError,\n} from \"../utils/helpers\";\n\n/**\n * Common object generation logic for both small and large models\n */\nasync function generateObjectWithModel(\n runtime: IAgentRuntime,\n modelType: typeof ModelType.OBJECT_SMALL | typeof ModelType.OBJECT_LARGE,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n const openrouter = createOpenRouterProvider(runtime);\n const modelName =\n modelType === ModelType.OBJECT_SMALL\n ? getSmallModel(runtime)\n : getLargeModel(runtime);\n const modelLabel =\n modelType === ModelType.OBJECT_SMALL ? \"OBJECT_SMALL\" : \"OBJECT_LARGE\";\n\n logger.log(`[OpenRouter] Using ${modelLabel} model: ${modelName}`);\n const temperature = params.temperature ?? 0.7;\n\n try {\n const { object, usage } = await generateObject({\n model: openrouter.chat(modelName),\n output: \"no-schema\",\n prompt: params.prompt,\n temperature: temperature,\n experimental_repairText: getJsonRepairFunction(),\n });\n\n if (usage) {\n emitModelUsageEvent(runtime, modelType, params.prompt, usage);\n }\n return object;\n } catch (error: unknown) {\n return handleObjectGenerationError(error);\n }\n}\n\n/**\n * OBJECT_SMALL model handler\n */\nexport async function handleObjectSmall(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n return generateObjectWithModel(runtime, ModelType.OBJECT_SMALL, params);\n}\n\n/**\n * OBJECT_LARGE model handler\n */\nexport async function handleObjectLarge(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n return generateObjectWithModel(runtime, ModelType.OBJECT_LARGE, params);\n}\n",
12
+ "import {\n ModelType,\n logger,\n type IAgentRuntime,\n type ObjectGenerationParams,\n} from \"@elizaos/core\";\nimport { generateObject } from \"ai\";\nimport { createOpenRouterProvider } from \"../providers\";\nimport { getSmallModel, getLargeModel } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport {\n getJsonRepairFunction,\n handleObjectGenerationError,\n} from \"../utils/helpers\";\n\n/**\n * Common object generation logic for both small and large models\n */\nasync function generateObjectWithModel(\n runtime: IAgentRuntime,\n modelType: typeof ModelType.OBJECT_SMALL | typeof ModelType.OBJECT_LARGE,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n const openrouter = createOpenRouterProvider(runtime);\n const modelName =\n modelType === ModelType.OBJECT_SMALL\n ? getSmallModel(runtime)\n : getLargeModel(runtime);\n const modelLabel =\n modelType === ModelType.OBJECT_SMALL ? \"OBJECT_SMALL\" : \"OBJECT_LARGE\";\n\n logger.log(`[OpenRouter] Using ${modelLabel} model: ${modelName}`);\n const temperature = params.temperature ?? 0.7;\n\n try {\n const { object, usage } = await generateObject({\n model: openrouter.chat(modelName),\n ...(params.schema && { schema: params.schema }),\n output: (params.schema ? \"object\" : \"no-schema\") as any,\n prompt: params.prompt,\n temperature: temperature,\n experimental_repairText: getJsonRepairFunction(),\n });\n\n if (usage) {\n emitModelUsageEvent(runtime, modelType, params.prompt, usage);\n }\n return object;\n } catch (error: unknown) {\n return handleObjectGenerationError(error);\n }\n}\n\n/**\n * OBJECT_SMALL model handler\n */\nexport async function handleObjectSmall(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n return generateObjectWithModel(runtime, ModelType.OBJECT_SMALL, params);\n}\n\n/**\n * OBJECT_LARGE model handler\n */\nexport async function handleObjectLarge(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n return generateObjectWithModel(runtime, ModelType.OBJECT_LARGE, params);\n}\n",
13
13
  "import {\n logger,\n type IAgentRuntime,\n type ImageDescriptionParams,\n type ImageGenerationParams,\n} from \"@elizaos/core\";\nimport { generateText } from \"ai\";\nimport type { OpenRouterImageResponse } from \"../types\";\nimport { createOpenRouterProvider } from \"../providers\";\nimport {\n getApiKey,\n getBaseURL,\n getImageGenerationModel,\n getImageModel,\n shouldAutoCleanupImages,\n} from \"../utils/config\";\nimport { parseImageDescriptionResponse } from \"../utils/helpers\";\nimport { deleteImage, saveBase64Image } from \"../utils/image-storage\";\n\n/**\n * IMAGE_DESCRIPTION model handler\n */\nexport async function handleImageDescription(\n runtime: IAgentRuntime,\n params: ImageDescriptionParams | string,\n): Promise<{ title: string; description: string }> {\n let imageUrl: string;\n let promptText: string | undefined;\n const modelName = getImageModel(runtime);\n logger.log(`[OpenRouter] Using IMAGE_DESCRIPTION model: ${modelName}`);\n const maxOutputTokens = 300;\n\n if (typeof params === \"string\") {\n imageUrl = params;\n promptText =\n \"Please analyze this image and provide a title and detailed description.\";\n } else {\n imageUrl = params.imageUrl;\n promptText =\n params.prompt ||\n \"Please analyze this image and provide a title and detailed description.\";\n }\n\n const openrouter = createOpenRouterProvider(runtime);\n\n const messages = [\n {\n role: \"user\" as const,\n content: [\n { type: \"text\" as const, text: promptText },\n { type: \"image\" as const, image: imageUrl },\n ],\n },\n ];\n\n try {\n const model = openrouter.chat(modelName);\n\n const { text: responseText } = await generateText({\n model: model,\n messages: messages,\n maxOutputTokens: maxOutputTokens,\n });\n\n return parseImageDescriptionResponse(responseText);\n } catch (error: unknown) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error(`Error analyzing image: ${message}`);\n return {\n title: \"Failed to analyze image\",\n description: `Error: ${message}`,\n };\n }\n}\n\n/**\n * IMAGE model handler for image generation\n */\nexport async function handleImageGeneration(\n runtime: IAgentRuntime,\n params: ImageGenerationParams,\n): Promise<{ url: string }[]> {\n const modelName = getImageGenerationModel(runtime);\n logger.log(`[OpenRouter] Using IMAGE_GENERATION model: ${modelName}`);\n const apiKey = getApiKey(runtime);\n\n try {\n const baseUrl = getBaseURL(runtime);\n const isBrowser =\n typeof globalThis !== \"undefined\" && (globalThis as any).document;\n const response = await fetch(`${baseUrl}/chat/completions`, {\n method: \"POST\",\n headers: {\n ...(isBrowser ? {} : { Authorization: `Bearer ${apiKey}` }),\n \"Content-Type\": \"application/json\",\n },\n body: JSON.stringify({\n model: modelName,\n messages: [\n {\n role: \"user\",\n content: params.prompt,\n },\n ],\n modalities: [\"image\", \"text\"],\n }),\n // 60 seconds timeout\n signal: AbortSignal.timeout ? AbortSignal.timeout(60000) : undefined,\n });\n\n if (!response.ok) {\n const errorText = await response.text().catch(() => \"\");\n throw new Error(\n `HTTP ${response.status} ${response.statusText} ${errorText}`,\n );\n }\n\n const result = (await response.json()) as OpenRouterImageResponse;\n\n const images: { url: string; filepath?: string }[] = [];\n const savedPaths: string[] = [];\n\n // Extract images from the response\n if (result.choices?.[0]?.message?.images) {\n for (const [index, image] of result.choices[0].message.images.entries()) {\n const base64Url = image.image_url.url;\n\n // Save image to disk\n const filepath = await saveBase64Image(\n base64Url,\n runtime.agentId,\n index,\n );\n if (filepath) {\n // Return the actual file path for Discord/Telegram compatibility\n logger.log(`[OpenRouter] Returning image with filepath: ${filepath}`);\n images.push({\n url: filepath, // Use actual file path\n });\n savedPaths.push(filepath);\n } else if (!base64Url.startsWith(\"data:\")) {\n // If not base64, return as is (might be a URL)\n images.push({ url: base64Url });\n } else {\n // Failed to save base64 image\n logger.warn(\n `[OpenRouter] Failed to save image ${index + 1}, skipping`,\n );\n }\n }\n }\n\n // Clean up images after a short delay if auto-cleanup is enabled\n if (savedPaths.length > 0 && shouldAutoCleanupImages(runtime)) {\n setTimeout(() => {\n savedPaths.forEach((path) => {\n deleteImage(path);\n });\n }, 30000); // Delete after 30 seconds\n }\n\n if (images.length === 0) {\n throw new Error(\"No images generated in response\");\n }\n\n logger.log(`[OpenRouter] Generated ${images.length} image(s)`);\n return images;\n } catch (error: unknown) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error(`[OpenRouter] Error generating image: ${message}`);\n return [];\n }\n}\n",
14
14
  "import { logger, getGeneratedDir } from \"@elizaos/core\";\n\nfunction isBrowser(): boolean {\n return typeof globalThis !== \"undefined\" && (globalThis as any).document;\n}\n\n// Restrict identifiers to a safe subset to prevent path traversal/FS escape\nfunction sanitizeId(id: string): string {\n const src = (id ?? \"\").toString();\n const normalized = src.normalize(\"NFKC\");\n let safe = normalized.replace(/[^a-zA-Z0-9_-]/g, \"_\");\n safe = safe.replace(/_+/g, \"_\");\n safe = safe.slice(0, 64);\n safe = safe.replace(/^_+|_+$/g, \"\");\n return safe || \"agent\";\n}\n\n// Lightweight base64 decoder that avoids Node Buffer and works in browser/Node\nfunction base64ToBytes(base64: string): Uint8Array {\n // Remove padding\n const cleaned = base64.replace(/\\s+/g, \"\");\n const chars =\n \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\";\n const lookup: number[] = new Array(256).fill(-1);\n for (let i = 0; i < chars.length; i++) lookup[chars.charCodeAt(i)] = i;\n\n const len = cleaned.length;\n let pad = 0;\n if (len >= 2 && cleaned[len - 1] === \"=\") pad++;\n if (len >= 2 && cleaned[len - 2] === \"=\") pad++;\n const outLen = ((len * 3) >> 2) - pad;\n const out = new Uint8Array(outLen);\n\n let o = 0;\n for (let i = 0; i < len; i += 4) {\n const c0 = lookup[cleaned.charCodeAt(i)];\n const c1 = lookup[cleaned.charCodeAt(i + 1)];\n const c2 = lookup[cleaned.charCodeAt(i + 2)];\n const c3 = lookup[cleaned.charCodeAt(i + 3)];\n const n = (c0 << 18) | (c1 << 12) | ((c2 & 63) << 6) | (c3 & 63);\n if (o < outLen) out[o++] = (n >> 16) & 255;\n if (o < outLen) out[o++] = (n >> 8) & 255;\n if (o < outLen) out[o++] = n & 255;\n }\n return out;\n}\n\n/**\n * Save base64 image to disk and return the file path\n */\nexport async function saveBase64Image(\n base64Url: string,\n agentId: string,\n index: number = 0,\n): Promise<string | null> {\n if (isBrowser()) {\n return null;\n }\n // Extract base64 data and extension with MIME type validation\n const m = base64Url.match(\n /^data:(image\\/[a-zA-Z0-9.+-]+);base64,([A-Za-z0-9+/=]+)$/,\n );\n if (!m) return null;\n\n const mime = m[1];\n const base64Data = m[2];\n\n // Whitelist of allowed MIME types mapped to extensions\n const extMap: Record<string, string> = {\n \"image/png\": \"png\",\n \"image/jpeg\": \"jpg\",\n \"image/jpg\": \"jpg\",\n \"image/webp\": \"webp\",\n \"image/gif\": \"gif\",\n \"image/bmp\": \"bmp\",\n \"image/tiff\": \"tiff\",\n };\n\n const extension = extMap[mime];\n if (!extension) return null;\n\n // Use ElizaOS convention: .eliza/data/generated/{agentId}/\n const { join } = await import(\"node:path\");\n const safeAgentId = sanitizeId(agentId);\n const baseDir = join(getGeneratedDir(), safeAgentId);\n\n // Create directory if it doesn't exist\n const { existsSync } = await import(\"node:fs\");\n if (!existsSync(baseDir)) {\n const { mkdir } = await import(\"node:fs/promises\");\n await mkdir(baseDir, { recursive: true });\n }\n\n // Generate filename with timestamp\n const timestamp = Date.now();\n const filename = `image_${timestamp}_${index}.${extension}`;\n const filepath = join(baseDir, filename);\n\n // Save image to disk\n const buffer = base64ToBytes(base64Data);\n const { writeFile } = await import(\"node:fs/promises\");\n await writeFile(filepath, buffer);\n\n logger.info(`[OpenRouter] Saved generated image to ${filepath}`);\n\n // Return only the file path for Discord/Telegram to read\n return filepath;\n}\n\n/**\n * Delete a specific image file\n */\nexport function deleteImage(filepath: string): void {\n if (isBrowser()) {\n return;\n }\n try {\n (async () => {\n const { existsSync, unlinkSync } = await import(\"node:fs\");\n if (existsSync(filepath)) {\n unlinkSync(filepath);\n logger.debug(`[OpenRouter] Deleted image: ${filepath}`);\n }\n })().catch((error) => {\n logger.warn(\n `[OpenRouter] Failed to delete image ${filepath}:`,\n String(error),\n );\n });\n } catch (error) {\n logger.warn(\n `[OpenRouter] Failed to delete image ${filepath}:`,\n String(error),\n );\n }\n}\n"
15
15
  ],
16
- "mappings": "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",
17
- "debugId": "542D5C87F44C9E5B64756E2164756E21",
16
+ "mappings": "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",
17
+ "debugId": "CE876441FA57CD5464756E2164756E21",
18
18
  "names": []
19
19
  }
@@ -56,6 +56,15 @@ function shouldAutoCleanupImages(runtime) {
56
56
  const setting = getSetting(runtime, "OPENROUTER_AUTO_CLEANUP_IMAGES", "false");
57
57
  return setting?.toLowerCase() === "true";
58
58
  }
59
+ function getToolExecutionMaxSteps(runtime) {
60
+ const setting = getSetting(runtime, "OPENROUTER_TOOL_EXECUTION_MAX_STEPS", "15");
61
+ const value = parseInt(setting || "15", 10);
62
+ if (Number.isNaN(value) || value < 1)
63
+ return 15;
64
+ if (value > 100)
65
+ return 100;
66
+ return value;
67
+ }
59
68
 
60
69
  // src/init.ts
61
70
  function initializeOpenRouter(_config, runtime) {
@@ -95,7 +104,7 @@ function initializeOpenRouter(_config, runtime) {
95
104
 
96
105
  // src/models/text.ts
97
106
  import { logger as logger3, ModelType } from "@elizaos/core";
98
- import { generateText } from "ai";
107
+ import { generateText, stepCountIs } from "ai";
99
108
 
100
109
  // src/providers/openrouter.ts
101
110
  import { createOpenRouter } from "@openrouter/ai-sdk-provider";
@@ -248,7 +257,7 @@ async function generateTextWithModel(runtime, modelType, params) {
248
257
  const openrouter = createOpenRouterProvider(runtime);
249
258
  const modelName = modelType === ModelType.TEXT_SMALL ? getSmallModel(runtime) : getLargeModel(runtime);
250
259
  const modelLabel = modelType === ModelType.TEXT_SMALL ? "TEXT_SMALL" : "TEXT_LARGE";
251
- logger3.log(`[OpenRouter] Generating text with ${modelLabel} model: ${modelName}`);
260
+ logger3.debug(`[OpenRouter] Generating text with ${modelLabel} model: ${modelName}`);
252
261
  const generateParams = {
253
262
  model: openrouter.chat(modelName),
254
263
  prompt,
@@ -261,6 +270,9 @@ async function generateTextWithModel(runtime, modelType, params) {
261
270
  generateParams.maxOutputTokens = resolvedMaxOutput;
262
271
  if (tools) {
263
272
  generateParams.tools = tools;
273
+ const maxSteps = getToolExecutionMaxSteps(runtime);
274
+ generateParams.stopWhen = stepCountIs(maxSteps);
275
+ logger3.debug(`[OpenRouter] Using maxSteps: ${maxSteps} for tool execution`);
264
276
  }
265
277
  if (toolChoice) {
266
278
  generateParams.toolChoice = toolChoice;
@@ -275,12 +287,14 @@ async function generateTextWithModel(runtime, modelType, params) {
275
287
  ...stepResult.toolCalls
276
288
  ];
277
289
  }
278
- if (stepResult.toolResults && stepResult.toolResults.length > 0) {
279
- const decodedToolResults = stepResult.toolResults.map((result) => ({
280
- toolCallId: result.toolCallId,
281
- result: decodeBase64Fields(result.result)
290
+ if (stepResult.content && Array.isArray(stepResult.content)) {
291
+ const toolResultsFromContent = stepResult.content.filter((content) => content.type === "tool-result" && content.output).map((content) => ({
292
+ toolCallId: content.toolCallId,
293
+ result: decodeBase64Fields(content.output)
282
294
  }));
283
- capturedToolResults = [...capturedToolResults, ...decodedToolResults];
295
+ if (toolResultsFromContent.length > 0) {
296
+ capturedToolResults = [...capturedToolResults, ...toolResultsFromContent];
297
+ }
284
298
  }
285
299
  };
286
300
  }
@@ -294,11 +308,12 @@ async function generateTextWithModel(runtime, modelType, params) {
294
308
  if (response.usage) {
295
309
  emitModelUsageEvent(runtime, modelType, prompt, response.usage);
296
310
  }
297
- if (tools && (capturedToolCalls.length > 0 || capturedToolResults.length > 0)) {
311
+ if (tools && response.steps && response.steps.length > 0) {
298
312
  return {
299
313
  text: responseText,
300
314
  toolCalls: capturedToolCalls,
301
315
  toolResults: capturedToolResults,
316
+ steps: response.steps,
302
317
  usage: response.usage,
303
318
  finishReason: response.finishReason
304
319
  };
@@ -327,7 +342,8 @@ async function generateObjectWithModel(runtime, modelType, params) {
327
342
  try {
328
343
  const { object, usage } = await generateObject({
329
344
  model: openrouter.chat(modelName),
330
- output: "no-schema",
345
+ ...params.schema && { schema: params.schema },
346
+ output: params.schema ? "object" : "no-schema",
331
347
  prompt: params.prompt,
332
348
  temperature,
333
349
  experimental_repairText: getJsonRepairFunction()
@@ -610,4 +626,4 @@ export {
610
626
  src_default as default
611
627
  };
612
628
 
613
- //# debugId=E1E5C3C96B97EF5164756E2164756E21
629
+ //# debugId=75373780AEA49BE664756E2164756E21
@@ -4,16 +4,16 @@
4
4
  "sourcesContent": [
5
5
  "import {\n ModelType,\n type Plugin,\n type IAgentRuntime,\n type GenerateTextParams,\n type ObjectGenerationParams,\n type ImageDescriptionParams,\n type ImageGenerationParams,\n} from \"@elizaos/core\";\nimport type { Tool, ToolChoice } from \"ai\";\nimport { initializeOpenRouter } from \"./init\";\nimport { handleTextSmall, handleTextLarge } from \"./models/text\";\nimport { handleObjectSmall, handleObjectLarge } from \"./models/object\";\nimport { handleImageDescription, handleImageGeneration } from \"./models/image\";\n\n/**\n * Defines the OpenRouter plugin with its name, description, and configuration options.\n * @type {Plugin}\n */\nexport const openrouterPlugin: Plugin = {\n name: \"openrouter\",\n description: \"OpenRouter plugin\",\n config: {\n OPENROUTER_API_KEY: process.env.OPENROUTER_API_KEY,\n OPENROUTER_BASE_URL: process.env.OPENROUTER_BASE_URL,\n OPENROUTER_SMALL_MODEL: process.env.OPENROUTER_SMALL_MODEL,\n OPENROUTER_LARGE_MODEL: process.env.OPENROUTER_LARGE_MODEL,\n OPENROUTER_IMAGE_MODEL: process.env.OPENROUTER_IMAGE_MODEL,\n OPENROUTER_IMAGE_GENERATION_MODEL:\n process.env.OPENROUTER_IMAGE_GENERATION_MODEL,\n OPENROUTER_AUTO_CLEANUP_IMAGES: process.env.OPENROUTER_AUTO_CLEANUP_IMAGES,\n SMALL_MODEL: process.env.SMALL_MODEL,\n LARGE_MODEL: process.env.LARGE_MODEL,\n IMAGE_MODEL: process.env.IMAGE_MODEL,\n IMAGE_GENERATION_MODEL: process.env.IMAGE_GENERATION_MODEL,\n },\n async init(config, runtime) {\n // Note: We intentionally don't await here because ElizaOS expects\n // the init method to return quickly. The initializeOpenRouter function\n // only performs synchronous validation and logging, so it's safe to\n // call without await. This prevents blocking the plugin initialization.\n initializeOpenRouter(config, runtime);\n },\n models: {\n [ModelType.TEXT_SMALL]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n ) => {\n return handleTextSmall(runtime, params);\n },\n [ModelType.TEXT_LARGE]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n ) => {\n return handleTextLarge(runtime, params);\n },\n [ModelType.OBJECT_SMALL]: async (\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n ) => {\n return handleObjectSmall(runtime, params);\n },\n [ModelType.OBJECT_LARGE]: async (\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n ) => {\n return handleObjectLarge(runtime, params);\n },\n [ModelType.IMAGE_DESCRIPTION]: async (\n runtime: IAgentRuntime,\n params: ImageDescriptionParams | string,\n ) => {\n return handleImageDescription(runtime, params);\n },\n [ModelType.IMAGE]: async (\n runtime: IAgentRuntime,\n params: ImageGenerationParams,\n ) => {\n return handleImageGeneration(runtime, params);\n },\n },\n};\n\nexport default openrouterPlugin;\n",
6
6
  "import { logger, type IAgentRuntime } from \"@elizaos/core\";\nimport { fetch } from \"undici\";\nimport { getApiKey, getBaseURL } from \"./utils/config\";\n\n/**\n * Initialize and validate OpenRouter configuration\n * Returns the exact same function that works inline\n */\nexport function initializeOpenRouter(_config: any, runtime: IAgentRuntime) {\n // do check in the background\n (async () => {\n try {\n const isBrowser =\n typeof globalThis !== \"undefined\" && (globalThis as any).document;\n // In browser, skip validation entirely to avoid exposing secrets\n if (isBrowser) {\n return;\n }\n if (!getApiKey(runtime)) {\n logger.warn(\n \"OPENROUTER_API_KEY is not set in environment - OpenRouter functionality will be limited\",\n );\n return;\n }\n try {\n const baseURL = getBaseURL(runtime);\n const response = await fetch(`${baseURL}/models`, {\n headers: { Authorization: `Bearer ${getApiKey(runtime)}` },\n });\n if (!response.ok) {\n logger.warn(\n `OpenRouter API key validation failed: ${response.statusText}`,\n );\n logger.warn(\n \"OpenRouter functionality will be limited until a valid API key is provided\",\n );\n } else {\n logger.log(\"OpenRouter API key validated successfully\");\n }\n } catch (fetchError: unknown) {\n const message =\n fetchError instanceof Error ? fetchError.message : String(fetchError);\n logger.warn(`Error validating OpenRouter API key: ${message}`);\n logger.warn(\n \"OpenRouter functionality will be limited until a valid API key is provided\",\n );\n }\n } catch (error: unknown) {\n const message =\n (error as { errors?: Array<{ message: string }> })?.errors\n ?.map((e) => e.message)\n .join(\", \") ||\n (error instanceof Error ? error.message : String(error));\n logger.warn(\n `OpenRouter plugin configuration issue: ${message} - You need to configure the OPENROUTER_API_KEY in your environment variables`,\n );\n }\n })();\n return;\n}\n",
7
- "import type { IAgentRuntime } from \"@elizaos/core\";\n\n/**\n * Retrieves a configuration setting from the runtime, falling back to environment variables or a default value if not found.\n *\n * @param key - The name of the setting to retrieve.\n * @param defaultValue - The value to return if the setting is not found in the runtime or environment.\n * @returns The resolved setting value, or {@link defaultValue} if not found.\n */\nexport function getSetting(\n runtime: IAgentRuntime,\n key: string,\n defaultValue?: string,\n): string | undefined {\n return runtime.getSetting(key) ?? process.env[key] ?? defaultValue;\n}\n\n/**\n * Retrieves the OpenRouter API base URL from runtime settings, environment variables, or defaults.\n *\n * @returns The resolved base URL for OpenRouter API requests.\n */\nexport function getBaseURL(runtime: IAgentRuntime): string {\n const browserURL = getSetting(runtime, \"OPENROUTER_BROWSER_BASE_URL\");\n if (\n typeof globalThis !== \"undefined\" &&\n (globalThis as any).document &&\n browserURL\n ) {\n return browserURL;\n }\n return (\n getSetting(\n runtime,\n \"OPENROUTER_BASE_URL\",\n \"https://openrouter.ai/api/v1\",\n ) || \"https://openrouter.ai/api/v1\"\n );\n}\n\n/**\n * Helper function to get the API key for OpenRouter\n *\n * @param runtime The runtime context\n * @returns The configured API key\n */\nexport function getApiKey(runtime: IAgentRuntime): string | undefined {\n return getSetting(runtime, \"OPENROUTER_API_KEY\");\n}\n\n/**\n * Helper function to get the small model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured small model name\n */\nexport function getSmallModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_SMALL_MODEL\") ??\n getSetting(runtime, \"SMALL_MODEL\", \"google/gemini-2.0-flash-001\") ??\n \"google/gemini-2.0-flash-001\"\n );\n}\n\n/**\n * Helper function to get the large model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured large model name\n */\nexport function getLargeModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_LARGE_MODEL\") ??\n getSetting(runtime, \"LARGE_MODEL\", \"google/gemini-2.5-flash\") ??\n \"google/gemini-2.5-flash\"\n );\n}\n\n/**\n * Helper function to get the image model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured image model name\n */\nexport function getImageModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_IMAGE_MODEL\") ??\n getSetting(runtime, \"IMAGE_MODEL\", \"x-ai/grok-2-vision-1212\") ??\n \"x-ai/grok-2-vision-1212\"\n );\n}\n\n/**\n * Helper function to get the image generation model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured image generation model name\n */\nexport function getImageGenerationModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_IMAGE_GENERATION_MODEL\") ??\n getSetting(\n runtime,\n \"IMAGE_GENERATION_MODEL\",\n \"google/gemini-2.5-flash-image-preview\",\n ) ??\n \"google/gemini-2.5-flash-image-preview\"\n );\n}\n\n/**\n * Helper function to check if auto cleanup is enabled for generated images\n *\n * @param runtime The runtime context\n * @returns Whether to auto-cleanup generated images (default: false)\n */\nexport function shouldAutoCleanupImages(runtime: IAgentRuntime): boolean {\n const setting = getSetting(\n runtime,\n \"OPENROUTER_AUTO_CLEANUP_IMAGES\",\n \"false\",\n );\n return setting?.toLowerCase() === \"true\";\n}\n",
8
- "import type { GenerateTextParams, IAgentRuntime } from \"@elizaos/core\";\nimport { logger, ModelType } from \"@elizaos/core\";\nimport { generateText } from \"ai\";\nimport type { Tool, ToolChoice } from \"ai\";\n\nimport { createOpenRouterProvider } from \"../providers\";\nimport type { ToolCall, ToolResponse, ToolResult } from \"../types\";\nimport { getSmallModel, getLargeModel } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport { handleEmptyToolResponse, decodeBase64Fields } from \"../utils/helpers\";\n\n/**\n * Common text generation logic for both small and large models\n */\nasync function generateTextWithModel(\n runtime: IAgentRuntime,\n modelType: typeof ModelType.TEXT_SMALL | typeof ModelType.TEXT_LARGE,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n const { prompt, stopSequences = [], tools, toolChoice } = params;\n const temperature = params.temperature ?? 0.7;\n const frequencyPenalty = params.frequencyPenalty ?? 0.7;\n const presencePenalty = params.presencePenalty ?? 0.7;\n // AI SDK v5: prefer maxOutputTokens; keep legacy maxTokens as fallback; default 8192\n const resolvedMaxOutput =\n (params as any).maxOutputTokens ?? (params as any).maxTokens ?? 8192;\n\n const openrouter = createOpenRouterProvider(runtime);\n const modelName =\n modelType === ModelType.TEXT_SMALL\n ? getSmallModel(runtime)\n : getLargeModel(runtime);\n const modelLabel =\n modelType === ModelType.TEXT_SMALL ? \"TEXT_SMALL\" : \"TEXT_LARGE\";\n\n logger.log(\n `[OpenRouter] Generating text with ${modelLabel} model: ${modelName}`,\n );\n\n const generateParams: Parameters<typeof generateText>[0] = {\n model: openrouter.chat(modelName),\n prompt: prompt,\n system: runtime.character.system ?? undefined,\n temperature: temperature,\n frequencyPenalty: frequencyPenalty,\n presencePenalty: presencePenalty,\n stopSequences: stopSequences,\n };\n\n (generateParams as any).maxOutputTokens = resolvedMaxOutput;\n\n // Add tools if provided\n if (tools) {\n (generateParams as any).tools = tools;\n }\n\n // Add toolChoice if provided\n if (toolChoice) {\n (generateParams as any).toolChoice = toolChoice;\n }\n\n // Capture tool results if tools are used\n let capturedToolResults: ToolResult[] = [];\n let capturedToolCalls: ToolCall[] = [];\n\n if (tools) {\n (generateParams as any).onStepFinish = async (stepResult: any) => {\n if (stepResult.toolCalls && stepResult.toolCalls.length > 0) {\n capturedToolCalls = [\n ...capturedToolCalls,\n ...(stepResult.toolCalls as any),\n ];\n }\n if (stepResult.toolResults && stepResult.toolResults.length > 0) {\n const decodedToolResults = (stepResult.toolResults as any[]).map(\n (result: any) => ({\n toolCallId: result.toolCallId,\n result: decodeBase64Fields(result.result),\n }),\n );\n capturedToolResults = [...capturedToolResults, ...decodedToolResults];\n }\n };\n }\n\n const response = await generateText(generateParams);\n\n // Handle cases where tool execution doesn't generate text\n let responseText: string;\n if (\n tools &&\n (!response.text ||\n response.text.trim() === \"\" ||\n response.text === \"Tools executed successfully.\")\n ) {\n responseText = handleEmptyToolResponse(modelLabel);\n } else {\n responseText = response.text;\n }\n\n if (response.usage) {\n emitModelUsageEvent(runtime, modelType, prompt, response.usage);\n }\n\n // If tools were used, return the full response object to access toolCalls and toolResults\n if (\n tools &&\n (capturedToolCalls.length > 0 || capturedToolResults.length > 0)\n ) {\n return {\n text: responseText,\n toolCalls: capturedToolCalls,\n toolResults: capturedToolResults,\n // Include other useful properties\n usage: response.usage,\n finishReason: response.finishReason,\n };\n }\n\n return responseText;\n}\n\n/**\n * TEXT_SMALL model handler\n */\nexport async function handleTextSmall(\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n return generateTextWithModel(runtime, ModelType.TEXT_SMALL, params);\n}\n\n/**\n * TEXT_LARGE model handler\n */\nexport async function handleTextLarge(\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n return generateTextWithModel(runtime, ModelType.TEXT_LARGE, params);\n}\n",
7
+ "import type { IAgentRuntime } from \"@elizaos/core\";\n\n/**\n * Retrieves a configuration setting from the runtime, falling back to environment variables or a default value if not found.\n *\n * @param key - The name of the setting to retrieve.\n * @param defaultValue - The value to return if the setting is not found in the runtime or environment.\n * @returns The resolved setting value, or {@link defaultValue} if not found.\n */\nexport function getSetting(\n runtime: IAgentRuntime,\n key: string,\n defaultValue?: string,\n): string | undefined {\n return runtime.getSetting(key) ?? process.env[key] ?? defaultValue;\n}\n\n/**\n * Retrieves the OpenRouter API base URL from runtime settings, environment variables, or defaults.\n *\n * @returns The resolved base URL for OpenRouter API requests.\n */\nexport function getBaseURL(runtime: IAgentRuntime): string {\n const browserURL = getSetting(runtime, \"OPENROUTER_BROWSER_BASE_URL\");\n if (\n typeof globalThis !== \"undefined\" &&\n (globalThis as any).document &&\n browserURL\n ) {\n return browserURL;\n }\n return (\n getSetting(\n runtime,\n \"OPENROUTER_BASE_URL\",\n \"https://openrouter.ai/api/v1\",\n ) || \"https://openrouter.ai/api/v1\"\n );\n}\n\n/**\n * Helper function to get the API key for OpenRouter\n *\n * @param runtime The runtime context\n * @returns The configured API key\n */\nexport function getApiKey(runtime: IAgentRuntime): string | undefined {\n return getSetting(runtime, \"OPENROUTER_API_KEY\");\n}\n\n/**\n * Helper function to get the small model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured small model name\n */\nexport function getSmallModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_SMALL_MODEL\") ??\n getSetting(runtime, \"SMALL_MODEL\", \"google/gemini-2.0-flash-001\") ??\n \"google/gemini-2.0-flash-001\"\n );\n}\n\n/**\n * Helper function to get the large model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured large model name\n */\nexport function getLargeModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_LARGE_MODEL\") ??\n getSetting(runtime, \"LARGE_MODEL\", \"google/gemini-2.5-flash\") ??\n \"google/gemini-2.5-flash\"\n );\n}\n\n/**\n * Helper function to get the image model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured image model name\n */\nexport function getImageModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_IMAGE_MODEL\") ??\n getSetting(runtime, \"IMAGE_MODEL\", \"x-ai/grok-2-vision-1212\") ??\n \"x-ai/grok-2-vision-1212\"\n );\n}\n\n/**\n * Helper function to get the image generation model name with fallbacks\n *\n * @param runtime The runtime context\n * @returns The configured image generation model name\n */\nexport function getImageGenerationModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"OPENROUTER_IMAGE_GENERATION_MODEL\") ??\n getSetting(\n runtime,\n \"IMAGE_GENERATION_MODEL\",\n \"google/gemini-2.5-flash-image-preview\",\n ) ??\n \"google/gemini-2.5-flash-image-preview\"\n );\n}\n\n/**\n * Helper function to check if auto cleanup is enabled for generated images\n *\n * @param runtime The runtime context\n * @returns Whether to auto-cleanup generated images (default: false)\n */\nexport function shouldAutoCleanupImages(runtime: IAgentRuntime): boolean {\n const setting = getSetting(\n runtime,\n \"OPENROUTER_AUTO_CLEANUP_IMAGES\",\n \"false\",\n );\n return setting?.toLowerCase() === \"true\";\n}\n\n/**\n * Helper function to get the max steps for tool execution\n *\n * @param runtime The runtime context\n * @returns The maximum number of steps for tool execution (default: 15)\n */\nexport function getToolExecutionMaxSteps(runtime: IAgentRuntime): number {\n const setting = getSetting(\n runtime,\n \"OPENROUTER_TOOL_EXECUTION_MAX_STEPS\",\n \"15\",\n );\n const value = parseInt(setting || \"15\", 10);\n // Ensure valid range (1-100)\n if (Number.isNaN(value) || value < 1) return 15;\n if (value > 100) return 100;\n return value;\n}\n",
8
+ "import type { GenerateTextParams, IAgentRuntime } from \"@elizaos/core\";\nimport { logger, ModelType } from \"@elizaos/core\";\nimport { generateText, stepCountIs } from \"ai\";\nimport type { Tool, ToolChoice } from \"ai\";\n\nimport { createOpenRouterProvider } from \"../providers\";\nimport type { ToolCall, ToolResponse, ToolResult } from \"../types\";\nimport { getSmallModel, getLargeModel, getToolExecutionMaxSteps } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport { handleEmptyToolResponse, decodeBase64Fields } from \"../utils/helpers\";\n\n/**\n * Common text generation logic for both small and large models\n */\nasync function generateTextWithModel(\n runtime: IAgentRuntime,\n modelType: typeof ModelType.TEXT_SMALL | typeof ModelType.TEXT_LARGE,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n const { prompt, stopSequences = [], tools, toolChoice } = params;\n const temperature = params.temperature ?? 0.7;\n const frequencyPenalty = params.frequencyPenalty ?? 0.7;\n const presencePenalty = params.presencePenalty ?? 0.7;\n // AI SDK v5: prefer maxOutputTokens; keep legacy maxTokens as fallback; default 8192\n const resolvedMaxOutput =\n (params as any).maxOutputTokens ?? (params as any).maxTokens ?? 8192;\n\n const openrouter = createOpenRouterProvider(runtime);\n const modelName =\n modelType === ModelType.TEXT_SMALL\n ? getSmallModel(runtime)\n : getLargeModel(runtime);\n const modelLabel =\n modelType === ModelType.TEXT_SMALL ? \"TEXT_SMALL\" : \"TEXT_LARGE\";\n\n logger.debug(\n `[OpenRouter] Generating text with ${modelLabel} model: ${modelName}`,\n );\n\n const generateParams: Parameters<typeof generateText>[0] = {\n model: openrouter.chat(modelName),\n prompt: prompt,\n system: runtime.character.system ?? undefined,\n temperature: temperature,\n frequencyPenalty: frequencyPenalty,\n presencePenalty: presencePenalty,\n stopSequences: stopSequences,\n };\n\n (generateParams as any).maxOutputTokens = resolvedMaxOutput;\n\n // Add tools if provided\n if (tools) {\n (generateParams as any).tools = tools;\n const maxSteps = getToolExecutionMaxSteps(runtime);\n\n (generateParams as any).stopWhen = stepCountIs(maxSteps);\n logger.debug(`[OpenRouter] Using maxSteps: ${maxSteps} for tool execution`);\n }\n\n // Add toolChoice if provided\n if (toolChoice) {\n (generateParams as any).toolChoice = toolChoice;\n }\n\n // Capture tool results if tools are used\n let capturedToolResults: ToolResult[] = [];\n let capturedToolCalls: ToolCall[] = [];\n\n if (tools) {\n (generateParams as any).onStepFinish = async (stepResult: any) => {\n if (stepResult.toolCalls && stepResult.toolCalls.length > 0) {\n capturedToolCalls = [\n ...capturedToolCalls,\n ...(stepResult.toolCalls as any),\n ];\n }\n\n // Extract tool results from content array in steps\n if (stepResult.content && Array.isArray(stepResult.content)) {\n const toolResultsFromContent = stepResult.content\n .filter((content: any) => content.type === 'tool-result' && content.output)\n .map((content: any) => ({\n toolCallId: content.toolCallId,\n result: decodeBase64Fields(content.output),\n }));\n\n if (toolResultsFromContent.length > 0) {\n capturedToolResults = [...capturedToolResults, ...toolResultsFromContent];\n }\n }\n };\n }\n\n const response = await generateText(generateParams);\n\n // Handle cases where tool execution doesn't generate text\n let responseText: string;\n if (\n tools &&\n (!response.text ||\n response.text.trim() === \"\" ||\n response.text === \"Tools executed successfully.\")\n ) {\n responseText = handleEmptyToolResponse(modelLabel);\n } else {\n responseText = response.text;\n }\n\n if (response.usage) {\n emitModelUsageEvent(runtime, modelType, prompt, response.usage);\n }\n\n // If tools were used, return the full response object with steps for proper tool results access\n if (tools && response.steps && response.steps.length > 0) {\n return {\n text: responseText,\n toolCalls: capturedToolCalls,\n toolResults: capturedToolResults,\n steps: response.steps,\n usage: response.usage,\n finishReason: response.finishReason,\n };\n }\n\n return responseText;\n}\n\n/**\n * TEXT_SMALL model handler\n */\nexport async function handleTextSmall(\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n return generateTextWithModel(runtime, ModelType.TEXT_SMALL, params);\n}\n\n/**\n * TEXT_LARGE model handler\n */\nexport async function handleTextLarge(\n runtime: IAgentRuntime,\n params: GenerateTextParams & {\n tools?: Record<string, Tool>;\n toolChoice?: ToolChoice<Record<string, Tool>>;\n },\n): Promise<string | ToolResponse> {\n return generateTextWithModel(runtime, ModelType.TEXT_LARGE, params);\n}\n",
9
9
  "import { createOpenRouter } from \"@openrouter/ai-sdk-provider\";\nimport { logger, type IAgentRuntime } from \"@elizaos/core\";\nimport { getApiKey, getBaseURL } from \"../utils/config\";\n\n/**\n * Create an OpenRouter provider instance with proper configuration\n *\n * @param runtime The runtime context\n * @returns Configured OpenRouter provider instance\n */\nexport function createOpenRouterProvider(runtime: IAgentRuntime) {\n const apiKey = getApiKey(runtime);\n const isBrowser =\n typeof globalThis !== \"undefined\" && (globalThis as any).document;\n const baseURL = getBaseURL(runtime);\n // In browser, omit apiKey and rely on proxy baseURL\n return createOpenRouter({\n apiKey: isBrowser ? undefined : apiKey,\n baseURL,\n });\n}\n",
10
- "import {\n EventType,\n type IAgentRuntime,\n type ModelTypeName,\n} from \"@elizaos/core\";\nimport type { LanguageModelUsage } from \"ai\";\n\n/**\n * Emits a model usage event\n */\nexport function emitModelUsageEvent(\n runtime: IAgentRuntime,\n type: ModelTypeName,\n prompt: string,\n usage: LanguageModelUsage,\n) {\n // Never emit the full prompt; truncate to avoid leaking secrets/PII\n const truncatedPrompt =\n typeof prompt === \"string\"\n ? prompt.length > 200\n ? `${prompt.slice(0, 200)}…`\n : prompt\n : \"\";\n // Coalesce optional usage fields to stable numbers\n const inputTokens = Number(usage.inputTokens || 0);\n const outputTokens = Number(usage.outputTokens || 0);\n const totalTokens = Number(\n usage.totalTokens != null ? usage.totalTokens : inputTokens + outputTokens,\n );\n runtime.emitEvent(EventType.MODEL_USED, {\n provider: \"openrouter\",\n type,\n prompt: truncatedPrompt,\n tokens: {\n prompt: inputTokens,\n completion: outputTokens,\n total: totalTokens,\n },\n });\n}\n",
10
+ "import {\n EventType,\n type IAgentRuntime,\n type ModelTypeName,\n} from \"@elizaos/core\";\nimport type { LanguageModelUsage } from \"ai\";\n\n/**\n * Emits a model usage event\n */\nexport function emitModelUsageEvent(\n runtime: IAgentRuntime,\n type: ModelTypeName,\n prompt: string,\n usage: LanguageModelUsage,\n) {\n // Never emit the full prompt; truncate to avoid leaking secrets/PII\n const truncatedPrompt =\n typeof prompt === \"string\"\n ? prompt.length > 200\n ? `${prompt.slice(0, 200)}…`\n : prompt\n : \"\";\n // Coalesce optional usage fields to stable numbers\n const inputTokens = Number((usage as { inputTokens?: number }).inputTokens || 0);\n const outputTokens = Number((usage as { outputTokens?: number }).outputTokens || 0);\n const totalTokens = Number(\n usage.totalTokens != null ? usage.totalTokens : inputTokens + outputTokens,\n );\n runtime.emitEvent(EventType.MODEL_USED, {\n provider: \"openrouter\",\n type,\n prompt: truncatedPrompt,\n tokens: {\n prompt: inputTokens,\n completion: outputTokens,\n total: totalTokens,\n },\n });\n}\n",
11
11
  "import { logger } from \"@elizaos/core\";\nimport { JSONParseError } from \"ai\";\nimport type { GenerateTextResponse, ImageDescriptionResult } from \"../types\";\n\n/**\n * Returns a function to repair JSON text\n */\nexport function getJsonRepairFunction(): (params: {\n text: string;\n error: unknown;\n}) => Promise<string | null> {\n return async ({ text, error }: { text: string; error: unknown }) => {\n try {\n if (error instanceof JSONParseError) {\n const cleanedText = text.replace(/```json\\n|\\n```|```/g, \"\");\n JSON.parse(cleanedText);\n return cleanedText;\n }\n return null;\n } catch (jsonError: unknown) {\n const message =\n jsonError instanceof Error ? jsonError.message : String(jsonError);\n logger.warn(`Failed to repair JSON text: ${message}`);\n return null;\n }\n };\n}\n\n// Re-export for backward compatibility\nexport { emitModelUsageEvent } from \"./events\";\n\n/**\n * Logs response structure for debugging (debug level only)\n */\nexport function logResponseStructure(\n modelType: string,\n response: GenerateTextResponse,\n) {\n // Only log safe, non-sensitive usage fields (avoid raw request bodies)\n const u = (response as any)?.usage;\n const safeUsage =\n u && typeof u === \"object\"\n ? {\n inputTokens: u.inputTokens,\n outputTokens: u.outputTokens,\n totalTokens: u.totalTokens,\n }\n : undefined;\n logger.debug(\n `[${modelType}] Response structure: ${JSON.stringify(\n {\n hasText: !!response.text,\n textLength: response.text?.length || 0,\n hasSteps: !!response.steps,\n stepsCount: response.steps?.length || 0,\n finishReason: response.finishReason,\n usage: safeUsage,\n },\n null,\n 2,\n )}`,\n );\n}\n\n/**\n * Handles cases where tool execution doesn't generate text\n */\nexport function handleEmptyToolResponse(modelType: string): string {\n logger.warn(`[${modelType}] No text generated after tool execution`);\n\n const fallbackText =\n \"I executed the requested action. The tool completed successfully.\";\n logger.warn(`[${modelType}] Using fallback response text`);\n return fallbackText;\n}\n\n/**\n * Parses image description response from text or JSON format\n */\nexport function parseImageDescriptionResponse(\n responseText: string,\n): ImageDescriptionResult {\n // Try to parse as JSON first\n try {\n const jsonResponse = JSON.parse(responseText);\n if (jsonResponse.title && jsonResponse.description) {\n return jsonResponse;\n }\n } catch (e) {\n // If not valid JSON, process as text\n logger.debug(`Parsing as JSON failed, processing as text: ${e}`);\n }\n\n // Extract title and description from text format\n const titleMatch = responseText.match(/title[:\\s]+(.+?)(?:\\n|$)/i);\n const title = titleMatch?.[1]?.trim() || \"Image Analysis\";\n const description = responseText\n .replace(/title[:\\s]+(.+?)(?:\\n|$)/i, \"\")\n .trim();\n\n return { title, description };\n}\n\n/**\n * Handles errors during object generation, including JSON repair attempts\n */\nexport async function handleObjectGenerationError(\n error: unknown,\n): Promise<unknown> {\n if (error instanceof JSONParseError) {\n logger.error(`[generateObject] Failed to parse JSON: ${error.message}`);\n const repairFunction = getJsonRepairFunction();\n const repairedJsonString = await repairFunction({\n text: error.text,\n error,\n });\n\n if (repairedJsonString) {\n try {\n const repairedObject = JSON.parse(repairedJsonString);\n logger.log(\"[generateObject] Successfully repaired JSON.\");\n return repairedObject;\n } catch (repairParseError: unknown) {\n const message =\n repairParseError instanceof Error\n ? repairParseError.message\n : String(repairParseError);\n logger.error(\n `[generateObject] Failed to parse repaired JSON: ${message}`,\n );\n if (repairParseError instanceof Error) throw repairParseError;\n throw Object.assign(new Error(message), { cause: repairParseError });\n }\n } else {\n logger.error(\"[generateObject] JSON repair failed.\");\n throw error;\n }\n } else {\n const message = error instanceof Error ? error.message : String(error);\n logger.error(`[generateObject] Unknown error: ${message}`);\n if (error instanceof Error) throw error;\n throw Object.assign(new Error(message), { cause: error });\n }\n}\n\n/**\n * Quick heuristic to detect if a field likely contains base64 data\n */\nfunction isLikelyBase64(key: string, value: string): boolean {\n // Check key name patterns (expanded base64 field names)\n const base64KeyPattern =\n /^(data|content|body|payload|encoded|b64|base64|document)$/i;\n if (!base64KeyPattern.test(key)) return false;\n\n // Basic format checks\n if (value.length < 20 || value.length > 1024 * 1024) return false; // Size limits\n if (value.length % 4 !== 0) return false; // Invalid base64 length\n if (!/^[A-Za-z0-9+/]*={0,2}$/.test(value)) return false; // Invalid chars\n\n return true;\n}\n\n/**\n * Recursively decodes base64 fields in tool results\n */\nexport function decodeBase64Fields(obj: unknown, depth = 0): unknown {\n // Simple depth protection\n if (depth > 5) return obj;\n if (!obj || typeof obj !== \"object\") return obj;\n if (Array.isArray(obj))\n return obj.map((item) => decodeBase64Fields(item, depth + 1));\n\n const decoded: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(obj)) {\n if (typeof value === \"string\" && isLikelyBase64(key, value)) {\n try {\n decoded[key] = Buffer.from(value, \"base64\").toString(\"utf8\");\n logger.debug(\n `[decodeBase64] Decoded field '${key}' (${value.length} chars)`,\n );\n } catch (error) {\n logger.warn(`[decodeBase64] Failed to decode field '${key}': ${error}`);\n decoded[key] = value; // Keep original if decode fails\n }\n } else if (value && typeof value === \"object\") {\n decoded[key] = decodeBase64Fields(value, depth + 1);\n } else {\n decoded[key] = value;\n }\n }\n return decoded;\n}\n",
12
- "import {\n ModelType,\n logger,\n type IAgentRuntime,\n type ObjectGenerationParams,\n} from \"@elizaos/core\";\nimport { generateObject } from \"ai\";\nimport { createOpenRouterProvider } from \"../providers\";\nimport { getSmallModel, getLargeModel } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport {\n getJsonRepairFunction,\n handleObjectGenerationError,\n} from \"../utils/helpers\";\n\n/**\n * Common object generation logic for both small and large models\n */\nasync function generateObjectWithModel(\n runtime: IAgentRuntime,\n modelType: typeof ModelType.OBJECT_SMALL | typeof ModelType.OBJECT_LARGE,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n const openrouter = createOpenRouterProvider(runtime);\n const modelName =\n modelType === ModelType.OBJECT_SMALL\n ? getSmallModel(runtime)\n : getLargeModel(runtime);\n const modelLabel =\n modelType === ModelType.OBJECT_SMALL ? \"OBJECT_SMALL\" : \"OBJECT_LARGE\";\n\n logger.log(`[OpenRouter] Using ${modelLabel} model: ${modelName}`);\n const temperature = params.temperature ?? 0.7;\n\n try {\n const { object, usage } = await generateObject({\n model: openrouter.chat(modelName),\n output: \"no-schema\",\n prompt: params.prompt,\n temperature: temperature,\n experimental_repairText: getJsonRepairFunction(),\n });\n\n if (usage) {\n emitModelUsageEvent(runtime, modelType, params.prompt, usage);\n }\n return object;\n } catch (error: unknown) {\n return handleObjectGenerationError(error);\n }\n}\n\n/**\n * OBJECT_SMALL model handler\n */\nexport async function handleObjectSmall(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n return generateObjectWithModel(runtime, ModelType.OBJECT_SMALL, params);\n}\n\n/**\n * OBJECT_LARGE model handler\n */\nexport async function handleObjectLarge(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n return generateObjectWithModel(runtime, ModelType.OBJECT_LARGE, params);\n}\n",
12
+ "import {\n ModelType,\n logger,\n type IAgentRuntime,\n type ObjectGenerationParams,\n} from \"@elizaos/core\";\nimport { generateObject } from \"ai\";\nimport { createOpenRouterProvider } from \"../providers\";\nimport { getSmallModel, getLargeModel } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport {\n getJsonRepairFunction,\n handleObjectGenerationError,\n} from \"../utils/helpers\";\n\n/**\n * Common object generation logic for both small and large models\n */\nasync function generateObjectWithModel(\n runtime: IAgentRuntime,\n modelType: typeof ModelType.OBJECT_SMALL | typeof ModelType.OBJECT_LARGE,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n const openrouter = createOpenRouterProvider(runtime);\n const modelName =\n modelType === ModelType.OBJECT_SMALL\n ? getSmallModel(runtime)\n : getLargeModel(runtime);\n const modelLabel =\n modelType === ModelType.OBJECT_SMALL ? \"OBJECT_SMALL\" : \"OBJECT_LARGE\";\n\n logger.log(`[OpenRouter] Using ${modelLabel} model: ${modelName}`);\n const temperature = params.temperature ?? 0.7;\n\n try {\n const { object, usage } = await generateObject({\n model: openrouter.chat(modelName),\n ...(params.schema && { schema: params.schema }),\n output: (params.schema ? \"object\" : \"no-schema\") as any,\n prompt: params.prompt,\n temperature: temperature,\n experimental_repairText: getJsonRepairFunction(),\n });\n\n if (usage) {\n emitModelUsageEvent(runtime, modelType, params.prompt, usage);\n }\n return object;\n } catch (error: unknown) {\n return handleObjectGenerationError(error);\n }\n}\n\n/**\n * OBJECT_SMALL model handler\n */\nexport async function handleObjectSmall(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n return generateObjectWithModel(runtime, ModelType.OBJECT_SMALL, params);\n}\n\n/**\n * OBJECT_LARGE model handler\n */\nexport async function handleObjectLarge(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<unknown> {\n return generateObjectWithModel(runtime, ModelType.OBJECT_LARGE, params);\n}\n",
13
13
  "import {\n logger,\n type IAgentRuntime,\n type ImageDescriptionParams,\n type ImageGenerationParams,\n} from \"@elizaos/core\";\nimport { generateText } from \"ai\";\nimport type { OpenRouterImageResponse } from \"../types\";\nimport { createOpenRouterProvider } from \"../providers\";\nimport {\n getApiKey,\n getBaseURL,\n getImageGenerationModel,\n getImageModel,\n shouldAutoCleanupImages,\n} from \"../utils/config\";\nimport { parseImageDescriptionResponse } from \"../utils/helpers\";\nimport { deleteImage, saveBase64Image } from \"../utils/image-storage\";\n\n/**\n * IMAGE_DESCRIPTION model handler\n */\nexport async function handleImageDescription(\n runtime: IAgentRuntime,\n params: ImageDescriptionParams | string,\n): Promise<{ title: string; description: string }> {\n let imageUrl: string;\n let promptText: string | undefined;\n const modelName = getImageModel(runtime);\n logger.log(`[OpenRouter] Using IMAGE_DESCRIPTION model: ${modelName}`);\n const maxOutputTokens = 300;\n\n if (typeof params === \"string\") {\n imageUrl = params;\n promptText =\n \"Please analyze this image and provide a title and detailed description.\";\n } else {\n imageUrl = params.imageUrl;\n promptText =\n params.prompt ||\n \"Please analyze this image and provide a title and detailed description.\";\n }\n\n const openrouter = createOpenRouterProvider(runtime);\n\n const messages = [\n {\n role: \"user\" as const,\n content: [\n { type: \"text\" as const, text: promptText },\n { type: \"image\" as const, image: imageUrl },\n ],\n },\n ];\n\n try {\n const model = openrouter.chat(modelName);\n\n const { text: responseText } = await generateText({\n model: model,\n messages: messages,\n maxOutputTokens: maxOutputTokens,\n });\n\n return parseImageDescriptionResponse(responseText);\n } catch (error: unknown) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error(`Error analyzing image: ${message}`);\n return {\n title: \"Failed to analyze image\",\n description: `Error: ${message}`,\n };\n }\n}\n\n/**\n * IMAGE model handler for image generation\n */\nexport async function handleImageGeneration(\n runtime: IAgentRuntime,\n params: ImageGenerationParams,\n): Promise<{ url: string }[]> {\n const modelName = getImageGenerationModel(runtime);\n logger.log(`[OpenRouter] Using IMAGE_GENERATION model: ${modelName}`);\n const apiKey = getApiKey(runtime);\n\n try {\n const baseUrl = getBaseURL(runtime);\n const isBrowser =\n typeof globalThis !== \"undefined\" && (globalThis as any).document;\n const response = await fetch(`${baseUrl}/chat/completions`, {\n method: \"POST\",\n headers: {\n ...(isBrowser ? {} : { Authorization: `Bearer ${apiKey}` }),\n \"Content-Type\": \"application/json\",\n },\n body: JSON.stringify({\n model: modelName,\n messages: [\n {\n role: \"user\",\n content: params.prompt,\n },\n ],\n modalities: [\"image\", \"text\"],\n }),\n // 60 seconds timeout\n signal: AbortSignal.timeout ? AbortSignal.timeout(60000) : undefined,\n });\n\n if (!response.ok) {\n const errorText = await response.text().catch(() => \"\");\n throw new Error(\n `HTTP ${response.status} ${response.statusText} ${errorText}`,\n );\n }\n\n const result = (await response.json()) as OpenRouterImageResponse;\n\n const images: { url: string; filepath?: string }[] = [];\n const savedPaths: string[] = [];\n\n // Extract images from the response\n if (result.choices?.[0]?.message?.images) {\n for (const [index, image] of result.choices[0].message.images.entries()) {\n const base64Url = image.image_url.url;\n\n // Save image to disk\n const filepath = await saveBase64Image(\n base64Url,\n runtime.agentId,\n index,\n );\n if (filepath) {\n // Return the actual file path for Discord/Telegram compatibility\n logger.log(`[OpenRouter] Returning image with filepath: ${filepath}`);\n images.push({\n url: filepath, // Use actual file path\n });\n savedPaths.push(filepath);\n } else if (!base64Url.startsWith(\"data:\")) {\n // If not base64, return as is (might be a URL)\n images.push({ url: base64Url });\n } else {\n // Failed to save base64 image\n logger.warn(\n `[OpenRouter] Failed to save image ${index + 1}, skipping`,\n );\n }\n }\n }\n\n // Clean up images after a short delay if auto-cleanup is enabled\n if (savedPaths.length > 0 && shouldAutoCleanupImages(runtime)) {\n setTimeout(() => {\n savedPaths.forEach((path) => {\n deleteImage(path);\n });\n }, 30000); // Delete after 30 seconds\n }\n\n if (images.length === 0) {\n throw new Error(\"No images generated in response\");\n }\n\n logger.log(`[OpenRouter] Generated ${images.length} image(s)`);\n return images;\n } catch (error: unknown) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error(`[OpenRouter] Error generating image: ${message}`);\n return [];\n }\n}\n",
14
14
  "import { logger, getGeneratedDir } from \"@elizaos/core\";\n\nfunction isBrowser(): boolean {\n return typeof globalThis !== \"undefined\" && (globalThis as any).document;\n}\n\n// Restrict identifiers to a safe subset to prevent path traversal/FS escape\nfunction sanitizeId(id: string): string {\n const src = (id ?? \"\").toString();\n const normalized = src.normalize(\"NFKC\");\n let safe = normalized.replace(/[^a-zA-Z0-9_-]/g, \"_\");\n safe = safe.replace(/_+/g, \"_\");\n safe = safe.slice(0, 64);\n safe = safe.replace(/^_+|_+$/g, \"\");\n return safe || \"agent\";\n}\n\n// Lightweight base64 decoder that avoids Node Buffer and works in browser/Node\nfunction base64ToBytes(base64: string): Uint8Array {\n // Remove padding\n const cleaned = base64.replace(/\\s+/g, \"\");\n const chars =\n \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\";\n const lookup: number[] = new Array(256).fill(-1);\n for (let i = 0; i < chars.length; i++) lookup[chars.charCodeAt(i)] = i;\n\n const len = cleaned.length;\n let pad = 0;\n if (len >= 2 && cleaned[len - 1] === \"=\") pad++;\n if (len >= 2 && cleaned[len - 2] === \"=\") pad++;\n const outLen = ((len * 3) >> 2) - pad;\n const out = new Uint8Array(outLen);\n\n let o = 0;\n for (let i = 0; i < len; i += 4) {\n const c0 = lookup[cleaned.charCodeAt(i)];\n const c1 = lookup[cleaned.charCodeAt(i + 1)];\n const c2 = lookup[cleaned.charCodeAt(i + 2)];\n const c3 = lookup[cleaned.charCodeAt(i + 3)];\n const n = (c0 << 18) | (c1 << 12) | ((c2 & 63) << 6) | (c3 & 63);\n if (o < outLen) out[o++] = (n >> 16) & 255;\n if (o < outLen) out[o++] = (n >> 8) & 255;\n if (o < outLen) out[o++] = n & 255;\n }\n return out;\n}\n\n/**\n * Save base64 image to disk and return the file path\n */\nexport async function saveBase64Image(\n base64Url: string,\n agentId: string,\n index: number = 0,\n): Promise<string | null> {\n if (isBrowser()) {\n return null;\n }\n // Extract base64 data and extension with MIME type validation\n const m = base64Url.match(\n /^data:(image\\/[a-zA-Z0-9.+-]+);base64,([A-Za-z0-9+/=]+)$/,\n );\n if (!m) return null;\n\n const mime = m[1];\n const base64Data = m[2];\n\n // Whitelist of allowed MIME types mapped to extensions\n const extMap: Record<string, string> = {\n \"image/png\": \"png\",\n \"image/jpeg\": \"jpg\",\n \"image/jpg\": \"jpg\",\n \"image/webp\": \"webp\",\n \"image/gif\": \"gif\",\n \"image/bmp\": \"bmp\",\n \"image/tiff\": \"tiff\",\n };\n\n const extension = extMap[mime];\n if (!extension) return null;\n\n // Use ElizaOS convention: .eliza/data/generated/{agentId}/\n const { join } = await import(\"node:path\");\n const safeAgentId = sanitizeId(agentId);\n const baseDir = join(getGeneratedDir(), safeAgentId);\n\n // Create directory if it doesn't exist\n const { existsSync } = await import(\"node:fs\");\n if (!existsSync(baseDir)) {\n const { mkdir } = await import(\"node:fs/promises\");\n await mkdir(baseDir, { recursive: true });\n }\n\n // Generate filename with timestamp\n const timestamp = Date.now();\n const filename = `image_${timestamp}_${index}.${extension}`;\n const filepath = join(baseDir, filename);\n\n // Save image to disk\n const buffer = base64ToBytes(base64Data);\n const { writeFile } = await import(\"node:fs/promises\");\n await writeFile(filepath, buffer);\n\n logger.info(`[OpenRouter] Saved generated image to ${filepath}`);\n\n // Return only the file path for Discord/Telegram to read\n return filepath;\n}\n\n/**\n * Delete a specific image file\n */\nexport function deleteImage(filepath: string): void {\n if (isBrowser()) {\n return;\n }\n try {\n (async () => {\n const { existsSync, unlinkSync } = await import(\"node:fs\");\n if (existsSync(filepath)) {\n unlinkSync(filepath);\n logger.debug(`[OpenRouter] Deleted image: ${filepath}`);\n }\n })().catch((error) => {\n logger.warn(\n `[OpenRouter] Failed to delete image ${filepath}:`,\n String(error),\n );\n });\n } catch (error) {\n logger.warn(\n `[OpenRouter] Failed to delete image ${filepath}:`,\n String(error),\n );\n }\n}\n"
15
15
  ],
16
- "mappings": "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",
17
- "debugId": "E1E5C3C96B97EF5164756E2164756E21",
16
+ "mappings": "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",
17
+ "debugId": "75373780AEA49BE664756E2164756E21",
18
18
  "names": []
19
19
  }
@@ -19,6 +19,20 @@ export interface ToolResponse {
19
19
  text: string;
20
20
  toolCalls: ToolCall[];
21
21
  toolResults: ToolResult[];
22
+ steps?: Array<{
23
+ toolCalls?: Array<{
24
+ type: 'tool-call';
25
+ toolCallId: string;
26
+ toolName: string;
27
+ input: any;
28
+ }>;
29
+ toolResults?: Array<{
30
+ toolCallId: string;
31
+ result?: any;
32
+ }>;
33
+ text?: string;
34
+ finishReason?: string;
35
+ }>;
22
36
  usage?: LanguageModelUsage;
23
37
  finishReason?: string;
24
38
  }
@@ -55,3 +55,10 @@ export declare function getImageGenerationModel(runtime: IAgentRuntime): string;
55
55
  * @returns Whether to auto-cleanup generated images (default: false)
56
56
  */
57
57
  export declare function shouldAutoCleanupImages(runtime: IAgentRuntime): boolean;
58
+ /**
59
+ * Helper function to get the max steps for tool execution
60
+ *
61
+ * @param runtime The runtime context
62
+ * @returns The maximum number of steps for tool execution (default: 15)
63
+ */
64
+ export declare function getToolExecutionMaxSteps(runtime: IAgentRuntime): number;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@elizaos/plugin-openrouter",
3
- "version": "1.5.10",
3
+ "version": "1.5.14",
4
4
  "type": "module",
5
5
  "main": "dist/cjs/index.node.cjs",
6
6
  "module": "dist/node/index.node.js",
@@ -26,7 +26,7 @@
26
26
  "dependencies": {
27
27
  "@ai-sdk/openai": "^2.0.32",
28
28
  "@ai-sdk/ui-utils": "1.2.11",
29
- "@elizaos/core": "^1.5.10",
29
+ "@elizaos/core": "^1.6.1",
30
30
  "@openrouter/ai-sdk-provider": "^1.2.0",
31
31
  "ai": "^5.0.47",
32
32
  "undici": "^7.16.0"
@@ -36,7 +36,7 @@
36
36
  "@types/node": "^24.5.2",
37
37
  "dotenv": "^17.2.2",
38
38
  "prettier": "3.6.2",
39
- "typescript": "5.9.2"
39
+ "typescript": "^5.9.3"
40
40
  },
41
41
  "scripts": {
42
42
  "build": "bun run build.ts",
@@ -134,6 +134,13 @@
134
134
  "required": false,
135
135
  "default": false,
136
136
  "sensitive": false
137
+ },
138
+ "OPENROUTER_TOOL_EXECUTION_MAX_STEPS": {
139
+ "type": "number",
140
+ "description": "Maximum number of steps for multi-step tool execution. Allows the AI to generate descriptive text after calling tools in AI SDK v5.",
141
+ "required": false,
142
+ "default": 15,
143
+ "sensitive": false
137
144
  }
138
145
  }
139
146
  }