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 API from "./resources/index.js"; declare const environments: { production: string; staging: string; development: string; }; type Environment = keyof typeof environments; export interface ClientOptions { /** * Defaults to process.env['MIDDAY_ENGINE_API_KEY']. */ bearerToken?: string | undefined; /** * Specifies the environment to use for the API. * * Each environment maps to a different base URL: * - `production` corresponds to `https://engine.midday.ai` * - `staging` corresponds to `https://engine-staging.midday.ai` * - `development` corresponds to `http://localhost:3002` */ environment?: Environment; /** * Override the default base URL for the API, e.g., "https://api.example.com/v2/" * * Defaults to process.env['MIDDAY_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; } /** * API Client for interfacing with the Midday API. */ export declare class Midday extends Core.APIClient { bearerToken: string; private _options; /** * API Client for interfacing with the Midday API. * * @param {string | undefined} [opts.bearerToken=process.env['MIDDAY_ENGINE_API_KEY'] ?? undefined] * @param {Environment} [opts.environment=production] - Specifies the environment URL to use for the API. * @param {string} [opts.baseURL=process.env['MIDDAY_BASE_URL'] ?? https://engine.midday.ai] - Override the default base URL for the API. * @param {number} [opts.timeout=1 minute] - 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. */ constructor({ baseURL, bearerToken, ...opts }?: ClientOptions); transactions: API.Transactions; accounts: API.Accounts; institutions: API.Institutions; auth: API.Auth; health: API.Health; rates: API.Rates; protected defaultQuery(): Core.DefaultQuery | undefined; protected defaultHeaders(opts: Core.FinalRequestOptions): Core.Headers; protected authHeaders(opts: Core.FinalRequestOptions): Core.Headers; static Midday: typeof Midday; static DEFAULT_TIMEOUT: number; static MiddayError: typeof Errors.MiddayError; 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 MiddayError: typeof Errors.MiddayError, 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 Midday { export import RequestOptions = Core.RequestOptions; export import Transactions = API.Transactions; export import TransactionListParams = API.TransactionListParams; export import Accounts = API.Accounts; export import AccountBalance = API.AccountBalance; export import AccountDeleteResponse = API.AccountDeleteResponse; export import AccountListParams = API.AccountListParams; export import AccountDeleteParams = API.AccountDeleteParams; export import AccountBalanceParams = API.AccountBalanceParams; export import Institutions = API.Institutions; export import InstitutionListParams = API.InstitutionListParams; export import Auth = API.Auth; export import Health = API.Health; export import Rates = API.Rates; export import RatesSchema = API.RatesSchema; } export default Midday; //# sourceMappingURL=index.d.ts.map