UNPKG

@tanstack/ai

Version:

Core TanStack AI library - Open source AI SDK

63 lines (62 loc) 2.48 kB
import { TranscriptionOptions, TranscriptionResult } from '../../types.js'; /** * Configuration for transcription adapter instances */ export interface TranscriptionAdapterConfig { apiKey?: string; baseUrl?: string; timeout?: number; maxRetries?: number; headers?: Record<string, string>; } /** * Transcription adapter interface with pre-resolved generics. * * An adapter is created by a provider function: `provider('model')` → `adapter` * All type resolution happens at the provider call site, not in this interface. * * Generic parameters: * - TModel: The specific model name (e.g., 'whisper-1') * - TProviderOptions: Provider-specific options (already resolved) */ export interface TranscriptionAdapter<TModel extends string = string, TProviderOptions extends object = Record<string, unknown>> { /** Discriminator for adapter kind - used to determine API shape */ readonly kind: 'transcription'; /** Adapter name identifier */ readonly name: string; /** The model this adapter is configured for */ readonly model: TModel; /** * @internal Type-only properties for inference. Not assigned at runtime. */ '~types': { providerOptions: TProviderOptions; }; /** * Transcribe audio to text */ transcribe: (options: TranscriptionOptions<TProviderOptions>) => Promise<TranscriptionResult>; } /** * A TranscriptionAdapter with any/unknown type parameters. * Useful as a constraint in generic functions and interfaces. */ export type AnyTranscriptionAdapter = TranscriptionAdapter<any, any>; /** * Abstract base class for audio transcription adapters. * Extend this class to implement a transcription adapter for a specific provider. * * Generic parameters match TranscriptionAdapter - all pre-resolved by the provider function. */ export declare abstract class BaseTranscriptionAdapter<TModel extends string = string, TProviderOptions extends object = Record<string, unknown>> implements TranscriptionAdapter<TModel, TProviderOptions> { readonly kind: "transcription"; abstract readonly name: string; readonly model: TModel; '~types': { providerOptions: TProviderOptions; }; protected config: TranscriptionAdapterConfig; constructor(config: TranscriptionAdapterConfig | undefined, model: TModel); abstract transcribe(options: TranscriptionOptions<TProviderOptions>): Promise<TranscriptionResult>; protected generateId(): string; }