@matthewdunbar/amazon-bedrock-mantle 0.0.7 → 0.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -58,6 +58,52 @@ function createMantleSigV4FetchFunction(getCredentials, fetchImpl = globalThis.f
58
58
  });
59
59
  };
60
60
  }
61
+ function createLoggingFetch(fetchImpl) {
62
+ return async (input, init) => {
63
+ var _a;
64
+ const response = await fetchImpl(input, init);
65
+ const clonedResponse = response.clone();
66
+ try {
67
+ const text = await clonedResponse.text();
68
+ console.error(
69
+ "[BEDROCK-MANTLE DEBUG] Response body:",
70
+ text.slice(0, 2e3)
71
+ );
72
+ try {
73
+ const json = JSON.parse(text);
74
+ console.error(
75
+ "[BEDROCK-MANTLE DEBUG] Parsed JSON keys:",
76
+ Object.keys(json)
77
+ );
78
+ if ((_a = json.choices) == null ? void 0 : _a[0]) {
79
+ console.error(
80
+ "[BEDROCK-MANTLE DEBUG] First choice keys:",
81
+ Object.keys(json.choices[0])
82
+ );
83
+ if (json.choices[0].message) {
84
+ console.error(
85
+ "[BEDROCK-MANTLE DEBUG] Message keys:",
86
+ Object.keys(json.choices[0].message)
87
+ );
88
+ if (json.choices[0].message.reasoning_content) {
89
+ console.error(
90
+ "[BEDROCK-MANTLE DEBUG] Reasoning content:",
91
+ JSON.stringify(json.choices[0].message.reasoning_content).slice(
92
+ 0,
93
+ 500
94
+ )
95
+ );
96
+ }
97
+ }
98
+ }
99
+ } catch (e) {
100
+ }
101
+ } catch (e) {
102
+ console.error("[BEDROCK-MANTLE DEBUG] Error reading response:", e);
103
+ }
104
+ return response;
105
+ };
106
+ }
61
107
  function createAmazonBedrockMantle(options = {}) {
62
108
  var _a, _b, _c, _d, _e, _f, _g, _h;
63
109
  const region = (_b = (_a = options.region) != null ? _a : (0, import_provider_utils.loadOptionalSetting)({
@@ -123,6 +169,7 @@ function createAmazonBedrockMantle(options = {}) {
123
169
  }, options.fetch);
124
170
  }
125
171
  }
172
+ const loggingFetch = createLoggingFetch(fetchFunction);
126
173
  const baseURL = (_h = (0, import_provider_utils.withoutTrailingSlash)(
127
174
  (_g = options.baseURL) != null ? _g : `https://bedrock-mantle.${region}.api.aws/v1`
128
175
  )) != null ? _h : `https://bedrock-mantle.us-east-1.api.aws/v1`;
@@ -130,7 +177,7 @@ function createAmazonBedrockMantle(options = {}) {
130
177
  baseURL,
131
178
  name: "amazon-bedrock-mantle",
132
179
  apiKey: apiKey != null ? apiKey : "dummy-key-for-sigv4",
133
- fetch: fetchFunction,
180
+ fetch: loggingFetch,
134
181
  headers: options.headers,
135
182
  includeUsage: false
136
183
  });
