ai-sdk-provider-claude-code 0.2.0

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.
@@ -0,0 +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"]}
@@ -0,0 +1,221 @@
1
+ # Community Provider Status Analysis
2
+
3
+ ## Overview
4
+ This document analyzes the requirements for ai-sdk-provider-claude-code to achieve community provider status in the Vercel AI SDK ecosystem.
5
+
6
+ ## Current Implementation Status
7
+
8
+ ### ✅ What We Have
9
+
10
+ #### Core Functionality
11
+ - **SDK Integration**: Uses official `@anthropic-ai/claude-code` SDK for all Claude interactions
12
+ - **Text Generation**: Full support for both streaming and non-streaming text generation
13
+ - **Object Generation**: Reliable JSON generation through prompt engineering and extraction
14
+ - **Multi-turn Conversations**: Proper message history support (recommended AI SDK pattern)
15
+ - **Provider Metadata**: Rich metadata including sessionId, costUsd, durationMs, and rawUsage
16
+ - **Error Handling**: Comprehensive error handling with authentication detection
17
+ - **AbortSignal Support**: Standard AI SDK pattern for timeouts and cancellation
18
+
19
+ #### Build & Distribution
20
+ - **TypeScript**: Full TypeScript support with proper type definitions
21
+ - **Dual Formats**: Both CommonJS and ES Module builds via tsup
22
+ - **Source Maps**: Generated for debugging support
23
+ - **Package Structure**: Proper exports configuration for modern Node.js
24
+
25
+ #### Testing
26
+ - **Unit Tests**: Comprehensive test coverage with Vitest
27
+ - **Integration Tests**: Full integration test suite
28
+ - **Edge/Node Tests**: Separate configurations for different environments
29
+ - **Examples**: Extensive example collection demonstrating all features
30
+
31
+ #### Documentation
32
+ - **README**: Comprehensive documentation with examples
33
+ - **CHANGELOG**: Proper version history following Keep a Changelog format
34
+ - **Examples README**: Detailed guide for all example files
35
+ - **API Documentation**: Clear documentation of all configuration options
36
+
37
+ ### 🚀 Meeting AI SDK Standards
38
+
39
+ Based on analysis of official providers (Mistral, OpenAI, etc.), we now meet all requirements:
40
+
41
+ 1. **Provider Pattern** ✅
42
+ - Factory function with provider instance
43
+ - Default export
44
+ - Proper settings interface
45
+ - Protection against `new` keyword misuse
46
+
47
+ 2. **Language Model Implementation** ✅
48
+ - `specificationVersion: 'v1'`
49
+ - Correct `doGenerate` and `doStream` methods
50
+ - Proper provider metadata
51
+ - Object generation support
52
+
53
+ 3. **Build System** ✅
54
+ - tsup for dual format builds
55
+ - Source maps
56
+ - Proper package.json configuration
57
+
58
+ 4. **Testing** ✅
59
+ - Separate edge/node configurations
60
+ - Unit and integration tests
61
+ - Example test coverage
62
+
63
+ 5. **Error Handling** ✅
64
+ - Standard AI SDK error classes
65
+ - Proper `isRetryable` flags
66
+ - AbortSignal support
67
+
68
+ ## 📁 Current Project Structure
69
+
70
+ ```
71
+ ai-sdk-provider-claude-code/
72
+ ├── src/
73
+ │ ├── index.ts # Main exports
74
+ │ ├── claude-code-provider.ts # Provider factory
75
+ │ ├── claude-code-language-model.ts # Language model implementation
76
+ │ ├── convert-to-claude-code-messages.ts # Message formatting
77
+ │ ├── extract-json.ts # JSON extraction (using jsonc-parser)
78
+ │ ├── errors.ts # Error utilities
79
+ │ └── types.ts # TypeScript definitions
80
+ ├── docs/
81
+ │ ├── GUIDE.md # Comprehensive usage guide
82
+ │ ├── TROUBLESHOOTING.md # Common issues and solutions
83
+ │ └── DEVELOPMENT-STATUS.md # This document
84
+ ├── examples/
85
+ │ ├── README.md # Examples guide
86
+ │ ├── basic-usage.ts # Simple generation
87
+ │ ├── streaming.ts # Streaming demo
88
+ │ ├── conversation-history.ts # Multi-turn conversations
89
+ │ ├── custom-config.ts # Configuration options
90
+ │ ├── generate-object-*.ts # Object generation examples
91
+ │ ├── tool-management.ts # Tool access control
92
+ │ ├── long-running-tasks.ts # Timeout handling
93
+ │ ├── abort-signal.ts # Cancellation
94
+ │ ├── integration-test.ts # Test suite
95
+ │ └── check-cli.ts # Setup verification
96
+ ├── vitest.config.js # Test configuration
97
+ ├── vitest.edge.config.js # Edge runtime tests
98
+ ├── vitest.node.config.js # Node runtime tests
99
+ ├── tsup.config.ts # Build configuration
100
+ ├── package.json # Package metadata
101
+ ├── CHANGELOG.md # Version history
102
+ ├── README.md # Concise getting started guide
103
+ └── LICENSE # MIT license
104
+ ```
105
+
106
+ ## 🎯 Ready for Community Status
107
+
108
+ The provider now meets all requirements for community provider status:
109
+
110
+ ### Technical Requirements ✅
111
+ - Implements LanguageModelV1 specification
112
+ - Follows provider factory pattern
113
+ - Uses standard error handling
114
+ - Supports AbortSignal
115
+ - Has proper TypeScript types
116
+ - Includes comprehensive tests
117
+
118
+ ### Build Requirements ✅
119
+ - Uses tsup for builds
120
+ - Generates both CJS and ESM
121
+ - Includes source maps
122
+ - Has proper package.json configuration
123
+
124
+ ### Documentation Requirements ✅
125
+ - Comprehensive README
126
+ - CHANGELOG with version history
127
+ - Extensive examples
128
+ - Clear setup instructions
129
+
130
+ ## Next Steps for Community Submission
131
+
132
+ 1. **Publish to npm**
133
+ ```bash
134
+ npm publish
135
+ ```
136
+
137
+ 2. **Prepare MDX Documentation**
138
+ Create a documentation file following the community provider format (see example below)
139
+
140
+ 3. **Submit PR to AI SDK Repository**
141
+ - Add provider to community providers list
142
+ - Include MDX documentation
143
+ - Reference npm package
144
+
145
+ ## Example Community Provider MDX
146
+
147
+ ```mdx
148
+ ---
149
+ title: Claude Code
150
+ description: Use Claude via the official Claude Code SDK with your Pro/Max subscription
151
+ ---
152
+
153
+ # Claude Code Provider
154
+
155
+ [ben-vargas/ai-sdk-provider-claude-code](https://github.com/ben-vargas/ai-sdk-provider-claude-code)
156
+ is a community provider that uses the official [Claude Code SDK](https://www.npmjs.com/package/@anthropic-ai/claude-code)
157
+ to provide language model support for the AI SDK.
158
+
159
+ ## Setup
160
+
161
+ The Claude Code provider is available in the `ai-sdk-provider-claude-code` module. You can install it with:
162
+
163
+ <Tabs items={['pnpm', 'npm', 'yarn']}>
164
+ <Tab>
165
+ <Snippet text="pnpm add ai-sdk-provider-claude-code" dark />
166
+ </Tab>
167
+ <Tab>
168
+ <Snippet text="npm install ai-sdk-provider-claude-code" dark />
169
+ </Tab>
170
+ <Tab>
171
+ <Snippet text="yarn add ai-sdk-provider-claude-code" dark />
172
+ </Tab>
173
+ </Tabs>
174
+
175
+ ### Prerequisites
176
+
177
+ Install and authenticate the Claude Code CLI:
178
+
179
+ ```bash
180
+ npm install -g @anthropic-ai/claude-code
181
+ claude login
182
+ ```
183
+
184
+ ## Provider Instance
185
+
186
+ You can import the default provider instance `claudeCode` from `ai-sdk-provider-claude-code`:
187
+
188
+ ```ts
189
+ import { claudeCode } from 'ai-sdk-provider-claude-code';
190
+ ```
191
+
192
+ ## Language Models
193
+
194
+ The Claude Code provider supports the following models:
195
+
196
+ - `sonnet` - Claude 4 Sonnet (balanced speed and capability)
197
+ - `opus` - Claude 4 Opus (most capable)
198
+
199
+ ```ts
200
+ import { generateText } from 'ai';
201
+ import { claudeCode } from 'ai-sdk-provider-claude-code';
202
+
203
+ const { text } = await generateText({
204
+ model: claudeCode('sonnet'),
205
+ prompt: 'Explain recursion in one sentence',
206
+ });
207
+ ```
208
+
209
+ ### Model Capabilities
210
+
211
+ | Model | Text Generation | Object Generation | Image Input | AI SDK Tool Calling | MCP Tools |
212
+ |-------|----------------|-------------------|-------------|---------------------|-----------|
213
+ | opus | ✅ | ✅ | ❌ | ❌ | ✅ |
214
+ | sonnet | ✅ | ✅ | ❌ | ❌ | ✅ |
215
+
216
+ <Note>
217
+ The provider uses the official Claude Code SDK. While the models support tool use, this provider
218
+ doesn't implement the AI SDK's tool calling interface. However, you can configure MCP servers
219
+ for tool functionality, and Claude can use built-in tools (Bash, Read, Write, etc.) through
220
+ the Claude Code CLI.
221
+ </Note>