import * as Errors from "./error.js";
import * as Uploads from "./uploads.js";
import { type Agent } from "./_shims/index.js";
import * as Core from "./core.js";
import * as Pagination from "./pagination.js";
import * as API from "./resources/index.js";
export interface ClientOptions {
    /**
     * Defaults to process.env['ANTHROPIC_API_KEY'].
     */
    apiKey?: string | null | undefined;
    /**
     * Defaults to process.env['ANTHROPIC_AUTH_TOKEN'].
     */
    authToken?: string | null | undefined;
    /**
     * Override the default base URL for the API, e.g., "https://api.example.com/v2/"
     *
     * Defaults to process.env['ANTHROPIC_BASE_URL'].
     */
    baseURL?: string | null | undefined;
    /**
     * The maximum amount of time (in milliseconds) that the client should wait for a response
     * from the server before timing out a single request.
     *
     * Note that request timeouts are retried by default, so in a worst-case scenario you may wait
     * much longer than this timeout before the promise succeeds or fails.
     */
    timeout?: number;
    /**
     * An HTTP agent used to manage HTTP(S) connections.
     *
     * If not provided, an agent will be constructed by default in the Node.js environment,
     * otherwise no agent is used.
     */
    httpAgent?: Agent;
    /**
     * Specify a custom `fetch` function implementation.
     *
     * If not provided, we use `node-fetch` on Node.js and otherwise expect that `fetch` is
     * defined globally.
     */
    fetch?: Core.Fetch | undefined;
    /**
     * The maximum number of times that the client will retry a request in case of a
     * temporary failure, like a network error or a 5XX error from the server.
     *
     * @default 2
     */
    maxRetries?: number;
    /**
     * Default headers to include with every request to the API.
     *
     * These can be removed in individual requests by explicitly setting the
     * header to `undefined` or `null` in request options.
     */
    defaultHeaders?: Core.Headers;
    /**
     * Default query parameters to include with every request to the API.
     *
     * These can be removed in individual requests by explicitly setting the
     * param to `undefined` in request options.
     */
    defaultQuery?: Core.DefaultQuery;
    /**
     * By default, client-side use of this library is not allowed, as it risks exposing your secret API credentials to attackers.
     * Only set this option to `true` if you understand the risks and have appropriate mitigations in place.
     */
    dangerouslyAllowBrowser?: boolean;
}
/**
 * API Client for interfacing with the Anthropic API.
 */