@@ -152,7 +199,7 @@ function createAmazonBedrockMantle(options = {}) {
152
199
  var bedrockMantle = createAmazonBedrockMantle();
153
200
 
154
201
  // src/version.ts
155
- var VERSION = true ? "0.0.6" : "0.0.0-test";
202
+ var VERSION = true ? "0.0.7" : "0.0.0-test";
156
203
  // Annotate the CommonJS export names for ESM import in node:
157
204
  0 && (module.exports = {
158
205
  VERSION,
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../src/bedrock-mantle-provider.ts","../src/version.ts"],"sourcesContent":["export {\n bedrockMantle,\n createAmazonBedrockMantle,\n} from './bedrock-mantle-provider';\nexport type {\n AmazonBedrockMantleProvider,\n AmazonBedrockMantleProviderSettings,\n BedrockMantleChatModelId,\n} from './bedrock-mantle-provider';\nexport { VERSION } from './version';\n","import {\n EmbeddingModelV3,\n ImageModelV3,\n LanguageModelV3,\n ProviderV3,\n} from '@ai-sdk/provider';\nimport {\n FetchFunction,\n loadOptionalSetting,\n withoutTrailingSlash,\n} from '@ai-sdk/provider-utils';\nimport {\n createOpenAICompatible,\n OpenAICompatibleProvider,\n} from '@ai-sdk/openai-compatible';\nimport { AwsV4Signer } from 'aws4fetch';\nimport { fromNodeProviderChain } from '@aws-sdk/credential-providers';\n\nexport interface AmazonBedrockMantleProviderSettings {\n /**\n * The AWS region to use for the Bedrock Mantle provider. Defaults to 'us-east-1'.\n */\n region?: string;\n\n /**\n * API key for authenticating requests using Bearer token authentication.\n * When provided, this will be used instead of AWS SigV4 authentication.\n * Defaults to the value of the `AWS_BEARER_TOKEN_BEDROCK` environment variable.\n *\n * Note: When `apiKey` is provided, it takes precedence over AWS SigV4 authentication.\n * If neither `apiKey` nor `AWS_BEARER_TOKEN_BEDROCK` environment variable is set,\n * the provider will fall back to AWS SigV4 authentication using AWS credentials.\n */\n apiKey?: string;\n\n /**\n * The AWS access key ID to use for the Bedrock Mantle provider. Defaults to the value of the\n * `AWS_ACCESS_KEY_ID` environment variable.\n */\n accessKeyId?: string;\n\n /**\n * The AWS secret access key to use for the Bedrock Mantle provider. Defaults to the value of the\n * `AWS_SECRET_ACCESS_KEY` environment variable.\n */\n secretAccessKey?: string;\n\n /**\n * The AWS session token to use for the Bedrock Mantle provider. Defaults to the value of the\n * `AWS_SESSION_TOKEN` environment variable.\n */\n sessionToken?: string;\n\n /**\n * The AWS profile to use for loading credentials from the AWS CLI configuration.\n * When specified, credentials will be loaded from ~/.aws/credentials for the given profile.\n * This uses the AWS credential provider chain to support SSO, IAM roles, etc.\n * This takes precedence over static credentials but is overridden by `apiKey`.\n */\n profile?: string;\n\n /**\n * Base URL for the Bedrock Mantle API calls. Defaults to the bedrock-mantle endpoint.\n */\n baseURL?: string;\n\n /**\n * Custom headers to include in the requests.\n */\n headers?: Record<string, string>;\n\n /**\n * Custom fetch implementation. You can use it as a middleware to intercept requests,\n * or to provide a custom fetch implementation for e.g. testing.\n */\n fetch?: FetchFunction;\n\n /**\n * The AWS credential provider to use for the Bedrock Mantle provider to get dynamic\n * credentials similar to the AWS SDK. Setting a provider here will cause its\n * credential values to be used instead of the `accessKeyId`, `secretAccessKey`,\n * and `sessionToken` settings.\n */\n credentialProvider?: () => PromiseLike<{\n accessKeyId: string;\n secretAccessKey: string;\n sessionToken?: string;\n }>;\n}\n\nexport type BedrockMantleChatModelId = string;\nexport type BedrockMantleEmbeddingModelId = string;\nexport type BedrockMantleImageModelId = string;\n\nexport interface AmazonBedrockMantleProvider extends ProviderV3 {\n (modelId: BedrockMantleChatModelId): LanguageModelV3;\n\n languageModel(modelId: BedrockMantleChatModelId): LanguageModelV3;\n\n chatModel(modelId: BedrockMantleChatModelId): LanguageModelV3;\n\n embeddingModel(modelId: BedrockMantleEmbeddingModelId): EmbeddingModelV3;\n\n imageModel(modelId: BedrockMantleImageModelId): ImageModelV3;\n}\n\ninterface BedrockCredentials {\n region: string;\n accessKeyId: string;\n secretAccessKey: string;\n sessionToken?: string;\n}\n\n/**\n * Creates a fetch function that applies AWS Signature Version 4 signing for bedrock-mantle service.\n *\n * @param getCredentials - Function that returns the AWS credentials to use when signing.\n * @param fetchImpl - Optional original fetch implementation to wrap. Defaults to global fetch.\n * @returns A FetchFunction that signs requests before passing them to the underlying fetch.\n */\nfunction createMantleSigV4FetchFunction(\n getCredentials: () => BedrockCredentials | PromiseLike<BedrockCredentials>,\n fetchImpl: FetchFunction = globalThis.fetch,\n): FetchFunction {\n return async (\n input: RequestInfo | URL,\n init?: RequestInit,\n ): Promise<Response> => {\n const url =\n typeof input === 'string'\n ? input\n : input instanceof URL\n ? input.href\n : input.url;\n\n const body =\n typeof init?.body === 'string'\n ? init.body\n : init?.body\n ? JSON.stringify(init.body)\n : undefined;\n\n const headers = init?.headers ?? {};\n const headerEntries =\n headers instanceof Headers\n ? Array.from(headers.entries())\n : Array.isArray(headers)\n ? headers\n : Object.entries(headers);\n\n const credentials = await getCredentials();\n const signer = new AwsV4Signer({\n url,\n method: init?.method ?? 'POST',\n headers: headerEntries,\n body,\n region: credentials.region,\n accessKeyId: credentials.accessKeyId,\n secretAccessKey: credentials.secretAccessKey,\n sessionToken: credentials.sessionToken,\n service: 'bedrock-mantle',\n });\n\n const signed = await signer.sign();\n return fetchImpl(input, {\n ...init,\n body,\n headers: Object.fromEntries(signed.headers.entries()),\n });\n };\n}\n\n/**\n * Create an Amazon Bedrock Mantle provider instance.\n * Bedrock Mantle is AWS Bedrock's OpenAI-compatible endpoint that routes all requests\n * through bedrock-mantle.<region>.api.aws/v1 using OpenAI API format.\n */\nexport function createAmazonBedrockMantle(\n options: AmazonBedrockMantleProviderSettings = {},\n): AmazonBedrockMantleProvider {\n // Get region - use option first, then environment variable, then default to us-east-1\n const region =\n options.region ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_REGION',\n }) ??\n 'us-east-1';\n\n // Check for API key authentication\n const rawApiKey = loadOptionalSetting({\n settingValue: options.apiKey,\n environmentVariableName: 'AWS_BEARER_TOKEN_BEDROCK',\n });\n\n // Only use API key if it's a non-empty, non-whitespace string\n const apiKey =\n rawApiKey && rawApiKey.trim().length > 0 ? rawApiKey.trim() : undefined;\n\n // Use API key authentication if available, otherwise fall back to SigV4\n let fetchFunction: FetchFunction;\n if (apiKey) {\n fetchFunction = options.fetch ?? globalThis.fetch;\n } else if (options.profile) {\n // Use AWS credential provider chain with profile\n const credentialProvider = fromNodeProviderChain({\n profile: options.profile,\n });\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n const creds = await credentialProvider();\n return {\n ...creds,\n region,\n };\n }, options.fetch);\n } else if (options.credentialProvider) {\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n return {\n ...(await options.credentialProvider!()),\n region,\n };\n }, options.fetch);\n } else {\n // For static credentials, load from options or environment variables\n const accessKeyId =\n options.accessKeyId ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_ACCESS_KEY_ID',\n });\n\n const secretAccessKey =\n options.secretAccessKey ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_SECRET_ACCESS_KEY',\n });\n\n const sessionToken =\n options.sessionToken ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_SESSION_TOKEN',\n });\n\n // If no static credentials, use the default credential provider chain\n if (!accessKeyId || !secretAccessKey) {\n const credentialProvider = fromNodeProviderChain();\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n const creds = await credentialProvider();\n return {\n ...creds,\n region,\n };\n }, options.fetch);\n } else {\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n return {\n region,\n accessKeyId: accessKeyId!,\n secretAccessKey: secretAccessKey!,\n sessionToken,\n };\n }, options.fetch);\n }\n }\n\n const baseURL =\n withoutTrailingSlash(\n options.baseURL ?? `https://bedrock-mantle.${region}.api.aws/v1`,\n ) ?? `https://bedrock-mantle.us-east-1.api.aws/v1`;\n\n // Create the OpenAI-compatible provider\n const mantleProvider: OpenAICompatibleProvider<\n string,\n string,\n string,\n string\n > = createOpenAICompatible({\n baseURL,\n name: 'amazon-bedrock-mantle',\n apiKey: apiKey ?? 'dummy-key-for-sigv4',\n fetch: fetchFunction,\n headers: options.headers,\n includeUsage: false,\n });\n\n const provider = function (modelId: BedrockMantleChatModelId) {\n if (new.target) {\n throw new Error(\n 'The Amazon Bedrock Mantle model function cannot be called with the new keyword.',\n );\n }\n return mantleProvider.languageModel(modelId);\n };\n\n provider.specificationVersion = 'v3' as const;\n provider.languageModel = mantleProvider.languageModel;\n provider.chatModel = mantleProvider.languageModel;\n provider.embeddingModel = mantleProvider.embeddingModel;\n provider.imageModel = mantleProvider.imageModel;\n\n return provider as AmazonBedrockMantleProvider;\n}\n\n/**\n * Default Bedrock Mantle provider instance.\n */\nexport const bedrockMantle = createAmazonBedrockMantle();\n","// Version string of this package injected at build time.\ndeclare const __PACKAGE_VERSION__: string | undefined;\nexport const VERSION: string =\n typeof __PACKAGE_VERSION__ !== 'undefined'\n ? __PACKAGE_VERSION__\n : '0.0.0-test';\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../src/index.ts","../src/bedrock-mantle-provider.ts","../src/version.ts"],"sourcesContent":["export {\n bedrockMantle,\n createAmazonBedrockMantle,\n} from './bedrock-mantle-provider';\nexport type {\n AmazonBedrockMantleProvider,\n AmazonBedrockMantleProviderSettings,\n BedrockMantleChatModelId,\n} from './bedrock-mantle-provider';\nexport { VERSION } from './version';\n","import {\n EmbeddingModelV3,\n ImageModelV3,\n LanguageModelV3,\n ProviderV3,\n} from '@ai-sdk/provider';\nimport {\n FetchFunction,\n loadOptionalSetting,\n withoutTrailingSlash,\n} from '@ai-sdk/provider-utils';\nimport {\n createOpenAICompatible,\n OpenAICompatibleProvider,\n} from '@ai-sdk/openai-compatible';\nimport { AwsV4Signer } from 'aws4fetch';\nimport { fromNodeProviderChain } from '@aws-sdk/credential-providers';\n\nexport interface AmazonBedrockMantleProviderSettings {\n /**\n * The AWS region to use for the Bedrock Mantle provider. Defaults to 'us-east-1'.\n */\n region?: string;\n\n /**\n * API key for authenticating requests using Bearer token authentication.\n * When provided, this will be used instead of AWS SigV4 authentication.\n * Defaults to the value of the `AWS_BEARER_TOKEN_BEDROCK` environment variable.\n *\n * Note: When `apiKey` is provided, it takes precedence over AWS SigV4 authentication.\n * If neither `apiKey` nor `AWS_BEARER_TOKEN_BEDROCK` environment variable is set,\n * the provider will fall back to AWS SigV4 authentication using AWS credentials.\n */\n apiKey?: string;\n\n /**\n * The AWS access key ID to use for the Bedrock Mantle provider. Defaults to the value of the\n * `AWS_ACCESS_KEY_ID` environment variable.\n */\n accessKeyId?: string;\n\n /**\n * The AWS secret access key to use for the Bedrock Mantle provider. Defaults to the value of the\n * `AWS_SECRET_ACCESS_KEY` environment variable.\n */\n secretAccessKey?: string;\n\n /**\n * The AWS session token to use for the Bedrock Mantle provider. Defaults to the value of the\n * `AWS_SESSION_TOKEN` environment variable.\n */\n sessionToken?: string;\n\n /**\n * The AWS profile to use for loading credentials from the AWS CLI configuration.\n * When specified, credentials will be loaded from ~/.aws/credentials for the given profile.\n * This uses the AWS credential provider chain to support SSO, IAM roles, etc.\n * This takes precedence over static credentials but is overridden by `apiKey`.\n */\n profile?: string;\n\n /**\n * Base URL for the Bedrock Mantle API calls. Defaults to the bedrock-mantle endpoint.\n */\n baseURL?: string;\n\n /**\n * Custom headers to include in the requests.\n */\n headers?: Record<string, string>;\n\n /**\n * Custom fetch implementation. You can use it as a middleware to intercept requests,\n * or to provide a custom fetch implementation for e.g. testing.\n */\n fetch?: FetchFunction;\n\n /**\n * The AWS credential provider to use for the Bedrock Mantle provider to get dynamic\n * credentials similar to the AWS SDK. Setting a provider here will cause its\n * credential values to be used instead of the `accessKeyId`, `secretAccessKey`,\n * and `sessionToken` settings.\n */\n credentialProvider?: () => PromiseLike<{\n accessKeyId: string;\n secretAccessKey: string;\n sessionToken?: string;\n }>;\n}\n\nexport type BedrockMantleChatModelId = string;\nexport type BedrockMantleEmbeddingModelId = string;\nexport type BedrockMantleImageModelId = string;\n\nexport interface AmazonBedrockMantleProvider extends ProviderV3 {\n (modelId: BedrockMantleChatModelId): LanguageModelV3;\n\n languageModel(modelId: BedrockMantleChatModelId): LanguageModelV3;\n\n chatModel(modelId: BedrockMantleChatModelId): LanguageModelV3;\n\n embeddingModel(modelId: BedrockMantleEmbeddingModelId): EmbeddingModelV3;\n\n imageModel(modelId: BedrockMantleImageModelId): ImageModelV3;\n}\n\ninterface BedrockCredentials {\n region: string;\n accessKeyId: string;\n secretAccessKey: string;\n sessionToken?: string;\n}\n\n/**\n * Creates a fetch function that applies AWS Signature Version 4 signing for bedrock-mantle service.\n *\n * @param getCredentials - Function that returns the AWS credentials to use when signing.\n * @param fetchImpl - Optional original fetch implementation to wrap. Defaults to global fetch.\n * @returns A FetchFunction that signs requests before passing them to the underlying fetch.\n */\nfunction createMantleSigV4FetchFunction(\n getCredentials: () => BedrockCredentials | PromiseLike<BedrockCredentials>,\n fetchImpl: FetchFunction = globalThis.fetch,\n): FetchFunction {\n return async (\n input: RequestInfo | URL,\n init?: RequestInit,\n ): Promise<Response> => {\n const url =\n typeof input === 'string'\n ? input\n : input instanceof URL\n ? input.href\n : input.url;\n\n const body =\n typeof init?.body === 'string'\n ? init.body\n : init?.body\n ? JSON.stringify(init.body)\n : undefined;\n\n const headers = init?.headers ?? {};\n const headerEntries =\n headers instanceof Headers\n ? Array.from(headers.entries())\n : Array.isArray(headers)\n ? headers\n : Object.entries(headers);\n\n const credentials = await getCredentials();\n const signer = new AwsV4Signer({\n url,\n method: init?.method ?? 'POST',\n headers: headerEntries,\n body,\n region: credentials.region,\n accessKeyId: credentials.accessKeyId,\n secretAccessKey: credentials.secretAccessKey,\n sessionToken: credentials.sessionToken,\n service: 'bedrock-mantle',\n });\n\n const signed = await signer.sign();\n return fetchImpl(input, {\n ...init,\n body,\n headers: Object.fromEntries(signed.headers.entries()),\n });\n };\n}\n\n/**\n * Create a wrapped fetch function that logs responses for debugging\n */\nfunction createLoggingFetch(fetchImpl: FetchFunction): FetchFunction {\n return async (\n input: RequestInfo | URL,\n init?: RequestInit,\n ): Promise<Response> => {\n const response = await fetchImpl(input, init);\n\n // Clone the response so we can read it and still return the original\n const clonedResponse = response.clone();\n\n try {\n const text = await clonedResponse.text();\n console.error(\n '[BEDROCK-MANTLE DEBUG] Response body:',\n text.slice(0, 2000),\n );\n\n // Try to parse as JSON to see structure\n try {\n const json = JSON.parse(text);\n console.error(\n '[BEDROCK-MANTLE DEBUG] Parsed JSON keys:',\n Object.keys(json),\n );\n if (json.choices?.[0]) {\n console.error(\n '[BEDROCK-MANTLE DEBUG] First choice keys:',\n Object.keys(json.choices[0]),\n );\n if (json.choices[0].message) {\n console.error(\n '[BEDROCK-MANTLE DEBUG] Message keys:',\n Object.keys(json.choices[0].message),\n );\n if (json.choices[0].message.reasoning_content) {\n console.error(\n '[BEDROCK-MANTLE DEBUG] Reasoning content:',\n JSON.stringify(json.choices[0].message.reasoning_content).slice(\n 0,\n 500,\n ),\n );\n }\n }\n }\n } catch (e) {\n // Not JSON\n }\n } catch (e) {\n console.error('[BEDROCK-MANTLE DEBUG] Error reading response:', e);\n }\n\n return response;\n };\n}\n\n/**\n * Create an Amazon Bedrock Mantle provider instance.\n * Bedrock Mantle is AWS Bedrock's OpenAI-compatible endpoint that routes all requests\n * through bedrock-mantle.<region>.api.aws/v1 using OpenAI API format.\n */\nexport function createAmazonBedrockMantle(\n options: AmazonBedrockMantleProviderSettings = {},\n): AmazonBedrockMantleProvider {\n // Get region - use option first, then environment variable, then default to us-east-1\n const region =\n options.region ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_REGION',\n }) ??\n 'us-east-1';\n\n // Check for API key authentication\n const rawApiKey = loadOptionalSetting({\n settingValue: options.apiKey,\n environmentVariableName: 'AWS_BEARER_TOKEN_BEDROCK',\n });\n\n // Only use API key if it's a non-empty, non-whitespace string\n const apiKey =\n rawApiKey && rawApiKey.trim().length > 0 ? rawApiKey.trim() : undefined;\n\n // Use API key authentication if available, otherwise fall back to SigV4\n let fetchFunction: FetchFunction;\n if (apiKey) {\n fetchFunction = options.fetch ?? globalThis.fetch;\n } else if (options.profile) {\n // Use AWS credential provider chain with profile\n const credentialProvider = fromNodeProviderChain({\n profile: options.profile,\n });\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n const creds = await credentialProvider();\n return {\n ...creds,\n region,\n };\n }, options.fetch);\n } else if (options.credentialProvider) {\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n return {\n ...(await options.credentialProvider!()),\n region,\n };\n }, options.fetch);\n } else {\n // For static credentials, load from options or environment variables\n const accessKeyId =\n options.accessKeyId ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_ACCESS_KEY_ID',\n });\n\n const secretAccessKey =\n options.secretAccessKey ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_SECRET_ACCESS_KEY',\n });\n\n const sessionToken =\n options.sessionToken ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_SESSION_TOKEN',\n });\n\n // If no static credentials, use the default credential provider chain\n if (!accessKeyId || !secretAccessKey) {\n const credentialProvider = fromNodeProviderChain();\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n const creds = await credentialProvider();\n return {\n ...creds,\n region,\n };\n }, options.fetch);\n } else {\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n return {\n region,\n accessKeyId: accessKeyId!,\n secretAccessKey: secretAccessKey!,\n sessionToken,\n };\n }, options.fetch);\n }\n }\n\n // Wrap with logging fetch to debug responses\n const loggingFetch = createLoggingFetch(fetchFunction);\n\n const baseURL =\n withoutTrailingSlash(\n options.baseURL ?? `https://bedrock-mantle.${region}.api.aws/v1`,\n ) ?? `https://bedrock-mantle.us-east-1.api.aws/v1`;\n\n // Create the OpenAI-compatible provider\n const mantleProvider: OpenAICompatibleProvider<\n string,\n string,\n string,\n string\n > = createOpenAICompatible({\n baseURL,\n name: 'amazon-bedrock-mantle',\n apiKey: apiKey ?? 'dummy-key-for-sigv4',\n fetch: loggingFetch,\n headers: options.headers,\n includeUsage: false,\n });\n\n const provider = function (modelId: BedrockMantleChatModelId) {\n if (new.target) {\n throw new Error(\n 'The Amazon Bedrock Mantle model function cannot be called with the new keyword.',\n );\n }\n return mantleProvider.languageModel(modelId);\n };\n\n provider.specificationVersion = 'v3' as const;\n provider.languageModel = mantleProvider.languageModel;\n provider.chatModel = mantleProvider.languageModel;\n provider.embeddingModel = mantleProvider.embeddingModel;\n provider.imageModel = mantleProvider.imageModel;\n\n return provider as AmazonBedrockMantleProvider;\n}\n\n/**\n * Default Bedrock Mantle provider instance.\n */\nexport const bedrockMantle = createAmazonBedrockMantle();\n","// Version string of this package injected at build time.\ndeclare const __PACKAGE_VERSION__: string | undefined;\nexport const VERSION: string =\n typeof __PACKAGE_VERSION__ !== 'undefined'\n ? __PACKAGE_VERSION__\n : '0.0.0-test';\n"],"mappings":"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","names":[]}
package/dist/index.mjs CHANGED
@@ -35,6 +35,52 @@ function createMantleSigV4FetchFunction(getCredentials, fetchImpl = globalThis.f
35
35
  });
36
36
  };
37
37
  }
38
+ function createLoggingFetch(fetchImpl) {
39
+ return async (input, init) => {
40
+ var _a;
41
+ const response = await fetchImpl(input, init);
42
+ const clonedResponse = response.clone();
43
+ try {
44
+ const text = await clonedResponse.text();
45
+ console.error(
46
+ "[BEDROCK-MANTLE DEBUG] Response body:",
47
+ text.slice(0, 2e3)
48
+ );
49
+ try {
50
+ const json = JSON.parse(text);
51
+ console.error(
52
+ "[BEDROCK-MANTLE DEBUG] Parsed JSON keys:",
53
+ Object.keys(json)
54
+ );
55
+ if ((_a = json.choices) == null ? void 0 : _a[0]) {
56
+ console.error(
57
+ "[BEDROCK-MANTLE DEBUG] First choice keys:",
58
+ Object.keys(json.choices[0])
59
+ );
60
+ if (json.choices[0].message) {
61
+ console.error(
62
+ "[BEDROCK-MANTLE DEBUG] Message keys:",
63
+ Object.keys(json.choices[0].message)
64
+ );
65
+ if (json.choices[0].message.reasoning_content) {
66
+ console.error(
67
+ "[BEDROCK-MANTLE DEBUG] Reasoning content:",
68
+ JSON.stringify(json.choices[0].message.reasoning_content).slice(
69
+ 0,
70
+ 500
71
+ )
72
+ );
73
+ }
74
+ }
75
+ }
76
+ } catch (e) {
77
+ }
78
+ } catch (e) {
79
+ console.error("[BEDROCK-MANTLE DEBUG] Error reading response:", e);
80
+ }
81
+ return response;
82
+ };
83
+ }
38
84
  function createAmazonBedrockMantle(options = {}) {
39
85
  var _a, _b, _c, _d, _e, _f, _g, _h;
40
86
  const region = (_b = (_a = options.region) != null ? _a : loadOptionalSetting({
@@ -100,6 +146,7 @@ function createAmazonBedrockMantle(options = {}) {
100
146
  }, options.fetch);
101
147
  }
102
148
  }
149
+ const loggingFetch = createLoggingFetch(fetchFunction);
103
150
  const baseURL = (_h = withoutTrailingSlash(
104
151
  (_g = options.baseURL) != null ? _g : `https://bedrock-mantle.${region}.api.aws/v1`
105
152
  )) != null ? _h : `https://bedrock-mantle.us-east-1.api.aws/v1`;
@@ -107,7 +154,7 @@ function createAmazonBedrockMantle(options = {}) {
107
154
  baseURL,
108
155
  name: "amazon-bedrock-mantle",
109
156
  apiKey: apiKey != null ? apiKey : "dummy-key-for-sigv4",
110
- fetch: fetchFunction,
157
+ fetch: loggingFetch,
111
158
  headers: options.headers,
112
159
  includeUsage: false
113
160
  });
@@ -129,7 +176,7 @@ function createAmazonBedrockMantle(options = {}) {
129
176
  var bedrockMantle = createAmazonBedrockMantle();
130
177
 
131
178
  // src/version.ts
132
- var VERSION = true ? "0.0.6" : "0.0.0-test";
179
+ var VERSION = true ? "0.0.7" : "0.0.0-test";
133
180
  export {
134
181
  VERSION,
135
182
  bedrockMantle,
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/bedrock-mantle-provider.ts","../src/version.ts"],"sourcesContent":["import {\n EmbeddingModelV3,\n ImageModelV3,\n LanguageModelV3,\n ProviderV3,\n} from '@ai-sdk/provider';\nimport {\n FetchFunction,\n loadOptionalSetting,\n withoutTrailingSlash,\n} from '@ai-sdk/provider-utils';\nimport {\n createOpenAICompatible,\n OpenAICompatibleProvider,\n} from '@ai-sdk/openai-compatible';\nimport { AwsV4Signer } from 'aws4fetch';\nimport { fromNodeProviderChain } from '@aws-sdk/credential-providers';\n\nexport interface AmazonBedrockMantleProviderSettings {\n /**\n * The AWS region to use for the Bedrock Mantle provider. Defaults to 'us-east-1'.\n */\n region?: string;\n\n /**\n * API key for authenticating requests using Bearer token authentication.\n * When provided, this will be used instead of AWS SigV4 authentication.\n * Defaults to the value of the `AWS_BEARER_TOKEN_BEDROCK` environment variable.\n *\n * Note: When `apiKey` is provided, it takes precedence over AWS SigV4 authentication.\n * If neither `apiKey` nor `AWS_BEARER_TOKEN_BEDROCK` environment variable is set,\n * the provider will fall back to AWS SigV4 authentication using AWS credentials.\n */\n apiKey?: string;\n\n /**\n * The AWS access key ID to use for the Bedrock Mantle provider. Defaults to the value of the\n * `AWS_ACCESS_KEY_ID` environment variable.\n */\n accessKeyId?: string;\n\n /**\n * The AWS secret access key to use for the Bedrock Mantle provider. Defaults to the value of the\n * `AWS_SECRET_ACCESS_KEY` environment variable.\n */\n secretAccessKey?: string;\n\n /**\n * The AWS session token to use for the Bedrock Mantle provider. Defaults to the value of the\n * `AWS_SESSION_TOKEN` environment variable.\n */\n sessionToken?: string;\n\n /**\n * The AWS profile to use for loading credentials from the AWS CLI configuration.\n * When specified, credentials will be loaded from ~/.aws/credentials for the given profile.\n * This uses the AWS credential provider chain to support SSO, IAM roles, etc.\n * This takes precedence over static credentials but is overridden by `apiKey`.\n */\n profile?: string;\n\n /**\n * Base URL for the Bedrock Mantle API calls. Defaults to the bedrock-mantle endpoint.\n */\n baseURL?: string;\n\n /**\n * Custom headers to include in the requests.\n */\n headers?: Record<string, string>;\n\n /**\n * Custom fetch implementation. You can use it as a middleware to intercept requests,\n * or to provide a custom fetch implementation for e.g. testing.\n */\n fetch?: FetchFunction;\n\n /**\n * The AWS credential provider to use for the Bedrock Mantle provider to get dynamic\n * credentials similar to the AWS SDK. Setting a provider here will cause its\n * credential values to be used instead of the `accessKeyId`, `secretAccessKey`,\n * and `sessionToken` settings.\n */\n credentialProvider?: () => PromiseLike<{\n accessKeyId: string;\n secretAccessKey: string;\n sessionToken?: string;\n }>;\n}\n\nexport type BedrockMantleChatModelId = string;\nexport type BedrockMantleEmbeddingModelId = string;\nexport type BedrockMantleImageModelId = string;\n\nexport interface AmazonBedrockMantleProvider extends ProviderV3 {\n (modelId: BedrockMantleChatModelId): LanguageModelV3;\n\n languageModel(modelId: BedrockMantleChatModelId): LanguageModelV3;\n\n chatModel(modelId: BedrockMantleChatModelId): LanguageModelV3;\n\n embeddingModel(modelId: BedrockMantleEmbeddingModelId): EmbeddingModelV3;\n\n imageModel(modelId: BedrockMantleImageModelId): ImageModelV3;\n}\n\ninterface BedrockCredentials {\n region: string;\n accessKeyId: string;\n secretAccessKey: string;\n sessionToken?: string;\n}\n\n/**\n * Creates a fetch function that applies AWS Signature Version 4 signing for bedrock-mantle service.\n *\n * @param getCredentials - Function that returns the AWS credentials to use when signing.\n * @param fetchImpl - Optional original fetch implementation to wrap. Defaults to global fetch.\n * @returns A FetchFunction that signs requests before passing them to the underlying fetch.\n */\nfunction createMantleSigV4FetchFunction(\n getCredentials: () => BedrockCredentials | PromiseLike<BedrockCredentials>,\n fetchImpl: FetchFunction = globalThis.fetch,\n): FetchFunction {\n return async (\n input: RequestInfo | URL,\n init?: RequestInit,\n ): Promise<Response> => {\n const url =\n typeof input === 'string'\n ? input\n : input instanceof URL\n ? input.href\n : input.url;\n\n const body =\n typeof init?.body === 'string'\n ? init.body\n : init?.body\n ? JSON.stringify(init.body)\n : undefined;\n\n const headers = init?.headers ?? {};\n const headerEntries =\n headers instanceof Headers\n ? Array.from(headers.entries())\n : Array.isArray(headers)\n ? headers\n : Object.entries(headers);\n\n const credentials = await getCredentials();\n const signer = new AwsV4Signer({\n url,\n method: init?.method ?? 'POST',\n headers: headerEntries,\n body,\n region: credentials.region,\n accessKeyId: credentials.accessKeyId,\n secretAccessKey: credentials.secretAccessKey,\n sessionToken: credentials.sessionToken,\n service: 'bedrock-mantle',\n });\n\n const signed = await signer.sign();\n return fetchImpl(input, {\n ...init,\n body,\n headers: Object.fromEntries(signed.headers.entries()),\n });\n };\n}\n\n/**\n * Create an Amazon Bedrock Mantle provider instance.\n * Bedrock Mantle is AWS Bedrock's OpenAI-compatible endpoint that routes all requests\n * through bedrock-mantle.<region>.api.aws/v1 using OpenAI API format.\n */\nexport function createAmazonBedrockMantle(\n options: AmazonBedrockMantleProviderSettings = {},\n): AmazonBedrockMantleProvider {\n // Get region - use option first, then environment variable, then default to us-east-1\n const region =\n options.region ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_REGION',\n }) ??\n 'us-east-1';\n\n // Check for API key authentication\n const rawApiKey = loadOptionalSetting({\n settingValue: options.apiKey,\n environmentVariableName: 'AWS_BEARER_TOKEN_BEDROCK',\n });\n\n // Only use API key if it's a non-empty, non-whitespace string\n const apiKey =\n rawApiKey && rawApiKey.trim().length > 0 ? rawApiKey.trim() : undefined;\n\n // Use API key authentication if available, otherwise fall back to SigV4\n let fetchFunction: FetchFunction;\n if (apiKey) {\n fetchFunction = options.fetch ?? globalThis.fetch;\n } else if (options.profile) {\n // Use AWS credential provider chain with profile\n const credentialProvider = fromNodeProviderChain({\n profile: options.profile,\n });\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n const creds = await credentialProvider();\n return {\n ...creds,\n region,\n };\n }, options.fetch);\n } else if (options.credentialProvider) {\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n return {\n ...(await options.credentialProvider!()),\n region,\n };\n }, options.fetch);\n } else {\n // For static credentials, load from options or environment variables\n const accessKeyId =\n options.accessKeyId ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_ACCESS_KEY_ID',\n });\n\n const secretAccessKey =\n options.secretAccessKey ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_SECRET_ACCESS_KEY',\n });\n\n const sessionToken =\n options.sessionToken ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_SESSION_TOKEN',\n });\n\n // If no static credentials, use the default credential provider chain\n if (!accessKeyId || !secretAccessKey) {\n const credentialProvider = fromNodeProviderChain();\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n const creds = await credentialProvider();\n return {\n ...creds,\n region,\n };\n }, options.fetch);\n } else {\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n return {\n region,\n accessKeyId: accessKeyId!,\n secretAccessKey: secretAccessKey!,\n sessionToken,\n };\n }, options.fetch);\n }\n }\n\n const baseURL =\n withoutTrailingSlash(\n options.baseURL ?? `https://bedrock-mantle.${region}.api.aws/v1`,\n ) ?? `https://bedrock-mantle.us-east-1.api.aws/v1`;\n\n // Create the OpenAI-compatible provider\n const mantleProvider: OpenAICompatibleProvider<\n string,\n string,\n string,\n string\n > = createOpenAICompatible({\n baseURL,\n name: 'amazon-bedrock-mantle',\n apiKey: apiKey ?? 'dummy-key-for-sigv4',\n fetch: fetchFunction,\n headers: options.headers,\n includeUsage: false,\n });\n\n const provider = function (modelId: BedrockMantleChatModelId) {\n if (new.target) {\n throw new Error(\n 'The Amazon Bedrock Mantle model function cannot be called with the new keyword.',\n );\n }\n return mantleProvider.languageModel(modelId);\n };\n\n provider.specificationVersion = 'v3' as const;\n provider.languageModel = mantleProvider.languageModel;\n provider.chatModel = mantleProvider.languageModel;\n provider.embeddingModel = mantleProvider.embeddingModel;\n provider.imageModel = mantleProvider.imageModel;\n\n return provider as AmazonBedrockMantleProvider;\n}\n\n/**\n * Default Bedrock Mantle provider instance.\n */\nexport const bedrockMantle = createAmazonBedrockMantle();\n","// Version string of this package injected at build time.\ndeclare const __PACKAGE_VERSION__: string | undefined;\nexport const VERSION: string =\n typeof __PACKAGE_VERSION__ !== 'undefined'\n ? __PACKAGE_VERSION__\n : '0.0.0-test';\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../src/bedrock-mantle-provider.ts","../src/version.ts"],"sourcesContent":["import {\n EmbeddingModelV3,\n ImageModelV3,\n LanguageModelV3,\n ProviderV3,\n} from '@ai-sdk/provider';\nimport {\n FetchFunction,\n loadOptionalSetting,\n withoutTrailingSlash,\n} from '@ai-sdk/provider-utils';\nimport {\n createOpenAICompatible,\n OpenAICompatibleProvider,\n} from '@ai-sdk/openai-compatible';\nimport { AwsV4Signer } from 'aws4fetch';\nimport { fromNodeProviderChain } from '@aws-sdk/credential-providers';\n\nexport interface AmazonBedrockMantleProviderSettings {\n /**\n * The AWS region to use for the Bedrock Mantle provider. Defaults to 'us-east-1'.\n */\n region?: string;\n\n /**\n * API key for authenticating requests using Bearer token authentication.\n * When provided, this will be used instead of AWS SigV4 authentication.\n * Defaults to the value of the `AWS_BEARER_TOKEN_BEDROCK` environment variable.\n *\n * Note: When `apiKey` is provided, it takes precedence over AWS SigV4 authentication.\n * If neither `apiKey` nor `AWS_BEARER_TOKEN_BEDROCK` environment variable is set,\n * the provider will fall back to AWS SigV4 authentication using AWS credentials.\n */\n apiKey?: string;\n\n /**\n * The AWS access key ID to use for the Bedrock Mantle provider. Defaults to the value of the\n * `AWS_ACCESS_KEY_ID` environment variable.\n */\n accessKeyId?: string;\n\n /**\n * The AWS secret access key to use for the Bedrock Mantle provider. Defaults to the value of the\n * `AWS_SECRET_ACCESS_KEY` environment variable.\n */\n secretAccessKey?: string;\n\n /**\n * The AWS session token to use for the Bedrock Mantle provider. Defaults to the value of the\n * `AWS_SESSION_TOKEN` environment variable.\n */\n sessionToken?: string;\n\n /**\n * The AWS profile to use for loading credentials from the AWS CLI configuration.\n * When specified, credentials will be loaded from ~/.aws/credentials for the given profile.\n * This uses the AWS credential provider chain to support SSO, IAM roles, etc.\n * This takes precedence over static credentials but is overridden by `apiKey`.\n */\n profile?: string;\n\n /**\n * Base URL for the Bedrock Mantle API calls. Defaults to the bedrock-mantle endpoint.\n */\n baseURL?: string;\n\n /**\n * Custom headers to include in the requests.\n */\n headers?: Record<string, string>;\n\n /**\n * Custom fetch implementation. You can use it as a middleware to intercept requests,\n * or to provide a custom fetch implementation for e.g. testing.\n */\n fetch?: FetchFunction;\n\n /**\n * The AWS credential provider to use for the Bedrock Mantle provider to get dynamic\n * credentials similar to the AWS SDK. Setting a provider here will cause its\n * credential values to be used instead of the `accessKeyId`, `secretAccessKey`,\n * and `sessionToken` settings.\n */\n credentialProvider?: () => PromiseLike<{\n accessKeyId: string;\n secretAccessKey: string;\n sessionToken?: string;\n }>;\n}\n\nexport type BedrockMantleChatModelId = string;\nexport type BedrockMantleEmbeddingModelId = string;\nexport type BedrockMantleImageModelId = string;\n\nexport interface AmazonBedrockMantleProvider extends ProviderV3 {\n (modelId: BedrockMantleChatModelId): LanguageModelV3;\n\n languageModel(modelId: BedrockMantleChatModelId): LanguageModelV3;\n\n chatModel(modelId: BedrockMantleChatModelId): LanguageModelV3;\n\n embeddingModel(modelId: BedrockMantleEmbeddingModelId): EmbeddingModelV3;\n\n imageModel(modelId: BedrockMantleImageModelId): ImageModelV3;\n}\n\ninterface BedrockCredentials {\n region: string;\n accessKeyId: string;\n secretAccessKey: string;\n sessionToken?: string;\n}\n\n/**\n * Creates a fetch function that applies AWS Signature Version 4 signing for bedrock-mantle service.\n *\n * @param getCredentials - Function that returns the AWS credentials to use when signing.\n * @param fetchImpl - Optional original fetch implementation to wrap. Defaults to global fetch.\n * @returns A FetchFunction that signs requests before passing them to the underlying fetch.\n */\nfunction createMantleSigV4FetchFunction(\n getCredentials: () => BedrockCredentials | PromiseLike<BedrockCredentials>,\n fetchImpl: FetchFunction = globalThis.fetch,\n): FetchFunction {\n return async (\n input: RequestInfo | URL,\n init?: RequestInit,\n ): Promise<Response> => {\n const url =\n typeof input === 'string'\n ? input\n : input instanceof URL\n ? input.href\n : input.url;\n\n const body =\n typeof init?.body === 'string'\n ? init.body\n : init?.body\n ? JSON.stringify(init.body)\n : undefined;\n\n const headers = init?.headers ?? {};\n const headerEntries =\n headers instanceof Headers\n ? Array.from(headers.entries())\n : Array.isArray(headers)\n ? headers\n : Object.entries(headers);\n\n const credentials = await getCredentials();\n const signer = new AwsV4Signer({\n url,\n method: init?.method ?? 'POST',\n headers: headerEntries,\n body,\n region: credentials.region,\n accessKeyId: credentials.accessKeyId,\n secretAccessKey: credentials.secretAccessKey,\n sessionToken: credentials.sessionToken,\n service: 'bedrock-mantle',\n });\n\n const signed = await signer.sign();\n return fetchImpl(input, {\n ...init,\n body,\n headers: Object.fromEntries(signed.headers.entries()),\n });\n };\n}\n\n/**\n * Create a wrapped fetch function that logs responses for debugging\n */\nfunction createLoggingFetch(fetchImpl: FetchFunction): FetchFunction {\n return async (\n input: RequestInfo | URL,\n init?: RequestInit,\n ): Promise<Response> => {\n const response = await fetchImpl(input, init);\n\n // Clone the response so we can read it and still return the original\n const clonedResponse = response.clone();\n\n try {\n const text = await clonedResponse.text();\n console.error(\n '[BEDROCK-MANTLE DEBUG] Response body:',\n text.slice(0, 2000),\n );\n\n // Try to parse as JSON to see structure\n try {\n const json = JSON.parse(text);\n console.error(\n '[BEDROCK-MANTLE DEBUG] Parsed JSON keys:',\n Object.keys(json),\n );\n if (json.choices?.[0]) {\n console.error(\n '[BEDROCK-MANTLE DEBUG] First choice keys:',\n Object.keys(json.choices[0]),\n );\n if (json.choices[0].message) {\n console.error(\n '[BEDROCK-MANTLE DEBUG] Message keys:',\n Object.keys(json.choices[0].message),\n );\n if (json.choices[0].message.reasoning_content) {\n console.error(\n '[BEDROCK-MANTLE DEBUG] Reasoning content:',\n JSON.stringify(json.choices[0].message.reasoning_content).slice(\n 0,\n 500,\n ),\n );\n }\n }\n }\n } catch (e) {\n // Not JSON\n }\n } catch (e) {\n console.error('[BEDROCK-MANTLE DEBUG] Error reading response:', e);\n }\n\n return response;\n };\n}\n\n/**\n * Create an Amazon Bedrock Mantle provider instance.\n * Bedrock Mantle is AWS Bedrock's OpenAI-compatible endpoint that routes all requests\n * through bedrock-mantle.<region>.api.aws/v1 using OpenAI API format.\n */\nexport function createAmazonBedrockMantle(\n options: AmazonBedrockMantleProviderSettings = {},\n): AmazonBedrockMantleProvider {\n // Get region - use option first, then environment variable, then default to us-east-1\n const region =\n options.region ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_REGION',\n }) ??\n 'us-east-1';\n\n // Check for API key authentication\n const rawApiKey = loadOptionalSetting({\n settingValue: options.apiKey,\n environmentVariableName: 'AWS_BEARER_TOKEN_BEDROCK',\n });\n\n // Only use API key if it's a non-empty, non-whitespace string\n const apiKey =\n rawApiKey && rawApiKey.trim().length > 0 ? rawApiKey.trim() : undefined;\n\n // Use API key authentication if available, otherwise fall back to SigV4\n let fetchFunction: FetchFunction;\n if (apiKey) {\n fetchFunction = options.fetch ?? globalThis.fetch;\n } else if (options.profile) {\n // Use AWS credential provider chain with profile\n const credentialProvider = fromNodeProviderChain({\n profile: options.profile,\n });\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n const creds = await credentialProvider();\n return {\n ...creds,\n region,\n };\n }, options.fetch);\n } else if (options.credentialProvider) {\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n return {\n ...(await options.credentialProvider!()),\n region,\n };\n }, options.fetch);\n } else {\n // For static credentials, load from options or environment variables\n const accessKeyId =\n options.accessKeyId ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_ACCESS_KEY_ID',\n });\n\n const secretAccessKey =\n options.secretAccessKey ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_SECRET_ACCESS_KEY',\n });\n\n const sessionToken =\n options.sessionToken ??\n loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'AWS_SESSION_TOKEN',\n });\n\n // If no static credentials, use the default credential provider chain\n if (!accessKeyId || !secretAccessKey) {\n const credentialProvider = fromNodeProviderChain();\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n const creds = await credentialProvider();\n return {\n ...creds,\n region,\n };\n }, options.fetch);\n } else {\n fetchFunction = createMantleSigV4FetchFunction(async () => {\n return {\n region,\n accessKeyId: accessKeyId!,\n secretAccessKey: secretAccessKey!,\n sessionToken,\n };\n }, options.fetch);\n }\n }\n\n // Wrap with logging fetch to debug responses\n const loggingFetch = createLoggingFetch(fetchFunction);\n\n const baseURL =\n withoutTrailingSlash(\n options.baseURL ?? `https://bedrock-mantle.${region}.api.aws/v1`,\n ) ?? `https://bedrock-mantle.us-east-1.api.aws/v1`;\n\n // Create the OpenAI-compatible provider\n const mantleProvider: OpenAICompatibleProvider<\n string,\n string,\n string,\n string\n > = createOpenAICompatible({\n baseURL,\n name: 'amazon-bedrock-mantle',\n apiKey: apiKey ?? 'dummy-key-for-sigv4',\n fetch: loggingFetch,\n headers: options.headers,\n includeUsage: false,\n });\n\n const provider = function (modelId: BedrockMantleChatModelId) {\n if (new.target) {\n throw new Error(\n 'The Amazon Bedrock Mantle model function cannot be called with the new keyword.',\n );\n }\n return mantleProvider.languageModel(modelId);\n };\n\n provider.specificationVersion = 'v3' as const;\n provider.languageModel = mantleProvider.languageModel;\n provider.chatModel = mantleProvider.languageModel;\n provider.embeddingModel = mantleProvider.embeddingModel;\n provider.imageModel = mantleProvider.imageModel;\n\n return provider as AmazonBedrockMantleProvider;\n}\n\n/**\n * Default Bedrock Mantle provider instance.\n */\nexport const bedrockMantle = createAmazonBedrockMantle();\n","// Version string of this package injected at build time.\ndeclare const __PACKAGE_VERSION__: string | undefined;\nexport const VERSION: string =\n typeof __PACKAGE_VERSION__ !== 'undefined'\n ? __PACKAGE_VERSION__\n : '0.0.0-test';\n"],"mappings":"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","names":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@matthewdunbar/amazon-bedrock-mantle",
3
- "version": "0.0.7",
3
+ "version": "0.0.8",
4
4
  "license": "Apache-2.0",
5
5
  "sideEffects": false,
6
6
  "main": "./dist/index.js",