@elizaos/plugin-google-genai 2.0.0-alpha.5 → 2.0.0-alpha.537

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/README.md +122 -0
  2. package/dist/browser/index.browser.js +232 -32
  3. package/dist/browser/index.browser.js.map +12 -11
  4. package/dist/build.d.ts +3 -0
  5. package/dist/build.d.ts.map +1 -0
  6. package/dist/build.js +117 -0
  7. package/dist/cjs/index.node.cjs +300 -66
  8. package/dist/cjs/index.node.js.map +12 -11
  9. package/dist/generated/specs/specs.d.ts +55 -0
  10. package/dist/generated/specs/specs.d.ts.map +1 -0
  11. package/dist/generated/specs/specs.js +34 -0
  12. package/dist/index.browser.d.ts +5 -0
  13. package/dist/index.browser.d.ts.map +1 -0
  14. package/dist/index.browser.js +4 -0
  15. package/dist/index.d.ts.map +1 -0
  16. package/dist/index.js +252 -0
  17. package/dist/index.node.d.ts +5 -0
  18. package/dist/index.node.d.ts.map +1 -0
  19. package/dist/index.node.js +4 -0
  20. package/dist/init.d.ts +16 -0
  21. package/dist/init.d.ts.map +1 -0
  22. package/dist/init.js +27 -0
  23. package/dist/models/embedding.d.ts +6 -0
  24. package/dist/models/embedding.d.ts.map +1 -0
  25. package/dist/models/embedding.js +57 -0
  26. package/dist/models/image.d.ts +7 -0
  27. package/dist/models/image.d.ts.map +1 -0
  28. package/dist/models/image.js +91 -0
  29. package/dist/models/index.d.ts +13 -0
  30. package/dist/models/index.d.ts.map +1 -0
  31. package/dist/models/index.js +12 -0
  32. package/dist/models/object.d.ts +10 -0
  33. package/dist/models/object.d.ts.map +1 -0
  34. package/dist/models/object.js +84 -0
  35. package/dist/models/text.d.ts +51 -0
  36. package/dist/models/text.d.ts.map +1 -0
  37. package/dist/models/text.js +257 -0
  38. package/dist/node/index.node.js +232 -32
  39. package/dist/node/index.node.js.map +12 -11
  40. package/dist/types/index.d.ts +47 -0
  41. package/dist/types/index.d.ts.map +1 -0
  42. package/dist/types/index.js +1 -0
  43. package/dist/utils/config.d.ts +25 -0
  44. package/dist/utils/config.d.ts.map +1 -0
  45. package/dist/utils/config.js +115 -0
  46. package/dist/utils/events.d.ts +12 -0
  47. package/dist/utils/events.d.ts.map +1 -0
  48. package/dist/utils/events.js +14 -0
  49. package/dist/utils/index.d.ts +4 -0
  50. package/dist/utils/index.d.ts.map +1 -0
  51. package/dist/utils/index.js +3 -0
  52. package/dist/utils/tokenization.d.ts +2 -0
  53. package/dist/utils/tokenization.d.ts.map +1 -0
  54. package/dist/utils/tokenization.js +3 -0
  55. package/dist/vitest.config.d.ts +3 -0
  56. package/dist/vitest.config.d.ts.map +1 -0
  57. package/dist/vitest.config.js +8 -0
  58. package/package.json +17 -13