export declare class Anthropic extends Core.APIClient {
    apiKey: string | null;
    authToken: string | null;
    private _options;
    /**
     * API Client for interfacing with the Anthropic API.
     *
     * @param {string | null | undefined} [opts.apiKey=process.env['ANTHROPIC_API_KEY'] ?? null]
     * @param {string | null | undefined} [opts.authToken=process.env['ANTHROPIC_AUTH_TOKEN'] ?? null]
     * @param {string} [opts.baseURL=process.env['ANTHROPIC_BASE_URL'] ?? https://api.anthropic.com] - Override the default base URL for the API.
     * @param {number} [opts.timeout=10 minutes] - The maximum amount of time (in milliseconds) the client will wait for a response before timing out.
     * @param {number} [opts.httpAgent] - An HTTP agent used to manage HTTP(s) connections.
     * @param {Core.Fetch} [opts.fetch] - Specify a custom `fetch` function implementation.
     * @param {number} [opts.maxRetries=2] - The maximum number of times the client will retry a request.
     * @param {Core.Headers} opts.defaultHeaders - Default headers to include with every request to the API.
     * @param {Core.DefaultQuery} opts.defaultQuery - Default query parameters to include with every request to the API.
     * @param {boolean} [opts.dangerouslyAllowBrowser=false] - By default, client-side use of this library is not allowed, as it risks exposing your secret API credentials to attackers.
     */
    constructor({ baseURL, apiKey, authToken, ...opts }?: ClientOptions);
    completions: API.Completions;
    messages: API.Messages;
    beta: API.Beta;
    protected defaultQuery(): Core.DefaultQuery | undefined;
    protected defaultHeaders(opts: Core.FinalRequestOptions): Core.Headers;
    protected validateHeaders(headers: Core.Headers, customHeaders: Core.Headers): void;
    protected authHeaders(opts: Core.FinalRequestOptions): Core.Headers;
    protected apiKeyAuth(opts: Core.FinalRequestOptions): Core.Headers;
    protected bearerAuth(opts: Core.FinalRequestOptions): Core.Headers;
    static Anthropic: typeof Anthropic;
    static HUMAN_PROMPT: string;
    static AI_PROMPT: string;
    static DEFAULT_TIMEOUT: number;
    static AnthropicError: typeof Errors.AnthropicError;
    static APIError: typeof Errors.APIError;
    static APIConnectionError: typeof Errors.APIConnectionError;
    static APIConnectionTimeoutError: typeof Errors.APIConnectionTimeoutError;
    static APIUserAbortError: typeof Errors.APIUserAbortError;
    static NotFoundError: typeof Errors.NotFoundError;
    static ConflictError: typeof Errors.ConflictError;
    static RateLimitError: typeof Errors.RateLimitError;
    static BadRequestError: typeof Errors.BadRequestError;
    static AuthenticationError: typeof Errors.AuthenticationError;
    static InternalServerError: typeof Errors.InternalServerError;
    static PermissionDeniedError: typeof Errors.PermissionDeniedError;
    static UnprocessableEntityError: typeof Errors.UnprocessableEntityError;
    static toFile: typeof Uploads.toFile;
    static fileFromPath: typeof Uploads.fileFromPath;
}
export declare const HUMAN_PROMPT: string, AI_PROMPT: string;
export declare const AnthropicError: typeof Errors.AnthropicError, APIError: typeof Errors.APIError, APIConnectionError: typeof Errors.APIConnectionError, APIConnectionTimeoutError: typeof Errors.APIConnectionTimeoutError, APIUserAbortError: typeof Errors.APIUserAbortError, NotFoundError: typeof Errors.NotFoundError, ConflictError: typeof Errors.ConflictError, RateLimitError: typeof Errors.RateLimitError, BadRequestError: typeof Errors.BadRequestError, AuthenticationError: typeof Errors.AuthenticationError, InternalServerError: typeof Errors.InternalServerError, PermissionDeniedError: typeof Errors.PermissionDeniedError, UnprocessableEntityError: typeof Errors.UnprocessableEntityError;
export import toFile = Uploads.toFile;
export import fileFromPath = Uploads.fileFromPath;
export declare namespace Anthropic {
    export import RequestOptions = Core.RequestOptions;
    export import Page = Pagination.Page;
    export import PageParams = Pagination.PageParams;
    export import PageResponse = Pagination.PageResponse;
    export import Completions = API.Completions;
    export import Completion = API.Completion;
    export import CompletionCreateParams = API.CompletionCreateParams;
    export import CompletionCreateParamsNonStreaming = API.CompletionCreateParamsNonStreaming;
    export import CompletionCreateParamsStreaming = API.CompletionCreateParamsStreaming;
    export import Messages = API.Messages;
    export import ContentBlock = API.ContentBlock;
    export import ContentBlockDeltaEvent = API.ContentBlockDeltaEvent;
    export import ContentBlockStartEvent = API.ContentBlockStartEvent;
    export import ContentBlockStopEvent = API.ContentBlockStopEvent;
    export import ImageBlockParam = API.ImageBlockParam;
    export import InputJSONDelta = API.InputJSONDelta;
    export import Message = API.Message;
    export import MessageDeltaEvent = API.MessageDeltaEvent;
    export import MessageDeltaUsage = API.MessageDeltaUsage;
    export import MessageParam = API.MessageParam;
    export import MessageStartEvent = API.MessageStartEvent;
    export import MessageStopEvent = API.MessageStopEvent;
    export import MessageStreamEvent = API.MessageStreamEvent;
    export import Metadata = API.Metadata;
    export import Model = API.Model;
    export import RawContentBlockDeltaEvent = API.RawContentBlockDeltaEvent;
    export import RawContentBlockStartEvent = API.RawContentBlockStartEvent;
    export import RawContentBlockStopEvent = API.RawContentBlockStopEvent;
    export import RawMessageDeltaEvent = API.RawMessageDeltaEvent;
    export import RawMessageStartEvent = API.RawMessageStartEvent;
    export import RawMessageStopEvent = API.RawMessageStopEvent;
    export import RawMessageStreamEvent = API.RawMessageStreamEvent;
    export import TextBlock = API.TextBlock;
    export import TextBlockParam = API.TextBlockParam;
    export import TextDelta = API.TextDelta;
    export import Tool = API.Tool;
    export import ToolChoice = API.ToolChoice;
    export import ToolChoiceAny = API.ToolChoiceAny;
    export import ToolChoiceAuto = API.ToolChoiceAuto;
    export import ToolChoiceTool = API.ToolChoiceTool;
    export import ToolResultBlockParam = API.ToolResultBlockParam;
    export import ToolUseBlock = API.ToolUseBlock;
    export import ToolUseBlockParam = API.ToolUseBlockParam;
    export import Usage = API.Usage;
    export import MessageCreateParams = API.MessageCreateParams;
    export import MessageCreateParamsNonStreaming = API.MessageCreateParamsNonStreaming;
    export import MessageCreateParamsStreaming = API.MessageCreateParamsStreaming;
    export import MessageStreamParams = API.MessageStreamParams;
    export import Beta = API.Beta;
    export import AnthropicBeta = API.AnthropicBeta;
    export import BetaAPIError = API.BetaAPIError;
    export import BetaAuthenticationError = API.BetaAuthenticationError;
    export import BetaError = API.BetaError;
    export import BetaErrorResponse = API.BetaErrorResponse;
    export import BetaInvalidRequestError = API.BetaInvalidRequestError;
    export import BetaNotFoundError = API.BetaNotFoundError;
    export import BetaOverloadedError = API.BetaOverloadedError;
    export import BetaPermissionError = API.BetaPermissionError;
    export import BetaRateLimitError = API.BetaRateLimitError;
}
export default Anthropic;
//# sourceMappingURL=index.d.ts.map