ai-sdk-provider-claude-code 0.2.0 → 0.2.2
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/README.md +13 -5
- package/dist/index.cjs +5 -5
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +10 -10
- package/dist/index.d.ts +10 -10
- package/dist/index.js +5 -5
- package/dist/index.js.map +1 -1
- package/docs/DEVELOPMENT-STATUS.md +2 -2
- package/docs/GUIDE.md +4 -4
- package/docs/TROUBLESHOOTING.md +1 -1
- package/package.json +2 -2
package/README.md
CHANGED
|
@@ -1,8 +1,17 @@
|
|
|
1
|
-
|
|
1
|
+
<p align="center">
|
|
2
|
+
<img src="https://img.shields.io/badge/warning-alpha-FF6700" alt="alpha warning">
|
|
3
|
+
<a href="https://www.npmjs.com/package/ai-sdk-provider-claude-code"><img src="https://img.shields.io/npm/v/ai-sdk-provider-claude-code?color=00A79E" alt="npm version" /></a>
|
|
4
|
+
<a href="https://www.npmjs.com/package/ai-sdk-provider-claude-code"><img src="https://img.shields.io/npm/unpacked-size/ai-sdk-provider-claude-code?color=00A79E" alt="install size" /></a>
|
|
5
|
+
<a href="https://www.npmjs.com/package/ai-sdk-provider-claude-code"><img src="https://img.shields.io/npm/dy/ai-sdk-provider-claude-code.svg?color=00A79E" alt="npm downloads" /></a>
|
|
6
|
+
<a href="https://nodejs.org/en/about/releases/"><img src="https://img.shields.io/badge/node-%3E%3D18-00A79E" alt="Node.js ≥ 18" /></a>
|
|
7
|
+
<a href="https://www.npmjs.com/package/ai-sdk-provider-claude-code"><img src="https://img.shields.io/npm/l/ai-sdk-provider-claude-code?color=00A79E" alt="License: MIT" /></a>
|
|
8
|
+
</p>
|
|
9
|
+
|
|
10
|
+
# AI SDK Provider for Claude Code SDK
|
|
2
11
|
|
|
3
12
|
> **Warning**: This package is experimental and subject to change.
|
|
4
13
|
|
|
5
|
-
**ai-sdk-provider-claude-code** lets you use Claude via the [Vercel AI SDK](https://sdk.vercel.ai/docs) through the official `@anthropic-ai/claude-code` CLI.
|
|
14
|
+
**ai-sdk-provider-claude-code** lets you use Claude via the [Vercel AI SDK](https://sdk.vercel.ai/docs) through the official `@anthropic-ai/claude-code` SDK/CLI.
|
|
6
15
|
|
|
7
16
|
## Installation
|
|
8
17
|
|
|
@@ -14,15 +23,14 @@ claude login
|
|
|
14
23
|
|
|
15
24
|
### 2. Add the provider
|
|
16
25
|
```bash
|
|
17
|
-
npm install
|
|
18
|
-
npm install ai
|
|
26
|
+
npm install ai-sdk-provider-claude-code ai
|
|
19
27
|
```
|
|
20
28
|
|
|
21
29
|
## Disclaimer
|
|
22
30
|
|
|
23
31
|
**This is an unofficial community provider** and is not affiliated with or endorsed by Anthropic or Vercel. By using this provider:
|
|
24
32
|
|
|
25
|
-
- You understand that your data will be sent to Anthropic's servers through the Claude Code
|
|
33
|
+
- You understand that your data will be sent to Anthropic's servers through the Claude Code SDK
|
|
26
34
|
- You agree to comply with [Anthropic's Terms of Service](https://www.anthropic.com/legal/consumer-terms)
|
|
27
35
|
- You acknowledge this software is provided "as is" without warranties of any kind
|
|
28
36
|
|
package/dist/index.cjs
CHANGED
|
@@ -59,7 +59,7 @@ function convertToClaudeCodeMessages(prompt, mode) {
|
|
|
59
59
|
}
|
|
60
60
|
const imageParts = message.content.filter((part) => part.type === "image");
|
|
61
61
|
if (imageParts.length > 0) {
|
|
62
|
-
warnings.push("Claude Code
|
|
62
|
+
warnings.push("Claude Code SDK does not support image inputs. Images will be ignored.");
|
|
63
63
|
}
|
|
64
64
|
}
|
|
65
65
|
break;
|
|
@@ -239,7 +239,7 @@ function createAuthenticationError({
|
|
|
239
239
|
message
|
|
240
240
|
}) {
|
|
241
241
|
return new import_provider.LoadAPIKeyError({
|
|
242
|
-
message: message || "Authentication failed. Please ensure Claude Code
|
|
242
|
+
message: message || "Authentication failed. Please ensure Claude Code SDK is properly authenticated."
|
|
243
243
|
});
|
|
244
244
|
}
|
|
245
245
|
function createTimeoutError({
|
|
@@ -481,7 +481,7 @@ var ClaudeCodeLanguageModel = class {
|
|
|
481
481
|
warnings.push({
|
|
482
482
|
type: "unsupported-setting",
|
|
483
483
|
setting: param,
|
|
484
|
-
details: `Claude Code
|
|
484
|
+
details: `Claude Code SDK does not support the ${param} parameter. It will be ignored.`
|
|
485
485
|
});
|
|
486
486
|
}
|
|
487
487
|
}
|
|
@@ -550,7 +550,7 @@ var ClaudeCodeLanguageModel = class {
|
|
|
550
550
|
const isAuthError = authErrorPatterns.some((pattern) => errorMessage.includes(pattern)) || exitCode === 401;
|
|
551
551
|
if (isAuthError) {
|
|
552
552
|
return createAuthenticationError({
|
|
553
|
-
message: isErrorWithMessage(error) && error.message ? error.message : "Authentication failed. Please ensure Claude Code
|
|
553
|
+
message: isErrorWithMessage(error) && error.message ? error.message : "Authentication failed. Please ensure Claude Code SDK is properly authenticated."
|
|
554
554
|
});
|
|
555
555
|
}
|
|
556
556
|
const errorCode = isErrorWithCode(error) && typeof error.code === "string" ? error.code : "";
|
|
@@ -564,7 +564,7 @@ var ClaudeCodeLanguageModel = class {
|
|
|
564
564
|
}
|
|
565
565
|
const isRetryable = errorCode === "ENOENT" || errorCode === "ECONNREFUSED" || errorCode === "ETIMEDOUT" || errorCode === "ECONNRESET";
|
|
566
566
|
return createAPICallError({
|
|
567
|
-
message: isErrorWithMessage(error) && error.message ? error.message : "Claude Code
|
|
567
|
+
message: isErrorWithMessage(error) && error.message ? error.message : "Claude Code SDK error",
|
|
568
568
|
code: errorCode || void 0,
|
|
569
569
|
exitCode,
|
|
570
570
|
stderr: isErrorWithCode(error) && typeof error.stderr === "string" ? error.stderr : void 0,
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/claude-code-provider.ts","../src/claude-code-language-model.ts","../src/convert-to-claude-code-messages.ts","../src/extract-json.ts","../src/errors.ts","../src/map-claude-code-finish-reason.ts","../src/validation.ts","../src/logger.ts"],"sourcesContent":["/**\n * Provider exports for creating and configuring Claude Code instances.\n * @module claude-code\n */\n\n/**\n * Creates a new Claude Code provider instance and the default provider instance.\n * @see {@link createClaudeCode} for creating custom provider instances\n * @see {@link claudeCode} for the default provider instance\n */\nexport { createClaudeCode, claudeCode } from './claude-code-provider.js';\n\n/**\n * Type definitions for the Claude Code provider.\n * @see {@link ClaudeCodeProvider} for the provider interface\n * @see {@link ClaudeCodeProviderSettings} for provider configuration options\n */\nexport type { ClaudeCodeProvider, ClaudeCodeProviderSettings } from './claude-code-provider.js';\n\n/**\n * Language model implementation for Claude Code.\n * This class implements the AI SDK's LanguageModelV1 interface.\n */\nexport { ClaudeCodeLanguageModel } from './claude-code-language-model.js';\n\n/**\n * Type definitions for Claude Code language models.\n * @see {@link ClaudeCodeModelId} for supported model identifiers\n * @see {@link ClaudeCodeLanguageModelOptions} for model configuration options\n */\nexport type { ClaudeCodeModelId, ClaudeCodeLanguageModelOptions } from './claude-code-language-model.js';\n\n/**\n * Settings for configuring Claude Code behavior.\n * Includes options for customizing the CLI execution, permissions, and tool usage.\n */\nexport type { ClaudeCodeSettings, Logger } from './types.js';\n\n/**\n * Error handling utilities for Claude Code.\n * These functions help create and identify specific error types.\n * \n * @see {@link isAuthenticationError} to check for authentication failures\n * @see {@link isTimeoutError} to check for timeout errors\n * @see {@link getErrorMetadata} to extract error metadata\n * @see {@link createAPICallError} to create general API errors\n * @see {@link createAuthenticationError} to create authentication errors\n * @see {@link createTimeoutError} to create timeout errors\n */\nexport { \n isAuthenticationError, \n isTimeoutError, \n getErrorMetadata,\n createAPICallError,\n createAuthenticationError,\n createTimeoutError\n} from './errors.js';\n\n/**\n * Metadata associated with Claude Code errors.\n * Contains additional context about CLI execution failures.\n */\nexport type { ClaudeCodeErrorMetadata } from './errors.js';","import type { LanguageModelV1, ProviderV1 } from '@ai-sdk/provider';\nimport { NoSuchModelError } from '@ai-sdk/provider';\nimport { ClaudeCodeLanguageModel, type ClaudeCodeModelId } from './claude-code-language-model.js';\nimport type { ClaudeCodeSettings } from './types.js';\nimport { validateSettings } from './validation.js';\nimport { getLogger } from './logger.js';\n\n/**\n * Claude Code provider interface that extends the AI SDK's ProviderV1.\n * Provides methods to create language models for interacting with Claude via the CLI.\n * \n * @example\n * ```typescript\n * import { claudeCode } from 'ai-sdk-provider-claude-code';\n * \n * // Create a model instance\n * const model = claudeCode('opus');\n * \n * // Or use the explicit methods\n * const chatModel = claudeCode.chat('sonnet');\n * const languageModel = claudeCode.languageModel('opus', { maxTurns: 10 });\n * ```\n */\nexport interface ClaudeCodeProvider extends ProviderV1 {\n /**\n * Creates a language model instance for the specified model ID.\n * This is a shorthand for calling `languageModel()`.\n * \n * @param modelId - The Claude model to use ('opus' or 'sonnet')\n * @param settings - Optional settings to configure the model\n * @returns A language model instance\n */\n (modelId: ClaudeCodeModelId, settings?: ClaudeCodeSettings): LanguageModelV1;\n\n /**\n * Creates a language model instance for text generation.\n * \n * @param modelId - The Claude model to use ('opus' or 'sonnet')\n * @param settings - Optional settings to configure the model\n * @returns A language model instance\n */\n languageModel(\n modelId: ClaudeCodeModelId,\n settings?: ClaudeCodeSettings,\n ): LanguageModelV1;\n\n /**\n * Alias for `languageModel()` to maintain compatibility with AI SDK patterns.\n * \n * @param modelId - The Claude model to use ('opus' or 'sonnet')\n * @param settings - Optional settings to configure the model\n * @returns A language model instance\n */\n chat(\n modelId: ClaudeCodeModelId,\n settings?: ClaudeCodeSettings,\n ): LanguageModelV1;\n}\n\n/**\n * Configuration options for creating a Claude Code provider instance.\n * These settings will be applied as defaults to all models created by the provider.\n * \n * @example\n * ```typescript\n * const provider = createClaudeCode({\n * defaultSettings: {\n * maxTurns: 5,\n * cwd: '/path/to/project'\n * }\n * });\n * ```\n */\nexport interface ClaudeCodeProviderSettings {\n /**\n * Default settings to use for all models created by this provider.\n * Individual model settings will override these defaults.\n */\n defaultSettings?: ClaudeCodeSettings;\n}\n\n/**\n * Creates a Claude Code provider instance with the specified configuration.\n * The provider can be used to create language models for interacting with Claude 4 models.\n *\n * @param options - Provider configuration options\n * @returns Claude Code provider instance\n * \n * @example\n * ```typescript\n * const provider = createClaudeCode({\n * defaultSettings: {\n * permissionMode: 'bypassPermissions',\n * maxTurns: 10\n * }\n * });\n * \n * const model = provider('opus');\n * ```\n */\nexport function createClaudeCode(\n options: ClaudeCodeProviderSettings = {},\n): ClaudeCodeProvider {\n // Get logger from default settings if provided\n const logger = getLogger(options.defaultSettings?.logger);\n \n // Validate default settings if provided\n if (options.defaultSettings) {\n const validation = validateSettings(options.defaultSettings);\n if (!validation.valid) {\n throw new Error(`Invalid default settings: ${validation.errors.join(', ')}`);\n }\n if (validation.warnings.length > 0) {\n validation.warnings.forEach(warning => logger.warn(`Claude Code Provider: ${warning}`));\n }\n }\n\n const createModel = (\n modelId: ClaudeCodeModelId,\n settings: ClaudeCodeSettings = {},\n ): LanguageModelV1 => {\n const mergedSettings = {\n ...options.defaultSettings,\n ...settings,\n };\n \n // Validate merged settings\n const validation = validateSettings(mergedSettings);\n if (!validation.valid) {\n throw new Error(`Invalid settings: ${validation.errors.join(', ')}`);\n }\n \n return new ClaudeCodeLanguageModel({\n id: modelId,\n settings: mergedSettings,\n settingsValidationWarnings: validation.warnings,\n });\n };\n\n const provider = function (\n modelId: ClaudeCodeModelId,\n settings?: ClaudeCodeSettings,\n ) {\n if (new.target) {\n throw new Error(\n 'The Claude Code model function cannot be called with the new keyword.',\n );\n }\n\n return createModel(modelId, settings);\n };\n\n provider.languageModel = createModel;\n provider.chat = createModel; // Alias for languageModel\n\n // Add textEmbeddingModel method that throws NoSuchModelError\n provider.textEmbeddingModel = (modelId: string) => {\n throw new NoSuchModelError({\n modelId,\n modelType: 'textEmbeddingModel',\n });\n };\n\n return provider as ClaudeCodeProvider;\n}\n\n/**\n * Default Claude Code provider instance.\n * Pre-configured provider for quick usage without custom settings.\n * \n * @example\n * ```typescript\n * import { claudeCode } from 'ai-sdk-provider-claude-code';\n * import { generateText } from 'ai';\n * \n * const { text } = await generateText({\n * model: claudeCode('sonnet'),\n * prompt: 'Hello, Claude!'\n * });\n * ```\n */\nexport const claudeCode = createClaudeCode();","import type {\n LanguageModelV1,\n LanguageModelV1CallWarning,\n LanguageModelV1FinishReason,\n LanguageModelV1StreamPart,\n JSONValue,\n} from '@ai-sdk/provider';\nimport { NoSuchModelError, APICallError, LoadAPIKeyError } from '@ai-sdk/provider';\nimport { generateId } from '@ai-sdk/provider-utils';\nimport type { ClaudeCodeSettings, Logger } from './types.js';\nimport { convertToClaudeCodeMessages } from './convert-to-claude-code-messages.js';\nimport { extractJson } from './extract-json.js';\nimport { createAPICallError, createAuthenticationError, createTimeoutError } from './errors.js';\nimport { mapClaudeCodeFinishReason } from './map-claude-code-finish-reason.js';\nimport { validateModelId, validatePrompt, validateSessionId } from './validation.js';\nimport { getLogger } from './logger.js';\n\nimport { query, AbortError, type Options } from '@anthropic-ai/claude-code';\n\n/**\n * Options for creating a Claude Code language model instance.\n * \n * @example\n * ```typescript\n * const model = new ClaudeCodeLanguageModel({\n * id: 'opus',\n * settings: {\n * maxTurns: 10,\n * permissionMode: 'auto'\n * }\n * });\n * ```\n */\nexport interface ClaudeCodeLanguageModelOptions {\n /**\n * The model identifier to use.\n * Can be 'opus', 'sonnet', or a custom model string.\n */\n id: ClaudeCodeModelId;\n \n /**\n * Optional settings to configure the model behavior.\n */\n settings?: ClaudeCodeSettings;\n \n /**\n * Validation warnings from settings validation.\n * Used internally to pass warnings from provider.\n */\n settingsValidationWarnings?: string[];\n}\n\n/**\n * Supported Claude model identifiers.\n * - 'opus': Claude 4 Opus model (most capable)\n * - 'sonnet': Claude 4 Sonnet model (balanced performance)\n * - Custom string: Any other model identifier supported by the CLI\n * \n * @example\n * ```typescript\n * const opusModel = claudeCode('opus');\n * const sonnetModel = claudeCode('sonnet');\n * const customModel = claudeCode('claude-3-opus-20240229');\n * ```\n */\nexport type ClaudeCodeModelId = 'opus' | 'sonnet' | (string & {});\n\nconst modelMap: Record<string, string> = {\n 'opus': 'opus',\n 'sonnet': 'sonnet',\n};\n\n/**\n * Language model implementation for Claude Code CLI.\n * This class implements the AI SDK's LanguageModelV1 interface to provide\n * integration with Claude models through the Claude Code CLI.\n * \n * Features:\n * - Supports streaming and non-streaming generation\n * - Handles JSON object generation mode\n * - Manages CLI sessions for conversation continuity\n * - Provides detailed error handling and retry logic\n * \n * Limitations:\n * - Does not support image inputs\n * - Does not support structured outputs (tool mode)\n * - Some parameters like temperature and max tokens are not supported by the CLI\n * \n * @example\n * ```typescript\n * const model = new ClaudeCodeLanguageModel({\n * id: 'opus',\n * settings: { maxTurns: 5 }\n * });\n * \n * const result = await model.doGenerate({\n * prompt: [{ role: 'user', content: 'Hello!' }],\n * mode: { type: 'regular' }\n * });\n * ```\n */\nexport class ClaudeCodeLanguageModel implements LanguageModelV1 {\n readonly specificationVersion = 'v1' as const;\n readonly defaultObjectGenerationMode = 'json' as const;\n readonly supportsImageUrls = false;\n readonly supportsStructuredOutputs = false;\n\n readonly modelId: ClaudeCodeModelId;\n readonly settings: ClaudeCodeSettings;\n \n private sessionId?: string;\n private modelValidationWarning?: string;\n private settingsValidationWarnings: string[];\n private logger: Logger;\n\n constructor(options: ClaudeCodeLanguageModelOptions) {\n this.modelId = options.id;\n this.settings = options.settings ?? {};\n this.settingsValidationWarnings = options.settingsValidationWarnings ?? [];\n this.logger = getLogger(this.settings.logger);\n \n // Validate model ID format\n if (!this.modelId || typeof this.modelId !== 'string' || this.modelId.trim() === '') {\n throw new NoSuchModelError({\n modelId: this.modelId,\n modelType: 'languageModel',\n });\n }\n \n // Additional model ID validation\n this.modelValidationWarning = validateModelId(this.modelId);\n if (this.modelValidationWarning) {\n this.logger.warn(`Claude Code Model: ${this.modelValidationWarning}`);\n }\n }\n\n get provider(): string {\n return 'claude-code';\n }\n\n private getModel(): string {\n const mapped = modelMap[this.modelId];\n return mapped ?? this.modelId;\n }\n\n private generateAllWarnings(\n options: Parameters<LanguageModelV1['doGenerate']>[0] | Parameters<LanguageModelV1['doStream']>[0],\n prompt: string\n ): LanguageModelV1CallWarning[] {\n const warnings: LanguageModelV1CallWarning[] = [];\n const unsupportedParams: string[] = [];\n \n // Check for unsupported parameters\n if (options.temperature !== undefined) unsupportedParams.push('temperature');\n if (options.maxTokens !== undefined) unsupportedParams.push('maxTokens');\n if (options.topP !== undefined) unsupportedParams.push('topP');\n if (options.topK !== undefined) unsupportedParams.push('topK');\n if (options.presencePenalty !== undefined) unsupportedParams.push('presencePenalty');\n if (options.frequencyPenalty !== undefined) unsupportedParams.push('frequencyPenalty');\n if (options.stopSequences !== undefined && options.stopSequences.length > 0) unsupportedParams.push('stopSequences');\n if (options.seed !== undefined) unsupportedParams.push('seed');\n \n if (unsupportedParams.length > 0) {\n // Add a warning for each unsupported parameter\n for (const param of unsupportedParams) {\n warnings.push({\n type: 'unsupported-setting',\n setting: param as 'temperature' | 'maxTokens' | 'topP' | 'topK' | 'presencePenalty' | 'frequencyPenalty' | 'stopSequences' | 'seed',\n details: `Claude Code CLI does not support the ${param} parameter. It will be ignored.`,\n });\n }\n }\n \n // Add model validation warning if present\n if (this.modelValidationWarning) {\n warnings.push({\n type: 'other',\n message: this.modelValidationWarning,\n });\n }\n \n // Add settings validation warnings\n this.settingsValidationWarnings.forEach(warning => {\n warnings.push({\n type: 'other',\n message: warning,\n });\n });\n \n // Validate prompt\n const promptWarning = validatePrompt(prompt);\n if (promptWarning) {\n warnings.push({\n type: 'other',\n message: promptWarning,\n });\n }\n \n return warnings;\n }\n\n private createQueryOptions(abortController: AbortController): Options {\n return {\n model: this.getModel(),\n abortController,\n resume: this.settings.resume ?? this.sessionId,\n pathToClaudeCodeExecutable: this.settings.pathToClaudeCodeExecutable,\n customSystemPrompt: this.settings.customSystemPrompt,\n appendSystemPrompt: this.settings.appendSystemPrompt,\n maxTurns: this.settings.maxTurns,\n maxThinkingTokens: this.settings.maxThinkingTokens,\n cwd: this.settings.cwd,\n executable: this.settings.executable,\n executableArgs: this.settings.executableArgs,\n permissionMode: this.settings.permissionMode,\n permissionPromptToolName: this.settings.permissionPromptToolName,\n continue: this.settings.continue,\n allowedTools: this.settings.allowedTools,\n disallowedTools: this.settings.disallowedTools,\n mcpServers: this.settings.mcpServers,\n };\n }\n\n private handleClaudeCodeError(\n error: unknown,\n messagesPrompt: string\n ): APICallError | LoadAPIKeyError {\n // Handle AbortError from the SDK\n if (error instanceof AbortError) {\n // Return the abort reason if available, otherwise the error itself\n throw error;\n }\n\n // Type guard for error with properties\n const isErrorWithMessage = (err: unknown): err is { message?: string } => {\n return typeof err === 'object' && err !== null && 'message' in err;\n };\n\n const isErrorWithCode = (err: unknown): err is { code?: string; exitCode?: number; stderr?: string } => {\n return typeof err === 'object' && err !== null;\n };\n\n // Check for authentication errors with improved detection\n const authErrorPatterns = [\n 'not logged in',\n 'authentication',\n 'unauthorized',\n 'auth failed',\n 'please login',\n 'claude login'\n ];\n \n const errorMessage = isErrorWithMessage(error) && error.message \n ? error.message.toLowerCase() \n : '';\n \n const exitCode = isErrorWithCode(error) && typeof error.exitCode === 'number' \n ? error.exitCode \n : undefined;\n \n const isAuthError = authErrorPatterns.some(pattern => errorMessage.includes(pattern)) ||\n exitCode === 401;\n\n if (isAuthError) {\n return createAuthenticationError({\n message: isErrorWithMessage(error) && error.message \n ? error.message \n : 'Authentication failed. Please ensure Claude Code CLI is properly authenticated.',\n });\n }\n\n // Check for timeout errors\n const errorCode = isErrorWithCode(error) && typeof error.code === 'string' \n ? error.code \n : '';\n \n if (errorCode === 'ETIMEDOUT' || errorMessage.includes('timeout')) {\n return createTimeoutError({\n message: isErrorWithMessage(error) && error.message \n ? error.message \n : 'Request timed out',\n promptExcerpt: messagesPrompt.substring(0, 200),\n // Don't specify timeoutMs since we don't know the actual timeout value\n // It's controlled by the consumer via AbortSignal\n });\n }\n\n // Create general API call error with appropriate retry flag\n const isRetryable = errorCode === 'ENOENT' || \n errorCode === 'ECONNREFUSED' ||\n errorCode === 'ETIMEDOUT' ||\n errorCode === 'ECONNRESET';\n\n return createAPICallError({\n message: isErrorWithMessage(error) && error.message \n ? error.message \n : 'Claude Code CLI error',\n code: errorCode || undefined,\n exitCode: exitCode,\n stderr: isErrorWithCode(error) && typeof error.stderr === 'string' \n ? error.stderr \n : undefined,\n promptExcerpt: messagesPrompt.substring(0, 200),\n isRetryable,\n });\n }\n\n private setSessionId(sessionId: string): void {\n this.sessionId = sessionId;\n const warning = validateSessionId(sessionId);\n if (warning) {\n this.logger.warn(`Claude Code Session: ${warning}`);\n }\n }\n\n private validateJsonExtraction(\n originalText: string,\n extractedJson: string\n ): { valid: boolean; warning?: LanguageModelV1CallWarning } {\n // If the extracted JSON is the same as original, extraction likely failed\n if (extractedJson === originalText) {\n return {\n valid: false,\n warning: {\n type: 'other',\n message: 'JSON extraction from model response may be incomplete or modified. The model may not have returned valid JSON.',\n },\n };\n }\n\n // Try to parse the extracted JSON to validate it\n try {\n JSON.parse(extractedJson);\n return { valid: true };\n } catch {\n return {\n valid: false,\n warning: {\n type: 'other',\n message: 'JSON extraction resulted in invalid JSON. The response may be malformed.',\n },\n };\n }\n }\n\n async doGenerate(\n options: Parameters<LanguageModelV1['doGenerate']>[0],\n ): Promise<Awaited<ReturnType<LanguageModelV1['doGenerate']>>> {\n const { messagesPrompt, warnings: messageWarnings } = convertToClaudeCodeMessages(options.prompt, options.mode);\n\n const abortController = new AbortController();\n let abortListener: (() => void) | undefined;\n if (options.abortSignal) {\n abortListener = () => abortController.abort();\n options.abortSignal.addEventListener('abort', abortListener, { once: true });\n }\n\n const queryOptions = this.createQueryOptions(abortController);\n\n let text = '';\n let usage = { promptTokens: 0, completionTokens: 0 };\n let finishReason: LanguageModelV1FinishReason = 'stop';\n let costUsd: number | undefined;\n let durationMs: number | undefined;\n let rawUsage: unknown | undefined;\n const warnings: LanguageModelV1CallWarning[] = this.generateAllWarnings(options, messagesPrompt);\n \n // Add warnings from message conversion\n if (messageWarnings) {\n messageWarnings.forEach(warning => {\n warnings.push({\n type: 'other',\n message: warning,\n });\n });\n }\n\n try {\n const response = query({\n prompt: messagesPrompt,\n options: queryOptions,\n });\n\n for await (const message of response) {\n if (message.type === 'assistant') {\n text += message.message.content.map((c: { type: string; text?: string }) => \n c.type === 'text' ? c.text : ''\n ).join('');\n } else if (message.type === 'result') {\n this.setSessionId(message.session_id);\n costUsd = message.total_cost_usd;\n durationMs = message.duration_ms;\n \n if ('usage' in message) {\n rawUsage = message.usage;\n usage = {\n promptTokens: (message.usage.cache_creation_input_tokens ?? 0) + \n (message.usage.cache_read_input_tokens ?? 0) +\n (message.usage.input_tokens ?? 0),\n completionTokens: message.usage.output_tokens ?? 0,\n };\n }\n\n finishReason = mapClaudeCodeFinishReason(message.subtype);\n } else if (message.type === 'system' && message.subtype === 'init') {\n this.setSessionId(message.session_id);\n }\n }\n } catch (error: unknown) {\n // Special handling for AbortError to preserve abort signal reason\n if (error instanceof AbortError) {\n throw options.abortSignal?.aborted ? options.abortSignal.reason : error;\n }\n \n // Use unified error handler\n throw this.handleClaudeCodeError(error, messagesPrompt);\n } finally {\n if (options.abortSignal && abortListener) {\n options.abortSignal.removeEventListener('abort', abortListener);\n }\n }\n\n // Extract JSON if in object-json mode\n if (options.mode?.type === 'object-json' && text) {\n const extracted = extractJson(text);\n const validation = this.validateJsonExtraction(text, extracted);\n \n if (!validation.valid && validation.warning) {\n warnings.push(validation.warning);\n }\n \n text = extracted;\n }\n\n return {\n text: text || undefined,\n usage,\n finishReason,\n rawCall: {\n rawPrompt: messagesPrompt,\n rawSettings: queryOptions,\n },\n warnings: warnings.length > 0 ? warnings : undefined,\n response: {\n id: generateId(),\n timestamp: new Date(),\n modelId: this.modelId,\n },\n request: {\n body: messagesPrompt,\n },\n providerMetadata: {\n 'claude-code': {\n ...(this.sessionId !== undefined && { sessionId: this.sessionId }),\n ...(costUsd !== undefined && { costUsd }),\n ...(durationMs !== undefined && { durationMs }),\n ...(rawUsage !== undefined && { rawUsage: rawUsage as JSONValue }),\n },\n },\n };\n }\n\n async doStream(\n options: Parameters<LanguageModelV1['doStream']>[0],\n ): Promise<Awaited<ReturnType<LanguageModelV1['doStream']>>> {\n const { messagesPrompt, warnings: messageWarnings } = convertToClaudeCodeMessages(options.prompt, options.mode);\n\n const abortController = new AbortController();\n let abortListener: (() => void) | undefined;\n if (options.abortSignal) {\n abortListener = () => abortController.abort();\n options.abortSignal.addEventListener('abort', abortListener, { once: true });\n }\n\n const queryOptions = this.createQueryOptions(abortController);\n\n const warnings: LanguageModelV1CallWarning[] = this.generateAllWarnings(options, messagesPrompt);\n \n // Add warnings from message conversion\n if (messageWarnings) {\n messageWarnings.forEach(warning => {\n warnings.push({\n type: 'other',\n message: warning,\n });\n });\n }\n\n const stream = new ReadableStream<LanguageModelV1StreamPart>({\n start: async (controller) => {\n try {\n const response = query({\n prompt: messagesPrompt,\n options: queryOptions,\n });\n\n let usage = { promptTokens: 0, completionTokens: 0 };\n let accumulatedText = '';\n\n for await (const message of response) {\n if (message.type === 'assistant') {\n const text = message.message.content\n .map((c: { type: string; text?: string }) => (c.type === 'text' ? c.text : ''))\n .join('');\n \n if (text) {\n accumulatedText += text;\n \n // In object-json mode, we need to accumulate the full text\n // and extract JSON at the end, so don't stream individual deltas\n if (options.mode?.type !== 'object-json') {\n controller.enqueue({\n type: 'text-delta',\n textDelta: text,\n });\n }\n }\n } else if (message.type === 'result') {\n let rawUsage: unknown | undefined;\n if ('usage' in message) {\n rawUsage = message.usage;\n usage = {\n promptTokens: (message.usage.cache_creation_input_tokens ?? 0) + \n (message.usage.cache_read_input_tokens ?? 0) +\n (message.usage.input_tokens ?? 0),\n completionTokens: message.usage.output_tokens ?? 0,\n };\n }\n\n const finishReason: LanguageModelV1FinishReason = mapClaudeCodeFinishReason(message.subtype);\n\n // Store session ID in the model instance\n this.setSessionId(message.session_id);\n \n // In object-json mode, extract JSON and send the full text at once\n if (options.mode?.type === 'object-json' && accumulatedText) {\n const extractedJson = extractJson(accumulatedText);\n this.validateJsonExtraction(accumulatedText, extractedJson);\n \n // If validation failed, we should add a warning but we can't modify warnings array in stream\n // So we'll just send the extracted JSON anyway\n // In the future, we could emit a warning stream part if the SDK supports it\n \n controller.enqueue({\n type: 'text-delta',\n textDelta: extractedJson,\n });\n }\n \n controller.enqueue({\n type: 'finish',\n finishReason,\n usage,\n providerMetadata: {\n 'claude-code': {\n sessionId: message.session_id,\n ...(message.total_cost_usd !== undefined && { costUsd: message.total_cost_usd }),\n ...(message.duration_ms !== undefined && { durationMs: message.duration_ms }),\n ...(rawUsage !== undefined && { rawUsage: rawUsage as JSONValue }),\n },\n },\n });\n } else if (message.type === 'system' && message.subtype === 'init') {\n // Store session ID for future use\n this.setSessionId(message.session_id);\n \n // Emit response metadata when session is initialized\n controller.enqueue({\n type: 'response-metadata',\n id: message.session_id,\n timestamp: new Date(),\n modelId: this.modelId,\n });\n }\n }\n\n controller.close();\n } catch (error: unknown) {\n let errorToEmit: unknown;\n \n // Special handling for AbortError to preserve abort signal reason\n if (error instanceof AbortError) {\n errorToEmit = options.abortSignal?.aborted ? options.abortSignal.reason : error;\n } else {\n // Use unified error handler\n errorToEmit = this.handleClaudeCodeError(error, messagesPrompt);\n }\n \n // Emit error as a stream part\n controller.enqueue({\n type: 'error',\n error: errorToEmit,\n });\n \n controller.close();\n } finally {\n if (options.abortSignal && abortListener) {\n options.abortSignal.removeEventListener('abort', abortListener);\n }\n }\n },\n cancel: () => {\n if (options.abortSignal && abortListener) {\n options.abortSignal.removeEventListener('abort', abortListener);\n }\n },\n });\n\n return {\n stream,\n rawCall: {\n rawPrompt: messagesPrompt,\n rawSettings: queryOptions,\n },\n warnings: warnings.length > 0 ? warnings : undefined,\n request: {\n body: messagesPrompt,\n },\n };\n }\n}","import type { LanguageModelV1Prompt } from '@ai-sdk/provider';\n\n/**\n * Converts AI SDK prompt format to Claude Code CLI message format.\n * Handles system prompts, user messages, assistant responses, and tool interactions.\n * \n * @param prompt - The AI SDK prompt containing messages\n * @param mode - Optional mode for specialized output formats (e.g., JSON generation)\n * @returns An object containing the formatted message prompt and optional system prompt\n * \n * @example\n * ```typescript\n * const { messagesPrompt } = convertToClaudeCodeMessages(\n * [{ role: 'user', content: 'Hello!' }],\n * { type: 'regular' }\n * );\n * ```\n * \n * @remarks\n * - Image inputs are not supported and will be ignored with a warning\n * - Tool calls are simplified to \"[Tool calls made]\" notation\n * - In 'object-json' mode, explicit JSON instructions are appended\n */\nexport function convertToClaudeCodeMessages(\n prompt: LanguageModelV1Prompt,\n mode?: { type: 'regular' | 'object-json' | 'object-tool' }\n): {\n messagesPrompt: string;\n systemPrompt?: string;\n warnings?: string[];\n} {\n const messages: string[] = [];\n const warnings: string[] = [];\n let systemPrompt: string | undefined;\n\n for (const message of prompt) {\n switch (message.role) {\n case 'system':\n systemPrompt = message.content;\n break;\n \n case 'user':\n if (typeof message.content === 'string') {\n messages.push(message.content);\n } else {\n // Handle multi-part content\n const textParts = message.content\n .filter(part => part.type === 'text')\n .map(part => part.text)\n .join('\\n');\n \n if (textParts) {\n messages.push(textParts);\n }\n \n // Note: Image parts are not supported by Claude Code CLI\n const imageParts = message.content.filter(part => part.type === 'image');\n if (imageParts.length > 0) {\n warnings.push('Claude Code CLI does not support image inputs. Images will be ignored.');\n }\n }\n break;\n \n case 'assistant':\n if (typeof message.content === 'string') {\n messages.push(`Assistant: ${message.content}`);\n } else {\n const textParts = message.content\n .filter(part => part.type === 'text')\n .map(part => part.text)\n .join('\\n');\n \n if (textParts) {\n messages.push(`Assistant: ${textParts}`);\n }\n \n // Handle tool calls if present\n const toolCalls = message.content.filter(part => part.type === 'tool-call');\n if (toolCalls.length > 0) {\n // For now, we'll just note that tool calls were made\n messages.push(`Assistant: [Tool calls made]`);\n }\n }\n break;\n \n case 'tool':\n // Tool results could be included in the conversation\n messages.push(`Tool Result (${message.content[0].toolName}): ${JSON.stringify(message.content[0].result)}`);\n break;\n }\n }\n\n // For the SDK, we need to provide a single prompt string\n // Format the conversation history properly\n \n // Combine system prompt with messages\n let finalPrompt = '';\n \n // Add system prompt at the beginning if present\n if (systemPrompt) {\n finalPrompt = systemPrompt;\n }\n \n if (messages.length === 0) {\n return { messagesPrompt: finalPrompt, systemPrompt };\n }\n \n // Format messages\n const formattedMessages = [];\n for (let i = 0; i < messages.length; i++) {\n const msg = messages[i];\n // Check if this is a user or assistant message based on content\n if (msg.startsWith('Assistant:') || msg.startsWith('Tool Result')) {\n formattedMessages.push(msg);\n } else {\n // User messages\n formattedMessages.push(`Human: ${msg}`);\n }\n }\n \n // Combine system prompt with messages\n if (finalPrompt) {\n finalPrompt = finalPrompt + '\\n\\n' + formattedMessages.join('\\n\\n');\n } else {\n finalPrompt = formattedMessages.join('\\n\\n');\n }\n \n // For JSON mode, add explicit instruction to ensure JSON output\n if (mode?.type === 'object-json') {\n // Make the JSON instruction even more explicit\n finalPrompt = `${finalPrompt}\n\nCRITICAL INSTRUCTION: You MUST respond with ONLY valid JSON. Follow these rules EXACTLY:\n1. Start your response with an opening brace {\n2. End your response with a closing brace }\n3. Do NOT include any text before the opening brace\n4. Do NOT include any text after the closing brace\n5. Do NOT use markdown code blocks or backticks\n6. Do NOT include explanations or commentary\n7. The ENTIRE response must be valid JSON that can be parsed with JSON.parse()\n\nBegin your response with { and end with }`;\n }\n \n return {\n messagesPrompt: finalPrompt,\n systemPrompt,\n ...(warnings.length > 0 && { warnings }),\n };\n}","/**\n * Extract JSON from Claude's response using a tolerant parser.\n *\n * The function removes common wrappers such as markdown fences or variable\n * declarations and then attempts to parse the remaining text with\n * `jsonc-parser`. If valid JSON (or JSONC) can be parsed, it is returned as a\n * string via `JSON.stringify`. Otherwise the original text is returned.\n *\n * @param text - Raw text which may contain JSON\n * @returns A valid JSON string if extraction succeeds, otherwise the original text\n */\nimport { parse, type ParseError } from 'jsonc-parser';\n\nexport function extractJson(text: string): string {\n let content = text.trim();\n\n // Strip ```json or ``` fences\n const fenceMatch = /```(?:json)?\\s*([\\s\\S]*?)\\s*```/i.exec(content);\n if (fenceMatch) {\n content = fenceMatch[1];\n }\n\n // Strip variable declarations like `const foo =` or `let foo =`\n const varMatch = /^\\s*(?:const|let|var)\\s+\\w+\\s*=\\s*([\\s\\S]*)/i.exec(content);\n if (varMatch) {\n content = varMatch[1];\n // Remove trailing semicolon if present\n if (content.trim().endsWith(';')) {\n content = content.trim().slice(0, -1);\n }\n }\n\n // Find the first opening bracket\n const firstObj = content.indexOf('{');\n const firstArr = content.indexOf('[');\n if (firstObj === -1 && firstArr === -1) {\n return text;\n }\n const start = firstArr === -1 ? firstObj : firstObj === -1 ? firstArr : Math.min(firstObj, firstArr);\n content = content.slice(start);\n\n // Try to parse the entire string with jsonc-parser\n const tryParse = (value: string): string | undefined => {\n const errors: ParseError[] = [];\n try {\n const result = parse(value, errors, { allowTrailingComma: true });\n if (errors.length === 0) {\n return JSON.stringify(result, null, 2);\n }\n } catch {\n // ignore\n }\n return undefined;\n };\n\n const parsed = tryParse(content);\n if (parsed !== undefined) {\n return parsed;\n }\n\n // If parsing the full string failed, use a more efficient approach\n // to find valid JSON boundaries\n const openChar = content[0];\n const closeChar = openChar === '{' ? '}' : ']';\n \n // Find all potential closing positions by tracking nesting depth\n const closingPositions: number[] = [];\n let depth = 0;\n let inString = false;\n let escapeNext = false;\n \n for (let i = 0; i < content.length; i++) {\n const char = content[i];\n \n if (escapeNext) {\n escapeNext = false;\n continue;\n }\n \n if (char === '\\\\') {\n escapeNext = true;\n continue;\n }\n \n if (char === '\"' && !inString) {\n inString = true;\n continue;\n }\n \n if (char === '\"' && inString) {\n inString = false;\n continue;\n }\n \n // Skip content inside strings\n if (inString) continue;\n \n if (char === openChar) {\n depth++;\n } else if (char === closeChar) {\n depth--;\n if (depth === 0) {\n closingPositions.push(i + 1);\n }\n }\n }\n \n // Try parsing at each valid closing position, starting from the end\n for (let i = closingPositions.length - 1; i >= 0; i--) {\n const attempt = tryParse(content.slice(0, closingPositions[i]));\n if (attempt !== undefined) {\n return attempt;\n }\n }\n \n // As a final fallback, try the original character-by-character approach\n // but only for the last 1000 characters to limit performance impact\n const searchStart = Math.max(0, content.length - 1000);\n for (let end = content.length - 1; end > searchStart; end--) {\n const attempt = tryParse(content.slice(0, end));\n if (attempt !== undefined) {\n return attempt;\n }\n }\n\n return text;\n}","import { APICallError, LoadAPIKeyError } from '@ai-sdk/provider';\n\n/**\n * Metadata associated with Claude Code CLI errors.\n * Provides additional context about command execution failures.\n */\nexport interface ClaudeCodeErrorMetadata {\n /**\n * Error code from the CLI process (e.g., 'ENOENT', 'ETIMEDOUT').\n */\n code?: string;\n \n /**\n * Exit code from the Claude Code CLI process.\n * Common codes:\n * - 401: Authentication error\n * - 1: General error\n */\n exitCode?: number;\n \n /**\n * Standard error output from the CLI process.\n */\n stderr?: string;\n \n /**\n * Excerpt from the prompt that caused the error.\n * Limited to first 200 characters for debugging.\n */\n promptExcerpt?: string;\n}\n\n/**\n * Creates an APICallError with Claude Code specific metadata.\n * Used for general CLI execution errors.\n * \n * @param options - Error details and metadata\n * @param options.message - Human-readable error message\n * @param options.code - Error code from the CLI process\n * @param options.exitCode - Exit code from the CLI\n * @param options.stderr - Standard error output\n * @param options.promptExcerpt - Excerpt of the prompt that caused the error\n * @param options.isRetryable - Whether the error is potentially retryable\n * @returns An APICallError instance with Claude Code metadata\n * \n * @example\n * ```typescript\n * throw createAPICallError({\n * message: 'Claude Code CLI failed',\n * code: 'ENOENT',\n * isRetryable: true\n * });\n * ```\n */\nexport function createAPICallError({\n message,\n code,\n exitCode,\n stderr,\n promptExcerpt,\n isRetryable = false,\n}: ClaudeCodeErrorMetadata & {\n message: string;\n isRetryable?: boolean;\n}): APICallError {\n const metadata: ClaudeCodeErrorMetadata = {\n code,\n exitCode,\n stderr,\n promptExcerpt,\n };\n\n return new APICallError({\n message,\n isRetryable,\n url: 'claude-code-cli://command',\n requestBodyValues: promptExcerpt ? { prompt: promptExcerpt } : undefined,\n data: metadata,\n });\n}\n\n/**\n * Creates an authentication error for Claude Code CLI login failures.\n * \n * @param options - Error configuration\n * @param options.message - Error message describing the authentication failure\n * @returns A LoadAPIKeyError instance\n * \n * @example\n * ```typescript\n * throw createAuthenticationError({\n * message: 'Please run \"claude login\" to authenticate'\n * });\n * ```\n */\nexport function createAuthenticationError({\n message,\n}: {\n message: string;\n}): LoadAPIKeyError {\n return new LoadAPIKeyError({\n message: message || 'Authentication failed. Please ensure Claude Code CLI is properly authenticated.',\n });\n}\n\n/**\n * Creates a timeout error for Claude Code CLI operations.\n * \n * @param options - Timeout error details\n * @param options.message - Error message describing the timeout\n * @param options.promptExcerpt - Excerpt of the prompt that timed out\n * @param options.timeoutMs - Timeout duration in milliseconds\n * @returns An APICallError instance configured as a timeout error\n * \n * @example\n * ```typescript\n * throw createTimeoutError({\n * message: 'Request timed out after 2 minutes',\n * timeoutMs: 120000\n * });\n * ```\n */\nexport function createTimeoutError({\n message,\n promptExcerpt,\n timeoutMs,\n}: {\n message: string;\n promptExcerpt?: string;\n timeoutMs?: number;\n}): APICallError {\n // Store timeoutMs in metadata for potential use by error handlers\n const metadata: ClaudeCodeErrorMetadata = {\n code: 'TIMEOUT',\n promptExcerpt,\n };\n \n return new APICallError({\n message,\n isRetryable: true,\n url: 'claude-code-cli://command',\n requestBodyValues: promptExcerpt ? { prompt: promptExcerpt } : undefined,\n data: timeoutMs !== undefined ? { ...metadata, timeoutMs } : metadata,\n });\n}\n\n/**\n * Checks if an error is an authentication error.\n * Returns true for LoadAPIKeyError instances or APICallError with exit code 401.\n * \n * @param error - The error to check\n * @returns True if the error is an authentication error\n * \n * @example\n * ```typescript\n * try {\n * await model.generate(...);\n * } catch (error) {\n * if (isAuthenticationError(error)) {\n * console.log('Please authenticate with Claude Code CLI');\n * }\n * }\n * ```\n */\nexport function isAuthenticationError(error: unknown): boolean {\n if (error instanceof LoadAPIKeyError) return true;\n if (error instanceof APICallError && (error.data as ClaudeCodeErrorMetadata)?.exitCode === 401) return true;\n return false;\n}\n\n/**\n * Checks if an error is a timeout error.\n * Returns true for APICallError instances with code 'TIMEOUT'.\n * \n * @param error - The error to check\n * @returns True if the error is a timeout error\n * \n * @example\n * ```typescript\n * try {\n * await model.generate(...);\n * } catch (error) {\n * if (isTimeoutError(error)) {\n * console.log('Request timed out, consider retrying');\n * }\n * }\n * ```\n */\nexport function isTimeoutError(error: unknown): boolean {\n if (error instanceof APICallError && (error.data as ClaudeCodeErrorMetadata)?.code === 'TIMEOUT') return true;\n return false;\n}\n\n/**\n * Extracts Claude Code error metadata from an error object.\n * \n * @param error - The error to extract metadata from\n * @returns The error metadata if available, undefined otherwise\n * \n * @example\n * ```typescript\n * try {\n * await model.generate(...);\n * } catch (error) {\n * const metadata = getErrorMetadata(error);\n * if (metadata?.exitCode === 401) {\n * console.log('Authentication required');\n * }\n * }\n * ```\n */\nexport function getErrorMetadata(error: unknown): ClaudeCodeErrorMetadata | undefined {\n if (error instanceof APICallError && error.data) {\n return error.data as ClaudeCodeErrorMetadata;\n }\n return undefined;\n}","import type { LanguageModelV1FinishReason } from '@ai-sdk/provider';\n\n/**\n * Maps Claude Code CLI result subtypes to AI SDK finish reasons.\n * \n * @param subtype - The result subtype from Claude Code CLI\n * @returns The corresponding AI SDK finish reason\n * \n * @example\n * ```typescript\n * const finishReason = mapClaudeCodeFinishReason('error_max_turns');\n * // Returns: 'length'\n * ```\n * \n * @remarks\n * Mappings:\n * - 'success' -> 'stop' (normal completion)\n * - 'error_max_turns' -> 'length' (hit turn limit)\n * - 'error_during_execution' -> 'error' (execution error)\n * - default -> 'stop' (unknown subtypes treated as normal completion)\n */\nexport function mapClaudeCodeFinishReason(\n subtype?: string\n): LanguageModelV1FinishReason {\n switch (subtype) {\n case 'success':\n return 'stop';\n case 'error_max_turns':\n return 'length';\n case 'error_during_execution':\n return 'error';\n default:\n return 'stop';\n }\n}","import { z } from 'zod';\nimport { existsSync } from 'fs';\n\n/**\n * Validation schemas and utilities for Claude Code provider inputs.\n * Uses Zod for type-safe validation following AI SDK patterns.\n */\n\n/**\n * Schema for validating Claude Code settings.\n * Ensures all settings are within acceptable ranges and formats.\n */\nexport const claudeCodeSettingsSchema = z.object({\n pathToClaudeCodeExecutable: z.string().optional(),\n customSystemPrompt: z.string().optional(),\n appendSystemPrompt: z.string().optional(),\n maxTurns: z.number().int().min(1).max(100).optional(),\n maxThinkingTokens: z.number().int().positive().max(100000).optional(),\n cwd: z.string().refine(\n (val) => {\n // Skip directory validation in non-Node environments\n if (typeof process === 'undefined' || !process.versions?.node) {\n return true;\n }\n return !val || existsSync(val);\n },\n { message: \"Working directory must exist\" }\n ).optional(),\n executable: z.enum(['bun', 'deno', 'node']).optional(),\n executableArgs: z.array(z.string()).optional(),\n permissionMode: z.enum(['default', 'acceptEdits', 'bypassPermissions', 'plan']).optional(),\n permissionPromptToolName: z.string().optional(),\n continue: z.boolean().optional(),\n resume: z.string().optional(),\n allowedTools: z.array(z.string()).optional(),\n disallowedTools: z.array(z.string()).optional(),\n mcpServers: z.record(z.string(), z.union([\n // McpStdioServerConfig\n z.object({\n type: z.literal('stdio').optional(),\n command: z.string(),\n args: z.array(z.string()).optional(),\n env: z.record(z.string()).optional()\n }),\n // McpSSEServerConfig\n z.object({\n type: z.literal('sse'),\n url: z.string(),\n headers: z.record(z.string()).optional()\n })\n ])).optional(),\n verbose: z.boolean().optional(),\n logger: z.union([\n z.literal(false),\n z.object({\n warn: z.function().args(z.string()).returns(z.void()),\n error: z.function().args(z.string()).returns(z.void())\n })\n ]).optional(),\n}).strict();\n\n/**\n * Validates a model ID and returns warnings if needed.\n * \n * @param modelId - The model ID to validate\n * @returns Warning message if model is unknown, undefined otherwise\n */\nexport function validateModelId(modelId: string): string | undefined {\n const knownModels = ['opus', 'sonnet'];\n \n // Check for empty or whitespace-only\n if (!modelId || modelId.trim() === '') {\n throw new Error('Model ID cannot be empty');\n }\n \n // Warn about unknown models but allow them\n if (!knownModels.includes(modelId)) {\n return `Unknown model ID: '${modelId}'. Proceeding with custom model. Known models are: ${knownModels.join(', ')}`;\n }\n \n return undefined;\n}\n\n/**\n * Validates Claude Code settings and returns validation results.\n * \n * @param settings - The settings object to validate\n * @returns Object with validation results and any warnings\n */\nexport function validateSettings(settings: unknown): {\n valid: boolean;\n warnings: string[];\n errors: string[];\n} {\n const warnings: string[] = [];\n const errors: string[] = [];\n \n try {\n // Parse with Zod schema\n const result = claudeCodeSettingsSchema.safeParse(settings);\n \n if (!result.success) {\n // Extract user-friendly error messages\n result.error.errors.forEach(err => {\n const path = err.path.join('.');\n errors.push(`${path ? `${path}: ` : ''}${err.message}`);\n });\n return { valid: false, warnings, errors };\n }\n \n // Additional validation warnings\n const validSettings = result.data;\n \n // Warn about high turn limits\n if (validSettings.maxTurns && validSettings.maxTurns > 20) {\n warnings.push(`High maxTurns value (${validSettings.maxTurns}) may lead to long-running conversations`);\n }\n \n // Warn about very high thinking tokens\n if (validSettings.maxThinkingTokens && validSettings.maxThinkingTokens > 50000) {\n warnings.push(`Very high maxThinkingTokens (${validSettings.maxThinkingTokens}) may increase response time`);\n }\n \n // Check if both allowedTools and disallowedTools are specified\n if (validSettings.allowedTools && validSettings.disallowedTools) {\n warnings.push('Both allowedTools and disallowedTools are specified. Only allowedTools will be used.');\n }\n \n // Validate tool name format\n const validateToolNames = (tools: string[], type: string) => {\n tools.forEach(tool => {\n // Basic validation - tool names should be alphanumeric with optional specifiers\n if (!/^[a-zA-Z_][a-zA-Z0-9_]*(\\([^)]*\\))?$/.test(tool) && !tool.startsWith('mcp__')) {\n warnings.push(`Unusual ${type} tool name format: '${tool}'`);\n }\n });\n };\n \n if (validSettings.allowedTools) {\n validateToolNames(validSettings.allowedTools, 'allowed');\n }\n \n if (validSettings.disallowedTools) {\n validateToolNames(validSettings.disallowedTools, 'disallowed');\n }\n \n return { valid: true, warnings, errors };\n } catch (error) {\n errors.push(`Validation error: ${error instanceof Error ? error.message : String(error)}`);\n return { valid: false, warnings, errors };\n }\n}\n\n/**\n * Validates prompt length and format.\n * \n * @param prompt - The prompt to validate\n * @returns Warning message if prompt might cause issues\n */\nexport function validatePrompt(prompt: string): string | undefined {\n // Very long prompts might cause issues\n const MAX_PROMPT_LENGTH = 100000; // ~25k tokens\n \n if (prompt.length > MAX_PROMPT_LENGTH) {\n return `Very long prompt (${prompt.length} characters) may cause performance issues or timeouts`;\n }\n \n return undefined;\n}\n\n/**\n * Validates session ID format.\n * \n * @param sessionId - The session ID to validate\n * @returns Warning message if format is unusual\n */\nexport function validateSessionId(sessionId: string): string | undefined {\n // Session IDs from Claude Code are typically UUID-like\n // But we don't want to be too strict as format might change\n if (sessionId && !/^[a-zA-Z0-9-_]+$/.test(sessionId)) {\n return `Unusual session ID format. This may cause issues with session resumption.`;\n }\n \n return undefined;\n}","import type { Logger } from './types.js';\n\n/**\n * Default logger that uses console.\n */\nconst defaultLogger: Logger = {\n warn: (message: string) => console.warn(message),\n error: (message: string) => console.error(message),\n};\n\n/**\n * No-op logger that discards all messages.\n */\nconst noopLogger: Logger = {\n warn: () => {},\n error: () => {},\n};\n\n/**\n * Gets the appropriate logger based on configuration.\n * \n * @param logger - Logger configuration from settings\n * @returns The logger to use\n */\nexport function getLogger(logger: Logger | false | undefined): Logger {\n if (logger === false) {\n return noopLogger;\n }\n \n if (logger === undefined) {\n return defaultLogger;\n }\n \n return logger;\n}"],"mappings":"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","names":["import_provider","import_provider"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/claude-code-provider.ts","../src/claude-code-language-model.ts","../src/convert-to-claude-code-messages.ts","../src/extract-json.ts","../src/errors.ts","../src/map-claude-code-finish-reason.ts","../src/validation.ts","../src/logger.ts"],"sourcesContent":["/**\n * Provider exports for creating and configuring Claude Code instances.\n * @module claude-code\n */\n\n/**\n * Creates a new Claude Code provider instance and the default provider instance.\n * @see {@link createClaudeCode} for creating custom provider instances\n * @see {@link claudeCode} for the default provider instance\n */\nexport { createClaudeCode, claudeCode } from './claude-code-provider.js';\n\n/**\n * Type definitions for the Claude Code provider.\n * @see {@link ClaudeCodeProvider} for the provider interface\n * @see {@link ClaudeCodeProviderSettings} for provider configuration options\n */\nexport type { ClaudeCodeProvider, ClaudeCodeProviderSettings } from './claude-code-provider.js';\n\n/**\n * Language model implementation for Claude Code.\n * This class implements the AI SDK's LanguageModelV1 interface.\n */\nexport { ClaudeCodeLanguageModel } from './claude-code-language-model.js';\n\n/**\n * Type definitions for Claude Code language models.\n * @see {@link ClaudeCodeModelId} for supported model identifiers\n * @see {@link ClaudeCodeLanguageModelOptions} for model configuration options\n */\nexport type { ClaudeCodeModelId, ClaudeCodeLanguageModelOptions } from './claude-code-language-model.js';\n\n/**\n * Settings for configuring Claude Code behavior.\n * Includes options for customizing the CLI execution, permissions, and tool usage.\n */\nexport type { ClaudeCodeSettings, Logger } from './types.js';\n\n/**\n * Error handling utilities for Claude Code.\n * These functions help create and identify specific error types.\n * \n * @see {@link isAuthenticationError} to check for authentication failures\n * @see {@link isTimeoutError} to check for timeout errors\n * @see {@link getErrorMetadata} to extract error metadata\n * @see {@link createAPICallError} to create general API errors\n * @see {@link createAuthenticationError} to create authentication errors\n * @see {@link createTimeoutError} to create timeout errors\n */\nexport { \n isAuthenticationError, \n isTimeoutError, \n getErrorMetadata,\n createAPICallError,\n createAuthenticationError,\n createTimeoutError\n} from './errors.js';\n\n/**\n * Metadata associated with Claude Code errors.\n * Contains additional context about CLI execution failures.\n */\nexport type { ClaudeCodeErrorMetadata } from './errors.js';","import type { LanguageModelV1, ProviderV1 } from '@ai-sdk/provider';\nimport { NoSuchModelError } from '@ai-sdk/provider';\nimport { ClaudeCodeLanguageModel, type ClaudeCodeModelId } from './claude-code-language-model.js';\nimport type { ClaudeCodeSettings } from './types.js';\nimport { validateSettings } from './validation.js';\nimport { getLogger } from './logger.js';\n\n/**\n * Claude Code provider interface that extends the AI SDK's ProviderV1.\n * Provides methods to create language models for interacting with Claude via the CLI.\n * \n * @example\n * ```typescript\n * import { claudeCode } from 'ai-sdk-provider-claude-code';\n * \n * // Create a model instance\n * const model = claudeCode('opus');\n * \n * // Or use the explicit methods\n * const chatModel = claudeCode.chat('sonnet');\n * const languageModel = claudeCode.languageModel('opus', { maxTurns: 10 });\n * ```\n */\nexport interface ClaudeCodeProvider extends ProviderV1 {\n /**\n * Creates a language model instance for the specified model ID.\n * This is a shorthand for calling `languageModel()`.\n * \n * @param modelId - The Claude model to use ('opus' or 'sonnet')\n * @param settings - Optional settings to configure the model\n * @returns A language model instance\n */\n (modelId: ClaudeCodeModelId, settings?: ClaudeCodeSettings): LanguageModelV1;\n\n /**\n * Creates a language model instance for text generation.\n * \n * @param modelId - The Claude model to use ('opus' or 'sonnet')\n * @param settings - Optional settings to configure the model\n * @returns A language model instance\n */\n languageModel(\n modelId: ClaudeCodeModelId,\n settings?: ClaudeCodeSettings,\n ): LanguageModelV1;\n\n /**\n * Alias for `languageModel()` to maintain compatibility with AI SDK patterns.\n * \n * @param modelId - The Claude model to use ('opus' or 'sonnet')\n * @param settings - Optional settings to configure the model\n * @returns A language model instance\n */\n chat(\n modelId: ClaudeCodeModelId,\n settings?: ClaudeCodeSettings,\n ): LanguageModelV1;\n}\n\n/**\n * Configuration options for creating a Claude Code provider instance.\n * These settings will be applied as defaults to all models created by the provider.\n * \n * @example\n * ```typescript\n * const provider = createClaudeCode({\n * defaultSettings: {\n * maxTurns: 5,\n * cwd: '/path/to/project'\n * }\n * });\n * ```\n */\nexport interface ClaudeCodeProviderSettings {\n /**\n * Default settings to use for all models created by this provider.\n * Individual model settings will override these defaults.\n */\n defaultSettings?: ClaudeCodeSettings;\n}\n\n/**\n * Creates a Claude Code provider instance with the specified configuration.\n * The provider can be used to create language models for interacting with Claude 4 models.\n *\n * @param options - Provider configuration options\n * @returns Claude Code provider instance\n * \n * @example\n * ```typescript\n * const provider = createClaudeCode({\n * defaultSettings: {\n * permissionMode: 'bypassPermissions',\n * maxTurns: 10\n * }\n * });\n * \n * const model = provider('opus');\n * ```\n */\nexport function createClaudeCode(\n options: ClaudeCodeProviderSettings = {},\n): ClaudeCodeProvider {\n // Get logger from default settings if provided\n const logger = getLogger(options.defaultSettings?.logger);\n \n // Validate default settings if provided\n if (options.defaultSettings) {\n const validation = validateSettings(options.defaultSettings);\n if (!validation.valid) {\n throw new Error(`Invalid default settings: ${validation.errors.join(', ')}`);\n }\n if (validation.warnings.length > 0) {\n validation.warnings.forEach(warning => logger.warn(`Claude Code Provider: ${warning}`));\n }\n }\n\n const createModel = (\n modelId: ClaudeCodeModelId,\n settings: ClaudeCodeSettings = {},\n ): LanguageModelV1 => {\n const mergedSettings = {\n ...options.defaultSettings,\n ...settings,\n };\n \n // Validate merged settings\n const validation = validateSettings(mergedSettings);\n if (!validation.valid) {\n throw new Error(`Invalid settings: ${validation.errors.join(', ')}`);\n }\n \n return new ClaudeCodeLanguageModel({\n id: modelId,\n settings: mergedSettings,\n settingsValidationWarnings: validation.warnings,\n });\n };\n\n const provider = function (\n modelId: ClaudeCodeModelId,\n settings?: ClaudeCodeSettings,\n ) {\n if (new.target) {\n throw new Error(\n 'The Claude Code model function cannot be called with the new keyword.',\n );\n }\n\n return createModel(modelId, settings);\n };\n\n provider.languageModel = createModel;\n provider.chat = createModel; // Alias for languageModel\n\n // Add textEmbeddingModel method that throws NoSuchModelError\n provider.textEmbeddingModel = (modelId: string) => {\n throw new NoSuchModelError({\n modelId,\n modelType: 'textEmbeddingModel',\n });\n };\n\n return provider as ClaudeCodeProvider;\n}\n\n/**\n * Default Claude Code provider instance.\n * Pre-configured provider for quick usage without custom settings.\n * \n * @example\n * ```typescript\n * import { claudeCode } from 'ai-sdk-provider-claude-code';\n * import { generateText } from 'ai';\n * \n * const { text } = await generateText({\n * model: claudeCode('sonnet'),\n * prompt: 'Hello, Claude!'\n * });\n * ```\n */\nexport const claudeCode = createClaudeCode();","import type {\n LanguageModelV1,\n LanguageModelV1CallWarning,\n LanguageModelV1FinishReason,\n LanguageModelV1StreamPart,\n JSONValue,\n} from '@ai-sdk/provider';\nimport { NoSuchModelError, APICallError, LoadAPIKeyError } from '@ai-sdk/provider';\nimport { generateId } from '@ai-sdk/provider-utils';\nimport type { ClaudeCodeSettings, Logger } from './types.js';\nimport { convertToClaudeCodeMessages } from './convert-to-claude-code-messages.js';\nimport { extractJson } from './extract-json.js';\nimport { createAPICallError, createAuthenticationError, createTimeoutError } from './errors.js';\nimport { mapClaudeCodeFinishReason } from './map-claude-code-finish-reason.js';\nimport { validateModelId, validatePrompt, validateSessionId } from './validation.js';\nimport { getLogger } from './logger.js';\n\nimport { query, AbortError, type Options } from '@anthropic-ai/claude-code';\n\n/**\n * Options for creating a Claude Code language model instance.\n * \n * @example\n * ```typescript\n * const model = new ClaudeCodeLanguageModel({\n * id: 'opus',\n * settings: {\n * maxTurns: 10,\n * permissionMode: 'auto'\n * }\n * });\n * ```\n */\nexport interface ClaudeCodeLanguageModelOptions {\n /**\n * The model identifier to use.\n * Can be 'opus', 'sonnet', or a custom model string.\n */\n id: ClaudeCodeModelId;\n \n /**\n * Optional settings to configure the model behavior.\n */\n settings?: ClaudeCodeSettings;\n \n /**\n * Validation warnings from settings validation.\n * Used internally to pass warnings from provider.\n */\n settingsValidationWarnings?: string[];\n}\n\n/**\n * Supported Claude model identifiers.\n * - 'opus': Claude 4 Opus model (most capable)\n * - 'sonnet': Claude 4 Sonnet model (balanced performance)\n * - Custom string: Any other model identifier supported by the CLI\n * \n * @example\n * ```typescript\n * const opusModel = claudeCode('opus');\n * const sonnetModel = claudeCode('sonnet');\n * const customModel = claudeCode('claude-3-opus-20240229');\n * ```\n */\nexport type ClaudeCodeModelId = 'opus' | 'sonnet' | (string & {});\n\nconst modelMap: Record<string, string> = {\n 'opus': 'opus',\n 'sonnet': 'sonnet',\n};\n\n/**\n * Language model implementation for Claude Code SDK.\n * This class implements the AI SDK's LanguageModelV1 interface to provide\n * integration with Claude models through the Claude Code SDK.\n * \n * Features:\n * - Supports streaming and non-streaming generation\n * - Handles JSON object generation mode\n * - Manages CLI sessions for conversation continuity\n * - Provides detailed error handling and retry logic\n * \n * Limitations:\n * - Does not support image inputs\n * - Does not support structured outputs (tool mode)\n * - Some parameters like temperature and max tokens are not supported by the CLI\n * \n * @example\n * ```typescript\n * const model = new ClaudeCodeLanguageModel({\n * id: 'opus',\n * settings: { maxTurns: 5 }\n * });\n * \n * const result = await model.doGenerate({\n * prompt: [{ role: 'user', content: 'Hello!' }],\n * mode: { type: 'regular' }\n * });\n * ```\n */\nexport class ClaudeCodeLanguageModel implements LanguageModelV1 {\n readonly specificationVersion = 'v1' as const;\n readonly defaultObjectGenerationMode = 'json' as const;\n readonly supportsImageUrls = false;\n readonly supportsStructuredOutputs = false;\n\n readonly modelId: ClaudeCodeModelId;\n readonly settings: ClaudeCodeSettings;\n \n private sessionId?: string;\n private modelValidationWarning?: string;\n private settingsValidationWarnings: string[];\n private logger: Logger;\n\n constructor(options: ClaudeCodeLanguageModelOptions) {\n this.modelId = options.id;\n this.settings = options.settings ?? {};\n this.settingsValidationWarnings = options.settingsValidationWarnings ?? [];\n this.logger = getLogger(this.settings.logger);\n \n // Validate model ID format\n if (!this.modelId || typeof this.modelId !== 'string' || this.modelId.trim() === '') {\n throw new NoSuchModelError({\n modelId: this.modelId,\n modelType: 'languageModel',\n });\n }\n \n // Additional model ID validation\n this.modelValidationWarning = validateModelId(this.modelId);\n if (this.modelValidationWarning) {\n this.logger.warn(`Claude Code Model: ${this.modelValidationWarning}`);\n }\n }\n\n get provider(): string {\n return 'claude-code';\n }\n\n private getModel(): string {\n const mapped = modelMap[this.modelId];\n return mapped ?? this.modelId;\n }\n\n private generateAllWarnings(\n options: Parameters<LanguageModelV1['doGenerate']>[0] | Parameters<LanguageModelV1['doStream']>[0],\n prompt: string\n ): LanguageModelV1CallWarning[] {\n const warnings: LanguageModelV1CallWarning[] = [];\n const unsupportedParams: string[] = [];\n \n // Check for unsupported parameters\n if (options.temperature !== undefined) unsupportedParams.push('temperature');\n if (options.maxTokens !== undefined) unsupportedParams.push('maxTokens');\n if (options.topP !== undefined) unsupportedParams.push('topP');\n if (options.topK !== undefined) unsupportedParams.push('topK');\n if (options.presencePenalty !== undefined) unsupportedParams.push('presencePenalty');\n if (options.frequencyPenalty !== undefined) unsupportedParams.push('frequencyPenalty');\n if (options.stopSequences !== undefined && options.stopSequences.length > 0) unsupportedParams.push('stopSequences');\n if (options.seed !== undefined) unsupportedParams.push('seed');\n \n if (unsupportedParams.length > 0) {\n // Add a warning for each unsupported parameter\n for (const param of unsupportedParams) {\n warnings.push({\n type: 'unsupported-setting',\n setting: param as 'temperature' | 'maxTokens' | 'topP' | 'topK' | 'presencePenalty' | 'frequencyPenalty' | 'stopSequences' | 'seed',\n details: `Claude Code SDK does not support the ${param} parameter. It will be ignored.`,\n });\n }\n }\n \n // Add model validation warning if present\n if (this.modelValidationWarning) {\n warnings.push({\n type: 'other',\n message: this.modelValidationWarning,\n });\n }\n \n // Add settings validation warnings\n this.settingsValidationWarnings.forEach(warning => {\n warnings.push({\n type: 'other',\n message: warning,\n });\n });\n \n // Validate prompt\n const promptWarning = validatePrompt(prompt);\n if (promptWarning) {\n warnings.push({\n type: 'other',\n message: promptWarning,\n });\n }\n \n return warnings;\n }\n\n private createQueryOptions(abortController: AbortController): Options {\n return {\n model: this.getModel(),\n abortController,\n resume: this.settings.resume ?? this.sessionId,\n pathToClaudeCodeExecutable: this.settings.pathToClaudeCodeExecutable,\n customSystemPrompt: this.settings.customSystemPrompt,\n appendSystemPrompt: this.settings.appendSystemPrompt,\n maxTurns: this.settings.maxTurns,\n maxThinkingTokens: this.settings.maxThinkingTokens,\n cwd: this.settings.cwd,\n executable: this.settings.executable,\n executableArgs: this.settings.executableArgs,\n permissionMode: this.settings.permissionMode,\n permissionPromptToolName: this.settings.permissionPromptToolName,\n continue: this.settings.continue,\n allowedTools: this.settings.allowedTools,\n disallowedTools: this.settings.disallowedTools,\n mcpServers: this.settings.mcpServers,\n };\n }\n\n private handleClaudeCodeError(\n error: unknown,\n messagesPrompt: string\n ): APICallError | LoadAPIKeyError {\n // Handle AbortError from the SDK\n if (error instanceof AbortError) {\n // Return the abort reason if available, otherwise the error itself\n throw error;\n }\n\n // Type guard for error with properties\n const isErrorWithMessage = (err: unknown): err is { message?: string } => {\n return typeof err === 'object' && err !== null && 'message' in err;\n };\n\n const isErrorWithCode = (err: unknown): err is { code?: string; exitCode?: number; stderr?: string } => {\n return typeof err === 'object' && err !== null;\n };\n\n // Check for authentication errors with improved detection\n const authErrorPatterns = [\n 'not logged in',\n 'authentication',\n 'unauthorized',\n 'auth failed',\n 'please login',\n 'claude login'\n ];\n \n const errorMessage = isErrorWithMessage(error) && error.message \n ? error.message.toLowerCase() \n : '';\n \n const exitCode = isErrorWithCode(error) && typeof error.exitCode === 'number' \n ? error.exitCode \n : undefined;\n \n const isAuthError = authErrorPatterns.some(pattern => errorMessage.includes(pattern)) ||\n exitCode === 401;\n\n if (isAuthError) {\n return createAuthenticationError({\n message: isErrorWithMessage(error) && error.message \n ? error.message \n : 'Authentication failed. Please ensure Claude Code SDK is properly authenticated.',\n });\n }\n\n // Check for timeout errors\n const errorCode = isErrorWithCode(error) && typeof error.code === 'string' \n ? error.code \n : '';\n \n if (errorCode === 'ETIMEDOUT' || errorMessage.includes('timeout')) {\n return createTimeoutError({\n message: isErrorWithMessage(error) && error.message \n ? error.message \n : 'Request timed out',\n promptExcerpt: messagesPrompt.substring(0, 200),\n // Don't specify timeoutMs since we don't know the actual timeout value\n // It's controlled by the consumer via AbortSignal\n });\n }\n\n // Create general API call error with appropriate retry flag\n const isRetryable = errorCode === 'ENOENT' || \n errorCode === 'ECONNREFUSED' ||\n errorCode === 'ETIMEDOUT' ||\n errorCode === 'ECONNRESET';\n\n return createAPICallError({\n message: isErrorWithMessage(error) && error.message \n ? error.message \n : 'Claude Code SDK error',\n code: errorCode || undefined,\n exitCode: exitCode,\n stderr: isErrorWithCode(error) && typeof error.stderr === 'string' \n ? error.stderr \n : undefined,\n promptExcerpt: messagesPrompt.substring(0, 200),\n isRetryable,\n });\n }\n\n private setSessionId(sessionId: string): void {\n this.sessionId = sessionId;\n const warning = validateSessionId(sessionId);\n if (warning) {\n this.logger.warn(`Claude Code Session: ${warning}`);\n }\n }\n\n private validateJsonExtraction(\n originalText: string,\n extractedJson: string\n ): { valid: boolean; warning?: LanguageModelV1CallWarning } {\n // If the extracted JSON is the same as original, extraction likely failed\n if (extractedJson === originalText) {\n return {\n valid: false,\n warning: {\n type: 'other',\n message: 'JSON extraction from model response may be incomplete or modified. The model may not have returned valid JSON.',\n },\n };\n }\n\n // Try to parse the extracted JSON to validate it\n try {\n JSON.parse(extractedJson);\n return { valid: true };\n } catch {\n return {\n valid: false,\n warning: {\n type: 'other',\n message: 'JSON extraction resulted in invalid JSON. The response may be malformed.',\n },\n };\n }\n }\n\n async doGenerate(\n options: Parameters<LanguageModelV1['doGenerate']>[0],\n ): Promise<Awaited<ReturnType<LanguageModelV1['doGenerate']>>> {\n const { messagesPrompt, warnings: messageWarnings } = convertToClaudeCodeMessages(options.prompt, options.mode);\n\n const abortController = new AbortController();\n let abortListener: (() => void) | undefined;\n if (options.abortSignal) {\n abortListener = () => abortController.abort();\n options.abortSignal.addEventListener('abort', abortListener, { once: true });\n }\n\n const queryOptions = this.createQueryOptions(abortController);\n\n let text = '';\n let usage = { promptTokens: 0, completionTokens: 0 };\n let finishReason: LanguageModelV1FinishReason = 'stop';\n let costUsd: number | undefined;\n let durationMs: number | undefined;\n let rawUsage: unknown | undefined;\n const warnings: LanguageModelV1CallWarning[] = this.generateAllWarnings(options, messagesPrompt);\n \n // Add warnings from message conversion\n if (messageWarnings) {\n messageWarnings.forEach(warning => {\n warnings.push({\n type: 'other',\n message: warning,\n });\n });\n }\n\n try {\n const response = query({\n prompt: messagesPrompt,\n options: queryOptions,\n });\n\n for await (const message of response) {\n if (message.type === 'assistant') {\n text += message.message.content.map((c: { type: string; text?: string }) => \n c.type === 'text' ? c.text : ''\n ).join('');\n } else if (message.type === 'result') {\n this.setSessionId(message.session_id);\n costUsd = message.total_cost_usd;\n durationMs = message.duration_ms;\n \n if ('usage' in message) {\n rawUsage = message.usage;\n usage = {\n promptTokens: (message.usage.cache_creation_input_tokens ?? 0) + \n (message.usage.cache_read_input_tokens ?? 0) +\n (message.usage.input_tokens ?? 0),\n completionTokens: message.usage.output_tokens ?? 0,\n };\n }\n\n finishReason = mapClaudeCodeFinishReason(message.subtype);\n } else if (message.type === 'system' && message.subtype === 'init') {\n this.setSessionId(message.session_id);\n }\n }\n } catch (error: unknown) {\n // Special handling for AbortError to preserve abort signal reason\n if (error instanceof AbortError) {\n throw options.abortSignal?.aborted ? options.abortSignal.reason : error;\n }\n \n // Use unified error handler\n throw this.handleClaudeCodeError(error, messagesPrompt);\n } finally {\n if (options.abortSignal && abortListener) {\n options.abortSignal.removeEventListener('abort', abortListener);\n }\n }\n\n // Extract JSON if in object-json mode\n if (options.mode?.type === 'object-json' && text) {\n const extracted = extractJson(text);\n const validation = this.validateJsonExtraction(text, extracted);\n \n if (!validation.valid && validation.warning) {\n warnings.push(validation.warning);\n }\n \n text = extracted;\n }\n\n return {\n text: text || undefined,\n usage,\n finishReason,\n rawCall: {\n rawPrompt: messagesPrompt,\n rawSettings: queryOptions,\n },\n warnings: warnings.length > 0 ? warnings : undefined,\n response: {\n id: generateId(),\n timestamp: new Date(),\n modelId: this.modelId,\n },\n request: {\n body: messagesPrompt,\n },\n providerMetadata: {\n 'claude-code': {\n ...(this.sessionId !== undefined && { sessionId: this.sessionId }),\n ...(costUsd !== undefined && { costUsd }),\n ...(durationMs !== undefined && { durationMs }),\n ...(rawUsage !== undefined && { rawUsage: rawUsage as JSONValue }),\n },\n },\n };\n }\n\n async doStream(\n options: Parameters<LanguageModelV1['doStream']>[0],\n ): Promise<Awaited<ReturnType<LanguageModelV1['doStream']>>> {\n const { messagesPrompt, warnings: messageWarnings } = convertToClaudeCodeMessages(options.prompt, options.mode);\n\n const abortController = new AbortController();\n let abortListener: (() => void) | undefined;\n if (options.abortSignal) {\n abortListener = () => abortController.abort();\n options.abortSignal.addEventListener('abort', abortListener, { once: true });\n }\n\n const queryOptions = this.createQueryOptions(abortController);\n\n const warnings: LanguageModelV1CallWarning[] = this.generateAllWarnings(options, messagesPrompt);\n \n // Add warnings from message conversion\n if (messageWarnings) {\n messageWarnings.forEach(warning => {\n warnings.push({\n type: 'other',\n message: warning,\n });\n });\n }\n\n const stream = new ReadableStream<LanguageModelV1StreamPart>({\n start: async (controller) => {\n try {\n const response = query({\n prompt: messagesPrompt,\n options: queryOptions,\n });\n\n let usage = { promptTokens: 0, completionTokens: 0 };\n let accumulatedText = '';\n\n for await (const message of response) {\n if (message.type === 'assistant') {\n const text = message.message.content\n .map((c: { type: string; text?: string }) => (c.type === 'text' ? c.text : ''))\n .join('');\n \n if (text) {\n accumulatedText += text;\n \n // In object-json mode, we need to accumulate the full text\n // and extract JSON at the end, so don't stream individual deltas\n if (options.mode?.type !== 'object-json') {\n controller.enqueue({\n type: 'text-delta',\n textDelta: text,\n });\n }\n }\n } else if (message.type === 'result') {\n let rawUsage: unknown | undefined;\n if ('usage' in message) {\n rawUsage = message.usage;\n usage = {\n promptTokens: (message.usage.cache_creation_input_tokens ?? 0) + \n (message.usage.cache_read_input_tokens ?? 0) +\n (message.usage.input_tokens ?? 0),\n completionTokens: message.usage.output_tokens ?? 0,\n };\n }\n\n const finishReason: LanguageModelV1FinishReason = mapClaudeCodeFinishReason(message.subtype);\n\n // Store session ID in the model instance\n this.setSessionId(message.session_id);\n \n // In object-json mode, extract JSON and send the full text at once\n if (options.mode?.type === 'object-json' && accumulatedText) {\n const extractedJson = extractJson(accumulatedText);\n this.validateJsonExtraction(accumulatedText, extractedJson);\n \n // If validation failed, we should add a warning but we can't modify warnings array in stream\n // So we'll just send the extracted JSON anyway\n // In the future, we could emit a warning stream part if the SDK supports it\n \n controller.enqueue({\n type: 'text-delta',\n textDelta: extractedJson,\n });\n }\n \n controller.enqueue({\n type: 'finish',\n finishReason,\n usage,\n providerMetadata: {\n 'claude-code': {\n sessionId: message.session_id,\n ...(message.total_cost_usd !== undefined && { costUsd: message.total_cost_usd }),\n ...(message.duration_ms !== undefined && { durationMs: message.duration_ms }),\n ...(rawUsage !== undefined && { rawUsage: rawUsage as JSONValue }),\n },\n },\n });\n } else if (message.type === 'system' && message.subtype === 'init') {\n // Store session ID for future use\n this.setSessionId(message.session_id);\n \n // Emit response metadata when session is initialized\n controller.enqueue({\n type: 'response-metadata',\n id: message.session_id,\n timestamp: new Date(),\n modelId: this.modelId,\n });\n }\n }\n\n controller.close();\n } catch (error: unknown) {\n let errorToEmit: unknown;\n \n // Special handling for AbortError to preserve abort signal reason\n if (error instanceof AbortError) {\n errorToEmit = options.abortSignal?.aborted ? options.abortSignal.reason : error;\n } else {\n // Use unified error handler\n errorToEmit = this.handleClaudeCodeError(error, messagesPrompt);\n }\n \n // Emit error as a stream part\n controller.enqueue({\n type: 'error',\n error: errorToEmit,\n });\n \n controller.close();\n } finally {\n if (options.abortSignal && abortListener) {\n options.abortSignal.removeEventListener('abort', abortListener);\n }\n }\n },\n cancel: () => {\n if (options.abortSignal && abortListener) {\n options.abortSignal.removeEventListener('abort', abortListener);\n }\n },\n });\n\n return {\n stream,\n rawCall: {\n rawPrompt: messagesPrompt,\n rawSettings: queryOptions,\n },\n warnings: warnings.length > 0 ? warnings : undefined,\n request: {\n body: messagesPrompt,\n },\n };\n }\n}","import type { LanguageModelV1Prompt } from '@ai-sdk/provider';\n\n/**\n * Converts AI SDK prompt format to Claude Code SDK message format.\n * Handles system prompts, user messages, assistant responses, and tool interactions.\n * \n * @param prompt - The AI SDK prompt containing messages\n * @param mode - Optional mode for specialized output formats (e.g., JSON generation)\n * @returns An object containing the formatted message prompt and optional system prompt\n * \n * @example\n * ```typescript\n * const { messagesPrompt } = convertToClaudeCodeMessages(\n * [{ role: 'user', content: 'Hello!' }],\n * { type: 'regular' }\n * );\n * ```\n * \n * @remarks\n * - Image inputs are not supported and will be ignored with a warning\n * - Tool calls are simplified to \"[Tool calls made]\" notation\n * - In 'object-json' mode, explicit JSON instructions are appended\n */\nexport function convertToClaudeCodeMessages(\n prompt: LanguageModelV1Prompt,\n mode?: { type: 'regular' | 'object-json' | 'object-tool' }\n): {\n messagesPrompt: string;\n systemPrompt?: string;\n warnings?: string[];\n} {\n const messages: string[] = [];\n const warnings: string[] = [];\n let systemPrompt: string | undefined;\n\n for (const message of prompt) {\n switch (message.role) {\n case 'system':\n systemPrompt = message.content;\n break;\n \n case 'user':\n if (typeof message.content === 'string') {\n messages.push(message.content);\n } else {\n // Handle multi-part content\n const textParts = message.content\n .filter(part => part.type === 'text')\n .map(part => part.text)\n .join('\\n');\n \n if (textParts) {\n messages.push(textParts);\n }\n \n // Note: Image parts are not supported by Claude Code SDK\n const imageParts = message.content.filter(part => part.type === 'image');\n if (imageParts.length > 0) {\n warnings.push('Claude Code SDK does not support image inputs. Images will be ignored.');\n }\n }\n break;\n \n case 'assistant':\n if (typeof message.content === 'string') {\n messages.push(`Assistant: ${message.content}`);\n } else {\n const textParts = message.content\n .filter(part => part.type === 'text')\n .map(part => part.text)\n .join('\\n');\n \n if (textParts) {\n messages.push(`Assistant: ${textParts}`);\n }\n \n // Handle tool calls if present\n const toolCalls = message.content.filter(part => part.type === 'tool-call');\n if (toolCalls.length > 0) {\n // For now, we'll just note that tool calls were made\n messages.push(`Assistant: [Tool calls made]`);\n }\n }\n break;\n \n case 'tool':\n // Tool results could be included in the conversation\n messages.push(`Tool Result (${message.content[0].toolName}): ${JSON.stringify(message.content[0].result)}`);\n break;\n }\n }\n\n // For the SDK, we need to provide a single prompt string\n // Format the conversation history properly\n \n // Combine system prompt with messages\n let finalPrompt = '';\n \n // Add system prompt at the beginning if present\n if (systemPrompt) {\n finalPrompt = systemPrompt;\n }\n \n if (messages.length === 0) {\n return { messagesPrompt: finalPrompt, systemPrompt };\n }\n \n // Format messages\n const formattedMessages = [];\n for (let i = 0; i < messages.length; i++) {\n const msg = messages[i];\n // Check if this is a user or assistant message based on content\n if (msg.startsWith('Assistant:') || msg.startsWith('Tool Result')) {\n formattedMessages.push(msg);\n } else {\n // User messages\n formattedMessages.push(`Human: ${msg}`);\n }\n }\n \n // Combine system prompt with messages\n if (finalPrompt) {\n finalPrompt = finalPrompt + '\\n\\n' + formattedMessages.join('\\n\\n');\n } else {\n finalPrompt = formattedMessages.join('\\n\\n');\n }\n \n // For JSON mode, add explicit instruction to ensure JSON output\n if (mode?.type === 'object-json') {\n // Make the JSON instruction even more explicit\n finalPrompt = `${finalPrompt}\n\nCRITICAL INSTRUCTION: You MUST respond with ONLY valid JSON. Follow these rules EXACTLY:\n1. Start your response with an opening brace {\n2. End your response with a closing brace }\n3. Do NOT include any text before the opening brace\n4. Do NOT include any text after the closing brace\n5. Do NOT use markdown code blocks or backticks\n6. Do NOT include explanations or commentary\n7. The ENTIRE response must be valid JSON that can be parsed with JSON.parse()\n\nBegin your response with { and end with }`;\n }\n \n return {\n messagesPrompt: finalPrompt,\n systemPrompt,\n ...(warnings.length > 0 && { warnings }),\n };\n}","/**\n * Extract JSON from Claude's response using a tolerant parser.\n *\n * The function removes common wrappers such as markdown fences or variable\n * declarations and then attempts to parse the remaining text with\n * `jsonc-parser`. If valid JSON (or JSONC) can be parsed, it is returned as a\n * string via `JSON.stringify`. Otherwise the original text is returned.\n *\n * @param text - Raw text which may contain JSON\n * @returns A valid JSON string if extraction succeeds, otherwise the original text\n */\nimport { parse, type ParseError } from 'jsonc-parser';\n\nexport function extractJson(text: string): string {\n let content = text.trim();\n\n // Strip ```json or ``` fences\n const fenceMatch = /```(?:json)?\\s*([\\s\\S]*?)\\s*```/i.exec(content);\n if (fenceMatch) {\n content = fenceMatch[1];\n }\n\n // Strip variable declarations like `const foo =` or `let foo =`\n const varMatch = /^\\s*(?:const|let|var)\\s+\\w+\\s*=\\s*([\\s\\S]*)/i.exec(content);\n if (varMatch) {\n content = varMatch[1];\n // Remove trailing semicolon if present\n if (content.trim().endsWith(';')) {\n content = content.trim().slice(0, -1);\n }\n }\n\n // Find the first opening bracket\n const firstObj = content.indexOf('{');\n const firstArr = content.indexOf('[');\n if (firstObj === -1 && firstArr === -1) {\n return text;\n }\n const start = firstArr === -1 ? firstObj : firstObj === -1 ? firstArr : Math.min(firstObj, firstArr);\n content = content.slice(start);\n\n // Try to parse the entire string with jsonc-parser\n const tryParse = (value: string): string | undefined => {\n const errors: ParseError[] = [];\n try {\n const result = parse(value, errors, { allowTrailingComma: true });\n if (errors.length === 0) {\n return JSON.stringify(result, null, 2);\n }\n } catch {\n // ignore\n }\n return undefined;\n };\n\n const parsed = tryParse(content);\n if (parsed !== undefined) {\n return parsed;\n }\n\n // If parsing the full string failed, use a more efficient approach\n // to find valid JSON boundaries\n const openChar = content[0];\n const closeChar = openChar === '{' ? '}' : ']';\n \n // Find all potential closing positions by tracking nesting depth\n const closingPositions: number[] = [];\n let depth = 0;\n let inString = false;\n let escapeNext = false;\n \n for (let i = 0; i < content.length; i++) {\n const char = content[i];\n \n if (escapeNext) {\n escapeNext = false;\n continue;\n }\n \n if (char === '\\\\') {\n escapeNext = true;\n continue;\n }\n \n if (char === '\"' && !inString) {\n inString = true;\n continue;\n }\n \n if (char === '\"' && inString) {\n inString = false;\n continue;\n }\n \n // Skip content inside strings\n if (inString) continue;\n \n if (char === openChar) {\n depth++;\n } else if (char === closeChar) {\n depth--;\n if (depth === 0) {\n closingPositions.push(i + 1);\n }\n }\n }\n \n // Try parsing at each valid closing position, starting from the end\n for (let i = closingPositions.length - 1; i >= 0; i--) {\n const attempt = tryParse(content.slice(0, closingPositions[i]));\n if (attempt !== undefined) {\n return attempt;\n }\n }\n \n // As a final fallback, try the original character-by-character approach\n // but only for the last 1000 characters to limit performance impact\n const searchStart = Math.max(0, content.length - 1000);\n for (let end = content.length - 1; end > searchStart; end--) {\n const attempt = tryParse(content.slice(0, end));\n if (attempt !== undefined) {\n return attempt;\n }\n }\n\n return text;\n}","import { APICallError, LoadAPIKeyError } from '@ai-sdk/provider';\n\n/**\n * Metadata associated with Claude Code SDK errors.\n * Provides additional context about command execution failures.\n */\nexport interface ClaudeCodeErrorMetadata {\n /**\n * Error code from the CLI process (e.g., 'ENOENT', 'ETIMEDOUT').\n */\n code?: string;\n \n /**\n * Exit code from the Claude Code SDK process.\n * Common codes:\n * - 401: Authentication error\n * - 1: General error\n */\n exitCode?: number;\n \n /**\n * Standard error output from the CLI process.\n */\n stderr?: string;\n \n /**\n * Excerpt from the prompt that caused the error.\n * Limited to first 200 characters for debugging.\n */\n promptExcerpt?: string;\n}\n\n/**\n * Creates an APICallError with Claude Code specific metadata.\n * Used for general CLI execution errors.\n * \n * @param options - Error details and metadata\n * @param options.message - Human-readable error message\n * @param options.code - Error code from the CLI process\n * @param options.exitCode - Exit code from the CLI\n * @param options.stderr - Standard error output\n * @param options.promptExcerpt - Excerpt of the prompt that caused the error\n * @param options.isRetryable - Whether the error is potentially retryable\n * @returns An APICallError instance with Claude Code metadata\n * \n * @example\n * ```typescript\n * throw createAPICallError({\n * message: 'Claude Code SDK failed',\n * code: 'ENOENT',\n * isRetryable: true\n * });\n * ```\n */\nexport function createAPICallError({\n message,\n code,\n exitCode,\n stderr,\n promptExcerpt,\n isRetryable = false,\n}: ClaudeCodeErrorMetadata & {\n message: string;\n isRetryable?: boolean;\n}): APICallError {\n const metadata: ClaudeCodeErrorMetadata = {\n code,\n exitCode,\n stderr,\n promptExcerpt,\n };\n\n return new APICallError({\n message,\n isRetryable,\n url: 'claude-code-cli://command',\n requestBodyValues: promptExcerpt ? { prompt: promptExcerpt } : undefined,\n data: metadata,\n });\n}\n\n/**\n * Creates an authentication error for Claude Code SDK login failures.\n * \n * @param options - Error configuration\n * @param options.message - Error message describing the authentication failure\n * @returns A LoadAPIKeyError instance\n * \n * @example\n * ```typescript\n * throw createAuthenticationError({\n * message: 'Please run \"claude login\" to authenticate'\n * });\n * ```\n */\nexport function createAuthenticationError({\n message,\n}: {\n message: string;\n}): LoadAPIKeyError {\n return new LoadAPIKeyError({\n message: message || 'Authentication failed. Please ensure Claude Code SDK is properly authenticated.',\n });\n}\n\n/**\n * Creates a timeout error for Claude Code SDK operations.\n * \n * @param options - Timeout error details\n * @param options.message - Error message describing the timeout\n * @param options.promptExcerpt - Excerpt of the prompt that timed out\n * @param options.timeoutMs - Timeout duration in milliseconds\n * @returns An APICallError instance configured as a timeout error\n * \n * @example\n * ```typescript\n * throw createTimeoutError({\n * message: 'Request timed out after 2 minutes',\n * timeoutMs: 120000\n * });\n * ```\n */\nexport function createTimeoutError({\n message,\n promptExcerpt,\n timeoutMs,\n}: {\n message: string;\n promptExcerpt?: string;\n timeoutMs?: number;\n}): APICallError {\n // Store timeoutMs in metadata for potential use by error handlers\n const metadata: ClaudeCodeErrorMetadata = {\n code: 'TIMEOUT',\n promptExcerpt,\n };\n \n return new APICallError({\n message,\n isRetryable: true,\n url: 'claude-code-cli://command',\n requestBodyValues: promptExcerpt ? { prompt: promptExcerpt } : undefined,\n data: timeoutMs !== undefined ? { ...metadata, timeoutMs } : metadata,\n });\n}\n\n/**\n * Checks if an error is an authentication error.\n * Returns true for LoadAPIKeyError instances or APICallError with exit code 401.\n * \n * @param error - The error to check\n * @returns True if the error is an authentication error\n * \n * @example\n * ```typescript\n * try {\n * await model.generate(...);\n * } catch (error) {\n * if (isAuthenticationError(error)) {\n * console.log('Please authenticate with Claude Code SDK');\n * }\n * }\n * ```\n */\nexport function isAuthenticationError(error: unknown): boolean {\n if (error instanceof LoadAPIKeyError) return true;\n if (error instanceof APICallError && (error.data as ClaudeCodeErrorMetadata)?.exitCode === 401) return true;\n return false;\n}\n\n/**\n * Checks if an error is a timeout error.\n * Returns true for APICallError instances with code 'TIMEOUT'.\n * \n * @param error - The error to check\n * @returns True if the error is a timeout error\n * \n * @example\n * ```typescript\n * try {\n * await model.generate(...);\n * } catch (error) {\n * if (isTimeoutError(error)) {\n * console.log('Request timed out, consider retrying');\n * }\n * }\n * ```\n */\nexport function isTimeoutError(error: unknown): boolean {\n if (error instanceof APICallError && (error.data as ClaudeCodeErrorMetadata)?.code === 'TIMEOUT') return true;\n return false;\n}\n\n/**\n * Extracts Claude Code error metadata from an error object.\n * \n * @param error - The error to extract metadata from\n * @returns The error metadata if available, undefined otherwise\n * \n * @example\n * ```typescript\n * try {\n * await model.generate(...);\n * } catch (error) {\n * const metadata = getErrorMetadata(error);\n * if (metadata?.exitCode === 401) {\n * console.log('Authentication required');\n * }\n * }\n * ```\n */\nexport function getErrorMetadata(error: unknown): ClaudeCodeErrorMetadata | undefined {\n if (error instanceof APICallError && error.data) {\n return error.data as ClaudeCodeErrorMetadata;\n }\n return undefined;\n}","import type { LanguageModelV1FinishReason } from '@ai-sdk/provider';\n\n/**\n * Maps Claude Code SDK result subtypes to AI SDK finish reasons.\n * \n * @param subtype - The result subtype from Claude Code SDK\n * @returns The corresponding AI SDK finish reason\n * \n * @example\n * ```typescript\n * const finishReason = mapClaudeCodeFinishReason('error_max_turns');\n * // Returns: 'length'\n * ```\n * \n * @remarks\n * Mappings:\n * - 'success' -> 'stop' (normal completion)\n * - 'error_max_turns' -> 'length' (hit turn limit)\n * - 'error_during_execution' -> 'error' (execution error)\n * - default -> 'stop' (unknown subtypes treated as normal completion)\n */\nexport function mapClaudeCodeFinishReason(\n subtype?: string\n): LanguageModelV1FinishReason {\n switch (subtype) {\n case 'success':\n return 'stop';\n case 'error_max_turns':\n return 'length';\n case 'error_during_execution':\n return 'error';\n default:\n return 'stop';\n }\n}","import { z } from 'zod';\nimport { existsSync } from 'fs';\n\n/**\n * Validation schemas and utilities for Claude Code provider inputs.\n * Uses Zod for type-safe validation following AI SDK patterns.\n */\n\n/**\n * Schema for validating Claude Code settings.\n * Ensures all settings are within acceptable ranges and formats.\n */\nexport const claudeCodeSettingsSchema = z.object({\n pathToClaudeCodeExecutable: z.string().optional(),\n customSystemPrompt: z.string().optional(),\n appendSystemPrompt: z.string().optional(),\n maxTurns: z.number().int().min(1).max(100).optional(),\n maxThinkingTokens: z.number().int().positive().max(100000).optional(),\n cwd: z.string().refine(\n (val) => {\n // Skip directory validation in non-Node environments\n if (typeof process === 'undefined' || !process.versions?.node) {\n return true;\n }\n return !val || existsSync(val);\n },\n { message: \"Working directory must exist\" }\n ).optional(),\n executable: z.enum(['bun', 'deno', 'node']).optional(),\n executableArgs: z.array(z.string()).optional(),\n permissionMode: z.enum(['default', 'acceptEdits', 'bypassPermissions', 'plan']).optional(),\n permissionPromptToolName: z.string().optional(),\n continue: z.boolean().optional(),\n resume: z.string().optional(),\n allowedTools: z.array(z.string()).optional(),\n disallowedTools: z.array(z.string()).optional(),\n mcpServers: z.record(z.string(), z.union([\n // McpStdioServerConfig\n z.object({\n type: z.literal('stdio').optional(),\n command: z.string(),\n args: z.array(z.string()).optional(),\n env: z.record(z.string()).optional()\n }),\n // McpSSEServerConfig\n z.object({\n type: z.literal('sse'),\n url: z.string(),\n headers: z.record(z.string()).optional()\n })\n ])).optional(),\n verbose: z.boolean().optional(),\n logger: z.union([\n z.literal(false),\n z.object({\n warn: z.function().args(z.string()).returns(z.void()),\n error: z.function().args(z.string()).returns(z.void())\n })\n ]).optional(),\n}).strict();\n\n/**\n * Validates a model ID and returns warnings if needed.\n * \n * @param modelId - The model ID to validate\n * @returns Warning message if model is unknown, undefined otherwise\n */\nexport function validateModelId(modelId: string): string | undefined {\n const knownModels = ['opus', 'sonnet'];\n \n // Check for empty or whitespace-only\n if (!modelId || modelId.trim() === '') {\n throw new Error('Model ID cannot be empty');\n }\n \n // Warn about unknown models but allow them\n if (!knownModels.includes(modelId)) {\n return `Unknown model ID: '${modelId}'. Proceeding with custom model. Known models are: ${knownModels.join(', ')}`;\n }\n \n return undefined;\n}\n\n/**\n * Validates Claude Code settings and returns validation results.\n * \n * @param settings - The settings object to validate\n * @returns Object with validation results and any warnings\n */\nexport function validateSettings(settings: unknown): {\n valid: boolean;\n warnings: string[];\n errors: string[];\n} {\n const warnings: string[] = [];\n const errors: string[] = [];\n \n try {\n // Parse with Zod schema\n const result = claudeCodeSettingsSchema.safeParse(settings);\n \n if (!result.success) {\n // Extract user-friendly error messages\n result.error.errors.forEach(err => {\n const path = err.path.join('.');\n errors.push(`${path ? `${path}: ` : ''}${err.message}`);\n });\n return { valid: false, warnings, errors };\n }\n \n // Additional validation warnings\n const validSettings = result.data;\n \n // Warn about high turn limits\n if (validSettings.maxTurns && validSettings.maxTurns > 20) {\n warnings.push(`High maxTurns value (${validSettings.maxTurns}) may lead to long-running conversations`);\n }\n \n // Warn about very high thinking tokens\n if (validSettings.maxThinkingTokens && validSettings.maxThinkingTokens > 50000) {\n warnings.push(`Very high maxThinkingTokens (${validSettings.maxThinkingTokens}) may increase response time`);\n }\n \n // Check if both allowedTools and disallowedTools are specified\n if (validSettings.allowedTools && validSettings.disallowedTools) {\n warnings.push('Both allowedTools and disallowedTools are specified. Only allowedTools will be used.');\n }\n \n // Validate tool name format\n const validateToolNames = (tools: string[], type: string) => {\n tools.forEach(tool => {\n // Basic validation - tool names should be alphanumeric with optional specifiers\n if (!/^[a-zA-Z_][a-zA-Z0-9_]*(\\([^)]*\\))?$/.test(tool) && !tool.startsWith('mcp__')) {\n warnings.push(`Unusual ${type} tool name format: '${tool}'`);\n }\n });\n };\n \n if (validSettings.allowedTools) {\n validateToolNames(validSettings.allowedTools, 'allowed');\n }\n \n if (validSettings.disallowedTools) {\n validateToolNames(validSettings.disallowedTools, 'disallowed');\n }\n \n return { valid: true, warnings, errors };\n } catch (error) {\n errors.push(`Validation error: ${error instanceof Error ? error.message : String(error)}`);\n return { valid: false, warnings, errors };\n }\n}\n\n/**\n * Validates prompt length and format.\n * \n * @param prompt - The prompt to validate\n * @returns Warning message if prompt might cause issues\n */\nexport function validatePrompt(prompt: string): string | undefined {\n // Very long prompts might cause issues\n const MAX_PROMPT_LENGTH = 100000; // ~25k tokens\n \n if (prompt.length > MAX_PROMPT_LENGTH) {\n return `Very long prompt (${prompt.length} characters) may cause performance issues or timeouts`;\n }\n \n return undefined;\n}\n\n/**\n * Validates session ID format.\n * \n * @param sessionId - The session ID to validate\n * @returns Warning message if format is unusual\n */\nexport function validateSessionId(sessionId: string): string | undefined {\n // Session IDs from Claude Code are typically UUID-like\n // But we don't want to be too strict as format might change\n if (sessionId && !/^[a-zA-Z0-9-_]+$/.test(sessionId)) {\n return `Unusual session ID format. This may cause issues with session resumption.`;\n }\n \n return undefined;\n}","import type { Logger } from './types.js';\n\n/**\n * Default logger that uses console.\n */\nconst defaultLogger: Logger = {\n warn: (message: string) => console.warn(message),\n error: (message: string) => console.error(message),\n};\n\n/**\n * No-op logger that discards all messages.\n */\nconst noopLogger: Logger = {\n warn: () => {},\n error: () => {},\n};\n\n/**\n * Gets the appropriate logger based on configuration.\n * \n * @param logger - Logger configuration from settings\n * @returns The logger to use\n */\nexport function getLogger(logger: Logger | false | undefined): Logger {\n if (logger === false) {\n return noopLogger;\n }\n \n if (logger === undefined) {\n return defaultLogger;\n }\n \n return logger;\n}"],"mappings":"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","names":["import_provider","import_provider"]}
|
package/dist/index.d.cts
CHANGED
|
@@ -25,7 +25,7 @@ interface Logger {
|
|
|
25
25
|
error: (message: string) => void;
|
|
26
26
|
}
|
|
27
27
|
/**
|
|
28
|
-
* Configuration settings for Claude Code
|
|
28
|
+
* Configuration settings for Claude Code SDK behavior.
|
|
29
29
|
* These settings control how the CLI executes, what permissions it has,
|
|
30
30
|
* and which tools are available during conversations.
|
|
31
31
|
*
|
|
@@ -42,7 +42,7 @@ interface Logger {
|
|
|
42
42
|
*/
|
|
43
43
|
interface ClaudeCodeSettings {
|
|
44
44
|
/**
|
|
45
|
-
* Custom path to Claude Code
|
|
45
|
+
* Custom path to Claude Code SDK executable
|
|
46
46
|
* @default 'claude' (uses system PATH)
|
|
47
47
|
*/
|
|
48
48
|
pathToClaudeCodeExecutable?: string;
|
|
@@ -179,9 +179,9 @@ interface ClaudeCodeLanguageModelOptions {
|
|
|
179
179
|
*/
|
|
180
180
|
type ClaudeCodeModelId = 'opus' | 'sonnet' | (string & {});
|
|
181
181
|
/**
|
|
182
|
-
* Language model implementation for Claude Code
|
|
182
|
+
* Language model implementation for Claude Code SDK.
|
|
183
183
|
* This class implements the AI SDK's LanguageModelV1 interface to provide
|
|
184
|
-
* integration with Claude models through the Claude Code
|
|
184
|
+
* integration with Claude models through the Claude Code SDK.
|
|
185
185
|
*
|
|
186
186
|
* Features:
|
|
187
187
|
* - Supports streaming and non-streaming generation
|
|
@@ -332,7 +332,7 @@ declare function createClaudeCode(options?: ClaudeCodeProviderSettings): ClaudeC
|
|
|
332
332
|
declare const claudeCode: ClaudeCodeProvider;
|
|
333
333
|
|
|
334
334
|
/**
|
|
335
|
-
* Metadata associated with Claude Code
|
|
335
|
+
* Metadata associated with Claude Code SDK errors.
|
|
336
336
|
* Provides additional context about command execution failures.
|
|
337
337
|
*/
|
|
338
338
|
interface ClaudeCodeErrorMetadata {
|
|
@@ -341,7 +341,7 @@ interface ClaudeCodeErrorMetadata {
|
|
|
341
341
|
*/
|
|
342
342
|
code?: string;
|
|
343
343
|
/**
|
|
344
|
-
* Exit code from the Claude Code
|
|
344
|
+
* Exit code from the Claude Code SDK process.
|
|
345
345
|
* Common codes:
|
|
346
346
|
* - 401: Authentication error
|
|
347
347
|
* - 1: General error
|
|
@@ -373,7 +373,7 @@ interface ClaudeCodeErrorMetadata {
|
|
|
373
373
|
* @example
|
|
374
374
|
* ```typescript
|
|
375
375
|
* throw createAPICallError({
|
|
376
|
-
* message: 'Claude Code
|
|
376
|
+
* message: 'Claude Code SDK failed',
|
|
377
377
|
* code: 'ENOENT',
|
|
378
378
|
* isRetryable: true
|
|
379
379
|
* });
|
|
@@ -384,7 +384,7 @@ declare function createAPICallError({ message, code, exitCode, stderr, promptExc
|
|
|
384
384
|
isRetryable?: boolean;
|
|
385
385
|
}): APICallError;
|
|
386
386
|
/**
|
|
387
|
-
* Creates an authentication error for Claude Code
|
|
387
|
+
* Creates an authentication error for Claude Code SDK login failures.
|
|
388
388
|
*
|
|
389
389
|
* @param options - Error configuration
|
|
390
390
|
* @param options.message - Error message describing the authentication failure
|
|
@@ -401,7 +401,7 @@ declare function createAuthenticationError({ message, }: {
|
|
|
401
401
|
message: string;
|
|
402
402
|
}): LoadAPIKeyError;
|
|
403
403
|
/**
|
|
404
|
-
* Creates a timeout error for Claude Code
|
|
404
|
+
* Creates a timeout error for Claude Code SDK operations.
|
|
405
405
|
*
|
|
406
406
|
* @param options - Timeout error details
|
|
407
407
|
* @param options.message - Error message describing the timeout
|
|
@@ -435,7 +435,7 @@ declare function createTimeoutError({ message, promptExcerpt, timeoutMs, }: {
|
|
|
435
435
|
* await model.generate(...);
|
|
436
436
|
* } catch (error) {
|
|
437
437
|
* if (isAuthenticationError(error)) {
|
|
438
|
-
* console.log('Please authenticate with Claude Code
|
|
438
|
+
* console.log('Please authenticate with Claude Code SDK');
|
|
439
439
|
* }
|
|
440
440
|
* }
|
|
441
441
|
* ```
|
package/dist/index.d.ts
CHANGED
|
@@ -25,7 +25,7 @@ interface Logger {
|
|
|
25
25
|
error: (message: string) => void;
|
|
26
26
|
}
|
|
27
27
|
/**
|
|
28
|
-
* Configuration settings for Claude Code
|
|
28
|
+
* Configuration settings for Claude Code SDK behavior.
|
|
29
29
|
* These settings control how the CLI executes, what permissions it has,
|
|
30
30
|
* and which tools are available during conversations.
|
|
31
31
|
*
|
|
@@ -42,7 +42,7 @@ interface Logger {
|
|
|
42
42
|
*/
|
|
43
43
|
interface ClaudeCodeSettings {
|
|
44
44
|
/**
|
|
45
|
-
* Custom path to Claude Code
|
|
45
|
+
* Custom path to Claude Code SDK executable
|
|
46
46
|
* @default 'claude' (uses system PATH)
|
|
47
47
|
*/
|
|
48
48
|
pathToClaudeCodeExecutable?: string;
|
|
@@ -179,9 +179,9 @@ interface ClaudeCodeLanguageModelOptions {
|
|
|
179
179
|
*/
|
|
180
180
|
type ClaudeCodeModelId = 'opus' | 'sonnet' | (string & {});
|
|
181
181
|
/**
|
|
182
|
-
* Language model implementation for Claude Code
|
|
182
|
+
* Language model implementation for Claude Code SDK.
|
|
183
183
|
* This class implements the AI SDK's LanguageModelV1 interface to provide
|
|
184
|
-
* integration with Claude models through the Claude Code
|
|
184
|
+
* integration with Claude models through the Claude Code SDK.
|
|
185
185
|
*
|
|
186
186
|
* Features:
|
|
187
187
|
* - Supports streaming and non-streaming generation
|
|
@@ -332,7 +332,7 @@ declare function createClaudeCode(options?: ClaudeCodeProviderSettings): ClaudeC
|
|
|
332
332
|
declare const claudeCode: ClaudeCodeProvider;
|
|
333
333
|
|
|
334
334
|
/**
|
|
335
|
-
* Metadata associated with Claude Code
|
|
335
|
+
* Metadata associated with Claude Code SDK errors.
|
|
336
336
|
* Provides additional context about command execution failures.
|
|
337
337
|
*/
|
|
338
338
|
interface ClaudeCodeErrorMetadata {
|
|
@@ -341,7 +341,7 @@ interface ClaudeCodeErrorMetadata {
|
|
|
341
341
|
*/
|
|
342
342
|
code?: string;
|
|
343
343
|
/**
|
|
344
|
-
* Exit code from the Claude Code
|
|
344
|
+
* Exit code from the Claude Code SDK process.
|
|
345
345
|
* Common codes:
|
|
346
346
|
* - 401: Authentication error
|
|
347
347
|
* - 1: General error
|
|
@@ -373,7 +373,7 @@ interface ClaudeCodeErrorMetadata {
|
|
|
373
373
|
* @example
|
|
374
374
|
* ```typescript
|
|
375
375
|
* throw createAPICallError({
|
|
376
|
-
* message: 'Claude Code
|
|
376
|
+
* message: 'Claude Code SDK failed',
|
|
377
377
|
* code: 'ENOENT',
|
|
378
378
|
* isRetryable: true
|
|
379
379
|
* });
|
|
@@ -384,7 +384,7 @@ declare function createAPICallError({ message, code, exitCode, stderr, promptExc
|
|
|
384
384
|
isRetryable?: boolean;
|
|
385
385
|
}): APICallError;
|
|
386
386
|
/**
|
|
387
|
-
* Creates an authentication error for Claude Code
|
|
387
|
+
* Creates an authentication error for Claude Code SDK login failures.
|
|
388
388
|
*
|
|
389
389
|
* @param options - Error configuration
|
|
390
390
|
* @param options.message - Error message describing the authentication failure
|
|
@@ -401,7 +401,7 @@ declare function createAuthenticationError({ message, }: {
|
|
|
401
401
|
message: string;
|
|
402
402
|
}): LoadAPIKeyError;
|
|
403
403
|
/**
|
|
404
|
-
* Creates a timeout error for Claude Code
|
|
404
|
+
* Creates a timeout error for Claude Code SDK operations.
|
|
405
405
|
*
|
|
406
406
|
* @param options - Timeout error details
|
|
407
407
|
* @param options.message - Error message describing the timeout
|
|
@@ -435,7 +435,7 @@ declare function createTimeoutError({ message, promptExcerpt, timeoutMs, }: {
|
|
|
435
435
|
* await model.generate(...);
|
|
436
436
|
* } catch (error) {
|
|
437
437
|
* if (isAuthenticationError(error)) {
|
|
438
|
-
* console.log('Please authenticate with Claude Code
|
|
438
|
+
* console.log('Please authenticate with Claude Code SDK');
|
|
439
439
|
* }
|
|
440
440
|
* }
|
|
441
441
|
* ```
|
package/dist/index.js
CHANGED
|
@@ -25,7 +25,7 @@ function convertToClaudeCodeMessages(prompt, mode) {
|
|
|
25
25
|
}
|
|
26
26
|
const imageParts = message.content.filter((part) => part.type === "image");
|
|
27
27
|
if (imageParts.length > 0) {
|
|
28
|
-
warnings.push("Claude Code
|
|
28
|
+
warnings.push("Claude Code SDK does not support image inputs. Images will be ignored.");
|
|
29
29
|
}
|
|
30
30
|
}
|
|
31
31
|
break;
|
|
@@ -205,7 +205,7 @@ function createAuthenticationError({
|
|
|
205
205
|
message
|
|
206
206
|
}) {
|
|
207
207
|
return new LoadAPIKeyError({
|
|
208
|
-
message: message || "Authentication failed. Please ensure Claude Code
|
|
208
|
+
message: message || "Authentication failed. Please ensure Claude Code SDK is properly authenticated."
|
|
209
209
|
});
|
|
210
210
|
}
|
|
211
211
|
function createTimeoutError({
|
|
@@ -447,7 +447,7 @@ var ClaudeCodeLanguageModel = class {
|
|
|
447
447
|
warnings.push({
|
|
448
448
|
type: "unsupported-setting",
|
|
449
449
|
setting: param,
|
|
450
|
-
details: `Claude Code
|
|
450
|
+
details: `Claude Code SDK does not support the ${param} parameter. It will be ignored.`
|
|
451
451
|
});
|
|
452
452
|
}
|
|
453
453
|
}
|
|
@@ -516,7 +516,7 @@ var ClaudeCodeLanguageModel = class {
|
|
|
516
516
|
const isAuthError = authErrorPatterns.some((pattern) => errorMessage.includes(pattern)) || exitCode === 401;
|
|
517
517
|
if (isAuthError) {
|
|
518
518
|
return createAuthenticationError({
|
|
519
|
-
message: isErrorWithMessage(error) && error.message ? error.message : "Authentication failed. Please ensure Claude Code
|
|
519
|
+
message: isErrorWithMessage(error) && error.message ? error.message : "Authentication failed. Please ensure Claude Code SDK is properly authenticated."
|
|
520
520
|
});
|
|
521
521
|
}
|
|
522
522
|
const errorCode = isErrorWithCode(error) && typeof error.code === "string" ? error.code : "";
|
|
@@ -530,7 +530,7 @@ var ClaudeCodeLanguageModel = class {
|
|
|
530
530
|
}
|
|
531
531
|
const isRetryable = errorCode === "ENOENT" || errorCode === "ECONNREFUSED" || errorCode === "ETIMEDOUT" || errorCode === "ECONNRESET";
|
|
532
532
|
return createAPICallError({
|
|
533
|
-
message: isErrorWithMessage(error) && error.message ? error.message : "Claude Code
|
|
533
|
+
message: isErrorWithMessage(error) && error.message ? error.message : "Claude Code SDK error",
|
|
534
534
|
code: errorCode || void 0,
|
|
535
535
|
exitCode,
|
|
536
536
|
stderr: isErrorWithCode(error) && typeof error.stderr === "string" ? error.stderr : void 0,
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/claude-code-provider.ts","../src/claude-code-language-model.ts","../src/convert-to-claude-code-messages.ts","../src/extract-json.ts","../src/errors.ts","../src/map-claude-code-finish-reason.ts","../src/validation.ts","../src/logger.ts"],"sourcesContent":["import type { LanguageModelV1, ProviderV1 } from '@ai-sdk/provider';\nimport { NoSuchModelError } from '@ai-sdk/provider';\nimport { ClaudeCodeLanguageModel, type ClaudeCodeModelId } from './claude-code-language-model.js';\nimport type { ClaudeCodeSettings } from './types.js';\nimport { validateSettings } from './validation.js';\nimport { getLogger } from './logger.js';\n\n/**\n * Claude Code provider interface that extends the AI SDK's ProviderV1.\n * Provides methods to create language models for interacting with Claude via the CLI.\n * \n * @example\n * ```typescript\n * import { claudeCode } from 'ai-sdk-provider-claude-code';\n * \n * // Create a model instance\n * const model = claudeCode('opus');\n * \n * // Or use the explicit methods\n * const chatModel = claudeCode.chat('sonnet');\n * const languageModel = claudeCode.languageModel('opus', { maxTurns: 10 });\n * ```\n */\nexport interface ClaudeCodeProvider extends ProviderV1 {\n /**\n * Creates a language model instance for the specified model ID.\n * This is a shorthand for calling `languageModel()`.\n * \n * @param modelId - The Claude model to use ('opus' or 'sonnet')\n * @param settings - Optional settings to configure the model\n * @returns A language model instance\n */\n (modelId: ClaudeCodeModelId, settings?: ClaudeCodeSettings): LanguageModelV1;\n\n /**\n * Creates a language model instance for text generation.\n * \n * @param modelId - The Claude model to use ('opus' or 'sonnet')\n * @param settings - Optional settings to configure the model\n * @returns A language model instance\n */\n languageModel(\n modelId: ClaudeCodeModelId,\n settings?: ClaudeCodeSettings,\n ): LanguageModelV1;\n\n /**\n * Alias for `languageModel()` to maintain compatibility with AI SDK patterns.\n * \n * @param modelId - The Claude model to use ('opus' or 'sonnet')\n * @param settings - Optional settings to configure the model\n * @returns A language model instance\n */\n chat(\n modelId: ClaudeCodeModelId,\n settings?: ClaudeCodeSettings,\n ): LanguageModelV1;\n}\n\n/**\n * Configuration options for creating a Claude Code provider instance.\n * These settings will be applied as defaults to all models created by the provider.\n * \n * @example\n * ```typescript\n * const provider = createClaudeCode({\n * defaultSettings: {\n * maxTurns: 5,\n * cwd: '/path/to/project'\n * }\n * });\n * ```\n */\nexport interface ClaudeCodeProviderSettings {\n /**\n * Default settings to use for all models created by this provider.\n * Individual model settings will override these defaults.\n */\n defaultSettings?: ClaudeCodeSettings;\n}\n\n/**\n * Creates a Claude Code provider instance with the specified configuration.\n * The provider can be used to create language models for interacting with Claude 4 models.\n *\n * @param options - Provider configuration options\n * @returns Claude Code provider instance\n * \n * @example\n * ```typescript\n * const provider = createClaudeCode({\n * defaultSettings: {\n * permissionMode: 'bypassPermissions',\n * maxTurns: 10\n * }\n * });\n * \n * const model = provider('opus');\n * ```\n */\nexport function createClaudeCode(\n options: ClaudeCodeProviderSettings = {},\n): ClaudeCodeProvider {\n // Get logger from default settings if provided\n const logger = getLogger(options.defaultSettings?.logger);\n \n // Validate default settings if provided\n if (options.defaultSettings) {\n const validation = validateSettings(options.defaultSettings);\n if (!validation.valid) {\n throw new Error(`Invalid default settings: ${validation.errors.join(', ')}`);\n }\n if (validation.warnings.length > 0) {\n validation.warnings.forEach(warning => logger.warn(`Claude Code Provider: ${warning}`));\n }\n }\n\n const createModel = (\n modelId: ClaudeCodeModelId,\n settings: ClaudeCodeSettings = {},\n ): LanguageModelV1 => {\n const mergedSettings = {\n ...options.defaultSettings,\n ...settings,\n };\n \n // Validate merged settings\n const validation = validateSettings(mergedSettings);\n if (!validation.valid) {\n throw new Error(`Invalid settings: ${validation.errors.join(', ')}`);\n }\n \n return new ClaudeCodeLanguageModel({\n id: modelId,\n settings: mergedSettings,\n settingsValidationWarnings: validation.warnings,\n });\n };\n\n const provider = function (\n modelId: ClaudeCodeModelId,\n settings?: ClaudeCodeSettings,\n ) {\n if (new.target) {\n throw new Error(\n 'The Claude Code model function cannot be called with the new keyword.',\n );\n }\n\n return createModel(modelId, settings);\n };\n\n provider.languageModel = createModel;\n provider.chat = createModel; // Alias for languageModel\n\n // Add textEmbeddingModel method that throws NoSuchModelError\n provider.textEmbeddingModel = (modelId: string) => {\n throw new NoSuchModelError({\n modelId,\n modelType: 'textEmbeddingModel',\n });\n };\n\n return provider as ClaudeCodeProvider;\n}\n\n/**\n * Default Claude Code provider instance.\n * Pre-configured provider for quick usage without custom settings.\n * \n * @example\n * ```typescript\n * import { claudeCode } from 'ai-sdk-provider-claude-code';\n * import { generateText } from 'ai';\n * \n * const { text } = await generateText({\n * model: claudeCode('sonnet'),\n * prompt: 'Hello, Claude!'\n * });\n * ```\n */\nexport const claudeCode = createClaudeCode();","import type {\n LanguageModelV1,\n LanguageModelV1CallWarning,\n LanguageModelV1FinishReason,\n LanguageModelV1StreamPart,\n JSONValue,\n} from '@ai-sdk/provider';\nimport { NoSuchModelError, APICallError, LoadAPIKeyError } from '@ai-sdk/provider';\nimport { generateId } from '@ai-sdk/provider-utils';\nimport type { ClaudeCodeSettings, Logger } from './types.js';\nimport { convertToClaudeCodeMessages } from './convert-to-claude-code-messages.js';\nimport { extractJson } from './extract-json.js';\nimport { createAPICallError, createAuthenticationError, createTimeoutError } from './errors.js';\nimport { mapClaudeCodeFinishReason } from './map-claude-code-finish-reason.js';\nimport { validateModelId, validatePrompt, validateSessionId } from './validation.js';\nimport { getLogger } from './logger.js';\n\nimport { query, AbortError, type Options } from '@anthropic-ai/claude-code';\n\n/**\n * Options for creating a Claude Code language model instance.\n * \n * @example\n * ```typescript\n * const model = new ClaudeCodeLanguageModel({\n * id: 'opus',\n * settings: {\n * maxTurns: 10,\n * permissionMode: 'auto'\n * }\n * });\n * ```\n */\nexport interface ClaudeCodeLanguageModelOptions {\n /**\n * The model identifier to use.\n * Can be 'opus', 'sonnet', or a custom model string.\n */\n id: ClaudeCodeModelId;\n \n /**\n * Optional settings to configure the model behavior.\n */\n settings?: ClaudeCodeSettings;\n \n /**\n * Validation warnings from settings validation.\n * Used internally to pass warnings from provider.\n */\n settingsValidationWarnings?: string[];\n}\n\n/**\n * Supported Claude model identifiers.\n * - 'opus': Claude 4 Opus model (most capable)\n * - 'sonnet': Claude 4 Sonnet model (balanced performance)\n * - Custom string: Any other model identifier supported by the CLI\n * \n * @example\n * ```typescript\n * const opusModel = claudeCode('opus');\n * const sonnetModel = claudeCode('sonnet');\n * const customModel = claudeCode('claude-3-opus-20240229');\n * ```\n */\nexport type ClaudeCodeModelId = 'opus' | 'sonnet' | (string & {});\n\nconst modelMap: Record<string, string> = {\n 'opus': 'opus',\n 'sonnet': 'sonnet',\n};\n\n/**\n * Language model implementation for Claude Code CLI.\n * This class implements the AI SDK's LanguageModelV1 interface to provide\n * integration with Claude models through the Claude Code CLI.\n * \n * Features:\n * - Supports streaming and non-streaming generation\n * - Handles JSON object generation mode\n * - Manages CLI sessions for conversation continuity\n * - Provides detailed error handling and retry logic\n * \n * Limitations:\n * - Does not support image inputs\n * - Does not support structured outputs (tool mode)\n * - Some parameters like temperature and max tokens are not supported by the CLI\n * \n * @example\n * ```typescript\n * const model = new ClaudeCodeLanguageModel({\n * id: 'opus',\n * settings: { maxTurns: 5 }\n * });\n * \n * const result = await model.doGenerate({\n * prompt: [{ role: 'user', content: 'Hello!' }],\n * mode: { type: 'regular' }\n * });\n * ```\n */\nexport class ClaudeCodeLanguageModel implements LanguageModelV1 {\n readonly specificationVersion = 'v1' as const;\n readonly defaultObjectGenerationMode = 'json' as const;\n readonly supportsImageUrls = false;\n readonly supportsStructuredOutputs = false;\n\n readonly modelId: ClaudeCodeModelId;\n readonly settings: ClaudeCodeSettings;\n \n private sessionId?: string;\n private modelValidationWarning?: string;\n private settingsValidationWarnings: string[];\n private logger: Logger;\n\n constructor(options: ClaudeCodeLanguageModelOptions) {\n this.modelId = options.id;\n this.settings = options.settings ?? {};\n this.settingsValidationWarnings = options.settingsValidationWarnings ?? [];\n this.logger = getLogger(this.settings.logger);\n \n // Validate model ID format\n if (!this.modelId || typeof this.modelId !== 'string' || this.modelId.trim() === '') {\n throw new NoSuchModelError({\n modelId: this.modelId,\n modelType: 'languageModel',\n });\n }\n \n // Additional model ID validation\n this.modelValidationWarning = validateModelId(this.modelId);\n if (this.modelValidationWarning) {\n this.logger.warn(`Claude Code Model: ${this.modelValidationWarning}`);\n }\n }\n\n get provider(): string {\n return 'claude-code';\n }\n\n private getModel(): string {\n const mapped = modelMap[this.modelId];\n return mapped ?? this.modelId;\n }\n\n private generateAllWarnings(\n options: Parameters<LanguageModelV1['doGenerate']>[0] | Parameters<LanguageModelV1['doStream']>[0],\n prompt: string\n ): LanguageModelV1CallWarning[] {\n const warnings: LanguageModelV1CallWarning[] = [];\n const unsupportedParams: string[] = [];\n \n // Check for unsupported parameters\n if (options.temperature !== undefined) unsupportedParams.push('temperature');\n if (options.maxTokens !== undefined) unsupportedParams.push('maxTokens');\n if (options.topP !== undefined) unsupportedParams.push('topP');\n if (options.topK !== undefined) unsupportedParams.push('topK');\n if (options.presencePenalty !== undefined) unsupportedParams.push('presencePenalty');\n if (options.frequencyPenalty !== undefined) unsupportedParams.push('frequencyPenalty');\n if (options.stopSequences !== undefined && options.stopSequences.length > 0) unsupportedParams.push('stopSequences');\n if (options.seed !== undefined) unsupportedParams.push('seed');\n \n if (unsupportedParams.length > 0) {\n // Add a warning for each unsupported parameter\n for (const param of unsupportedParams) {\n warnings.push({\n type: 'unsupported-setting',\n setting: param as 'temperature' | 'maxTokens' | 'topP' | 'topK' | 'presencePenalty' | 'frequencyPenalty' | 'stopSequences' | 'seed',\n details: `Claude Code CLI does not support the ${param} parameter. It will be ignored.`,\n });\n }\n }\n \n // Add model validation warning if present\n if (this.modelValidationWarning) {\n warnings.push({\n type: 'other',\n message: this.modelValidationWarning,\n });\n }\n \n // Add settings validation warnings\n this.settingsValidationWarnings.forEach(warning => {\n warnings.push({\n type: 'other',\n message: warning,\n });\n });\n \n // Validate prompt\n const promptWarning = validatePrompt(prompt);\n if (promptWarning) {\n warnings.push({\n type: 'other',\n message: promptWarning,\n });\n }\n \n return warnings;\n }\n\n private createQueryOptions(abortController: AbortController): Options {\n return {\n model: this.getModel(),\n abortController,\n resume: this.settings.resume ?? this.sessionId,\n pathToClaudeCodeExecutable: this.settings.pathToClaudeCodeExecutable,\n customSystemPrompt: this.settings.customSystemPrompt,\n appendSystemPrompt: this.settings.appendSystemPrompt,\n maxTurns: this.settings.maxTurns,\n maxThinkingTokens: this.settings.maxThinkingTokens,\n cwd: this.settings.cwd,\n executable: this.settings.executable,\n executableArgs: this.settings.executableArgs,\n permissionMode: this.settings.permissionMode,\n permissionPromptToolName: this.settings.permissionPromptToolName,\n continue: this.settings.continue,\n allowedTools: this.settings.allowedTools,\n disallowedTools: this.settings.disallowedTools,\n mcpServers: this.settings.mcpServers,\n };\n }\n\n private handleClaudeCodeError(\n error: unknown,\n messagesPrompt: string\n ): APICallError | LoadAPIKeyError {\n // Handle AbortError from the SDK\n if (error instanceof AbortError) {\n // Return the abort reason if available, otherwise the error itself\n throw error;\n }\n\n // Type guard for error with properties\n const isErrorWithMessage = (err: unknown): err is { message?: string } => {\n return typeof err === 'object' && err !== null && 'message' in err;\n };\n\n const isErrorWithCode = (err: unknown): err is { code?: string; exitCode?: number; stderr?: string } => {\n return typeof err === 'object' && err !== null;\n };\n\n // Check for authentication errors with improved detection\n const authErrorPatterns = [\n 'not logged in',\n 'authentication',\n 'unauthorized',\n 'auth failed',\n 'please login',\n 'claude login'\n ];\n \n const errorMessage = isErrorWithMessage(error) && error.message \n ? error.message.toLowerCase() \n : '';\n \n const exitCode = isErrorWithCode(error) && typeof error.exitCode === 'number' \n ? error.exitCode \n : undefined;\n \n const isAuthError = authErrorPatterns.some(pattern => errorMessage.includes(pattern)) ||\n exitCode === 401;\n\n if (isAuthError) {\n return createAuthenticationError({\n message: isErrorWithMessage(error) && error.message \n ? error.message \n : 'Authentication failed. Please ensure Claude Code CLI is properly authenticated.',\n });\n }\n\n // Check for timeout errors\n const errorCode = isErrorWithCode(error) && typeof error.code === 'string' \n ? error.code \n : '';\n \n if (errorCode === 'ETIMEDOUT' || errorMessage.includes('timeout')) {\n return createTimeoutError({\n message: isErrorWithMessage(error) && error.message \n ? error.message \n : 'Request timed out',\n promptExcerpt: messagesPrompt.substring(0, 200),\n // Don't specify timeoutMs since we don't know the actual timeout value\n // It's controlled by the consumer via AbortSignal\n });\n }\n\n // Create general API call error with appropriate retry flag\n const isRetryable = errorCode === 'ENOENT' || \n errorCode === 'ECONNREFUSED' ||\n errorCode === 'ETIMEDOUT' ||\n errorCode === 'ECONNRESET';\n\n return createAPICallError({\n message: isErrorWithMessage(error) && error.message \n ? error.message \n : 'Claude Code CLI error',\n code: errorCode || undefined,\n exitCode: exitCode,\n stderr: isErrorWithCode(error) && typeof error.stderr === 'string' \n ? error.stderr \n : undefined,\n promptExcerpt: messagesPrompt.substring(0, 200),\n isRetryable,\n });\n }\n\n private setSessionId(sessionId: string): void {\n this.sessionId = sessionId;\n const warning = validateSessionId(sessionId);\n if (warning) {\n this.logger.warn(`Claude Code Session: ${warning}`);\n }\n }\n\n private validateJsonExtraction(\n originalText: string,\n extractedJson: string\n ): { valid: boolean; warning?: LanguageModelV1CallWarning } {\n // If the extracted JSON is the same as original, extraction likely failed\n if (extractedJson === originalText) {\n return {\n valid: false,\n warning: {\n type: 'other',\n message: 'JSON extraction from model response may be incomplete or modified. The model may not have returned valid JSON.',\n },\n };\n }\n\n // Try to parse the extracted JSON to validate it\n try {\n JSON.parse(extractedJson);\n return { valid: true };\n } catch {\n return {\n valid: false,\n warning: {\n type: 'other',\n message: 'JSON extraction resulted in invalid JSON. The response may be malformed.',\n },\n };\n }\n }\n\n async doGenerate(\n options: Parameters<LanguageModelV1['doGenerate']>[0],\n ): Promise<Awaited<ReturnType<LanguageModelV1['doGenerate']>>> {\n const { messagesPrompt, warnings: messageWarnings } = convertToClaudeCodeMessages(options.prompt, options.mode);\n\n const abortController = new AbortController();\n let abortListener: (() => void) | undefined;\n if (options.abortSignal) {\n abortListener = () => abortController.abort();\n options.abortSignal.addEventListener('abort', abortListener, { once: true });\n }\n\n const queryOptions = this.createQueryOptions(abortController);\n\n let text = '';\n let usage = { promptTokens: 0, completionTokens: 0 };\n let finishReason: LanguageModelV1FinishReason = 'stop';\n let costUsd: number | undefined;\n let durationMs: number | undefined;\n let rawUsage: unknown | undefined;\n const warnings: LanguageModelV1CallWarning[] = this.generateAllWarnings(options, messagesPrompt);\n \n // Add warnings from message conversion\n if (messageWarnings) {\n messageWarnings.forEach(warning => {\n warnings.push({\n type: 'other',\n message: warning,\n });\n });\n }\n\n try {\n const response = query({\n prompt: messagesPrompt,\n options: queryOptions,\n });\n\n for await (const message of response) {\n if (message.type === 'assistant') {\n text += message.message.content.map((c: { type: string; text?: string }) => \n c.type === 'text' ? c.text : ''\n ).join('');\n } else if (message.type === 'result') {\n this.setSessionId(message.session_id);\n costUsd = message.total_cost_usd;\n durationMs = message.duration_ms;\n \n if ('usage' in message) {\n rawUsage = message.usage;\n usage = {\n promptTokens: (message.usage.cache_creation_input_tokens ?? 0) + \n (message.usage.cache_read_input_tokens ?? 0) +\n (message.usage.input_tokens ?? 0),\n completionTokens: message.usage.output_tokens ?? 0,\n };\n }\n\n finishReason = mapClaudeCodeFinishReason(message.subtype);\n } else if (message.type === 'system' && message.subtype === 'init') {\n this.setSessionId(message.session_id);\n }\n }\n } catch (error: unknown) {\n // Special handling for AbortError to preserve abort signal reason\n if (error instanceof AbortError) {\n throw options.abortSignal?.aborted ? options.abortSignal.reason : error;\n }\n \n // Use unified error handler\n throw this.handleClaudeCodeError(error, messagesPrompt);\n } finally {\n if (options.abortSignal && abortListener) {\n options.abortSignal.removeEventListener('abort', abortListener);\n }\n }\n\n // Extract JSON if in object-json mode\n if (options.mode?.type === 'object-json' && text) {\n const extracted = extractJson(text);\n const validation = this.validateJsonExtraction(text, extracted);\n \n if (!validation.valid && validation.warning) {\n warnings.push(validation.warning);\n }\n \n text = extracted;\n }\n\n return {\n text: text || undefined,\n usage,\n finishReason,\n rawCall: {\n rawPrompt: messagesPrompt,\n rawSettings: queryOptions,\n },\n warnings: warnings.length > 0 ? warnings : undefined,\n response: {\n id: generateId(),\n timestamp: new Date(),\n modelId: this.modelId,\n },\n request: {\n body: messagesPrompt,\n },\n providerMetadata: {\n 'claude-code': {\n ...(this.sessionId !== undefined && { sessionId: this.sessionId }),\n ...(costUsd !== undefined && { costUsd }),\n ...(durationMs !== undefined && { durationMs }),\n ...(rawUsage !== undefined && { rawUsage: rawUsage as JSONValue }),\n },\n },\n };\n }\n\n async doStream(\n options: Parameters<LanguageModelV1['doStream']>[0],\n ): Promise<Awaited<ReturnType<LanguageModelV1['doStream']>>> {\n const { messagesPrompt, warnings: messageWarnings } = convertToClaudeCodeMessages(options.prompt, options.mode);\n\n const abortController = new AbortController();\n let abortListener: (() => void) | undefined;\n if (options.abortSignal) {\n abortListener = () => abortController.abort();\n options.abortSignal.addEventListener('abort', abortListener, { once: true });\n }\n\n const queryOptions = this.createQueryOptions(abortController);\n\n const warnings: LanguageModelV1CallWarning[] = this.generateAllWarnings(options, messagesPrompt);\n \n // Add warnings from message conversion\n if (messageWarnings) {\n messageWarnings.forEach(warning => {\n warnings.push({\n type: 'other',\n message: warning,\n });\n });\n }\n\n const stream = new ReadableStream<LanguageModelV1StreamPart>({\n start: async (controller) => {\n try {\n const response = query({\n prompt: messagesPrompt,\n options: queryOptions,\n });\n\n let usage = { promptTokens: 0, completionTokens: 0 };\n let accumulatedText = '';\n\n for await (const message of response) {\n if (message.type === 'assistant') {\n const text = message.message.content\n .map((c: { type: string; text?: string }) => (c.type === 'text' ? c.text : ''))\n .join('');\n \n if (text) {\n accumulatedText += text;\n \n // In object-json mode, we need to accumulate the full text\n // and extract JSON at the end, so don't stream individual deltas\n if (options.mode?.type !== 'object-json') {\n controller.enqueue({\n type: 'text-delta',\n textDelta: text,\n });\n }\n }\n } else if (message.type === 'result') {\n let rawUsage: unknown | undefined;\n if ('usage' in message) {\n rawUsage = message.usage;\n usage = {\n promptTokens: (message.usage.cache_creation_input_tokens ?? 0) + \n (message.usage.cache_read_input_tokens ?? 0) +\n (message.usage.input_tokens ?? 0),\n completionTokens: message.usage.output_tokens ?? 0,\n };\n }\n\n const finishReason: LanguageModelV1FinishReason = mapClaudeCodeFinishReason(message.subtype);\n\n // Store session ID in the model instance\n this.setSessionId(message.session_id);\n \n // In object-json mode, extract JSON and send the full text at once\n if (options.mode?.type === 'object-json' && accumulatedText) {\n const extractedJson = extractJson(accumulatedText);\n this.validateJsonExtraction(accumulatedText, extractedJson);\n \n // If validation failed, we should add a warning but we can't modify warnings array in stream\n // So we'll just send the extracted JSON anyway\n // In the future, we could emit a warning stream part if the SDK supports it\n \n controller.enqueue({\n type: 'text-delta',\n textDelta: extractedJson,\n });\n }\n \n controller.enqueue({\n type: 'finish',\n finishReason,\n usage,\n providerMetadata: {\n 'claude-code': {\n sessionId: message.session_id,\n ...(message.total_cost_usd !== undefined && { costUsd: message.total_cost_usd }),\n ...(message.duration_ms !== undefined && { durationMs: message.duration_ms }),\n ...(rawUsage !== undefined && { rawUsage: rawUsage as JSONValue }),\n },\n },\n });\n } else if (message.type === 'system' && message.subtype === 'init') {\n // Store session ID for future use\n this.setSessionId(message.session_id);\n \n // Emit response metadata when session is initialized\n controller.enqueue({\n type: 'response-metadata',\n id: message.session_id,\n timestamp: new Date(),\n modelId: this.modelId,\n });\n }\n }\n\n controller.close();\n } catch (error: unknown) {\n let errorToEmit: unknown;\n \n // Special handling for AbortError to preserve abort signal reason\n if (error instanceof AbortError) {\n errorToEmit = options.abortSignal?.aborted ? options.abortSignal.reason : error;\n } else {\n // Use unified error handler\n errorToEmit = this.handleClaudeCodeError(error, messagesPrompt);\n }\n \n // Emit error as a stream part\n controller.enqueue({\n type: 'error',\n error: errorToEmit,\n });\n \n controller.close();\n } finally {\n if (options.abortSignal && abortListener) {\n options.abortSignal.removeEventListener('abort', abortListener);\n }\n }\n },\n cancel: () => {\n if (options.abortSignal && abortListener) {\n options.abortSignal.removeEventListener('abort', abortListener);\n }\n },\n });\n\n return {\n stream,\n rawCall: {\n rawPrompt: messagesPrompt,\n rawSettings: queryOptions,\n },\n warnings: warnings.length > 0 ? warnings : undefined,\n request: {\n body: messagesPrompt,\n },\n };\n }\n}","import type { LanguageModelV1Prompt } from '@ai-sdk/provider';\n\n/**\n * Converts AI SDK prompt format to Claude Code CLI message format.\n * Handles system prompts, user messages, assistant responses, and tool interactions.\n * \n * @param prompt - The AI SDK prompt containing messages\n * @param mode - Optional mode for specialized output formats (e.g., JSON generation)\n * @returns An object containing the formatted message prompt and optional system prompt\n * \n * @example\n * ```typescript\n * const { messagesPrompt } = convertToClaudeCodeMessages(\n * [{ role: 'user', content: 'Hello!' }],\n * { type: 'regular' }\n * );\n * ```\n * \n * @remarks\n * - Image inputs are not supported and will be ignored with a warning\n * - Tool calls are simplified to \"[Tool calls made]\" notation\n * - In 'object-json' mode, explicit JSON instructions are appended\n */\nexport function convertToClaudeCodeMessages(\n prompt: LanguageModelV1Prompt,\n mode?: { type: 'regular' | 'object-json' | 'object-tool' }\n): {\n messagesPrompt: string;\n systemPrompt?: string;\n warnings?: string[];\n} {\n const messages: string[] = [];\n const warnings: string[] = [];\n let systemPrompt: string | undefined;\n\n for (const message of prompt) {\n switch (message.role) {\n case 'system':\n systemPrompt = message.content;\n break;\n \n case 'user':\n if (typeof message.content === 'string') {\n messages.push(message.content);\n } else {\n // Handle multi-part content\n const textParts = message.content\n .filter(part => part.type === 'text')\n .map(part => part.text)\n .join('\\n');\n \n if (textParts) {\n messages.push(textParts);\n }\n \n // Note: Image parts are not supported by Claude Code CLI\n const imageParts = message.content.filter(part => part.type === 'image');\n if (imageParts.length > 0) {\n warnings.push('Claude Code CLI does not support image inputs. Images will be ignored.');\n }\n }\n break;\n \n case 'assistant':\n if (typeof message.content === 'string') {\n messages.push(`Assistant: ${message.content}`);\n } else {\n const textParts = message.content\n .filter(part => part.type === 'text')\n .map(part => part.text)\n .join('\\n');\n \n if (textParts) {\n messages.push(`Assistant: ${textParts}`);\n }\n \n // Handle tool calls if present\n const toolCalls = message.content.filter(part => part.type === 'tool-call');\n if (toolCalls.length > 0) {\n // For now, we'll just note that tool calls were made\n messages.push(`Assistant: [Tool calls made]`);\n }\n }\n break;\n \n case 'tool':\n // Tool results could be included in the conversation\n messages.push(`Tool Result (${message.content[0].toolName}): ${JSON.stringify(message.content[0].result)}`);\n break;\n }\n }\n\n // For the SDK, we need to provide a single prompt string\n // Format the conversation history properly\n \n // Combine system prompt with messages\n let finalPrompt = '';\n \n // Add system prompt at the beginning if present\n if (systemPrompt) {\n finalPrompt = systemPrompt;\n }\n \n if (messages.length === 0) {\n return { messagesPrompt: finalPrompt, systemPrompt };\n }\n \n // Format messages\n const formattedMessages = [];\n for (let i = 0; i < messages.length; i++) {\n const msg = messages[i];\n // Check if this is a user or assistant message based on content\n if (msg.startsWith('Assistant:') || msg.startsWith('Tool Result')) {\n formattedMessages.push(msg);\n } else {\n // User messages\n formattedMessages.push(`Human: ${msg}`);\n }\n }\n \n // Combine system prompt with messages\n if (finalPrompt) {\n finalPrompt = finalPrompt + '\\n\\n' + formattedMessages.join('\\n\\n');\n } else {\n finalPrompt = formattedMessages.join('\\n\\n');\n }\n \n // For JSON mode, add explicit instruction to ensure JSON output\n if (mode?.type === 'object-json') {\n // Make the JSON instruction even more explicit\n finalPrompt = `${finalPrompt}\n\nCRITICAL INSTRUCTION: You MUST respond with ONLY valid JSON. Follow these rules EXACTLY:\n1. Start your response with an opening brace {\n2. End your response with a closing brace }\n3. Do NOT include any text before the opening brace\n4. Do NOT include any text after the closing brace\n5. Do NOT use markdown code blocks or backticks\n6. Do NOT include explanations or commentary\n7. The ENTIRE response must be valid JSON that can be parsed with JSON.parse()\n\nBegin your response with { and end with }`;\n }\n \n return {\n messagesPrompt: finalPrompt,\n systemPrompt,\n ...(warnings.length > 0 && { warnings }),\n };\n}","/**\n * Extract JSON from Claude's response using a tolerant parser.\n *\n * The function removes common wrappers such as markdown fences or variable\n * declarations and then attempts to parse the remaining text with\n * `jsonc-parser`. If valid JSON (or JSONC) can be parsed, it is returned as a\n * string via `JSON.stringify`. Otherwise the original text is returned.\n *\n * @param text - Raw text which may contain JSON\n * @returns A valid JSON string if extraction succeeds, otherwise the original text\n */\nimport { parse, type ParseError } from 'jsonc-parser';\n\nexport function extractJson(text: string): string {\n let content = text.trim();\n\n // Strip ```json or ``` fences\n const fenceMatch = /```(?:json)?\\s*([\\s\\S]*?)\\s*```/i.exec(content);\n if (fenceMatch) {\n content = fenceMatch[1];\n }\n\n // Strip variable declarations like `const foo =` or `let foo =`\n const varMatch = /^\\s*(?:const|let|var)\\s+\\w+\\s*=\\s*([\\s\\S]*)/i.exec(content);\n if (varMatch) {\n content = varMatch[1];\n // Remove trailing semicolon if present\n if (content.trim().endsWith(';')) {\n content = content.trim().slice(0, -1);\n }\n }\n\n // Find the first opening bracket\n const firstObj = content.indexOf('{');\n const firstArr = content.indexOf('[');\n if (firstObj === -1 && firstArr === -1) {\n return text;\n }\n const start = firstArr === -1 ? firstObj : firstObj === -1 ? firstArr : Math.min(firstObj, firstArr);\n content = content.slice(start);\n\n // Try to parse the entire string with jsonc-parser\n const tryParse = (value: string): string | undefined => {\n const errors: ParseError[] = [];\n try {\n const result = parse(value, errors, { allowTrailingComma: true });\n if (errors.length === 0) {\n return JSON.stringify(result, null, 2);\n }\n } catch {\n // ignore\n }\n return undefined;\n };\n\n const parsed = tryParse(content);\n if (parsed !== undefined) {\n return parsed;\n }\n\n // If parsing the full string failed, use a more efficient approach\n // to find valid JSON boundaries\n const openChar = content[0];\n const closeChar = openChar === '{' ? '}' : ']';\n \n // Find all potential closing positions by tracking nesting depth\n const closingPositions: number[] = [];\n let depth = 0;\n let inString = false;\n let escapeNext = false;\n \n for (let i = 0; i < content.length; i++) {\n const char = content[i];\n \n if (escapeNext) {\n escapeNext = false;\n continue;\n }\n \n if (char === '\\\\') {\n escapeNext = true;\n continue;\n }\n \n if (char === '\"' && !inString) {\n inString = true;\n continue;\n }\n \n if (char === '\"' && inString) {\n inString = false;\n continue;\n }\n \n // Skip content inside strings\n if (inString) continue;\n \n if (char === openChar) {\n depth++;\n } else if (char === closeChar) {\n depth--;\n if (depth === 0) {\n closingPositions.push(i + 1);\n }\n }\n }\n \n // Try parsing at each valid closing position, starting from the end\n for (let i = closingPositions.length - 1; i >= 0; i--) {\n const attempt = tryParse(content.slice(0, closingPositions[i]));\n if (attempt !== undefined) {\n return attempt;\n }\n }\n \n // As a final fallback, try the original character-by-character approach\n // but only for the last 1000 characters to limit performance impact\n const searchStart = Math.max(0, content.length - 1000);\n for (let end = content.length - 1; end > searchStart; end--) {\n const attempt = tryParse(content.slice(0, end));\n if (attempt !== undefined) {\n return attempt;\n }\n }\n\n return text;\n}","import { APICallError, LoadAPIKeyError } from '@ai-sdk/provider';\n\n/**\n * Metadata associated with Claude Code CLI errors.\n * Provides additional context about command execution failures.\n */\nexport interface ClaudeCodeErrorMetadata {\n /**\n * Error code from the CLI process (e.g., 'ENOENT', 'ETIMEDOUT').\n */\n code?: string;\n \n /**\n * Exit code from the Claude Code CLI process.\n * Common codes:\n * - 401: Authentication error\n * - 1: General error\n */\n exitCode?: number;\n \n /**\n * Standard error output from the CLI process.\n */\n stderr?: string;\n \n /**\n * Excerpt from the prompt that caused the error.\n * Limited to first 200 characters for debugging.\n */\n promptExcerpt?: string;\n}\n\n/**\n * Creates an APICallError with Claude Code specific metadata.\n * Used for general CLI execution errors.\n * \n * @param options - Error details and metadata\n * @param options.message - Human-readable error message\n * @param options.code - Error code from the CLI process\n * @param options.exitCode - Exit code from the CLI\n * @param options.stderr - Standard error output\n * @param options.promptExcerpt - Excerpt of the prompt that caused the error\n * @param options.isRetryable - Whether the error is potentially retryable\n * @returns An APICallError instance with Claude Code metadata\n * \n * @example\n * ```typescript\n * throw createAPICallError({\n * message: 'Claude Code CLI failed',\n * code: 'ENOENT',\n * isRetryable: true\n * });\n * ```\n */\nexport function createAPICallError({\n message,\n code,\n exitCode,\n stderr,\n promptExcerpt,\n isRetryable = false,\n}: ClaudeCodeErrorMetadata & {\n message: string;\n isRetryable?: boolean;\n}): APICallError {\n const metadata: ClaudeCodeErrorMetadata = {\n code,\n exitCode,\n stderr,\n promptExcerpt,\n };\n\n return new APICallError({\n message,\n isRetryable,\n url: 'claude-code-cli://command',\n requestBodyValues: promptExcerpt ? { prompt: promptExcerpt } : undefined,\n data: metadata,\n });\n}\n\n/**\n * Creates an authentication error for Claude Code CLI login failures.\n * \n * @param options - Error configuration\n * @param options.message - Error message describing the authentication failure\n * @returns A LoadAPIKeyError instance\n * \n * @example\n * ```typescript\n * throw createAuthenticationError({\n * message: 'Please run \"claude login\" to authenticate'\n * });\n * ```\n */\nexport function createAuthenticationError({\n message,\n}: {\n message: string;\n}): LoadAPIKeyError {\n return new LoadAPIKeyError({\n message: message || 'Authentication failed. Please ensure Claude Code CLI is properly authenticated.',\n });\n}\n\n/**\n * Creates a timeout error for Claude Code CLI operations.\n * \n * @param options - Timeout error details\n * @param options.message - Error message describing the timeout\n * @param options.promptExcerpt - Excerpt of the prompt that timed out\n * @param options.timeoutMs - Timeout duration in milliseconds\n * @returns An APICallError instance configured as a timeout error\n * \n * @example\n * ```typescript\n * throw createTimeoutError({\n * message: 'Request timed out after 2 minutes',\n * timeoutMs: 120000\n * });\n * ```\n */\nexport function createTimeoutError({\n message,\n promptExcerpt,\n timeoutMs,\n}: {\n message: string;\n promptExcerpt?: string;\n timeoutMs?: number;\n}): APICallError {\n // Store timeoutMs in metadata for potential use by error handlers\n const metadata: ClaudeCodeErrorMetadata = {\n code: 'TIMEOUT',\n promptExcerpt,\n };\n \n return new APICallError({\n message,\n isRetryable: true,\n url: 'claude-code-cli://command',\n requestBodyValues: promptExcerpt ? { prompt: promptExcerpt } : undefined,\n data: timeoutMs !== undefined ? { ...metadata, timeoutMs } : metadata,\n });\n}\n\n/**\n * Checks if an error is an authentication error.\n * Returns true for LoadAPIKeyError instances or APICallError with exit code 401.\n * \n * @param error - The error to check\n * @returns True if the error is an authentication error\n * \n * @example\n * ```typescript\n * try {\n * await model.generate(...);\n * } catch (error) {\n * if (isAuthenticationError(error)) {\n * console.log('Please authenticate with Claude Code CLI');\n * }\n * }\n * ```\n */\nexport function isAuthenticationError(error: unknown): boolean {\n if (error instanceof LoadAPIKeyError) return true;\n if (error instanceof APICallError && (error.data as ClaudeCodeErrorMetadata)?.exitCode === 401) return true;\n return false;\n}\n\n/**\n * Checks if an error is a timeout error.\n * Returns true for APICallError instances with code 'TIMEOUT'.\n * \n * @param error - The error to check\n * @returns True if the error is a timeout error\n * \n * @example\n * ```typescript\n * try {\n * await model.generate(...);\n * } catch (error) {\n * if (isTimeoutError(error)) {\n * console.log('Request timed out, consider retrying');\n * }\n * }\n * ```\n */\nexport function isTimeoutError(error: unknown): boolean {\n if (error instanceof APICallError && (error.data as ClaudeCodeErrorMetadata)?.code === 'TIMEOUT') return true;\n return false;\n}\n\n/**\n * Extracts Claude Code error metadata from an error object.\n * \n * @param error - The error to extract metadata from\n * @returns The error metadata if available, undefined otherwise\n * \n * @example\n * ```typescript\n * try {\n * await model.generate(...);\n * } catch (error) {\n * const metadata = getErrorMetadata(error);\n * if (metadata?.exitCode === 401) {\n * console.log('Authentication required');\n * }\n * }\n * ```\n */\nexport function getErrorMetadata(error: unknown): ClaudeCodeErrorMetadata | undefined {\n if (error instanceof APICallError && error.data) {\n return error.data as ClaudeCodeErrorMetadata;\n }\n return undefined;\n}","import type { LanguageModelV1FinishReason } from '@ai-sdk/provider';\n\n/**\n * Maps Claude Code CLI result subtypes to AI SDK finish reasons.\n * \n * @param subtype - The result subtype from Claude Code CLI\n * @returns The corresponding AI SDK finish reason\n * \n * @example\n * ```typescript\n * const finishReason = mapClaudeCodeFinishReason('error_max_turns');\n * // Returns: 'length'\n * ```\n * \n * @remarks\n * Mappings:\n * - 'success' -> 'stop' (normal completion)\n * - 'error_max_turns' -> 'length' (hit turn limit)\n * - 'error_during_execution' -> 'error' (execution error)\n * - default -> 'stop' (unknown subtypes treated as normal completion)\n */\nexport function mapClaudeCodeFinishReason(\n subtype?: string\n): LanguageModelV1FinishReason {\n switch (subtype) {\n case 'success':\n return 'stop';\n case 'error_max_turns':\n return 'length';\n case 'error_during_execution':\n return 'error';\n default:\n return 'stop';\n }\n}","import { z } from 'zod';\nimport { existsSync } from 'fs';\n\n/**\n * Validation schemas and utilities for Claude Code provider inputs.\n * Uses Zod for type-safe validation following AI SDK patterns.\n */\n\n/**\n * Schema for validating Claude Code settings.\n * Ensures all settings are within acceptable ranges and formats.\n */\nexport const claudeCodeSettingsSchema = z.object({\n pathToClaudeCodeExecutable: z.string().optional(),\n customSystemPrompt: z.string().optional(),\n appendSystemPrompt: z.string().optional(),\n maxTurns: z.number().int().min(1).max(100).optional(),\n maxThinkingTokens: z.number().int().positive().max(100000).optional(),\n cwd: z.string().refine(\n (val) => {\n // Skip directory validation in non-Node environments\n if (typeof process === 'undefined' || !process.versions?.node) {\n return true;\n }\n return !val || existsSync(val);\n },\n { message: \"Working directory must exist\" }\n ).optional(),\n executable: z.enum(['bun', 'deno', 'node']).optional(),\n executableArgs: z.array(z.string()).optional(),\n permissionMode: z.enum(['default', 'acceptEdits', 'bypassPermissions', 'plan']).optional(),\n permissionPromptToolName: z.string().optional(),\n continue: z.boolean().optional(),\n resume: z.string().optional(),\n allowedTools: z.array(z.string()).optional(),\n disallowedTools: z.array(z.string()).optional(),\n mcpServers: z.record(z.string(), z.union([\n // McpStdioServerConfig\n z.object({\n type: z.literal('stdio').optional(),\n command: z.string(),\n args: z.array(z.string()).optional(),\n env: z.record(z.string()).optional()\n }),\n // McpSSEServerConfig\n z.object({\n type: z.literal('sse'),\n url: z.string(),\n headers: z.record(z.string()).optional()\n })\n ])).optional(),\n verbose: z.boolean().optional(),\n logger: z.union([\n z.literal(false),\n z.object({\n warn: z.function().args(z.string()).returns(z.void()),\n error: z.function().args(z.string()).returns(z.void())\n })\n ]).optional(),\n}).strict();\n\n/**\n * Validates a model ID and returns warnings if needed.\n * \n * @param modelId - The model ID to validate\n * @returns Warning message if model is unknown, undefined otherwise\n */\nexport function validateModelId(modelId: string): string | undefined {\n const knownModels = ['opus', 'sonnet'];\n \n // Check for empty or whitespace-only\n if (!modelId || modelId.trim() === '') {\n throw new Error('Model ID cannot be empty');\n }\n \n // Warn about unknown models but allow them\n if (!knownModels.includes(modelId)) {\n return `Unknown model ID: '${modelId}'. Proceeding with custom model. Known models are: ${knownModels.join(', ')}`;\n }\n \n return undefined;\n}\n\n/**\n * Validates Claude Code settings and returns validation results.\n * \n * @param settings - The settings object to validate\n * @returns Object with validation results and any warnings\n */\nexport function validateSettings(settings: unknown): {\n valid: boolean;\n warnings: string[];\n errors: string[];\n} {\n const warnings: string[] = [];\n const errors: string[] = [];\n \n try {\n // Parse with Zod schema\n const result = claudeCodeSettingsSchema.safeParse(settings);\n \n if (!result.success) {\n // Extract user-friendly error messages\n result.error.errors.forEach(err => {\n const path = err.path.join('.');\n errors.push(`${path ? `${path}: ` : ''}${err.message}`);\n });\n return { valid: false, warnings, errors };\n }\n \n // Additional validation warnings\n const validSettings = result.data;\n \n // Warn about high turn limits\n if (validSettings.maxTurns && validSettings.maxTurns > 20) {\n warnings.push(`High maxTurns value (${validSettings.maxTurns}) may lead to long-running conversations`);\n }\n \n // Warn about very high thinking tokens\n if (validSettings.maxThinkingTokens && validSettings.maxThinkingTokens > 50000) {\n warnings.push(`Very high maxThinkingTokens (${validSettings.maxThinkingTokens}) may increase response time`);\n }\n \n // Check if both allowedTools and disallowedTools are specified\n if (validSettings.allowedTools && validSettings.disallowedTools) {\n warnings.push('Both allowedTools and disallowedTools are specified. Only allowedTools will be used.');\n }\n \n // Validate tool name format\n const validateToolNames = (tools: string[], type: string) => {\n tools.forEach(tool => {\n // Basic validation - tool names should be alphanumeric with optional specifiers\n if (!/^[a-zA-Z_][a-zA-Z0-9_]*(\\([^)]*\\))?$/.test(tool) && !tool.startsWith('mcp__')) {\n warnings.push(`Unusual ${type} tool name format: '${tool}'`);\n }\n });\n };\n \n if (validSettings.allowedTools) {\n validateToolNames(validSettings.allowedTools, 'allowed');\n }\n \n if (validSettings.disallowedTools) {\n validateToolNames(validSettings.disallowedTools, 'disallowed');\n }\n \n return { valid: true, warnings, errors };\n } catch (error) {\n errors.push(`Validation error: ${error instanceof Error ? error.message : String(error)}`);\n return { valid: false, warnings, errors };\n }\n}\n\n/**\n * Validates prompt length and format.\n * \n * @param prompt - The prompt to validate\n * @returns Warning message if prompt might cause issues\n */\nexport function validatePrompt(prompt: string): string | undefined {\n // Very long prompts might cause issues\n const MAX_PROMPT_LENGTH = 100000; // ~25k tokens\n \n if (prompt.length > MAX_PROMPT_LENGTH) {\n return `Very long prompt (${prompt.length} characters) may cause performance issues or timeouts`;\n }\n \n return undefined;\n}\n\n/**\n * Validates session ID format.\n * \n * @param sessionId - The session ID to validate\n * @returns Warning message if format is unusual\n */\nexport function validateSessionId(sessionId: string): string | undefined {\n // Session IDs from Claude Code are typically UUID-like\n // But we don't want to be too strict as format might change\n if (sessionId && !/^[a-zA-Z0-9-_]+$/.test(sessionId)) {\n return `Unusual session ID format. This may cause issues with session resumption.`;\n }\n \n return undefined;\n}","import type { Logger } from './types.js';\n\n/**\n * Default logger that uses console.\n */\nconst defaultLogger: Logger = {\n warn: (message: string) => console.warn(message),\n error: (message: string) => console.error(message),\n};\n\n/**\n * No-op logger that discards all messages.\n */\nconst noopLogger: Logger = {\n warn: () => {},\n error: () => {},\n};\n\n/**\n * Gets the appropriate logger based on configuration.\n * \n * @param logger - Logger configuration from settings\n * @returns The logger to use\n */\nexport function getLogger(logger: Logger | false | undefined): Logger {\n if (logger === false) {\n return noopLogger;\n }\n \n if (logger === undefined) {\n return defaultLogger;\n }\n \n return logger;\n}"],"mappings":"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","names":["NoSuchModelError","NoSuchModelError"]}
|
|
1
|
+
{"version":3,"sources":["../src/claude-code-provider.ts","../src/claude-code-language-model.ts","../src/convert-to-claude-code-messages.ts","../src/extract-json.ts","../src/errors.ts","../src/map-claude-code-finish-reason.ts","../src/validation.ts","../src/logger.ts"],"sourcesContent":["import type { LanguageModelV1, ProviderV1 } from '@ai-sdk/provider';\nimport { NoSuchModelError } from '@ai-sdk/provider';\nimport { ClaudeCodeLanguageModel, type ClaudeCodeModelId } from './claude-code-language-model.js';\nimport type { ClaudeCodeSettings } from './types.js';\nimport { validateSettings } from './validation.js';\nimport { getLogger } from './logger.js';\n\n/**\n * Claude Code provider interface that extends the AI SDK's ProviderV1.\n * Provides methods to create language models for interacting with Claude via the CLI.\n * \n * @example\n * ```typescript\n * import { claudeCode } from 'ai-sdk-provider-claude-code';\n * \n * // Create a model instance\n * const model = claudeCode('opus');\n * \n * // Or use the explicit methods\n * const chatModel = claudeCode.chat('sonnet');\n * const languageModel = claudeCode.languageModel('opus', { maxTurns: 10 });\n * ```\n */\nexport interface ClaudeCodeProvider extends ProviderV1 {\n /**\n * Creates a language model instance for the specified model ID.\n * This is a shorthand for calling `languageModel()`.\n * \n * @param modelId - The Claude model to use ('opus' or 'sonnet')\n * @param settings - Optional settings to configure the model\n * @returns A language model instance\n */\n (modelId: ClaudeCodeModelId, settings?: ClaudeCodeSettings): LanguageModelV1;\n\n /**\n * Creates a language model instance for text generation.\n * \n * @param modelId - The Claude model to use ('opus' or 'sonnet')\n * @param settings - Optional settings to configure the model\n * @returns A language model instance\n */\n languageModel(\n modelId: ClaudeCodeModelId,\n settings?: ClaudeCodeSettings,\n ): LanguageModelV1;\n\n /**\n * Alias for `languageModel()` to maintain compatibility with AI SDK patterns.\n * \n * @param modelId - The Claude model to use ('opus' or 'sonnet')\n * @param settings - Optional settings to configure the model\n * @returns A language model instance\n */\n chat(\n modelId: ClaudeCodeModelId,\n settings?: ClaudeCodeSettings,\n ): LanguageModelV1;\n}\n\n/**\n * Configuration options for creating a Claude Code provider instance.\n * These settings will be applied as defaults to all models created by the provider.\n * \n * @example\n * ```typescript\n * const provider = createClaudeCode({\n * defaultSettings: {\n * maxTurns: 5,\n * cwd: '/path/to/project'\n * }\n * });\n * ```\n */\nexport interface ClaudeCodeProviderSettings {\n /**\n * Default settings to use for all models created by this provider.\n * Individual model settings will override these defaults.\n */\n defaultSettings?: ClaudeCodeSettings;\n}\n\n/**\n * Creates a Claude Code provider instance with the specified configuration.\n * The provider can be used to create language models for interacting with Claude 4 models.\n *\n * @param options - Provider configuration options\n * @returns Claude Code provider instance\n * \n * @example\n * ```typescript\n * const provider = createClaudeCode({\n * defaultSettings: {\n * permissionMode: 'bypassPermissions',\n * maxTurns: 10\n * }\n * });\n * \n * const model = provider('opus');\n * ```\n */\nexport function createClaudeCode(\n options: ClaudeCodeProviderSettings = {},\n): ClaudeCodeProvider {\n // Get logger from default settings if provided\n const logger = getLogger(options.defaultSettings?.logger);\n \n // Validate default settings if provided\n if (options.defaultSettings) {\n const validation = validateSettings(options.defaultSettings);\n if (!validation.valid) {\n throw new Error(`Invalid default settings: ${validation.errors.join(', ')}`);\n }\n if (validation.warnings.length > 0) {\n validation.warnings.forEach(warning => logger.warn(`Claude Code Provider: ${warning}`));\n }\n }\n\n const createModel = (\n modelId: ClaudeCodeModelId,\n settings: ClaudeCodeSettings = {},\n ): LanguageModelV1 => {\n const mergedSettings = {\n ...options.defaultSettings,\n ...settings,\n };\n \n // Validate merged settings\n const validation = validateSettings(mergedSettings);\n if (!validation.valid) {\n throw new Error(`Invalid settings: ${validation.errors.join(', ')}`);\n }\n \n return new ClaudeCodeLanguageModel({\n id: modelId,\n settings: mergedSettings,\n settingsValidationWarnings: validation.warnings,\n });\n };\n\n const provider = function (\n modelId: ClaudeCodeModelId,\n settings?: ClaudeCodeSettings,\n ) {\n if (new.target) {\n throw new Error(\n 'The Claude Code model function cannot be called with the new keyword.',\n );\n }\n\n return createModel(modelId, settings);\n };\n\n provider.languageModel = createModel;\n provider.chat = createModel; // Alias for languageModel\n\n // Add textEmbeddingModel method that throws NoSuchModelError\n provider.textEmbeddingModel = (modelId: string) => {\n throw new NoSuchModelError({\n modelId,\n modelType: 'textEmbeddingModel',\n });\n };\n\n return provider as ClaudeCodeProvider;\n}\n\n/**\n * Default Claude Code provider instance.\n * Pre-configured provider for quick usage without custom settings.\n * \n * @example\n * ```typescript\n * import { claudeCode } from 'ai-sdk-provider-claude-code';\n * import { generateText } from 'ai';\n * \n * const { text } = await generateText({\n * model: claudeCode('sonnet'),\n * prompt: 'Hello, Claude!'\n * });\n * ```\n */\nexport const claudeCode = createClaudeCode();","import type {\n LanguageModelV1,\n LanguageModelV1CallWarning,\n LanguageModelV1FinishReason,\n LanguageModelV1StreamPart,\n JSONValue,\n} from '@ai-sdk/provider';\nimport { NoSuchModelError, APICallError, LoadAPIKeyError } from '@ai-sdk/provider';\nimport { generateId } from '@ai-sdk/provider-utils';\nimport type { ClaudeCodeSettings, Logger } from './types.js';\nimport { convertToClaudeCodeMessages } from './convert-to-claude-code-messages.js';\nimport { extractJson } from './extract-json.js';\nimport { createAPICallError, createAuthenticationError, createTimeoutError } from './errors.js';\nimport { mapClaudeCodeFinishReason } from './map-claude-code-finish-reason.js';\nimport { validateModelId, validatePrompt, validateSessionId } from './validation.js';\nimport { getLogger } from './logger.js';\n\nimport { query, AbortError, type Options } from '@anthropic-ai/claude-code';\n\n/**\n * Options for creating a Claude Code language model instance.\n * \n * @example\n * ```typescript\n * const model = new ClaudeCodeLanguageModel({\n * id: 'opus',\n * settings: {\n * maxTurns: 10,\n * permissionMode: 'auto'\n * }\n * });\n * ```\n */\nexport interface ClaudeCodeLanguageModelOptions {\n /**\n * The model identifier to use.\n * Can be 'opus', 'sonnet', or a custom model string.\n */\n id: ClaudeCodeModelId;\n \n /**\n * Optional settings to configure the model behavior.\n */\n settings?: ClaudeCodeSettings;\n \n /**\n * Validation warnings from settings validation.\n * Used internally to pass warnings from provider.\n */\n settingsValidationWarnings?: string[];\n}\n\n/**\n * Supported Claude model identifiers.\n * - 'opus': Claude 4 Opus model (most capable)\n * - 'sonnet': Claude 4 Sonnet model (balanced performance)\n * - Custom string: Any other model identifier supported by the CLI\n * \n * @example\n * ```typescript\n * const opusModel = claudeCode('opus');\n * const sonnetModel = claudeCode('sonnet');\n * const customModel = claudeCode('claude-3-opus-20240229');\n * ```\n */\nexport type ClaudeCodeModelId = 'opus' | 'sonnet' | (string & {});\n\nconst modelMap: Record<string, string> = {\n 'opus': 'opus',\n 'sonnet': 'sonnet',\n};\n\n/**\n * Language model implementation for Claude Code SDK.\n * This class implements the AI SDK's LanguageModelV1 interface to provide\n * integration with Claude models through the Claude Code SDK.\n * \n * Features:\n * - Supports streaming and non-streaming generation\n * - Handles JSON object generation mode\n * - Manages CLI sessions for conversation continuity\n * - Provides detailed error handling and retry logic\n * \n * Limitations:\n * - Does not support image inputs\n * - Does not support structured outputs (tool mode)\n * - Some parameters like temperature and max tokens are not supported by the CLI\n * \n * @example\n * ```typescript\n * const model = new ClaudeCodeLanguageModel({\n * id: 'opus',\n * settings: { maxTurns: 5 }\n * });\n * \n * const result = await model.doGenerate({\n * prompt: [{ role: 'user', content: 'Hello!' }],\n * mode: { type: 'regular' }\n * });\n * ```\n */\nexport class ClaudeCodeLanguageModel implements LanguageModelV1 {\n readonly specificationVersion = 'v1' as const;\n readonly defaultObjectGenerationMode = 'json' as const;\n readonly supportsImageUrls = false;\n readonly supportsStructuredOutputs = false;\n\n readonly modelId: ClaudeCodeModelId;\n readonly settings: ClaudeCodeSettings;\n \n private sessionId?: string;\n private modelValidationWarning?: string;\n private settingsValidationWarnings: string[];\n private logger: Logger;\n\n constructor(options: ClaudeCodeLanguageModelOptions) {\n this.modelId = options.id;\n this.settings = options.settings ?? {};\n this.settingsValidationWarnings = options.settingsValidationWarnings ?? [];\n this.logger = getLogger(this.settings.logger);\n \n // Validate model ID format\n if (!this.modelId || typeof this.modelId !== 'string' || this.modelId.trim() === '') {\n throw new NoSuchModelError({\n modelId: this.modelId,\n modelType: 'languageModel',\n });\n }\n \n // Additional model ID validation\n this.modelValidationWarning = validateModelId(this.modelId);\n if (this.modelValidationWarning) {\n this.logger.warn(`Claude Code Model: ${this.modelValidationWarning}`);\n }\n }\n\n get provider(): string {\n return 'claude-code';\n }\n\n private getModel(): string {\n const mapped = modelMap[this.modelId];\n return mapped ?? this.modelId;\n }\n\n private generateAllWarnings(\n options: Parameters<LanguageModelV1['doGenerate']>[0] | Parameters<LanguageModelV1['doStream']>[0],\n prompt: string\n ): LanguageModelV1CallWarning[] {\n const warnings: LanguageModelV1CallWarning[] = [];\n const unsupportedParams: string[] = [];\n \n // Check for unsupported parameters\n if (options.temperature !== undefined) unsupportedParams.push('temperature');\n if (options.maxTokens !== undefined) unsupportedParams.push('maxTokens');\n if (options.topP !== undefined) unsupportedParams.push('topP');\n if (options.topK !== undefined) unsupportedParams.push('topK');\n if (options.presencePenalty !== undefined) unsupportedParams.push('presencePenalty');\n if (options.frequencyPenalty !== undefined) unsupportedParams.push('frequencyPenalty');\n if (options.stopSequences !== undefined && options.stopSequences.length > 0) unsupportedParams.push('stopSequences');\n if (options.seed !== undefined) unsupportedParams.push('seed');\n \n if (unsupportedParams.length > 0) {\n // Add a warning for each unsupported parameter\n for (const param of unsupportedParams) {\n warnings.push({\n type: 'unsupported-setting',\n setting: param as 'temperature' | 'maxTokens' | 'topP' | 'topK' | 'presencePenalty' | 'frequencyPenalty' | 'stopSequences' | 'seed',\n details: `Claude Code SDK does not support the ${param} parameter. It will be ignored.`,\n });\n }\n }\n \n // Add model validation warning if present\n if (this.modelValidationWarning) {\n warnings.push({\n type: 'other',\n message: this.modelValidationWarning,\n });\n }\n \n // Add settings validation warnings\n this.settingsValidationWarnings.forEach(warning => {\n warnings.push({\n type: 'other',\n message: warning,\n });\n });\n \n // Validate prompt\n const promptWarning = validatePrompt(prompt);\n if (promptWarning) {\n warnings.push({\n type: 'other',\n message: promptWarning,\n });\n }\n \n return warnings;\n }\n\n private createQueryOptions(abortController: AbortController): Options {\n return {\n model: this.getModel(),\n abortController,\n resume: this.settings.resume ?? this.sessionId,\n pathToClaudeCodeExecutable: this.settings.pathToClaudeCodeExecutable,\n customSystemPrompt: this.settings.customSystemPrompt,\n appendSystemPrompt: this.settings.appendSystemPrompt,\n maxTurns: this.settings.maxTurns,\n maxThinkingTokens: this.settings.maxThinkingTokens,\n cwd: this.settings.cwd,\n executable: this.settings.executable,\n executableArgs: this.settings.executableArgs,\n permissionMode: this.settings.permissionMode,\n permissionPromptToolName: this.settings.permissionPromptToolName,\n continue: this.settings.continue,\n allowedTools: this.settings.allowedTools,\n disallowedTools: this.settings.disallowedTools,\n mcpServers: this.settings.mcpServers,\n };\n }\n\n private handleClaudeCodeError(\n error: unknown,\n messagesPrompt: string\n ): APICallError | LoadAPIKeyError {\n // Handle AbortError from the SDK\n if (error instanceof AbortError) {\n // Return the abort reason if available, otherwise the error itself\n throw error;\n }\n\n // Type guard for error with properties\n const isErrorWithMessage = (err: unknown): err is { message?: string } => {\n return typeof err === 'object' && err !== null && 'message' in err;\n };\n\n const isErrorWithCode = (err: unknown): err is { code?: string; exitCode?: number; stderr?: string } => {\n return typeof err === 'object' && err !== null;\n };\n\n // Check for authentication errors with improved detection\n const authErrorPatterns = [\n 'not logged in',\n 'authentication',\n 'unauthorized',\n 'auth failed',\n 'please login',\n 'claude login'\n ];\n \n const errorMessage = isErrorWithMessage(error) && error.message \n ? error.message.toLowerCase() \n : '';\n \n const exitCode = isErrorWithCode(error) && typeof error.exitCode === 'number' \n ? error.exitCode \n : undefined;\n \n const isAuthError = authErrorPatterns.some(pattern => errorMessage.includes(pattern)) ||\n exitCode === 401;\n\n if (isAuthError) {\n return createAuthenticationError({\n message: isErrorWithMessage(error) && error.message \n ? error.message \n : 'Authentication failed. Please ensure Claude Code SDK is properly authenticated.',\n });\n }\n\n // Check for timeout errors\n const errorCode = isErrorWithCode(error) && typeof error.code === 'string' \n ? error.code \n : '';\n \n if (errorCode === 'ETIMEDOUT' || errorMessage.includes('timeout')) {\n return createTimeoutError({\n message: isErrorWithMessage(error) && error.message \n ? error.message \n : 'Request timed out',\n promptExcerpt: messagesPrompt.substring(0, 200),\n // Don't specify timeoutMs since we don't know the actual timeout value\n // It's controlled by the consumer via AbortSignal\n });\n }\n\n // Create general API call error with appropriate retry flag\n const isRetryable = errorCode === 'ENOENT' || \n errorCode === 'ECONNREFUSED' ||\n errorCode === 'ETIMEDOUT' ||\n errorCode === 'ECONNRESET';\n\n return createAPICallError({\n message: isErrorWithMessage(error) && error.message \n ? error.message \n : 'Claude Code SDK error',\n code: errorCode || undefined,\n exitCode: exitCode,\n stderr: isErrorWithCode(error) && typeof error.stderr === 'string' \n ? error.stderr \n : undefined,\n promptExcerpt: messagesPrompt.substring(0, 200),\n isRetryable,\n });\n }\n\n private setSessionId(sessionId: string): void {\n this.sessionId = sessionId;\n const warning = validateSessionId(sessionId);\n if (warning) {\n this.logger.warn(`Claude Code Session: ${warning}`);\n }\n }\n\n private validateJsonExtraction(\n originalText: string,\n extractedJson: string\n ): { valid: boolean; warning?: LanguageModelV1CallWarning } {\n // If the extracted JSON is the same as original, extraction likely failed\n if (extractedJson === originalText) {\n return {\n valid: false,\n warning: {\n type: 'other',\n message: 'JSON extraction from model response may be incomplete or modified. The model may not have returned valid JSON.',\n },\n };\n }\n\n // Try to parse the extracted JSON to validate it\n try {\n JSON.parse(extractedJson);\n return { valid: true };\n } catch {\n return {\n valid: false,\n warning: {\n type: 'other',\n message: 'JSON extraction resulted in invalid JSON. The response may be malformed.',\n },\n };\n }\n }\n\n async doGenerate(\n options: Parameters<LanguageModelV1['doGenerate']>[0],\n ): Promise<Awaited<ReturnType<LanguageModelV1['doGenerate']>>> {\n const { messagesPrompt, warnings: messageWarnings } = convertToClaudeCodeMessages(options.prompt, options.mode);\n\n const abortController = new AbortController();\n let abortListener: (() => void) | undefined;\n if (options.abortSignal) {\n abortListener = () => abortController.abort();\n options.abortSignal.addEventListener('abort', abortListener, { once: true });\n }\n\n const queryOptions = this.createQueryOptions(abortController);\n\n let text = '';\n let usage = { promptTokens: 0, completionTokens: 0 };\n let finishReason: LanguageModelV1FinishReason = 'stop';\n let costUsd: number | undefined;\n let durationMs: number | undefined;\n let rawUsage: unknown | undefined;\n const warnings: LanguageModelV1CallWarning[] = this.generateAllWarnings(options, messagesPrompt);\n \n // Add warnings from message conversion\n if (messageWarnings) {\n messageWarnings.forEach(warning => {\n warnings.push({\n type: 'other',\n message: warning,\n });\n });\n }\n\n try {\n const response = query({\n prompt: messagesPrompt,\n options: queryOptions,\n });\n\n for await (const message of response) {\n if (message.type === 'assistant') {\n text += message.message.content.map((c: { type: string; text?: string }) => \n c.type === 'text' ? c.text : ''\n ).join('');\n } else if (message.type === 'result') {\n this.setSessionId(message.session_id);\n costUsd = message.total_cost_usd;\n durationMs = message.duration_ms;\n \n if ('usage' in message) {\n rawUsage = message.usage;\n usage = {\n promptTokens: (message.usage.cache_creation_input_tokens ?? 0) + \n (message.usage.cache_read_input_tokens ?? 0) +\n (message.usage.input_tokens ?? 0),\n completionTokens: message.usage.output_tokens ?? 0,\n };\n }\n\n finishReason = mapClaudeCodeFinishReason(message.subtype);\n } else if (message.type === 'system' && message.subtype === 'init') {\n this.setSessionId(message.session_id);\n }\n }\n } catch (error: unknown) {\n // Special handling for AbortError to preserve abort signal reason\n if (error instanceof AbortError) {\n throw options.abortSignal?.aborted ? options.abortSignal.reason : error;\n }\n \n // Use unified error handler\n throw this.handleClaudeCodeError(error, messagesPrompt);\n } finally {\n if (options.abortSignal && abortListener) {\n options.abortSignal.removeEventListener('abort', abortListener);\n }\n }\n\n // Extract JSON if in object-json mode\n if (options.mode?.type === 'object-json' && text) {\n const extracted = extractJson(text);\n const validation = this.validateJsonExtraction(text, extracted);\n \n if (!validation.valid && validation.warning) {\n warnings.push(validation.warning);\n }\n \n text = extracted;\n }\n\n return {\n text: text || undefined,\n usage,\n finishReason,\n rawCall: {\n rawPrompt: messagesPrompt,\n rawSettings: queryOptions,\n },\n warnings: warnings.length > 0 ? warnings : undefined,\n response: {\n id: generateId(),\n timestamp: new Date(),\n modelId: this.modelId,\n },\n request: {\n body: messagesPrompt,\n },\n providerMetadata: {\n 'claude-code': {\n ...(this.sessionId !== undefined && { sessionId: this.sessionId }),\n ...(costUsd !== undefined && { costUsd }),\n ...(durationMs !== undefined && { durationMs }),\n ...(rawUsage !== undefined && { rawUsage: rawUsage as JSONValue }),\n },\n },\n };\n }\n\n async doStream(\n options: Parameters<LanguageModelV1['doStream']>[0],\n ): Promise<Awaited<ReturnType<LanguageModelV1['doStream']>>> {\n const { messagesPrompt, warnings: messageWarnings } = convertToClaudeCodeMessages(options.prompt, options.mode);\n\n const abortController = new AbortController();\n let abortListener: (() => void) | undefined;\n if (options.abortSignal) {\n abortListener = () => abortController.abort();\n options.abortSignal.addEventListener('abort', abortListener, { once: true });\n }\n\n const queryOptions = this.createQueryOptions(abortController);\n\n const warnings: LanguageModelV1CallWarning[] = this.generateAllWarnings(options, messagesPrompt);\n \n // Add warnings from message conversion\n if (messageWarnings) {\n messageWarnings.forEach(warning => {\n warnings.push({\n type: 'other',\n message: warning,\n });\n });\n }\n\n const stream = new ReadableStream<LanguageModelV1StreamPart>({\n start: async (controller) => {\n try {\n const response = query({\n prompt: messagesPrompt,\n options: queryOptions,\n });\n\n let usage = { promptTokens: 0, completionTokens: 0 };\n let accumulatedText = '';\n\n for await (const message of response) {\n if (message.type === 'assistant') {\n const text = message.message.content\n .map((c: { type: string; text?: string }) => (c.type === 'text' ? c.text : ''))\n .join('');\n \n if (text) {\n accumulatedText += text;\n \n // In object-json mode, we need to accumulate the full text\n // and extract JSON at the end, so don't stream individual deltas\n if (options.mode?.type !== 'object-json') {\n controller.enqueue({\n type: 'text-delta',\n textDelta: text,\n });\n }\n }\n } else if (message.type === 'result') {\n let rawUsage: unknown | undefined;\n if ('usage' in message) {\n rawUsage = message.usage;\n usage = {\n promptTokens: (message.usage.cache_creation_input_tokens ?? 0) + \n (message.usage.cache_read_input_tokens ?? 0) +\n (message.usage.input_tokens ?? 0),\n completionTokens: message.usage.output_tokens ?? 0,\n };\n }\n\n const finishReason: LanguageModelV1FinishReason = mapClaudeCodeFinishReason(message.subtype);\n\n // Store session ID in the model instance\n this.setSessionId(message.session_id);\n \n // In object-json mode, extract JSON and send the full text at once\n if (options.mode?.type === 'object-json' && accumulatedText) {\n const extractedJson = extractJson(accumulatedText);\n this.validateJsonExtraction(accumulatedText, extractedJson);\n \n // If validation failed, we should add a warning but we can't modify warnings array in stream\n // So we'll just send the extracted JSON anyway\n // In the future, we could emit a warning stream part if the SDK supports it\n \n controller.enqueue({\n type: 'text-delta',\n textDelta: extractedJson,\n });\n }\n \n controller.enqueue({\n type: 'finish',\n finishReason,\n usage,\n providerMetadata: {\n 'claude-code': {\n sessionId: message.session_id,\n ...(message.total_cost_usd !== undefined && { costUsd: message.total_cost_usd }),\n ...(message.duration_ms !== undefined && { durationMs: message.duration_ms }),\n ...(rawUsage !== undefined && { rawUsage: rawUsage as JSONValue }),\n },\n },\n });\n } else if (message.type === 'system' && message.subtype === 'init') {\n // Store session ID for future use\n this.setSessionId(message.session_id);\n \n // Emit response metadata when session is initialized\n controller.enqueue({\n type: 'response-metadata',\n id: message.session_id,\n timestamp: new Date(),\n modelId: this.modelId,\n });\n }\n }\n\n controller.close();\n } catch (error: unknown) {\n let errorToEmit: unknown;\n \n // Special handling for AbortError to preserve abort signal reason\n if (error instanceof AbortError) {\n errorToEmit = options.abortSignal?.aborted ? options.abortSignal.reason : error;\n } else {\n // Use unified error handler\n errorToEmit = this.handleClaudeCodeError(error, messagesPrompt);\n }\n \n // Emit error as a stream part\n controller.enqueue({\n type: 'error',\n error: errorToEmit,\n });\n \n controller.close();\n } finally {\n if (options.abortSignal && abortListener) {\n options.abortSignal.removeEventListener('abort', abortListener);\n }\n }\n },\n cancel: () => {\n if (options.abortSignal && abortListener) {\n options.abortSignal.removeEventListener('abort', abortListener);\n }\n },\n });\n\n return {\n stream,\n rawCall: {\n rawPrompt: messagesPrompt,\n rawSettings: queryOptions,\n },\n warnings: warnings.length > 0 ? warnings : undefined,\n request: {\n body: messagesPrompt,\n },\n };\n }\n}","import type { LanguageModelV1Prompt } from '@ai-sdk/provider';\n\n/**\n * Converts AI SDK prompt format to Claude Code SDK message format.\n * Handles system prompts, user messages, assistant responses, and tool interactions.\n * \n * @param prompt - The AI SDK prompt containing messages\n * @param mode - Optional mode for specialized output formats (e.g., JSON generation)\n * @returns An object containing the formatted message prompt and optional system prompt\n * \n * @example\n * ```typescript\n * const { messagesPrompt } = convertToClaudeCodeMessages(\n * [{ role: 'user', content: 'Hello!' }],\n * { type: 'regular' }\n * );\n * ```\n * \n * @remarks\n * - Image inputs are not supported and will be ignored with a warning\n * - Tool calls are simplified to \"[Tool calls made]\" notation\n * - In 'object-json' mode, explicit JSON instructions are appended\n */\nexport function convertToClaudeCodeMessages(\n prompt: LanguageModelV1Prompt,\n mode?: { type: 'regular' | 'object-json' | 'object-tool' }\n): {\n messagesPrompt: string;\n systemPrompt?: string;\n warnings?: string[];\n} {\n const messages: string[] = [];\n const warnings: string[] = [];\n let systemPrompt: string | undefined;\n\n for (const message of prompt) {\n switch (message.role) {\n case 'system':\n systemPrompt = message.content;\n break;\n \n case 'user':\n if (typeof message.content === 'string') {\n messages.push(message.content);\n } else {\n // Handle multi-part content\n const textParts = message.content\n .filter(part => part.type === 'text')\n .map(part => part.text)\n .join('\\n');\n \n if (textParts) {\n messages.push(textParts);\n }\n \n // Note: Image parts are not supported by Claude Code SDK\n const imageParts = message.content.filter(part => part.type === 'image');\n if (imageParts.length > 0) {\n warnings.push('Claude Code SDK does not support image inputs. Images will be ignored.');\n }\n }\n break;\n \n case 'assistant':\n if (typeof message.content === 'string') {\n messages.push(`Assistant: ${message.content}`);\n } else {\n const textParts = message.content\n .filter(part => part.type === 'text')\n .map(part => part.text)\n .join('\\n');\n \n if (textParts) {\n messages.push(`Assistant: ${textParts}`);\n }\n \n // Handle tool calls if present\n const toolCalls = message.content.filter(part => part.type === 'tool-call');\n if (toolCalls.length > 0) {\n // For now, we'll just note that tool calls were made\n messages.push(`Assistant: [Tool calls made]`);\n }\n }\n break;\n \n case 'tool':\n // Tool results could be included in the conversation\n messages.push(`Tool Result (${message.content[0].toolName}): ${JSON.stringify(message.content[0].result)}`);\n break;\n }\n }\n\n // For the SDK, we need to provide a single prompt string\n // Format the conversation history properly\n \n // Combine system prompt with messages\n let finalPrompt = '';\n \n // Add system prompt at the beginning if present\n if (systemPrompt) {\n finalPrompt = systemPrompt;\n }\n \n if (messages.length === 0) {\n return { messagesPrompt: finalPrompt, systemPrompt };\n }\n \n // Format messages\n const formattedMessages = [];\n for (let i = 0; i < messages.length; i++) {\n const msg = messages[i];\n // Check if this is a user or assistant message based on content\n if (msg.startsWith('Assistant:') || msg.startsWith('Tool Result')) {\n formattedMessages.push(msg);\n } else {\n // User messages\n formattedMessages.push(`Human: ${msg}`);\n }\n }\n \n // Combine system prompt with messages\n if (finalPrompt) {\n finalPrompt = finalPrompt + '\\n\\n' + formattedMessages.join('\\n\\n');\n } else {\n finalPrompt = formattedMessages.join('\\n\\n');\n }\n \n // For JSON mode, add explicit instruction to ensure JSON output\n if (mode?.type === 'object-json') {\n // Make the JSON instruction even more explicit\n finalPrompt = `${finalPrompt}\n\nCRITICAL INSTRUCTION: You MUST respond with ONLY valid JSON. Follow these rules EXACTLY:\n1. Start your response with an opening brace {\n2. End your response with a closing brace }\n3. Do NOT include any text before the opening brace\n4. Do NOT include any text after the closing brace\n5. Do NOT use markdown code blocks or backticks\n6. Do NOT include explanations or commentary\n7. The ENTIRE response must be valid JSON that can be parsed with JSON.parse()\n\nBegin your response with { and end with }`;\n }\n \n return {\n messagesPrompt: finalPrompt,\n systemPrompt,\n ...(warnings.length > 0 && { warnings }),\n };\n}","/**\n * Extract JSON from Claude's response using a tolerant parser.\n *\n * The function removes common wrappers such as markdown fences or variable\n * declarations and then attempts to parse the remaining text with\n * `jsonc-parser`. If valid JSON (or JSONC) can be parsed, it is returned as a\n * string via `JSON.stringify`. Otherwise the original text is returned.\n *\n * @param text - Raw text which may contain JSON\n * @returns A valid JSON string if extraction succeeds, otherwise the original text\n */\nimport { parse, type ParseError } from 'jsonc-parser';\n\nexport function extractJson(text: string): string {\n let content = text.trim();\n\n // Strip ```json or ``` fences\n const fenceMatch = /```(?:json)?\\s*([\\s\\S]*?)\\s*```/i.exec(content);\n if (fenceMatch) {\n content = fenceMatch[1];\n }\n\n // Strip variable declarations like `const foo =` or `let foo =`\n const varMatch = /^\\s*(?:const|let|var)\\s+\\w+\\s*=\\s*([\\s\\S]*)/i.exec(content);\n if (varMatch) {\n content = varMatch[1];\n // Remove trailing semicolon if present\n if (content.trim().endsWith(';')) {\n content = content.trim().slice(0, -1);\n }\n }\n\n // Find the first opening bracket\n const firstObj = content.indexOf('{');\n const firstArr = content.indexOf('[');\n if (firstObj === -1 && firstArr === -1) {\n return text;\n }\n const start = firstArr === -1 ? firstObj : firstObj === -1 ? firstArr : Math.min(firstObj, firstArr);\n content = content.slice(start);\n\n // Try to parse the entire string with jsonc-parser\n const tryParse = (value: string): string | undefined => {\n const errors: ParseError[] = [];\n try {\n const result = parse(value, errors, { allowTrailingComma: true });\n if (errors.length === 0) {\n return JSON.stringify(result, null, 2);\n }\n } catch {\n // ignore\n }\n return undefined;\n };\n\n const parsed = tryParse(content);\n if (parsed !== undefined) {\n return parsed;\n }\n\n // If parsing the full string failed, use a more efficient approach\n // to find valid JSON boundaries\n const openChar = content[0];\n const closeChar = openChar === '{' ? '}' : ']';\n \n // Find all potential closing positions by tracking nesting depth\n const closingPositions: number[] = [];\n let depth = 0;\n let inString = false;\n let escapeNext = false;\n \n for (let i = 0; i < content.length; i++) {\n const char = content[i];\n \n if (escapeNext) {\n escapeNext = false;\n continue;\n }\n \n if (char === '\\\\') {\n escapeNext = true;\n continue;\n }\n \n if (char === '\"' && !inString) {\n inString = true;\n continue;\n }\n \n if (char === '\"' && inString) {\n inString = false;\n continue;\n }\n \n // Skip content inside strings\n if (inString) continue;\n \n if (char === openChar) {\n depth++;\n } else if (char === closeChar) {\n depth--;\n if (depth === 0) {\n closingPositions.push(i + 1);\n }\n }\n }\n \n // Try parsing at each valid closing position, starting from the end\n for (let i = closingPositions.length - 1; i >= 0; i--) {\n const attempt = tryParse(content.slice(0, closingPositions[i]));\n if (attempt !== undefined) {\n return attempt;\n }\n }\n \n // As a final fallback, try the original character-by-character approach\n // but only for the last 1000 characters to limit performance impact\n const searchStart = Math.max(0, content.length - 1000);\n for (let end = content.length - 1; end > searchStart; end--) {\n const attempt = tryParse(content.slice(0, end));\n if (attempt !== undefined) {\n return attempt;\n }\n }\n\n return text;\n}","import { APICallError, LoadAPIKeyError } from '@ai-sdk/provider';\n\n/**\n * Metadata associated with Claude Code SDK errors.\n * Provides additional context about command execution failures.\n */\nexport interface ClaudeCodeErrorMetadata {\n /**\n * Error code from the CLI process (e.g., 'ENOENT', 'ETIMEDOUT').\n */\n code?: string;\n \n /**\n * Exit code from the Claude Code SDK process.\n * Common codes:\n * - 401: Authentication error\n * - 1: General error\n */\n exitCode?: number;\n \n /**\n * Standard error output from the CLI process.\n */\n stderr?: string;\n \n /**\n * Excerpt from the prompt that caused the error.\n * Limited to first 200 characters for debugging.\n */\n promptExcerpt?: string;\n}\n\n/**\n * Creates an APICallError with Claude Code specific metadata.\n * Used for general CLI execution errors.\n * \n * @param options - Error details and metadata\n * @param options.message - Human-readable error message\n * @param options.code - Error code from the CLI process\n * @param options.exitCode - Exit code from the CLI\n * @param options.stderr - Standard error output\n * @param options.promptExcerpt - Excerpt of the prompt that caused the error\n * @param options.isRetryable - Whether the error is potentially retryable\n * @returns An APICallError instance with Claude Code metadata\n * \n * @example\n * ```typescript\n * throw createAPICallError({\n * message: 'Claude Code SDK failed',\n * code: 'ENOENT',\n * isRetryable: true\n * });\n * ```\n */\nexport function createAPICallError({\n message,\n code,\n exitCode,\n stderr,\n promptExcerpt,\n isRetryable = false,\n}: ClaudeCodeErrorMetadata & {\n message: string;\n isRetryable?: boolean;\n}): APICallError {\n const metadata: ClaudeCodeErrorMetadata = {\n code,\n exitCode,\n stderr,\n promptExcerpt,\n };\n\n return new APICallError({\n message,\n isRetryable,\n url: 'claude-code-cli://command',\n requestBodyValues: promptExcerpt ? { prompt: promptExcerpt } : undefined,\n data: metadata,\n });\n}\n\n/**\n * Creates an authentication error for Claude Code SDK login failures.\n * \n * @param options - Error configuration\n * @param options.message - Error message describing the authentication failure\n * @returns A LoadAPIKeyError instance\n * \n * @example\n * ```typescript\n * throw createAuthenticationError({\n * message: 'Please run \"claude login\" to authenticate'\n * });\n * ```\n */\nexport function createAuthenticationError({\n message,\n}: {\n message: string;\n}): LoadAPIKeyError {\n return new LoadAPIKeyError({\n message: message || 'Authentication failed. Please ensure Claude Code SDK is properly authenticated.',\n });\n}\n\n/**\n * Creates a timeout error for Claude Code SDK operations.\n * \n * @param options - Timeout error details\n * @param options.message - Error message describing the timeout\n * @param options.promptExcerpt - Excerpt of the prompt that timed out\n * @param options.timeoutMs - Timeout duration in milliseconds\n * @returns An APICallError instance configured as a timeout error\n * \n * @example\n * ```typescript\n * throw createTimeoutError({\n * message: 'Request timed out after 2 minutes',\n * timeoutMs: 120000\n * });\n * ```\n */\nexport function createTimeoutError({\n message,\n promptExcerpt,\n timeoutMs,\n}: {\n message: string;\n promptExcerpt?: string;\n timeoutMs?: number;\n}): APICallError {\n // Store timeoutMs in metadata for potential use by error handlers\n const metadata: ClaudeCodeErrorMetadata = {\n code: 'TIMEOUT',\n promptExcerpt,\n };\n \n return new APICallError({\n message,\n isRetryable: true,\n url: 'claude-code-cli://command',\n requestBodyValues: promptExcerpt ? { prompt: promptExcerpt } : undefined,\n data: timeoutMs !== undefined ? { ...metadata, timeoutMs } : metadata,\n });\n}\n\n/**\n * Checks if an error is an authentication error.\n * Returns true for LoadAPIKeyError instances or APICallError with exit code 401.\n * \n * @param error - The error to check\n * @returns True if the error is an authentication error\n * \n * @example\n * ```typescript\n * try {\n * await model.generate(...);\n * } catch (error) {\n * if (isAuthenticationError(error)) {\n * console.log('Please authenticate with Claude Code SDK');\n * }\n * }\n * ```\n */\nexport function isAuthenticationError(error: unknown): boolean {\n if (error instanceof LoadAPIKeyError) return true;\n if (error instanceof APICallError && (error.data as ClaudeCodeErrorMetadata)?.exitCode === 401) return true;\n return false;\n}\n\n/**\n * Checks if an error is a timeout error.\n * Returns true for APICallError instances with code 'TIMEOUT'.\n * \n * @param error - The error to check\n * @returns True if the error is a timeout error\n * \n * @example\n * ```typescript\n * try {\n * await model.generate(...);\n * } catch (error) {\n * if (isTimeoutError(error)) {\n * console.log('Request timed out, consider retrying');\n * }\n * }\n * ```\n */\nexport function isTimeoutError(error: unknown): boolean {\n if (error instanceof APICallError && (error.data as ClaudeCodeErrorMetadata)?.code === 'TIMEOUT') return true;\n return false;\n}\n\n/**\n * Extracts Claude Code error metadata from an error object.\n * \n * @param error - The error to extract metadata from\n * @returns The error metadata if available, undefined otherwise\n * \n * @example\n * ```typescript\n * try {\n * await model.generate(...);\n * } catch (error) {\n * const metadata = getErrorMetadata(error);\n * if (metadata?.exitCode === 401) {\n * console.log('Authentication required');\n * }\n * }\n * ```\n */\nexport function getErrorMetadata(error: unknown): ClaudeCodeErrorMetadata | undefined {\n if (error instanceof APICallError && error.data) {\n return error.data as ClaudeCodeErrorMetadata;\n }\n return undefined;\n}","import type { LanguageModelV1FinishReason } from '@ai-sdk/provider';\n\n/**\n * Maps Claude Code SDK result subtypes to AI SDK finish reasons.\n * \n * @param subtype - The result subtype from Claude Code SDK\n * @returns The corresponding AI SDK finish reason\n * \n * @example\n * ```typescript\n * const finishReason = mapClaudeCodeFinishReason('error_max_turns');\n * // Returns: 'length'\n * ```\n * \n * @remarks\n * Mappings:\n * - 'success' -> 'stop' (normal completion)\n * - 'error_max_turns' -> 'length' (hit turn limit)\n * - 'error_during_execution' -> 'error' (execution error)\n * - default -> 'stop' (unknown subtypes treated as normal completion)\n */\nexport function mapClaudeCodeFinishReason(\n subtype?: string\n): LanguageModelV1FinishReason {\n switch (subtype) {\n case 'success':\n return 'stop';\n case 'error_max_turns':\n return 'length';\n case 'error_during_execution':\n return 'error';\n default:\n return 'stop';\n }\n}","import { z } from 'zod';\nimport { existsSync } from 'fs';\n\n/**\n * Validation schemas and utilities for Claude Code provider inputs.\n * Uses Zod for type-safe validation following AI SDK patterns.\n */\n\n/**\n * Schema for validating Claude Code settings.\n * Ensures all settings are within acceptable ranges and formats.\n */\nexport const claudeCodeSettingsSchema = z.object({\n pathToClaudeCodeExecutable: z.string().optional(),\n customSystemPrompt: z.string().optional(),\n appendSystemPrompt: z.string().optional(),\n maxTurns: z.number().int().min(1).max(100).optional(),\n maxThinkingTokens: z.number().int().positive().max(100000).optional(),\n cwd: z.string().refine(\n (val) => {\n // Skip directory validation in non-Node environments\n if (typeof process === 'undefined' || !process.versions?.node) {\n return true;\n }\n return !val || existsSync(val);\n },\n { message: \"Working directory must exist\" }\n ).optional(),\n executable: z.enum(['bun', 'deno', 'node']).optional(),\n executableArgs: z.array(z.string()).optional(),\n permissionMode: z.enum(['default', 'acceptEdits', 'bypassPermissions', 'plan']).optional(),\n permissionPromptToolName: z.string().optional(),\n continue: z.boolean().optional(),\n resume: z.string().optional(),\n allowedTools: z.array(z.string()).optional(),\n disallowedTools: z.array(z.string()).optional(),\n mcpServers: z.record(z.string(), z.union([\n // McpStdioServerConfig\n z.object({\n type: z.literal('stdio').optional(),\n command: z.string(),\n args: z.array(z.string()).optional(),\n env: z.record(z.string()).optional()\n }),\n // McpSSEServerConfig\n z.object({\n type: z.literal('sse'),\n url: z.string(),\n headers: z.record(z.string()).optional()\n })\n ])).optional(),\n verbose: z.boolean().optional(),\n logger: z.union([\n z.literal(false),\n z.object({\n warn: z.function().args(z.string()).returns(z.void()),\n error: z.function().args(z.string()).returns(z.void())\n })\n ]).optional(),\n}).strict();\n\n/**\n * Validates a model ID and returns warnings if needed.\n * \n * @param modelId - The model ID to validate\n * @returns Warning message if model is unknown, undefined otherwise\n */\nexport function validateModelId(modelId: string): string | undefined {\n const knownModels = ['opus', 'sonnet'];\n \n // Check for empty or whitespace-only\n if (!modelId || modelId.trim() === '') {\n throw new Error('Model ID cannot be empty');\n }\n \n // Warn about unknown models but allow them\n if (!knownModels.includes(modelId)) {\n return `Unknown model ID: '${modelId}'. Proceeding with custom model. Known models are: ${knownModels.join(', ')}`;\n }\n \n return undefined;\n}\n\n/**\n * Validates Claude Code settings and returns validation results.\n * \n * @param settings - The settings object to validate\n * @returns Object with validation results and any warnings\n */\nexport function validateSettings(settings: unknown): {\n valid: boolean;\n warnings: string[];\n errors: string[];\n} {\n const warnings: string[] = [];\n const errors: string[] = [];\n \n try {\n // Parse with Zod schema\n const result = claudeCodeSettingsSchema.safeParse(settings);\n \n if (!result.success) {\n // Extract user-friendly error messages\n result.error.errors.forEach(err => {\n const path = err.path.join('.');\n errors.push(`${path ? `${path}: ` : ''}${err.message}`);\n });\n return { valid: false, warnings, errors };\n }\n \n // Additional validation warnings\n const validSettings = result.data;\n \n // Warn about high turn limits\n if (validSettings.maxTurns && validSettings.maxTurns > 20) {\n warnings.push(`High maxTurns value (${validSettings.maxTurns}) may lead to long-running conversations`);\n }\n \n // Warn about very high thinking tokens\n if (validSettings.maxThinkingTokens && validSettings.maxThinkingTokens > 50000) {\n warnings.push(`Very high maxThinkingTokens (${validSettings.maxThinkingTokens}) may increase response time`);\n }\n \n // Check if both allowedTools and disallowedTools are specified\n if (validSettings.allowedTools && validSettings.disallowedTools) {\n warnings.push('Both allowedTools and disallowedTools are specified. Only allowedTools will be used.');\n }\n \n // Validate tool name format\n const validateToolNames = (tools: string[], type: string) => {\n tools.forEach(tool => {\n // Basic validation - tool names should be alphanumeric with optional specifiers\n if (!/^[a-zA-Z_][a-zA-Z0-9_]*(\\([^)]*\\))?$/.test(tool) && !tool.startsWith('mcp__')) {\n warnings.push(`Unusual ${type} tool name format: '${tool}'`);\n }\n });\n };\n \n if (validSettings.allowedTools) {\n validateToolNames(validSettings.allowedTools, 'allowed');\n }\n \n if (validSettings.disallowedTools) {\n validateToolNames(validSettings.disallowedTools, 'disallowed');\n }\n \n return { valid: true, warnings, errors };\n } catch (error) {\n errors.push(`Validation error: ${error instanceof Error ? error.message : String(error)}`);\n return { valid: false, warnings, errors };\n }\n}\n\n/**\n * Validates prompt length and format.\n * \n * @param prompt - The prompt to validate\n * @returns Warning message if prompt might cause issues\n */\nexport function validatePrompt(prompt: string): string | undefined {\n // Very long prompts might cause issues\n const MAX_PROMPT_LENGTH = 100000; // ~25k tokens\n \n if (prompt.length > MAX_PROMPT_LENGTH) {\n return `Very long prompt (${prompt.length} characters) may cause performance issues or timeouts`;\n }\n \n return undefined;\n}\n\n/**\n * Validates session ID format.\n * \n * @param sessionId - The session ID to validate\n * @returns Warning message if format is unusual\n */\nexport function validateSessionId(sessionId: string): string | undefined {\n // Session IDs from Claude Code are typically UUID-like\n // But we don't want to be too strict as format might change\n if (sessionId && !/^[a-zA-Z0-9-_]+$/.test(sessionId)) {\n return `Unusual session ID format. This may cause issues with session resumption.`;\n }\n \n return undefined;\n}","import type { Logger } from './types.js';\n\n/**\n * Default logger that uses console.\n */\nconst defaultLogger: Logger = {\n warn: (message: string) => console.warn(message),\n error: (message: string) => console.error(message),\n};\n\n/**\n * No-op logger that discards all messages.\n */\nconst noopLogger: Logger = {\n warn: () => {},\n error: () => {},\n};\n\n/**\n * Gets the appropriate logger based on configuration.\n * \n * @param logger - Logger configuration from settings\n * @returns The logger to use\n */\nexport function getLogger(logger: Logger | false | undefined): Logger {\n if (logger === false) {\n return noopLogger;\n }\n \n if (logger === undefined) {\n return defaultLogger;\n }\n \n return logger;\n}"],"mappings":"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","names":["NoSuchModelError","NoSuchModelError"]}
|
|
@@ -174,7 +174,7 @@ The Claude Code provider is available in the `ai-sdk-provider-claude-code` modul
|
|
|
174
174
|
|
|
175
175
|
### Prerequisites
|
|
176
176
|
|
|
177
|
-
Install and authenticate the Claude Code
|
|
177
|
+
Install and authenticate the Claude Code SDK:
|
|
178
178
|
|
|
179
179
|
```bash
|
|
180
180
|
npm install -g @anthropic-ai/claude-code
|
|
@@ -217,5 +217,5 @@ const { text } = await generateText({
|
|
|
217
217
|
The provider uses the official Claude Code SDK. While the models support tool use, this provider
|
|
218
218
|
doesn't implement the AI SDK's tool calling interface. However, you can configure MCP servers
|
|
219
219
|
for tool functionality, and Claude can use built-in tools (Bash, Read, Write, etc.) through
|
|
220
|
-
the Claude Code
|
|
220
|
+
the Claude Code SDK.
|
|
221
221
|
</Note>
|
package/docs/GUIDE.md
CHANGED
|
@@ -708,13 +708,13 @@ Review our examples for implementation patterns
|
|
|
708
708
|
|
|
709
709
|
## Limitations
|
|
710
710
|
|
|
711
|
-
- **No image support**: The Claude Code
|
|
711
|
+
- **No image support**: The Claude Code SDK doesn't support image inputs (provider sets `supportsImageUrls = false`)
|
|
712
712
|
- **No embedding support**: Text embeddings are not available through this provider
|
|
713
713
|
- **Object-tool mode not supported**: Only `object-json` mode works via `generateObject`/`streamObject`. The AI SDK's tool calling interface is not implemented
|
|
714
714
|
- **Text-only responses**: No support for file generation or other modalities
|
|
715
715
|
- **Session management**: While sessions are supported, message history is the recommended approach
|
|
716
716
|
- **Unsupported generation settings**: The following AI SDK settings are ignored and will generate warnings:
|
|
717
|
-
- `temperature` - Claude Code
|
|
717
|
+
- `temperature` - Claude Code SDK doesn't expose temperature control
|
|
718
718
|
- `maxTokens` - Token limits aren't configurable via CLI
|
|
719
719
|
- `topP`, `topK` - Sampling parameters aren't available
|
|
720
720
|
- `presencePenalty`, `frequencyPenalty` - Penalty parameters aren't supported
|
|
@@ -831,7 +831,7 @@ ai-sdk-provider-claude-code/
|
|
|
831
831
|
## Known Limitations
|
|
832
832
|
|
|
833
833
|
1. **No image support**: The CLI doesn't accept image inputs
|
|
834
|
-
2. **Authentication required**: Requires separate Claude Code
|
|
834
|
+
2. **Authentication required**: Requires separate Claude Code SDK authentication (`claude login`)
|
|
835
835
|
3. **Session IDs change**: Each request gets a new session ID, even when using `--resume`
|
|
836
836
|
4. **No AI SDK tool calling interface**: The AI SDK's function/tool calling interface is not implemented, but Claude can use tools via MCP servers and built-in CLI tools
|
|
837
837
|
|
|
@@ -862,4 +862,4 @@ MIT - see [LICENSE](../LICENSE) for details.
|
|
|
862
862
|
|
|
863
863
|
## Acknowledgments
|
|
864
864
|
|
|
865
|
-
This provider is built for the [Vercel AI SDK](https://sdk.vercel.ai/) and uses the [Claude Code
|
|
865
|
+
This provider is built for the [Vercel AI SDK](https://sdk.vercel.ai/) and uses the [Claude Code SDK](https://docs.anthropic.com/claude-code/cli) by Anthropic.
|
package/docs/TROUBLESHOOTING.md
CHANGED
|
@@ -10,7 +10,7 @@ This guide documents common issues and solutions for the Claude Code AI SDK Prov
|
|
|
10
10
|
|
|
11
11
|
**Solution**:
|
|
12
12
|
```bash
|
|
13
|
-
# Install Claude Code
|
|
13
|
+
# Install Claude Code SDK globally
|
|
14
14
|
npm install -g @anthropic-ai/claude-code
|
|
15
15
|
|
|
16
16
|
# Authenticate with your Claude account
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ai-sdk-provider-claude-code",
|
|
3
|
-
"version": "0.2.
|
|
4
|
-
"description": "AI SDK provider for Claude via Claude Code
|
|
3
|
+
"version": "0.2.2",
|
|
4
|
+
"description": "AI SDK provider for Claude via Claude Code SDK (use Pro/Max subscription)",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"ai-sdk",
|
|
7
7
|
"claude-code",
|