@@ -1,18 +1,19 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../index.ts", "../../init.ts", "../../utils/config.ts", "../../models/embedding.ts", "../../utils/events.ts", "../../utils/tokenization.ts", "../../models/image.ts", "../../models/object.ts", "../../models/text.ts"],
3
+ "sources": ["../../index.ts", "../../init.ts", "../../utils/config.ts", "../../models/embedding.ts", "../../utils/events.ts", "../../utils/tokenization.ts", "../../models/image.ts", "../../models/object.ts", "../../models/text.ts", "../../index.browser.ts"],
4
4
  "sourcesContent": [
5
- "import type {\n GenerateTextParams,\n IAgentRuntime,\n ImageDescriptionParams,\n ObjectGenerationParams,\n Plugin,\n TestCase,\n TestSuite,\n TextEmbeddingParams,\n} from \"@elizaos/core\";\nimport { logger, ModelType } from \"@elizaos/core\";\nimport { GoogleGenAI } from \"@google/genai\";\nimport { initializeGoogleGenAI, type PluginConfig } from \"./init\";\nimport {\n handleImageDescription,\n handleObjectLarge,\n handleObjectSmall,\n handleTextEmbedding,\n handleTextLarge,\n handleTextSmall,\n} from \"./models\";\nimport { getApiKey } from \"./utils/config\";\n\nexport type { PluginConfig } from \"./init\";\nexport * from \"./types\";\n\nconst pluginTests = [\n {\n name: \"google_genai_plugin_tests\",\n tests: [\n {\n name: \"google_test_api_key_validation\",\n fn: async (runtime: IAgentRuntime) => {\n const apiKey = getApiKey(runtime);\n if (!apiKey) {\n throw new Error(\"GOOGLE_GENERATIVE_AI_API_KEY not set\");\n }\n const genAI = new GoogleGenAI({ apiKey });\n const modelList = await genAI.models.list();\n const models = [];\n for await (const model of modelList) {\n models.push(model);\n }\n logger.log(`Available models: ${models.length}`);\n },\n },\n {\n name: \"google_test_text_embedding\",\n fn: async (runtime: IAgentRuntime) => {\n try {\n const embedding = await runtime.useModel(ModelType.TEXT_EMBEDDING, {\n text: \"Hello, world!\",\n });\n logger.log(`Embedding dimension: ${embedding.length}`);\n if (embedding.length === 0) {\n throw new Error(\"Failed to generate embedding\");\n }\n } catch (error) {\n logger.error(\n `Error in test_text_embedding: ${error instanceof Error ? error.message : String(error)}`\n );\n throw error;\n }\n },\n },\n {\n name: \"google_test_text_small\",\n fn: async (runtime: IAgentRuntime) => {\n try {\n const text = await runtime.useModel(ModelType.TEXT_SMALL, {\n prompt: \"What is the nature of reality in 10 words?\",\n });\n if (text.length === 0) {\n throw new Error(\"Failed to generate text\");\n }\n logger.log(\"Generated with TEXT_SMALL:\", text);\n } catch (error) {\n logger.error(\n `Error in test_text_small: ${error instanceof Error ? error.message : String(error)}`\n );\n throw error;\n }\n },\n },\n {\n name: \"google_test_text_large\",\n fn: async (runtime: IAgentRuntime) => {\n try {\n const text = await runtime.useModel(ModelType.TEXT_LARGE, {\n prompt: \"Explain quantum mechanics in simple terms.\",\n });\n if (text.length === 0) {\n throw new Error(\"Failed to generate text\");\n }\n logger.log(\"Generated with TEXT_LARGE:\", `${text.substring(0, 100)}...`);\n } catch (error) {\n logger.error(\n `Error in test_text_large: ${error instanceof Error ? error.message : String(error)}`\n );\n throw error;\n }\n },\n },\n {\n name: \"google_test_image_description\",\n fn: async (runtime: IAgentRuntime) => {\n try {\n const result = await runtime.useModel(\n ModelType.IMAGE_DESCRIPTION,\n \"https://upload.wikimedia.org/wikipedia/commons/thumb/1/1c/Vitalik_Buterin_TechCrunch_London_2015_%28cropped%29.jpg/537px-Vitalik_Buterin_TechCrunch_London_2015_%28cropped%29.jpg\"\n );\n\n if (\n result &&\n typeof result === \"object\" &&\n \"title\" in result &&\n \"description\" in result\n ) {\n logger.log(\"Image description:\", JSON.stringify(result));\n } else {\n logger.error(`Invalid image description result format: ${JSON.stringify(result)}`);\n }\n } catch (error) {\n logger.error(\n `Error in test_image_description: ${error instanceof Error ? error.message : String(error)}`\n );\n throw error;\n }\n },\n },\n {\n name: \"google_test_object_generation\",\n fn: async (runtime: IAgentRuntime) => {\n try {\n const schema = {\n type: \"object\",\n properties: {\n name: { type: \"string\" },\n age: { type: \"number\" },\n hobbies: { type: \"array\", items: { type: \"string\" } },\n },\n required: [\"name\", \"age\", \"hobbies\"],\n };\n\n const result = await runtime.useModel(ModelType.OBJECT_SMALL, {\n prompt: \"Generate a person profile with name, age, and hobbies.\",\n schema,\n });\n\n logger.log(\"Generated object:\", JSON.stringify(result));\n\n if (!result.name || !result.age || !result.hobbies) {\n throw new Error(\"Generated object missing required fields\");\n }\n } catch (error) {\n logger.error(\n `Error in test_object_generation: ${error instanceof Error ? error.message : String(error)}`\n );\n throw error;\n }\n },\n },\n ] as TestCase[],\n },\n] as TestSuite[];\n\ntype ProcessEnvLike = Record<string, string | undefined>;\n\nfunction getProcessEnv(): ProcessEnvLike {\n if (typeof process === \"undefined\") {\n return {};\n }\n return process.env as ProcessEnvLike;\n}\n\nconst env = getProcessEnv();\n\nexport const googleGenAIPlugin: Plugin = {\n name: \"google-genai\",\n description: \"Google Generative AI plugin for Gemini models\",\n\n config: {\n GOOGLE_GENERATIVE_AI_API_KEY: env.GOOGLE_GENERATIVE_AI_API_KEY ?? null,\n GOOGLE_SMALL_MODEL: env.GOOGLE_SMALL_MODEL ?? null,\n GOOGLE_LARGE_MODEL: env.GOOGLE_LARGE_MODEL ?? null,\n GOOGLE_IMAGE_MODEL: env.GOOGLE_IMAGE_MODEL ?? null,\n GOOGLE_EMBEDDING_MODEL: env.GOOGLE_EMBEDDING_MODEL ?? null,\n SMALL_MODEL: env.SMALL_MODEL ?? null,\n LARGE_MODEL: env.LARGE_MODEL ?? null,\n IMAGE_MODEL: env.IMAGE_MODEL ?? null,\n },\n\n async init(config, runtime) {\n initializeGoogleGenAI(config as PluginConfig, runtime);\n },\n\n models: {\n [ModelType.TEXT_SMALL]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams\n ): Promise<string> => {\n return handleTextSmall(runtime, params);\n },\n\n [ModelType.TEXT_LARGE]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams\n ): Promise<string> => {\n return handleTextLarge(runtime, params);\n },\n\n [ModelType.TEXT_EMBEDDING]: async (\n runtime: IAgentRuntime,\n params: TextEmbeddingParams | string | null\n ): Promise<number[]> => {\n return handleTextEmbedding(runtime, params);\n },\n\n [ModelType.IMAGE_DESCRIPTION]: async (\n runtime: IAgentRuntime,\n params: ImageDescriptionParams | string\n ): Promise<{ title: string; description: string }> => {\n return handleImageDescription(runtime, params);\n },\n\n [ModelType.OBJECT_SMALL]: async (\n runtime: IAgentRuntime,\n params: ObjectGenerationParams\n ): Promise<Record<string, string | number | boolean | null>> => {\n return handleObjectSmall(runtime, params);\n },\n\n [ModelType.OBJECT_LARGE]: async (\n runtime: IAgentRuntime,\n params: ObjectGenerationParams\n ): Promise<Record<string, string | number | boolean | null>> => {\n return handleObjectLarge(runtime, params);\n },\n },\n\n tests: pluginTests,\n};\n\nexport default googleGenAIPlugin;\n",
6
- "import { type IAgentRuntime, logger } from \"@elizaos/core\";\nimport { GoogleGenAI } from \"@google/genai\";\nimport { getApiKey } from \"./utils/config\";\n\nexport interface PluginConfig {\n readonly GOOGLE_GENERATIVE_AI_API_KEY?: string;\n readonly GOOGLE_SMALL_MODEL?: string;\n readonly GOOGLE_LARGE_MODEL?: string;\n readonly GOOGLE_IMAGE_MODEL?: string;\n readonly GOOGLE_EMBEDDING_MODEL?: string;\n readonly SMALL_MODEL?: string;\n readonly LARGE_MODEL?: string;\n readonly IMAGE_MODEL?: string;\n}\n\nexport function initializeGoogleGenAI(_config: PluginConfig, runtime: IAgentRuntime): void {\n (async () => {\n try {\n const apiKey = getApiKey(runtime);\n if (!apiKey) {\n logger.warn(\"GOOGLE_GENERATIVE_AI_API_KEY is not set\");\n return;\n }\n\n const genAI = new GoogleGenAI({ apiKey });\n const modelList = await genAI.models.list();\n const models = [];\n for await (const model of modelList) {\n models.push(model);\n }\n logger.log(`Google AI API key validated. Available models: ${models.length}`);\n } catch (error) {\n logger.warn(\n `Google AI configuration error: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n })();\n}\n",
7
- "import type { IAgentRuntime } from \"@elizaos/core\";\nimport { logger } from \"@elizaos/core\";\nimport { GoogleGenAI, HarmBlockThreshold, HarmCategory } from \"@google/genai\";\n\nfunction getEnvValue(key: string): string | undefined {\n // In browsers, `process` is not defined. `typeof process` is safe.\n if (typeof process === \"undefined\") {\n return undefined;\n }\n const value = process.env[key];\n return value === undefined ? undefined : String(value);\n}\n\nexport function getSetting(\n runtime: IAgentRuntime,\n key: string,\n defaultValue?: string\n): string | undefined {\n const runtimeValue = runtime.getSetting(key);\n if (runtimeValue !== undefined) {\n return String(runtimeValue);\n }\n return getEnvValue(key) ?? defaultValue;\n}\n\nexport function getApiKey(runtime: IAgentRuntime): string | undefined {\n return getSetting(runtime, \"GOOGLE_GENERATIVE_AI_API_KEY\");\n}\n\nexport function getSmallModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"GOOGLE_SMALL_MODEL\") ??\n getSetting(runtime, \"SMALL_MODEL\", \"gemini-2.0-flash-001\") ??\n \"gemini-2.0-flash-001\"\n );\n}\n\nexport function getLargeModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"GOOGLE_LARGE_MODEL\") ??\n getSetting(runtime, \"LARGE_MODEL\", \"gemini-2.5-pro-preview-03-25\") ??\n \"gemini-2.5-pro-preview-03-25\"\n );\n}\n\nexport function getImageModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"GOOGLE_IMAGE_MODEL\") ??\n getSetting(runtime, \"IMAGE_MODEL\", \"gemini-2.5-pro-preview-03-25\") ??\n \"gemini-2.5-pro-preview-03-25\"\n );\n}\n\nexport function getEmbeddingModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"GOOGLE_EMBEDDING_MODEL\", \"text-embedding-004\") ?? \"text-embedding-004\"\n );\n}\n\nexport function createGoogleGenAI(runtime: IAgentRuntime): GoogleGenAI | null {\n const apiKey = getApiKey(runtime);\n if (!apiKey) {\n logger.error(\"Google Generative AI API Key is missing\");\n return null;\n }\n\n return new GoogleGenAI({ apiKey });\n}\n\nexport function getSafetySettings() {\n return [\n {\n category: HarmCategory.HARM_CATEGORY_HARASSMENT,\n threshold: HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE,\n },\n {\n category: HarmCategory.HARM_CATEGORY_HATE_SPEECH,\n threshold: HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE,\n },\n {\n category: HarmCategory.HARM_CATEGORY_SEXUALLY_EXPLICIT,\n threshold: HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE,\n },\n {\n category: HarmCategory.HARM_CATEGORY_DANGEROUS_CONTENT,\n threshold: HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE,\n },\n ];\n}\n",
8
- "import type { IAgentRuntime, TextEmbeddingParams } from \"@elizaos/core\";\nimport { logger, MAX_EMBEDDING_TOKENS, ModelType } from \"@elizaos/core\";\nimport { createGoogleGenAI, getEmbeddingModel } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport { countTokens } from \"../utils/tokenization\";\n\nexport async function handleTextEmbedding(\n runtime: IAgentRuntime,\n params: TextEmbeddingParams | string | null\n): Promise<number[]> {\n const genAI = createGoogleGenAI(runtime);\n if (!genAI) {\n throw new Error(\"Google Generative AI client not initialized\");\n }\n\n const embeddingModelName = getEmbeddingModel(runtime);\n logger.debug(`[TEXT_EMBEDDING] Using model: ${embeddingModelName}`);\n\n if (params === null) {\n return Array(768).fill(0) as number[];\n }\n\n let text =\n typeof params === \"string\"\n ? params\n : typeof params === \"object\" && params.text\n ? params.text\n : \"\";\n\n if (!text.trim()) {\n logger.warn(\"Empty text for embedding\");\n return Array(768).fill(0) as number[];\n }\n\n // Truncate to stay within embedding model token limits\n const maxChars = MAX_EMBEDDING_TOKENS * 4; // ~4 chars per token\n if (text.length > maxChars) {\n logger.warn(\n `[Google GenAI] Embedding input too long (~${Math.ceil(text.length / 4)} tokens), truncating to ~${MAX_EMBEDDING_TOKENS} tokens`\n );\n text = text.slice(0, maxChars);\n }\n\n try {\n const response = await genAI.models.embedContent({\n model: embeddingModelName,\n contents: text,\n });\n\n const embedding = response.embeddings?.[0]?.values || [];\n\n const promptTokens = await countTokens(text);\n\n emitModelUsageEvent(runtime, ModelType.TEXT_EMBEDDING, text, {\n promptTokens,\n completionTokens: 0,\n totalTokens: promptTokens,\n });\n\n logger.log(`Got embedding with length ${embedding.length}`);\n return embedding;\n } catch (error) {\n logger.error(\n `Error generating embedding: ${error instanceof Error ? error.message : String(error)}`\n );\n return Array(768).fill(0) as number[];\n }\n}\n",
9
- "import type { IAgentRuntime, ModelTypeName } from \"@elizaos/core\";\nimport { EventType } from \"@elizaos/core\";\n\nexport function emitModelUsageEvent(\n runtime: IAgentRuntime,\n type: ModelTypeName,\n _prompt: string,\n usage: {\n promptTokens: number;\n completionTokens: number;\n totalTokens: number;\n }\n): void {\n void _prompt; // Not included in ModelEventPayload\n runtime.emitEvent(EventType.MODEL_USED, {\n runtime,\n source: \"plugin-google-genai\",\n type,\n tokens: {\n prompt: usage.promptTokens,\n completion: usage.completionTokens,\n total: usage.totalTokens,\n },\n });\n}\n",
5
+ "import type {\n GenerateTextParams,\n IAgentRuntime,\n ImageDescriptionParams,\n ObjectGenerationParams,\n Plugin,\n TestCase,\n TestSuite,\n TextEmbeddingParams,\n} from \"@elizaos/core\";\nimport * as ElizaCore from \"@elizaos/core\";\nimport { logger, ModelType } from \"@elizaos/core\";\nimport { GoogleGenAI } from \"@google/genai\";\nimport { initializeGoogleGenAI, type PluginConfig } from \"./init\";\nimport {\n handleActionPlanner,\n handleImageDescription,\n handleObjectLarge,\n handleObjectSmall,\n handleResponseHandler,\n handleTextEmbedding,\n handleTextLarge,\n handleTextMedium,\n handleTextMega,\n handleTextNano,\n handleTextSmall,\n} from \"./models\";\nimport { getApiKey } from \"./utils/config\";\n\nexport type { PluginConfig } from \"./init\";\nexport * from \"./types\";\n\nconst CORE_MODEL_TYPES =\n (ElizaCore as { ModelType?: Record<string, string> }).ModelType ?? {};\nconst TEXT_NANO_MODEL_TYPE = (CORE_MODEL_TYPES.TEXT_NANO ??\n \"TEXT_NANO\") as string;\nconst TEXT_MEDIUM_MODEL_TYPE = (CORE_MODEL_TYPES.TEXT_MEDIUM ??\n \"TEXT_MEDIUM\") as string;\nconst TEXT_SMALL_MODEL_TYPE = (CORE_MODEL_TYPES.TEXT_SMALL ??\n \"TEXT_SMALL\") as string;\nconst TEXT_LARGE_MODEL_TYPE = (CORE_MODEL_TYPES.TEXT_LARGE ??\n \"TEXT_LARGE\") as string;\nconst TEXT_EMBEDDING_MODEL_TYPE = (CORE_MODEL_TYPES.TEXT_EMBEDDING ??\n \"TEXT_EMBEDDING\") as string;\nconst IMAGE_DESCRIPTION_MODEL_TYPE = (CORE_MODEL_TYPES.IMAGE_DESCRIPTION ??\n \"IMAGE_DESCRIPTION\") as string;\nconst OBJECT_SMALL_MODEL_TYPE = (CORE_MODEL_TYPES.OBJECT_SMALL ??\n \"OBJECT_SMALL\") as string;\nconst OBJECT_LARGE_MODEL_TYPE = (CORE_MODEL_TYPES.OBJECT_LARGE ??\n \"OBJECT_LARGE\") as string;\nconst TEXT_MEGA_MODEL_TYPE = (CORE_MODEL_TYPES.TEXT_MEGA ??\n \"TEXT_MEGA\") as string;\nconst RESPONSE_HANDLER_MODEL_TYPE = (CORE_MODEL_TYPES.RESPONSE_HANDLER ??\n \"RESPONSE_HANDLER\") as string;\nconst ACTION_PLANNER_MODEL_TYPE = (CORE_MODEL_TYPES.ACTION_PLANNER ??\n \"ACTION_PLANNER\") as string;\n\nconst pluginTests = [\n {\n name: \"google_genai_plugin_tests\",\n tests: [\n {\n name: \"google_test_api_key_validation\",\n fn: async (runtime: IAgentRuntime) => {\n const apiKey = getApiKey(runtime);\n if (!apiKey) {\n throw new Error(\"GOOGLE_GENERATIVE_AI_API_KEY not set\");\n }\n const genAI = new GoogleGenAI({ apiKey });\n const modelList = await genAI.models.list();\n const models = [];\n for await (const model of modelList) {\n models.push(model);\n }\n logger.log(`Available models: ${models.length}`);\n },\n },\n {\n name: \"google_test_text_embedding\",\n fn: async (runtime: IAgentRuntime) => {\n try {\n const embedding = await runtime.useModel(ModelType.TEXT_EMBEDDING, {\n text: \"Hello, world!\",\n });\n logger.log(`Embedding dimension: ${embedding.length}`);\n if (embedding.length === 0) {\n throw new Error(\"Failed to generate embedding\");\n }\n } catch (error) {\n logger.error(\n `Error in test_text_embedding: ${error instanceof Error ? error.message : String(error)}`,\n );\n throw error;\n }\n },\n },\n {\n name: \"google_test_text_small\",\n fn: async (runtime: IAgentRuntime) => {\n try {\n const text = await runtime.useModel(ModelType.TEXT_SMALL, {\n prompt: \"What is the nature of reality in 10 words?\",\n });\n if (text.length === 0) {\n throw new Error(\"Failed to generate text\");\n }\n logger.log(\"Generated with TEXT_SMALL:\", text);\n } catch (error) {\n logger.error(\n `Error in test_text_small: ${error instanceof Error ? error.message : String(error)}`,\n );\n throw error;\n }\n },\n },\n {\n name: \"google_test_text_large\",\n fn: async (runtime: IAgentRuntime) => {\n try {\n const text = await runtime.useModel(ModelType.TEXT_LARGE, {\n prompt: \"Explain quantum mechanics in simple terms.\",\n });\n if (text.length === 0) {\n throw new Error(\"Failed to generate text\");\n }\n logger.log(\n \"Generated with TEXT_LARGE:\",\n `${text.substring(0, 100)}...`,\n );\n } catch (error) {\n logger.error(\n `Error in test_text_large: ${error instanceof Error ? error.message : String(error)}`,\n );\n throw error;\n }\n },\n },\n {\n name: \"google_test_image_description\",\n fn: async (runtime: IAgentRuntime) => {\n try {\n const result = await runtime.useModel(\n ModelType.IMAGE_DESCRIPTION,\n \"https://upload.wikimedia.org/wikipedia/commons/thumb/1/1c/Vitalik_Buterin_TechCrunch_London_2015_%28cropped%29.jpg/537px-Vitalik_Buterin_TechCrunch_London_2015_%28cropped%29.jpg\",\n );\n\n if (\n result != null &&\n typeof result === \"object\" &&\n \"title\" in result &&\n \"description\" in result\n ) {\n logger.log(\"Image description:\", JSON.stringify(result));\n } else {\n logger.error(\n `Invalid image description result format: ${JSON.stringify(result)}`,\n );\n }\n } catch (error) {\n logger.error(\n `Error in test_image_description: ${error instanceof Error ? error.message : String(error)}`,\n );\n throw error;\n }\n },\n },\n {\n name: \"google_test_object_generation\",\n fn: async (runtime: IAgentRuntime) => {\n try {\n const schema = {\n type: \"object\",\n properties: {\n name: { type: \"string\" },\n age: { type: \"number\" },\n hobbies: { type: \"array\", items: { type: \"string\" } },\n },\n required: [\"name\", \"age\", \"hobbies\"],\n };\n\n const result = (await runtime.useModel(ModelType.OBJECT_SMALL, {\n prompt: \"Generate a person profile with name, age, and hobbies.\",\n schema,\n })) as Record<string, unknown>;\n\n logger.log(\"Generated object:\", JSON.stringify(result));\n\n if (!result?.name || !result?.age || !result?.hobbies) {\n throw new Error(\"Generated object missing required fields\");\n }\n } catch (error) {\n logger.error(\n `Error in test_object_generation: ${error instanceof Error ? error.message : String(error)}`,\n );\n throw error;\n }\n },\n },\n ] as TestCase[],\n },\n] as TestSuite[];\n\ntype ProcessEnvLike = Record<string, string | undefined>;\n\nfunction getProcessEnv(): ProcessEnvLike {\n if (typeof process === \"undefined\") {\n return {};\n }\n return process.env as ProcessEnvLike;\n}\n\nconst env = getProcessEnv();\n\nexport const googleGenAIPlugin: Plugin = {\n name: \"google-genai\",\n description: \"Google Generative AI plugin for Gemini models\",\n\n config: {\n GOOGLE_GENERATIVE_AI_API_KEY: env.GOOGLE_GENERATIVE_AI_API_KEY ?? null,\n GOOGLE_NANO_MODEL: env.GOOGLE_NANO_MODEL ?? null,\n GOOGLE_MEDIUM_MODEL: env.GOOGLE_MEDIUM_MODEL ?? null,\n GOOGLE_SMALL_MODEL: env.GOOGLE_SMALL_MODEL ?? null,\n GOOGLE_LARGE_MODEL: env.GOOGLE_LARGE_MODEL ?? null,\n GOOGLE_MEGA_MODEL: env.GOOGLE_MEGA_MODEL ?? null,\n GOOGLE_RESPONSE_HANDLER_MODEL: env.GOOGLE_RESPONSE_HANDLER_MODEL ?? null,\n GOOGLE_SHOULD_RESPOND_MODEL: env.GOOGLE_SHOULD_RESPOND_MODEL ?? null,\n GOOGLE_ACTION_PLANNER_MODEL: env.GOOGLE_ACTION_PLANNER_MODEL ?? null,\n GOOGLE_PLANNER_MODEL: env.GOOGLE_PLANNER_MODEL ?? null,\n GOOGLE_IMAGE_MODEL: env.GOOGLE_IMAGE_MODEL ?? null,\n GOOGLE_EMBEDDING_MODEL: env.GOOGLE_EMBEDDING_MODEL ?? null,\n NANO_MODEL: env.NANO_MODEL ?? null,\n MEDIUM_MODEL: env.MEDIUM_MODEL ?? null,\n SMALL_MODEL: env.SMALL_MODEL ?? null,\n LARGE_MODEL: env.LARGE_MODEL ?? null,\n MEGA_MODEL: env.MEGA_MODEL ?? null,\n RESPONSE_HANDLER_MODEL: env.RESPONSE_HANDLER_MODEL ?? null,\n SHOULD_RESPOND_MODEL: env.SHOULD_RESPOND_MODEL ?? null,\n ACTION_PLANNER_MODEL: env.ACTION_PLANNER_MODEL ?? null,\n PLANNER_MODEL: env.PLANNER_MODEL ?? null,\n IMAGE_MODEL: env.IMAGE_MODEL ?? null,\n },\n\n async init(config, runtime) {\n initializeGoogleGenAI(config as PluginConfig, runtime);\n },\n\n models: {\n [TEXT_NANO_MODEL_TYPE]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams,\n ): Promise<string> => {\n return handleTextNano(runtime, params);\n },\n\n [TEXT_MEDIUM_MODEL_TYPE]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams,\n ): Promise<string> => {\n return handleTextMedium(runtime, params);\n },\n\n [TEXT_SMALL_MODEL_TYPE]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams,\n ): Promise<string> => {\n return handleTextSmall(runtime, params);\n },\n\n [TEXT_LARGE_MODEL_TYPE]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams,\n ): Promise<string> => {\n return handleTextLarge(runtime, params);\n },\n\n [TEXT_MEGA_MODEL_TYPE]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams,\n ): Promise<string> => {\n return handleTextMega(runtime, params);\n },\n\n [RESPONSE_HANDLER_MODEL_TYPE]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams,\n ): Promise<string> => {\n return handleResponseHandler(runtime, params);\n },\n\n [ACTION_PLANNER_MODEL_TYPE]: async (\n runtime: IAgentRuntime,\n params: GenerateTextParams,\n ): Promise<string> => {\n return handleActionPlanner(runtime, params);\n },\n\n [TEXT_EMBEDDING_MODEL_TYPE]: async (\n runtime: IAgentRuntime,\n params: TextEmbeddingParams | string | null,\n ): Promise<number[]> => {\n return handleTextEmbedding(runtime, params);\n },\n\n [IMAGE_DESCRIPTION_MODEL_TYPE]: async (\n runtime: IAgentRuntime,\n params: ImageDescriptionParams | string,\n ): Promise<{ title: string; description: string }> => {\n return handleImageDescription(runtime, params);\n },\n\n [OBJECT_SMALL_MODEL_TYPE]: async (\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n ): Promise<Record<string, string | number | boolean | null>> => {\n return handleObjectSmall(runtime, params);\n },\n\n [OBJECT_LARGE_MODEL_TYPE]: async (\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n ): Promise<Record<string, string | number | boolean | null>> => {\n return handleObjectLarge(runtime, params);\n },\n },\n\n tests: pluginTests,\n};\n\nexport default googleGenAIPlugin;\n",
6
+ "import { type IAgentRuntime, logger } from \"@elizaos/core\";\nimport { GoogleGenAI } from \"@google/genai\";\nimport { getApiKey } from \"./utils/config\";\n\nexport interface PluginConfig {\n readonly GOOGLE_GENERATIVE_AI_API_KEY?: string;\n readonly GOOGLE_SMALL_MODEL?: string;\n readonly GOOGLE_LARGE_MODEL?: string;\n readonly GOOGLE_IMAGE_MODEL?: string;\n readonly GOOGLE_EMBEDDING_MODEL?: string;\n readonly SMALL_MODEL?: string;\n readonly LARGE_MODEL?: string;\n readonly IMAGE_MODEL?: string;\n}\n\nexport function initializeGoogleGenAI(\n _config: PluginConfig,\n runtime: IAgentRuntime,\n): void {\n (async () => {\n try {\n const apiKey = getApiKey(runtime);\n if (!apiKey) {\n logger.warn(\"GOOGLE_GENERATIVE_AI_API_KEY is not set\");\n return;\n }\n\n const genAI = new GoogleGenAI({ apiKey });\n const modelList = await genAI.models.list();\n const models = [];\n for await (const model of modelList) {\n models.push(model);\n }\n logger.log(\n `Google AI API key validated. Available models: ${models.length}`,\n );\n } catch (error) {\n logger.warn(\n `Google AI configuration error: ${error instanceof Error ? error.message : String(error)}`,\n );\n }\n })();\n}\n",
7
+ "import type { IAgentRuntime } from \"@elizaos/core\";\nimport { logger } from \"@elizaos/core\";\nimport { GoogleGenAI, HarmBlockThreshold, HarmCategory } from \"@google/genai\";\n\nfunction getEnvValue(key: string): string | undefined {\n // In browsers, `process` is not defined. `typeof process` is safe.\n if (typeof process === \"undefined\") {\n return undefined;\n }\n const value = process.env[key];\n return value === undefined ? undefined : String(value);\n}\n\nexport function getSetting(\n runtime: IAgentRuntime,\n key: string,\n defaultValue?: string,\n): string | undefined {\n const runtimeValue = runtime.getSetting(key);\n if (runtimeValue !== undefined) {\n return String(runtimeValue);\n }\n return getEnvValue(key) ?? defaultValue;\n}\n\nexport function getApiKey(runtime: IAgentRuntime): string | undefined {\n return getSetting(runtime, \"GOOGLE_GENERATIVE_AI_API_KEY\");\n}\n\nexport function getSmallModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"GOOGLE_SMALL_MODEL\") ??\n getSetting(runtime, \"SMALL_MODEL\", \"gemini-2.0-flash-001\") ??\n \"gemini-2.0-flash-001\"\n );\n}\n\nexport function getNanoModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"GOOGLE_NANO_MODEL\") ??\n getSetting(runtime, \"NANO_MODEL\") ??\n getSmallModel(runtime)\n );\n}\n\nexport function getMediumModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"GOOGLE_MEDIUM_MODEL\") ??\n getSetting(runtime, \"MEDIUM_MODEL\") ??\n getSmallModel(runtime)\n );\n}\n\nexport function getLargeModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"GOOGLE_LARGE_MODEL\") ??\n getSetting(runtime, \"LARGE_MODEL\", \"gemini-2.5-pro-preview-03-25\") ??\n \"gemini-2.5-pro-preview-03-25\"\n );\n}\n\nexport function getMegaModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"GOOGLE_MEGA_MODEL\") ??\n getSetting(runtime, \"MEGA_MODEL\") ??\n getLargeModel(runtime)\n );\n}\n\nexport function getResponseHandlerModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"GOOGLE_RESPONSE_HANDLER_MODEL\") ??\n getSetting(runtime, \"GOOGLE_SHOULD_RESPOND_MODEL\") ??\n getSetting(runtime, \"RESPONSE_HANDLER_MODEL\") ??\n getSetting(runtime, \"SHOULD_RESPOND_MODEL\") ??\n getNanoModel(runtime)\n );\n}\n\nexport function getActionPlannerModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"GOOGLE_ACTION_PLANNER_MODEL\") ??\n getSetting(runtime, \"GOOGLE_PLANNER_MODEL\") ??\n getSetting(runtime, \"ACTION_PLANNER_MODEL\") ??\n getSetting(runtime, \"PLANNER_MODEL\") ??\n getMediumModel(runtime)\n );\n}\n\nexport function getImageModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"GOOGLE_IMAGE_MODEL\") ??\n getSetting(runtime, \"IMAGE_MODEL\", \"gemini-2.5-pro-preview-03-25\") ??\n \"gemini-2.5-pro-preview-03-25\"\n );\n}\n\nexport function getEmbeddingModel(runtime: IAgentRuntime): string {\n return (\n getSetting(runtime, \"GOOGLE_EMBEDDING_MODEL\", \"text-embedding-004\") ??\n \"text-embedding-004\"\n );\n}\n\nexport function createGoogleGenAI(runtime: IAgentRuntime): GoogleGenAI | null {\n const apiKey = getApiKey(runtime);\n if (!apiKey) {\n logger.error(\"Google Generative AI API Key is missing\");\n return null;\n }\n\n return new GoogleGenAI({ apiKey });\n}\n\nexport function getSafetySettings() {\n return [\n {\n category: HarmCategory.HARM_CATEGORY_HARASSMENT,\n threshold: HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE,\n },\n {\n category: HarmCategory.HARM_CATEGORY_HATE_SPEECH,\n threshold: HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE,\n },\n {\n category: HarmCategory.HARM_CATEGORY_SEXUALLY_EXPLICIT,\n threshold: HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE,\n },\n {\n category: HarmCategory.HARM_CATEGORY_DANGEROUS_CONTENT,\n threshold: HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE,\n },\n ];\n}\n",
8
+ "import type { IAgentRuntime, TextEmbeddingParams } from \"@elizaos/core\";\nimport * as ElizaCore from \"@elizaos/core\";\nimport { logger } from \"@elizaos/core\";\nimport { createGoogleGenAI, getEmbeddingModel } from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport { countTokens } from \"../utils/tokenization\";\n\nconst TEXT_EMBEDDING_MODEL_TYPE = ((\n ElizaCore as { ModelType?: Record<string, string> }\n).ModelType?.TEXT_EMBEDDING ?? \"TEXT_EMBEDDING\") as string;\n\nexport async function handleTextEmbedding(\n runtime: IAgentRuntime,\n params: TextEmbeddingParams | string | null,\n): Promise<number[]> {\n const genAI = createGoogleGenAI(runtime);\n if (!genAI) {\n throw new Error(\"Google Generative AI client not initialized\");\n }\n\n const embeddingModelName = getEmbeddingModel(runtime);\n logger.debug(`[TEXT_EMBEDDING] Using model: ${embeddingModelName}`);\n\n if (params === null) {\n return Array(768).fill(0) as number[];\n }\n\n let text =\n typeof params === \"string\"\n ? params\n : typeof params === \"object\" && params.text\n ? params.text\n : \"\";\n\n if (!text.trim()) {\n logger.warn(\"Empty text for embedding\");\n return Array(768).fill(0) as number[];\n }\n\n // Truncate to stay within embedding model token limits (~4 chars per token)\n const maxChars = 8_192 * 4;\n if (text.length > maxChars) {\n logger.warn(\n `[Google GenAI] Embedding input too long (~${Math.ceil(text.length / 4)} tokens), truncating to ~8192 tokens`,\n );\n text = text.slice(0, maxChars);\n }\n\n try {\n const response = await genAI.models.embedContent({\n model: embeddingModelName,\n contents: text,\n });\n\n const embedding = response.embeddings?.[0]?.values || [];\n\n const promptTokens = await countTokens(text);\n\n emitModelUsageEvent(runtime, TEXT_EMBEDDING_MODEL_TYPE, text, {\n promptTokens,\n completionTokens: 0,\n totalTokens: promptTokens,\n });\n\n logger.log(`Got embedding with length ${embedding.length}`);\n return embedding;\n } catch (error) {\n logger.error(\n `Error generating embedding: ${error instanceof Error ? error.message : String(error)}`,\n );\n return Array(768).fill(0) as number[];\n }\n}\n",
9
+ "import type { EventPayload, IAgentRuntime, ModelTypeName } from \"@elizaos/core\";\n\nconst MODEL_USED_EVENT = \"MODEL_USED\";\n\nexport function emitModelUsageEvent(\n runtime: IAgentRuntime,\n type: ModelTypeName,\n _prompt: string,\n usage: {\n promptTokens: number;\n completionTokens: number;\n totalTokens: number;\n },\n): void {\n void _prompt; // Not included in ModelEventPayload\n runtime.emitEvent(MODEL_USED_EVENT, {\n runtime,\n source: \"plugin-google-genai\",\n type,\n tokens: {\n prompt: usage.promptTokens,\n completion: usage.completionTokens,\n total: usage.totalTokens,\n },\n } as EventPayload);\n}\n",
10
10
  "export async function countTokens(text: string): Promise<number> {\n return Math.ceil(text.length / 4);\n}\n",
11
- "import type { IAgentRuntime, ImageDescriptionParams } from \"@elizaos/core\";\nimport { logger } from \"@elizaos/core\";\nimport type { ImageDescriptionResponse } from \"../types\";\nimport { createGoogleGenAI, getImageModel, getSafetySettings } from \"../utils/config\";\n\nconst crossFetch = typeof globalThis.fetch === \"function\" ? globalThis.fetch : fetch;\n\nexport async function handleImageDescription(\n runtime: IAgentRuntime,\n params: ImageDescriptionParams | string\n): Promise<ImageDescriptionResponse> {\n const genAI = createGoogleGenAI(runtime);\n if (!genAI) {\n throw new Error(\"Google Generative AI client not initialized\");\n }\n\n let imageUrl: string;\n let promptText: string;\n const modelName = getImageModel(runtime);\n logger.log(`[IMAGE_DESCRIPTION] Using model: ${modelName}`);\n\n if (typeof params === \"string\") {\n imageUrl = params;\n promptText = \"Please analyze this image and provide a title and detailed description.\";\n } else {\n imageUrl = params.imageUrl;\n promptText =\n params.prompt || \"Please analyze this image and provide a title and detailed description.\";\n }\n\n try {\n const imageResponse = await crossFetch(imageUrl);\n if (!imageResponse.ok) {\n throw new Error(`Failed to fetch image: ${imageResponse.statusText}`);\n }\n\n const imageData = await imageResponse.arrayBuffer();\n const base64Image = Buffer.from(imageData).toString(\"base64\");\n const contentType = imageResponse.headers.get(\"content-type\") || \"image/jpeg\";\n\n const response = await genAI.models.generateContent({\n model: modelName,\n contents: [\n {\n role: \"user\",\n parts: [\n { text: promptText },\n {\n inlineData: {\n mimeType: contentType,\n data: base64Image,\n },\n },\n ],\n },\n ],\n config: {\n temperature: 0.7,\n topK: 40,\n topP: 0.95,\n maxOutputTokens: 8192,\n safetySettings: getSafetySettings(),\n },\n });\n\n const responseText = response.text || \"\";\n\n try {\n const jsonResponse = JSON.parse(responseText) as { title?: string; description?: string };\n if (typeof jsonResponse.title === \"string\" && typeof jsonResponse.description === \"string\") {\n return {\n title: jsonResponse.title,\n description: jsonResponse.description,\n };\n }\n } catch {\n // Fall through to text parsing\n }\n\n const titleMatch = responseText.match(/title[:\\s]+(.+?)(?:\\n|$)/i);\n const title = titleMatch?.[1]?.trim() || \"Image Analysis\";\n const description = titleMatch\n ? responseText.replace(/title[:\\s]+(.+?)(?:\\n|$)/i, \"\").trim()\n : responseText.trim();\n\n return { title, description };\n } catch (error) {\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",
12
- "import type { IAgentRuntime, ModelTypeName, ObjectGenerationParams } from \"@elizaos/core\";\nimport { logger } from \"@elizaos/core\";\nimport {\n createGoogleGenAI,\n getLargeModel,\n getSafetySettings,\n getSmallModel,\n} from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport { countTokens } from \"../utils/tokenization\";\n\nasync function generateObjectByModelType(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n modelType: string,\n getModelFn: (runtime: IAgentRuntime) => string\n): Promise<Record<string, string | number | boolean | null>> {\n const genAI = createGoogleGenAI(runtime);\n if (!genAI) {\n throw new Error(\"Google Generative AI client not initialized\");\n }\n\n const modelName = getModelFn(runtime);\n const temperature = params.temperature ?? 0.1;\n\n logger.info(`Using ${modelType} model: ${modelName}`);\n\n try {\n let enhancedPrompt = params.prompt;\n if (params.schema) {\n enhancedPrompt += `\\n\\nPlease respond with a JSON object that follows this schema:\\n${JSON.stringify(params.schema, null, 2)}`;\n }\n\n const response = await genAI.models.generateContent({\n model: modelName,\n contents: enhancedPrompt,\n config: {\n temperature,\n topK: 40,\n topP: 0.95,\n maxOutputTokens: 8192,\n responseMimeType: \"application/json\",\n safetySettings: getSafetySettings(),\n },\n });\n\n const text = response.text || \"\";\n\n const promptTokens = await countTokens(enhancedPrompt);\n const completionTokens = await countTokens(text);\n\n emitModelUsageEvent(runtime, modelType as ModelTypeName, params.prompt, {\n promptTokens,\n completionTokens,\n totalTokens: promptTokens + completionTokens,\n });\n\n try {\n return JSON.parse(text) as Record<string, string | number | boolean | null>;\n } catch {\n const jsonMatch = text.match(/\\{[\\s\\S]*\\}/);\n if (jsonMatch) {\n try {\n return JSON.parse(jsonMatch[0]) as Record<string, string | number | boolean | null>;\n } catch {\n throw new Error(\"Failed to parse JSON from response\");\n }\n }\n throw new Error(\"Failed to parse JSON from response\");\n }\n } catch (error) {\n logger.error(\n `[generateObject] Error: ${error instanceof Error ? error.message : String(error)}`\n );\n throw error;\n }\n}\n\nexport async function handleObjectSmall(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams\n): Promise<Record<string, string | number | boolean | null>> {\n return generateObjectByModelType(runtime, params, \"OBJECT_SMALL\", getSmallModel);\n}\n\nexport async function handleObjectLarge(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams\n): Promise<Record<string, string | number | boolean | null>> {\n return generateObjectByModelType(runtime, params, \"OBJECT_LARGE\", getLargeModel);\n}\n",
13
- "import type { GenerateTextParams, IAgentRuntime } from \"@elizaos/core\";\nimport { logger, ModelType } from \"@elizaos/core\";\nimport {\n createGoogleGenAI,\n getLargeModel,\n getSafetySettings,\n getSmallModel,\n} from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport { countTokens } from \"../utils/tokenization\";\n\nexport async function handleTextSmall(\n runtime: IAgentRuntime,\n { prompt, stopSequences = [], maxTokens = 8192, temperature = 0.7 }: GenerateTextParams\n): Promise<string> {\n const genAI = createGoogleGenAI(runtime);\n if (!genAI) {\n throw new Error(\"Google Generative AI client not initialized\");\n }\n\n const modelName = getSmallModel(runtime);\n\n logger.log(`[TEXT_SMALL] Using model: ${modelName}`);\n\n try {\n const systemInstruction = runtime.character.system || undefined;\n const response = await genAI.models.generateContent({\n model: modelName,\n contents: prompt,\n config: {\n temperature,\n topK: 40,\n topP: 0.95,\n maxOutputTokens: maxTokens,\n stopSequences,\n safetySettings: getSafetySettings(),\n ...(systemInstruction && { systemInstruction }),\n },\n });\n\n const text = response.text || \"\";\n\n const promptTokens = await countTokens(prompt);\n const completionTokens = await countTokens(text);\n\n emitModelUsageEvent(runtime, ModelType.TEXT_SMALL, prompt, {\n promptTokens,\n completionTokens,\n totalTokens: promptTokens + completionTokens,\n });\n\n return text;\n } catch (error) {\n logger.error(`[TEXT_SMALL] Error: ${error instanceof Error ? error.message : String(error)}`);\n throw error;\n }\n}\n\nexport async function handleTextLarge(\n runtime: IAgentRuntime,\n { prompt, stopSequences = [], maxTokens = 8192, temperature = 0.7 }: GenerateTextParams\n): Promise<string> {\n const genAI = createGoogleGenAI(runtime);\n if (!genAI) {\n throw new Error(\"Google Generative AI client not initialized\");\n }\n\n const modelName = getLargeModel(runtime);\n\n logger.log(`[TEXT_LARGE] Using model: ${modelName}`);\n\n try {\n const systemInstruction = runtime.character.system || undefined;\n const response = await genAI.models.generateContent({\n model: modelName,\n contents: prompt,\n config: {\n temperature,\n topK: 40,\n topP: 0.95,\n maxOutputTokens: maxTokens,\n stopSequences,\n safetySettings: getSafetySettings(),\n ...(systemInstruction && { systemInstruction }),\n },\n });\n\n const text = response.text || \"\";\n\n const promptTokens = await countTokens(prompt);\n const completionTokens = await countTokens(text);\n\n emitModelUsageEvent(runtime, ModelType.TEXT_LARGE, prompt, {\n promptTokens,\n completionTokens,\n totalTokens: promptTokens + completionTokens,\n });\n\n return text;\n } catch (error) {\n logger.error(`[TEXT_LARGE] Error: ${error instanceof Error ? error.message : String(error)}`);\n throw error;\n }\n}\n"
11
+ "import type { IAgentRuntime, ImageDescriptionParams } from \"@elizaos/core\";\nimport { logger } from \"@elizaos/core\";\nimport type { ImageDescriptionResponse } from \"../types\";\nimport {\n createGoogleGenAI,\n getImageModel,\n getSafetySettings,\n} from \"../utils/config\";\n\nconst crossFetch =\n typeof globalThis.fetch === \"function\" ? globalThis.fetch : fetch;\n\nexport async function handleImageDescription(\n runtime: IAgentRuntime,\n params: ImageDescriptionParams | string,\n): Promise<ImageDescriptionResponse> {\n const genAI = createGoogleGenAI(runtime);\n if (!genAI) {\n throw new Error(\"Google Generative AI client not initialized\");\n }\n\n let imageUrl: string;\n let promptText: string;\n const modelName = getImageModel(runtime);\n logger.log(`[IMAGE_DESCRIPTION] Using model: ${modelName}`);\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 try {\n const imageResponse = await crossFetch(imageUrl);\n if (!imageResponse.ok) {\n throw new Error(`Failed to fetch image: ${imageResponse.statusText}`);\n }\n\n const imageData = await imageResponse.arrayBuffer();\n const base64Image = Buffer.from(imageData).toString(\"base64\");\n const contentType =\n imageResponse.headers.get(\"content-type\") || \"image/jpeg\";\n\n const response = await genAI.models.generateContent({\n model: modelName,\n contents: [\n {\n role: \"user\",\n parts: [\n { text: promptText },\n {\n inlineData: {\n mimeType: contentType,\n data: base64Image,\n },\n },\n ],\n },\n ],\n config: {\n temperature: 0.7,\n topK: 40,\n topP: 0.95,\n maxOutputTokens: 8192,\n safetySettings: getSafetySettings(),\n },\n });\n\n const responseText = response.text || \"\";\n\n try {\n const jsonResponse = JSON.parse(responseText) as {\n title?: string;\n description?: string;\n };\n if (\n typeof jsonResponse.title === \"string\" &&\n typeof jsonResponse.description === \"string\"\n ) {\n return {\n title: jsonResponse.title,\n description: jsonResponse.description,\n };\n }\n } catch {\n // Fall through to text parsing\n }\n\n const titleMatch = responseText.match(/title[:\\s]+(.+?)(?:\\n|$)/i);\n const title = titleMatch?.[1]?.trim() || \"Image Analysis\";\n const description = titleMatch\n ? responseText.replace(/title[:\\s]+(.+?)(?:\\n|$)/i, \"\").trim()\n : responseText.trim();\n\n return { title, description };\n } catch (error) {\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",
12
+ "import type {\n IAgentRuntime,\n ModelTypeName,\n ObjectGenerationParams,\n} from \"@elizaos/core\";\nimport { logger } from \"@elizaos/core\";\nimport {\n createGoogleGenAI,\n getLargeModel,\n getSafetySettings,\n getSmallModel,\n} from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport { countTokens } from \"../utils/tokenization\";\n\nasync function generateObjectByModelType(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n modelType: string,\n getModelFn: (runtime: IAgentRuntime) => string,\n): Promise<Record<string, string | number | boolean | null>> {\n const genAI = createGoogleGenAI(runtime);\n if (!genAI) {\n throw new Error(\"Google Generative AI client not initialized\");\n }\n\n const modelName = getModelFn(runtime);\n const temperature = params.temperature ?? 0.1;\n\n logger.info(`Using ${modelType} model: ${modelName}`);\n\n try {\n let enhancedPrompt = params.prompt;\n if (params.schema) {\n enhancedPrompt += `\\n\\nPlease respond with a JSON object that follows this schema:\\n${JSON.stringify(params.schema, null, 2)}`;\n }\n\n const response = await genAI.models.generateContent({\n model: modelName,\n contents: enhancedPrompt,\n config: {\n temperature,\n topK: 40,\n topP: 0.95,\n maxOutputTokens: 8192,\n responseMimeType: \"application/json\",\n safetySettings: getSafetySettings(),\n },\n });\n\n const text = response.text || \"\";\n\n const promptTokens = await countTokens(enhancedPrompt);\n const completionTokens = await countTokens(text);\n\n emitModelUsageEvent(runtime, modelType as ModelTypeName, params.prompt, {\n promptTokens,\n completionTokens,\n totalTokens: promptTokens + completionTokens,\n });\n\n try {\n return JSON.parse(text) as Record<\n string,\n string | number | boolean | null\n >;\n } catch {\n const jsonMatch = text.match(/\\{[\\s\\S]*\\}/);\n if (jsonMatch) {\n try {\n return JSON.parse(jsonMatch[0]) as Record<\n string,\n string | number | boolean | null\n >;\n } catch {\n throw new Error(\"Failed to parse JSON from response\");\n }\n }\n throw new Error(\"Failed to parse JSON from response\");\n }\n } catch (error) {\n logger.error(\n `[generateObject] Error: ${error instanceof Error ? error.message : String(error)}`,\n );\n throw error;\n }\n}\n\nexport async function handleObjectSmall(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<Record<string, string | number | boolean | null>> {\n return generateObjectByModelType(\n runtime,\n params,\n \"OBJECT_SMALL\",\n getSmallModel,\n );\n}\n\nexport async function handleObjectLarge(\n runtime: IAgentRuntime,\n params: ObjectGenerationParams,\n): Promise<Record<string, string | number | boolean | null>> {\n return generateObjectByModelType(\n runtime,\n params,\n \"OBJECT_LARGE\",\n getLargeModel,\n );\n}\n",
13
+ "import type { GenerateTextParams, IAgentRuntime } from \"@elizaos/core\";\nimport * as ElizaCore from \"@elizaos/core\";\nimport { logger } from \"@elizaos/core\";\nimport {\n createGoogleGenAI,\n getActionPlannerModel,\n getLargeModel,\n getMediumModel,\n getMegaModel,\n getNanoModel,\n getResponseHandlerModel,\n getSafetySettings,\n getSmallModel,\n} from \"../utils/config\";\nimport { emitModelUsageEvent } from \"../utils/events\";\nimport { countTokens } from \"../utils/tokenization\";\n\nconst CORE_MODEL_TYPES =\n (ElizaCore as { ModelType?: Record<string, string> }).ModelType ?? {};\nconst TEXT_NANO_MODEL_TYPE = (CORE_MODEL_TYPES.TEXT_NANO ??\n \"TEXT_NANO\") as string;\nconst TEXT_MEDIUM_MODEL_TYPE = (CORE_MODEL_TYPES.TEXT_MEDIUM ??\n \"TEXT_MEDIUM\") as string;\nconst TEXT_SMALL_MODEL_TYPE = (CORE_MODEL_TYPES.TEXT_SMALL ??\n \"TEXT_SMALL\") as string;\nconst TEXT_LARGE_MODEL_TYPE = (CORE_MODEL_TYPES.TEXT_LARGE ??\n \"TEXT_LARGE\") as string;\nconst TEXT_MEGA_MODEL_TYPE = (CORE_MODEL_TYPES.TEXT_MEGA ??\n \"TEXT_MEGA\") as string;\nconst RESPONSE_HANDLER_MODEL_TYPE = (CORE_MODEL_TYPES.RESPONSE_HANDLER ??\n \"RESPONSE_HANDLER\") as string;\nconst ACTION_PLANNER_MODEL_TYPE = (CORE_MODEL_TYPES.ACTION_PLANNER ??\n \"ACTION_PLANNER\") as string;\n\ntype ChatAttachment = {\n data: string | Uint8Array | URL;\n mediaType: string;\n filename?: string;\n};\n\ntype GenerateTextParamsWithAttachments = GenerateTextParams & {\n attachments?: ChatAttachment[];\n};\n\nfunction buildPromptParts(prompt: string, attachments?: ChatAttachment[]) {\n const parts: Array<\n | { text: string }\n | { fileData: { mimeType: string; fileUri: string } }\n | { inlineData: { mimeType: string; data: string } }\n > = [{ text: prompt }];\n\n for (const attachment of attachments ?? []) {\n if (attachment.data instanceof URL) {\n parts.push({\n fileData: {\n mimeType: attachment.mediaType,\n fileUri: attachment.data.toString(),\n },\n });\n continue;\n }\n\n if (\n typeof attachment.data === \"string\" &&\n /^https?:\\/\\//i.test(attachment.data)\n ) {\n parts.push({\n fileData: {\n mimeType: attachment.mediaType,\n fileUri: attachment.data,\n },\n });\n continue;\n }\n\n if (typeof attachment.data === \"string\") {\n const dataUrlMatch = attachment.data.match(\n /^data:([^;,]+);base64,(.+)$/i,\n );\n parts.push({\n inlineData: {\n mimeType: dataUrlMatch?.[1] ?? attachment.mediaType,\n data: dataUrlMatch?.[2] ?? attachment.data,\n },\n });\n continue;\n }\n\n parts.push({\n inlineData: {\n mimeType: attachment.mediaType,\n data: Buffer.from(attachment.data).toString(\"base64\"),\n },\n });\n }\n\n return parts;\n}\n\nfunction getModelNameForType(\n runtime: IAgentRuntime,\n modelType: string,\n): string {\n switch (modelType) {\n case TEXT_NANO_MODEL_TYPE:\n return getNanoModel(runtime);\n case TEXT_MEDIUM_MODEL_TYPE:\n return getMediumModel(runtime);\n case TEXT_SMALL_MODEL_TYPE:\n return getSmallModel(runtime);\n case TEXT_LARGE_MODEL_TYPE:\n return getLargeModel(runtime);\n case TEXT_MEGA_MODEL_TYPE:\n return getMegaModel(runtime);\n case RESPONSE_HANDLER_MODEL_TYPE:\n return getResponseHandlerModel(runtime);\n case ACTION_PLANNER_MODEL_TYPE:\n return getActionPlannerModel(runtime);\n default:\n return getLargeModel(runtime);\n }\n}\n\nexport async function handleTextSmall(\n runtime: IAgentRuntime,\n {\n prompt,\n stopSequences = [],\n maxTokens = 8192,\n temperature = 0.7,\n attachments,\n }: GenerateTextParamsWithAttachments,\n): Promise<string> {\n const genAI = createGoogleGenAI(runtime);\n if (!genAI) {\n throw new Error(\"Google Generative AI client not initialized\");\n }\n\n const modelName = getModelNameForType(runtime, TEXT_SMALL_MODEL_TYPE);\n\n logger.log(`[TEXT_SMALL] Using model: ${modelName}`);\n\n try {\n const systemInstruction = runtime.character.system || undefined;\n const response = await genAI.models.generateContent({\n model: modelName,\n contents:\n (attachments?.length ?? 0) > 0\n ? [{ role: \"user\", parts: buildPromptParts(prompt, attachments) }]\n : prompt,\n config: {\n temperature,\n topK: 40,\n topP: 0.95,\n maxOutputTokens: maxTokens,\n stopSequences,\n safetySettings: getSafetySettings(),\n ...(systemInstruction && { systemInstruction }),\n },\n });\n\n const text = response.text || \"\";\n\n const promptTokens = await countTokens(prompt);\n const completionTokens = await countTokens(text);\n\n emitModelUsageEvent(runtime, TEXT_SMALL_MODEL_TYPE, prompt, {\n promptTokens,\n completionTokens,\n totalTokens: promptTokens + completionTokens,\n });\n\n return text;\n } catch (error) {\n logger.error(\n `[TEXT_SMALL] Error: ${error instanceof Error ? error.message : String(error)}`,\n );\n throw error;\n }\n}\n\nexport async function handleTextLarge(\n runtime: IAgentRuntime,\n {\n prompt,\n stopSequences = [],\n maxTokens = 8192,\n temperature = 0.7,\n attachments,\n }: GenerateTextParamsWithAttachments,\n): Promise<string> {\n const genAI = createGoogleGenAI(runtime);\n if (!genAI) {\n throw new Error(\"Google Generative AI client not initialized\");\n }\n\n const modelName = getModelNameForType(runtime, TEXT_LARGE_MODEL_TYPE);\n\n logger.log(`[TEXT_LARGE] Using model: ${modelName}`);\n\n try {\n const systemInstruction = runtime.character.system || undefined;\n const response = await genAI.models.generateContent({\n model: modelName,\n contents:\n (attachments?.length ?? 0) > 0\n ? [{ role: \"user\", parts: buildPromptParts(prompt, attachments) }]\n : prompt,\n config: {\n temperature,\n topK: 40,\n topP: 0.95,\n maxOutputTokens: maxTokens,\n stopSequences,\n safetySettings: getSafetySettings(),\n ...(systemInstruction && { systemInstruction }),\n },\n });\n\n const text = response.text || \"\";\n\n const promptTokens = await countTokens(prompt);\n const completionTokens = await countTokens(text);\n\n emitModelUsageEvent(runtime, TEXT_LARGE_MODEL_TYPE, prompt, {\n promptTokens,\n completionTokens,\n totalTokens: promptTokens + completionTokens,\n });\n\n return text;\n } catch (error) {\n logger.error(\n `[TEXT_LARGE] Error: ${error instanceof Error ? error.message : String(error)}`,\n );\n throw error;\n }\n}\n\nexport async function handleTextNano(\n runtime: IAgentRuntime,\n params: GenerateTextParamsWithAttachments,\n): Promise<string> {\n return handleTextWithType(runtime, TEXT_NANO_MODEL_TYPE, params);\n}\n\nexport async function handleTextMedium(\n runtime: IAgentRuntime,\n params: GenerateTextParamsWithAttachments,\n): Promise<string> {\n return handleTextWithType(runtime, TEXT_MEDIUM_MODEL_TYPE, params);\n}\n\nexport async function handleTextMega(\n runtime: IAgentRuntime,\n params: GenerateTextParamsWithAttachments,\n): Promise<string> {\n return handleTextWithType(runtime, TEXT_MEGA_MODEL_TYPE, params);\n}\n\nexport async function handleResponseHandler(\n runtime: IAgentRuntime,\n params: GenerateTextParamsWithAttachments,\n): Promise<string> {\n return handleTextWithType(runtime, RESPONSE_HANDLER_MODEL_TYPE, params);\n}\n\nexport async function handleActionPlanner(\n runtime: IAgentRuntime,\n params: GenerateTextParamsWithAttachments,\n): Promise<string> {\n return handleTextWithType(runtime, ACTION_PLANNER_MODEL_TYPE, params);\n}\n\nasync function handleTextWithType(\n runtime: IAgentRuntime,\n modelType: string,\n {\n prompt,\n stopSequences = [],\n maxTokens = 8192,\n temperature = 0.7,\n attachments,\n }: GenerateTextParamsWithAttachments,\n): Promise<string> {\n const genAI = createGoogleGenAI(runtime);\n if (!genAI) {\n throw new Error(\"Google Generative AI client not initialized\");\n }\n\n const modelName = getModelNameForType(runtime, modelType);\n\n logger.log(`[${modelType}] Using model: ${modelName}`);\n\n try {\n const systemInstruction = runtime.character.system || undefined;\n const response = await genAI.models.generateContent({\n model: modelName,\n contents:\n (attachments?.length ?? 0) > 0\n ? [{ role: \"user\", parts: buildPromptParts(prompt, attachments) }]\n : prompt,\n config: {\n temperature,\n topK: 40,\n topP: 0.95,\n maxOutputTokens: maxTokens,\n stopSequences,\n safetySettings: getSafetySettings(),\n ...(systemInstruction && { systemInstruction }),\n },\n });\n\n const text = response.text || \"\";\n\n const promptTokens = await countTokens(prompt);\n const completionTokens = await countTokens(text);\n\n emitModelUsageEvent(runtime, modelType, prompt, {\n promptTokens,\n completionTokens,\n totalTokens: promptTokens + completionTokens,\n });\n\n return text;\n } catch (error) {\n logger.error(\n `[${modelType}] Error: ${error instanceof Error ? error.message : String(error)}`,\n );\n throw error;\n }\n}\n",
14
+ "import pluginDefault from \"./index\";\n\nexport * from \"./index\";\nexport default pluginDefault;\n"
14
15
  ],
