import type { $ClientProtocol, $ClientProtocolCtor, Client as IClient, ClientProtocol, ClientProtocolCtor, Command, FetchHttpHandlerOptions, MetadataBearer, MiddlewareStack, NodeHttpHandlerOptions, RequestHandler } from "@smithy/types"; /** * @public */ export interface SmithyConfiguration { /** * @public */ requestHandler: RequestHandler | NodeHttpHandlerOptions | FetchHttpHandlerOptions | Record; /** * @public * * Default false. * * When true, the client will only resolve the middleware stack once per * Command class. This means modifying the middlewareStack of the * command or client after requests have been made will not be * recognized. * * Calling client.destroy() also clears this cache. * * Enable this only if needing the additional time saved (0-1ms per request) * and not needing middleware modifications between requests. */ cacheMiddleware?: boolean; /** * A client request/response protocol or constructor of one. * A protocol in this context is not e.g. https. * It is the combined implementation of how to (de)serialize and create * the messages (e.g. http requests/responses) that are being exchanged. * * @public */ protocol?: ClientProtocol | $ClientProtocol | ClientProtocolCtor | $ClientProtocolCtor; /** * These are automatically generated and will be passed to the * config.protocol if given as a constructor. * @internal */ protocolSettings?: { defaultNamespace?: string; [setting: string]: unknown; }; /** * The API version set internally by the SDK, and is * not planned to be used by customer code. * @internal */ readonly apiVersion: string; } /** * @internal */ export type SmithyResolvedConfiguration = { requestHandler: RequestHandler; cacheMiddleware?: boolean; protocol?: ClientProtocol | $ClientProtocol; protocolSettings?: { defaultNamespace?: string; [setting: string]: unknown; }; readonly apiVersion: string; }; /** * @public */ export declare class Client> implements IClient { readonly config: ResolvedClientConfiguration; middlewareStack: MiddlewareStack; /** * Holds an object reference to the initial configuration object. * Used to check that the config resolver stack does not create * dangling instances of an intermediate form of the configuration object. * * @internal */ initConfig?: object; /** * May be used to cache the resolved handler function for a Command class. */ private handlers?; constructor(config: ResolvedClientConfiguration); send(command: Command>, options?: HandlerOptions): Promise; send(command: Command>, cb: (err: any, data?: OutputType) => void): void; send(command: Command>, options: HandlerOptions, cb: (err: any, data?: OutputType) => void): void; destroy(): void; }