15
- "mappings": "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",
16
- "debugId": "B2AECF43CC82835464756E2164756E21",
16
+ "mappings": "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",
17
+ "debugId": "DB1428E48B045C3E64756E2164756E21",
17
18
  "names": []
18
19
  }
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env bun
2
+ export {};
3
+ //# sourceMappingURL=build.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../typescript/build.ts"],"names":[],"mappings":""}
package/dist/build.js ADDED
@@ -0,0 +1,117 @@
1
+ #!/usr/bin/env bun
2
+ import { existsSync } from "node:fs";
3
+ import { mkdir, writeFile } from "node:fs/promises";
4
+ import { join } from "node:path";
5
+
6
+ const externalDeps = ["@google/genai", "@elizaos/core"];
7
+ async function build() {
8
+ const totalStart = Date.now();
9
+ const distDir = join(process.cwd(), "dist");
10
+ const nodeStart = Date.now();
11
+ console.log("Building @elizaos/plugin-google-genai for Node...");
12
+ const nodeResult = await Bun.build({
13
+ entrypoints: ["index.node.ts"],
14
+ outdir: join(distDir, "node"),
15
+ target: "node",
16
+ format: "esm",
17
+ sourcemap: "external",
18
+ minify: false,
19
+ external: [...externalDeps, "undici"],
20
+ });
21
+ if (!nodeResult.success) {
22
+ console.error("Node build failed:", nodeResult.logs);
23
+ throw new Error("Node build failed");
24
+ }
25
+ console.log(
26
+ `Node build complete in ${((Date.now() - nodeStart) / 1000).toFixed(2)}s`,
27
+ );
28
+ const browserStart = Date.now();
29
+ console.log("Building @elizaos/plugin-google-genai for Browser...");
30
+ const browserResult = await Bun.build({
31
+ entrypoints: ["index.browser.ts"],
32
+ outdir: join(distDir, "browser"),
33
+ target: "browser",
34
+ format: "esm",
35
+ sourcemap: "external",
36
+ minify: false,
37
+ external: [...externalDeps, "undici"],
38
+ });
39
+ if (!browserResult.success) {
40
+ console.error("Browser build failed:", browserResult.logs);
41
+ throw new Error("Browser build failed");
42
+ }
43
+ console.log(
44
+ `Browser build complete in ${((Date.now() - browserStart) / 1000).toFixed(2)}s`,
45
+ );
46
+ const cjsStart = Date.now();
47
+ console.log("Building @elizaos/plugin-google-genai for Node (CJS)...");
48
+ const cjsResult = await Bun.build({
49
+ entrypoints: ["index.node.ts"],
50
+ outdir: join(distDir, "cjs"),
51
+ target: "node",
52
+ format: "cjs",
53
+ sourcemap: "external",
54
+ minify: false,
55
+ external: [...externalDeps, "undici"],
56
+ });
57
+ if (!cjsResult.success) {
58
+ console.error("CJS build failed:", cjsResult.logs);
59
+ throw new Error("CJS build failed");
60
+ }
61
+ try {
62
+ const { rename } = await import("node:fs/promises");
63
+ await rename(
64
+ join(distDir, "cjs", "index.node.js"),
65
+ join(distDir, "cjs", "index.node.cjs"),
66
+ );
67
+ } catch (e) {
68
+ console.warn("CJS rename step warning:", e);
69
+ }
70
+ console.log(
71
+ `CJS build complete in ${((Date.now() - cjsStart) / 1000).toFixed(2)}s`,
72
+ );
73
+ const dtsStart = Date.now();
74
+ console.log("Generating TypeScript declarations...");
75
+ const { $ } = await import("bun");
76
+ try {
77
+ await $`tsc --project tsconfig.build.json`;
78
+ } catch (_e) {
79
+ console.warn("TypeScript declaration generation had errors");
80
+ }
81
+ const nodeDir = join(distDir, "node");
82
+ const browserDir = join(distDir, "browser");
83
+ const cjsDir = join(distDir, "cjs");
84
+ if (!existsSync(nodeDir)) await mkdir(nodeDir, { recursive: true });
85
+ if (!existsSync(browserDir)) await mkdir(browserDir, { recursive: true });
86
+ if (!existsSync(cjsDir)) await mkdir(cjsDir, { recursive: true });
87
+ const rootIndexDtsPath = join(distDir, "index.d.ts");
88
+ const rootAlias = `export * from "./node/index";
89
+ export { default } from "./node/index";
90
+ `;
91
+ await writeFile(rootIndexDtsPath, rootAlias, "utf8");
92
+ const nodeIndexDtsPath = join(nodeDir, "index.d.ts");
93
+ const nodeAlias = `export * from "./index.node";
94
+ export { default } from "./index.node";
95
+ `;
96
+ await writeFile(nodeIndexDtsPath, nodeAlias, "utf8");
97
+ const browserIndexDtsPath = join(browserDir, "index.d.ts");
98
+ const browserAlias = `export * from "./index.browser";
99
+ export { default } from "./index.browser";
100
+ `;
101
+ await writeFile(browserIndexDtsPath, browserAlias, "utf8");
102
+ const cjsIndexDtsPath = join(cjsDir, "index.d.ts");
103
+ const cjsAlias = `export * from "./index.node";
104
+ export { default } from "./index.node";
105
+ `;
106
+ await writeFile(cjsIndexDtsPath, cjsAlias, "utf8");
107
+ console.log(
108
+ `Declarations generated in ${((Date.now() - dtsStart) / 1000).toFixed(2)}s`,
109
+ );
110
+ console.log(
111
+ `All builds completed in ${((Date.now() - totalStart) / 1000).toFixed(2)}s`,
112
+ );
113
+ }
114
+ build().catch((err) => {
115
+ console.error("Build failed:", err);
116
+ process.exit(1);
117
+ });