Socket
Socket
Sign inDemoInstall

@aws-sdk/types

Package Overview
Dependencies
Maintainers
5
Versions
145
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-sdk/types - npm Package Compare versions

Comparing version 3.0.0 to 3.1.0

7

dist/cjs/middleware.d.ts
import { Logger } from "./logger";
import { UserAgent } from "./util";
export interface InitializeHandlerArguments<Input extends object> {

@@ -316,2 +317,8 @@ /**

logger?: Logger;
/**
* Additional user agent that inferred by middleware. It can be used to save
* the internal user agent sections without overriding the `customUserAgent`
* config in clients.
*/
userAgent?: UserAgent;
[key: string]: any;

@@ -318,0 +325,0 @@ }

2

dist/cjs/middleware.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../src/middleware.ts"],"names":[],"mappings":"","sourcesContent":["import { Logger } from \"./logger\";\n\nexport interface InitializeHandlerArguments<Input extends object> {\n  /**\n   * User input to a command. Reflects the userland representation of the\n   * union of data types the command can effectively handle.\n   */\n  input: Input;\n}\n\nexport interface InitializeHandlerOutput<Output extends object> extends DeserializeHandlerOutput<Output> {\n  output: Output;\n}\n\nexport interface SerializeHandlerArguments<Input extends object> extends InitializeHandlerArguments<Input> {\n  /**\n   * The user input serialized as a request object. The request object is unknown,\n   * so you cannot modify it directly. When work with request, you need to guard its\n   * type to e.g. HttpRequest with 'instanceof' operand\n   *\n   * During the build phase of the execution of a middleware stack, a built\n   * request may or may not be available.\n   */\n  request?: unknown;\n}\n\nexport interface SerializeHandlerOutput<Output extends object> extends InitializeHandlerOutput<Output> {}\n\nexport interface BuildHandlerArguments<Input extends object> extends FinalizeHandlerArguments<Input> {}\n\nexport interface BuildHandlerOutput<Output extends object> extends InitializeHandlerOutput<Output> {}\n\nexport interface FinalizeHandlerArguments<Input extends object> extends SerializeHandlerArguments<Input> {\n  /**\n   * The user input serialized as a request.\n   */\n  request: unknown;\n}\n\nexport interface FinalizeHandlerOutput<Output extends object> extends InitializeHandlerOutput<Output> {}\n\nexport interface DeserializeHandlerArguments<Input extends object> extends FinalizeHandlerArguments<Input> {}\n\nexport interface DeserializeHandlerOutput<Output extends object> {\n  /**\n   * The raw response object from runtime is deserialized to structured output object.\n   * The response object is unknown so you cannot modify it directly. When work with\n   * response, you need to guard its type to e.g. HttpResponse with 'instanceof' operand.\n   *\n   * During the deserialize phase of the execution of a middleware stack, a deserialized\n   * response may or may not be available\n   */\n  response: unknown;\n  output?: Output;\n}\n\nexport interface InitializeHandler<Input extends object, Output extends object> {\n  /**\n   * Asynchronously converts an input object into an output object.\n   *\n   * @param args  An object containing a input to the command as well as any\n   *              associated or previously generated execution artifacts.\n   */\n  (args: InitializeHandlerArguments<Input>): Promise<InitializeHandlerOutput<Output>>;\n}\n\nexport type Handler<Input extends object, Output extends object> = InitializeHandler<Input, Output>;\n\nexport interface SerializeHandler<Input extends object, Output extends object> {\n  /**\n   * Asynchronously converts an input object into an output object.\n   *\n   * @param args  An object containing a input to the command as well as any\n   *              associated or previously generated execution artifacts.\n   */\n  (args: SerializeHandlerArguments<Input>): Promise<SerializeHandlerOutput<Output>>;\n}\n\nexport interface FinalizeHandler<Input extends object, Output extends object> {\n  /**\n   * Asynchronously converts an input object into an output object.\n   *\n   * @param args  An object containing a input to the command as well as any\n   *              associated or previously generated execution artifacts.\n   */\n  (args: FinalizeHandlerArguments<Input>): Promise<FinalizeHandlerOutput<Output>>;\n}\n\nexport interface BuildHandler<Input extends object, Output extends object> {\n  (args: BuildHandlerArguments<Input>): Promise<BuildHandlerOutput<Output>>;\n}\n\nexport interface DeserializeHandler<Input extends object, Output extends object> {\n  (args: DeserializeHandlerArguments<Input>): Promise<DeserializeHandlerOutput<Output>>;\n}\n\n/**\n * A factory function that creates functions implementing the {Handler}\n * interface.\n */\nexport interface InitializeMiddleware<Input extends object, Output extends object> {\n  /**\n   * @param next The handler to invoke after this middleware has operated on\n   * the user input and before this middleware operates on the output.\n   *\n   * @param context Invariant data and functions for use by the handler.\n   */\n  (next: InitializeHandler<Input, Output>, context: HandlerExecutionContext): InitializeHandler<Input, Output>;\n}\n\n/**\n * A factory function that creates functions implementing the {BuildHandler}\n * interface.\n */\nexport interface SerializeMiddleware<Input extends object, Output extends object> {\n  /**\n   * @param next The handler to invoke after this middleware has operated on\n   * the user input and before this middleware operates on the output.\n   *\n   * @param context Invariant data and functions for use by the handler.\n   */\n  (next: SerializeHandler<Input, Output>, context: HandlerExecutionContext): SerializeHandler<Input, Output>;\n}\n\n/**\n * A factory function that creates functions implementing the {FinalizeHandler}\n * interface.\n */\nexport interface FinalizeRequestMiddleware<Input extends object, Output extends object> {\n  /**\n   * @param next The handler to invoke after this middleware has operated on\n   * the user input and before this middleware operates on the output.\n   *\n   * @param context Invariant data and functions for use by the handler.\n   */\n  (next: FinalizeHandler<Input, Output>, context: HandlerExecutionContext): FinalizeHandler<Input, Output>;\n}\n\nexport interface BuildMiddleware<Input extends object, Output extends object> {\n  (next: BuildHandler<Input, Output>, context: HandlerExecutionContext): BuildHandler<Input, Output>;\n}\n\nexport interface DeserializeMiddleware<Input extends object, Output extends object> {\n  (next: DeserializeHandler<Input, Output>, context: HandlerExecutionContext): DeserializeHandler<Input, Output>;\n}\n\nexport type MiddlewareType<Input extends object, Output extends object> =\n  | InitializeMiddleware<Input, Output>\n  | SerializeMiddleware<Input, Output>\n  | BuildMiddleware<Input, Output>\n  | FinalizeRequestMiddleware<Input, Output>\n  | DeserializeMiddleware<Input, Output>;\n\n/**\n * A factory function that creates the terminal handler atop which a middleware\n * stack sits.\n */\nexport interface Terminalware {\n  <Input extends object, Output extends object>(context: HandlerExecutionContext): DeserializeHandler<Input, Output>;\n}\n\nexport type Step = \"initialize\" | \"serialize\" | \"build\" | \"finalizeRequest\" | \"deserialize\";\n\nexport type Priority = \"high\" | \"normal\" | \"low\";\n\nexport interface HandlerOptions {\n  /**\n   * Handlers are ordered using a \"step\" that describes the stage of command\n   * execution at which the handler will be executed. The available steps are:\n   *\n   * - initialize: The input is being prepared. Examples of typical\n   *      initialization tasks include injecting default options computing\n   *      derived parameters.\n   * - serialize: The input is complete and ready to be serialized. Examples\n   *      of typical serialization tasks include input validation and building\n   *      an HTTP request from user input.\n   * - build: The input has been serialized into an HTTP request, but that\n   *      request may require further modification. Any request alterations\n   *      will be applied to all retries. Examples of typical build tasks\n   *      include injecting HTTP headers that describe a stable aspect of the\n   *      request, such as `Content-Length` or a body checksum.\n   * - finalizeRequest: The request is being prepared to be sent over the wire. The\n   *      request in this stage should already be semantically complete and\n   *      should therefore only be altered as match the recipient's\n   *      expectations. Examples of typical finalization tasks include request\n   *      signing and injecting hop-by-hop headers.\n   * - deserialize: The response has arrived, the middleware here will deserialize\n   *      the raw response object to structured response\n   *\n   *      Unlike initialization and build handlers, which are executed once\n   *      per operation execution, finalization and deserialize handlers will be\n   *      executed foreach HTTP request sent.\n   *\n   * @default 'initialize'\n   */\n  step?: Step;\n\n  /**\n   * A list of strings to any that identify the general purpose or important\n   * characteristics of a given handler.\n   */\n  tags?: Array<string>;\n\n  /**\n   * A unique name to refer to a middleware\n   */\n  name?: string;\n}\nexport interface AbsoluteLocation {\n  /**\n   * By default middleware will be added to individual step in un-guaranteed order.\n   * In the case that\n   *\n   * @default 'normal'\n   */\n  priority?: Priority;\n}\n\nexport type Relation = \"before\" | \"after\";\n\nexport interface RelativeLocation {\n  /**\n   * Specify the relation to be before or after a know middleware.\n   */\n  relation: Relation;\n\n  /**\n   * A known middleware name to indicate inserting middleware's location.\n   */\n  toMiddleware: string;\n}\n\nexport type RelativeMiddlewareOptions = RelativeLocation & Omit<HandlerOptions, \"step\">;\n\nexport interface InitializeHandlerOptions extends HandlerOptions {\n  step?: \"initialize\";\n}\n\nexport interface SerializeHandlerOptions extends HandlerOptions {\n  step: \"serialize\";\n}\n\nexport interface BuildHandlerOptions extends HandlerOptions {\n  step: \"build\";\n}\n\nexport interface FinalizeRequestHandlerOptions extends HandlerOptions {\n  step: \"finalizeRequest\";\n}\n\nexport interface DeserializeHandlerOptions extends HandlerOptions {\n  step: \"deserialize\";\n}\n\n/**\n * A stack storing middleware. It can be resolved into a handler. It supports 2\n * approaches for adding middleware:\n * 1. Adding middleware to specific step with `add()`. The order of middleware\n *    added into same step is determined by order of adding them. If one middleware\n *    needs to be executed at the front of the step or at the end of step, set\n *    `priority` options to `high` or `low`.\n * 2. Adding middleware to location relative to known middleware with `addRelativeTo()`.\n *    This is useful when given middleware must be executed before or after specific\n *    middleware(`toMiddleware`). You can add a middleware relatively to another\n *    middleware which also added relatively. But eventually, this relative middleware\n *    chain **must** be 'anchored' by a middleware that added using `add()` API\n *    with absolute `step` and `priority`. This mothod will throw if specified\n *    `toMiddleware` is not found.\n */\nexport interface MiddlewareStack<Input extends object, Output extends object> extends Pluggable<Input, Output> {\n  /**\n   * Add middleware to the stack to be executed during the \"initialize\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: InitializeMiddleware<Input, Output>, options?: InitializeHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"serialize\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: SerializeMiddleware<Input, Output>, options: SerializeHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"build\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: BuildMiddleware<Input, Output>, options: BuildHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"finalizeRequest\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(\n    middleware: FinalizeRequestMiddleware<Input, Output>,\n    options: FinalizeRequestHandlerOptions & AbsoluteLocation\n  ): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"deserialize\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: DeserializeMiddleware<Input, Output>, options: DeserializeHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to a stack position before or after a known middleware，optionally\n   * specifying name and tags.\n   */\n  addRelativeTo(middleware: MiddlewareType<Input, Output>, options: RelativeMiddlewareOptions): void;\n\n  /**\n   * Apply a customization function to mutate the middleware stack, often\n   * used for customizations that requires mutating multiple middleware.\n   */\n  use(pluggable: Pluggable<Input, Output>): void;\n\n  /**\n   * Create a shallow clone of this stack. Step bindings and handler priorities\n   * and tags are preserved in the copy.\n   */\n  clone(): MiddlewareStack<Input, Output>;\n\n  /**\n   * Removes middleware from the stack.\n   *\n   * If a string is provided, it will be treated as middleware name. If a middleware\n   * is inserted with the given name, it will be removed.\n   *\n   * If a middleware class is provided, all usages thereof will be removed.\n   */\n  remove(toRemove: MiddlewareType<Input, Output> | string): boolean;\n\n  /**\n   * Removes middleware that contains given tag\n   *\n   * Multiple middleware will potentially be removed\n   */\n  removeByTag(toRemove: string): boolean;\n\n  /**\n   * Create a stack containing the middlewares in this stack as well as the\n   * middlewares in the `from` stack. Neither source is modified, and step\n   * bindings and handler priorities and tags are preserved in the copy.\n   */\n  concat<InputType extends Input, OutputType extends Output>(\n    from: MiddlewareStack<InputType, OutputType>\n  ): MiddlewareStack<InputType, OutputType>;\n\n  /**\n   * Builds a single handler function from zero or more middleware classes and\n   * a core handler. The core handler is meant to send command objects to AWS\n   * services and return promises that will resolve with the operation result\n   * or be rejected with an error.\n   *\n   * When a composed handler is invoked, the arguments will pass through all\n   * middleware in a defined order, and the return from the innermost handler\n   * will pass through all middleware in the reverse of that order.\n   */\n  resolve<InputType extends Input, OutputType extends Output>(\n    handler: DeserializeHandler<InputType, OutputType>,\n    context: HandlerExecutionContext\n  ): InitializeHandler<InputType, OutputType>;\n}\n\n/**\n * Data and helper objects that are not expected to change from one execution of\n * a composed handler to another.\n */\nexport interface HandlerExecutionContext {\n  /**\n   * A logger that may be invoked by any handler during execution of an\n   * operation.\n   */\n  logger?: Logger;\n\n  [key: string]: any;\n}\n\nexport interface Pluggable<Input extends object, Output extends object> {\n  /**\n   * A function that mutate the passed in middleware stack. Functions implementing\n   * this interface can add, remove, modify existing middleware stack from clients\n   * or commands\n   */\n  applyToStack: (stack: MiddlewareStack<Input, Output>) => void;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../src/middleware.ts"],"names":[],"mappings":"","sourcesContent":["import { Logger } from \"./logger\";\nimport { UserAgent } from \"./util\";\n\nexport interface InitializeHandlerArguments<Input extends object> {\n  /**\n   * User input to a command. Reflects the userland representation of the\n   * union of data types the command can effectively handle.\n   */\n  input: Input;\n}\n\nexport interface InitializeHandlerOutput<Output extends object> extends DeserializeHandlerOutput<Output> {\n  output: Output;\n}\n\nexport interface SerializeHandlerArguments<Input extends object> extends InitializeHandlerArguments<Input> {\n  /**\n   * The user input serialized as a request object. The request object is unknown,\n   * so you cannot modify it directly. When work with request, you need to guard its\n   * type to e.g. HttpRequest with 'instanceof' operand\n   *\n   * During the build phase of the execution of a middleware stack, a built\n   * request may or may not be available.\n   */\n  request?: unknown;\n}\n\nexport interface SerializeHandlerOutput<Output extends object> extends InitializeHandlerOutput<Output> {}\n\nexport interface BuildHandlerArguments<Input extends object> extends FinalizeHandlerArguments<Input> {}\n\nexport interface BuildHandlerOutput<Output extends object> extends InitializeHandlerOutput<Output> {}\n\nexport interface FinalizeHandlerArguments<Input extends object> extends SerializeHandlerArguments<Input> {\n  /**\n   * The user input serialized as a request.\n   */\n  request: unknown;\n}\n\nexport interface FinalizeHandlerOutput<Output extends object> extends InitializeHandlerOutput<Output> {}\n\nexport interface DeserializeHandlerArguments<Input extends object> extends FinalizeHandlerArguments<Input> {}\n\nexport interface DeserializeHandlerOutput<Output extends object> {\n  /**\n   * The raw response object from runtime is deserialized to structured output object.\n   * The response object is unknown so you cannot modify it directly. When work with\n   * response, you need to guard its type to e.g. HttpResponse with 'instanceof' operand.\n   *\n   * During the deserialize phase of the execution of a middleware stack, a deserialized\n   * response may or may not be available\n   */\n  response: unknown;\n  output?: Output;\n}\n\nexport interface InitializeHandler<Input extends object, Output extends object> {\n  /**\n   * Asynchronously converts an input object into an output object.\n   *\n   * @param args  An object containing a input to the command as well as any\n   *              associated or previously generated execution artifacts.\n   */\n  (args: InitializeHandlerArguments<Input>): Promise<InitializeHandlerOutput<Output>>;\n}\n\nexport type Handler<Input extends object, Output extends object> = InitializeHandler<Input, Output>;\n\nexport interface SerializeHandler<Input extends object, Output extends object> {\n  /**\n   * Asynchronously converts an input object into an output object.\n   *\n   * @param args  An object containing a input to the command as well as any\n   *              associated or previously generated execution artifacts.\n   */\n  (args: SerializeHandlerArguments<Input>): Promise<SerializeHandlerOutput<Output>>;\n}\n\nexport interface FinalizeHandler<Input extends object, Output extends object> {\n  /**\n   * Asynchronously converts an input object into an output object.\n   *\n   * @param args  An object containing a input to the command as well as any\n   *              associated or previously generated execution artifacts.\n   */\n  (args: FinalizeHandlerArguments<Input>): Promise<FinalizeHandlerOutput<Output>>;\n}\n\nexport interface BuildHandler<Input extends object, Output extends object> {\n  (args: BuildHandlerArguments<Input>): Promise<BuildHandlerOutput<Output>>;\n}\n\nexport interface DeserializeHandler<Input extends object, Output extends object> {\n  (args: DeserializeHandlerArguments<Input>): Promise<DeserializeHandlerOutput<Output>>;\n}\n\n/**\n * A factory function that creates functions implementing the {Handler}\n * interface.\n */\nexport interface InitializeMiddleware<Input extends object, Output extends object> {\n  /**\n   * @param next The handler to invoke after this middleware has operated on\n   * the user input and before this middleware operates on the output.\n   *\n   * @param context Invariant data and functions for use by the handler.\n   */\n  (next: InitializeHandler<Input, Output>, context: HandlerExecutionContext): InitializeHandler<Input, Output>;\n}\n\n/**\n * A factory function that creates functions implementing the {BuildHandler}\n * interface.\n */\nexport interface SerializeMiddleware<Input extends object, Output extends object> {\n  /**\n   * @param next The handler to invoke after this middleware has operated on\n   * the user input and before this middleware operates on the output.\n   *\n   * @param context Invariant data and functions for use by the handler.\n   */\n  (next: SerializeHandler<Input, Output>, context: HandlerExecutionContext): SerializeHandler<Input, Output>;\n}\n\n/**\n * A factory function that creates functions implementing the {FinalizeHandler}\n * interface.\n */\nexport interface FinalizeRequestMiddleware<Input extends object, Output extends object> {\n  /**\n   * @param next The handler to invoke after this middleware has operated on\n   * the user input and before this middleware operates on the output.\n   *\n   * @param context Invariant data and functions for use by the handler.\n   */\n  (next: FinalizeHandler<Input, Output>, context: HandlerExecutionContext): FinalizeHandler<Input, Output>;\n}\n\nexport interface BuildMiddleware<Input extends object, Output extends object> {\n  (next: BuildHandler<Input, Output>, context: HandlerExecutionContext): BuildHandler<Input, Output>;\n}\n\nexport interface DeserializeMiddleware<Input extends object, Output extends object> {\n  (next: DeserializeHandler<Input, Output>, context: HandlerExecutionContext): DeserializeHandler<Input, Output>;\n}\n\nexport type MiddlewareType<Input extends object, Output extends object> =\n  | InitializeMiddleware<Input, Output>\n  | SerializeMiddleware<Input, Output>\n  | BuildMiddleware<Input, Output>\n  | FinalizeRequestMiddleware<Input, Output>\n  | DeserializeMiddleware<Input, Output>;\n\n/**\n * A factory function that creates the terminal handler atop which a middleware\n * stack sits.\n */\nexport interface Terminalware {\n  <Input extends object, Output extends object>(context: HandlerExecutionContext): DeserializeHandler<Input, Output>;\n}\n\nexport type Step = \"initialize\" | \"serialize\" | \"build\" | \"finalizeRequest\" | \"deserialize\";\n\nexport type Priority = \"high\" | \"normal\" | \"low\";\n\nexport interface HandlerOptions {\n  /**\n   * Handlers are ordered using a \"step\" that describes the stage of command\n   * execution at which the handler will be executed. The available steps are:\n   *\n   * - initialize: The input is being prepared. Examples of typical\n   *      initialization tasks include injecting default options computing\n   *      derived parameters.\n   * - serialize: The input is complete and ready to be serialized. Examples\n   *      of typical serialization tasks include input validation and building\n   *      an HTTP request from user input.\n   * - build: The input has been serialized into an HTTP request, but that\n   *      request may require further modification. Any request alterations\n   *      will be applied to all retries. Examples of typical build tasks\n   *      include injecting HTTP headers that describe a stable aspect of the\n   *      request, such as `Content-Length` or a body checksum.\n   * - finalizeRequest: The request is being prepared to be sent over the wire. The\n   *      request in this stage should already be semantically complete and\n   *      should therefore only be altered as match the recipient's\n   *      expectations. Examples of typical finalization tasks include request\n   *      signing and injecting hop-by-hop headers.\n   * - deserialize: The response has arrived, the middleware here will deserialize\n   *      the raw response object to structured response\n   *\n   *      Unlike initialization and build handlers, which are executed once\n   *      per operation execution, finalization and deserialize handlers will be\n   *      executed foreach HTTP request sent.\n   *\n   * @default 'initialize'\n   */\n  step?: Step;\n\n  /**\n   * A list of strings to any that identify the general purpose or important\n   * characteristics of a given handler.\n   */\n  tags?: Array<string>;\n\n  /**\n   * A unique name to refer to a middleware\n   */\n  name?: string;\n}\nexport interface AbsoluteLocation {\n  /**\n   * By default middleware will be added to individual step in un-guaranteed order.\n   * In the case that\n   *\n   * @default 'normal'\n   */\n  priority?: Priority;\n}\n\nexport type Relation = \"before\" | \"after\";\n\nexport interface RelativeLocation {\n  /**\n   * Specify the relation to be before or after a know middleware.\n   */\n  relation: Relation;\n\n  /**\n   * A known middleware name to indicate inserting middleware's location.\n   */\n  toMiddleware: string;\n}\n\nexport type RelativeMiddlewareOptions = RelativeLocation & Omit<HandlerOptions, \"step\">;\n\nexport interface InitializeHandlerOptions extends HandlerOptions {\n  step?: \"initialize\";\n}\n\nexport interface SerializeHandlerOptions extends HandlerOptions {\n  step: \"serialize\";\n}\n\nexport interface BuildHandlerOptions extends HandlerOptions {\n  step: \"build\";\n}\n\nexport interface FinalizeRequestHandlerOptions extends HandlerOptions {\n  step: \"finalizeRequest\";\n}\n\nexport interface DeserializeHandlerOptions extends HandlerOptions {\n  step: \"deserialize\";\n}\n\n/**\n * A stack storing middleware. It can be resolved into a handler. It supports 2\n * approaches for adding middleware:\n * 1. Adding middleware to specific step with `add()`. The order of middleware\n *    added into same step is determined by order of adding them. If one middleware\n *    needs to be executed at the front of the step or at the end of step, set\n *    `priority` options to `high` or `low`.\n * 2. Adding middleware to location relative to known middleware with `addRelativeTo()`.\n *    This is useful when given middleware must be executed before or after specific\n *    middleware(`toMiddleware`). You can add a middleware relatively to another\n *    middleware which also added relatively. But eventually, this relative middleware\n *    chain **must** be 'anchored' by a middleware that added using `add()` API\n *    with absolute `step` and `priority`. This mothod will throw if specified\n *    `toMiddleware` is not found.\n */\nexport interface MiddlewareStack<Input extends object, Output extends object> extends Pluggable<Input, Output> {\n  /**\n   * Add middleware to the stack to be executed during the \"initialize\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: InitializeMiddleware<Input, Output>, options?: InitializeHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"serialize\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: SerializeMiddleware<Input, Output>, options: SerializeHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"build\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: BuildMiddleware<Input, Output>, options: BuildHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"finalizeRequest\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(\n    middleware: FinalizeRequestMiddleware<Input, Output>,\n    options: FinalizeRequestHandlerOptions & AbsoluteLocation\n  ): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"deserialize\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: DeserializeMiddleware<Input, Output>, options: DeserializeHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to a stack position before or after a known middleware，optionally\n   * specifying name and tags.\n   */\n  addRelativeTo(middleware: MiddlewareType<Input, Output>, options: RelativeMiddlewareOptions): void;\n\n  /**\n   * Apply a customization function to mutate the middleware stack, often\n   * used for customizations that requires mutating multiple middleware.\n   */\n  use(pluggable: Pluggable<Input, Output>): void;\n\n  /**\n   * Create a shallow clone of this stack. Step bindings and handler priorities\n   * and tags are preserved in the copy.\n   */\n  clone(): MiddlewareStack<Input, Output>;\n\n  /**\n   * Removes middleware from the stack.\n   *\n   * If a string is provided, it will be treated as middleware name. If a middleware\n   * is inserted with the given name, it will be removed.\n   *\n   * If a middleware class is provided, all usages thereof will be removed.\n   */\n  remove(toRemove: MiddlewareType<Input, Output> | string): boolean;\n\n  /**\n   * Removes middleware that contains given tag\n   *\n   * Multiple middleware will potentially be removed\n   */\n  removeByTag(toRemove: string): boolean;\n\n  /**\n   * Create a stack containing the middlewares in this stack as well as the\n   * middlewares in the `from` stack. Neither source is modified, and step\n   * bindings and handler priorities and tags are preserved in the copy.\n   */\n  concat<InputType extends Input, OutputType extends Output>(\n    from: MiddlewareStack<InputType, OutputType>\n  ): MiddlewareStack<InputType, OutputType>;\n\n  /**\n   * Builds a single handler function from zero or more middleware classes and\n   * a core handler. The core handler is meant to send command objects to AWS\n   * services and return promises that will resolve with the operation result\n   * or be rejected with an error.\n   *\n   * When a composed handler is invoked, the arguments will pass through all\n   * middleware in a defined order, and the return from the innermost handler\n   * will pass through all middleware in the reverse of that order.\n   */\n  resolve<InputType extends Input, OutputType extends Output>(\n    handler: DeserializeHandler<InputType, OutputType>,\n    context: HandlerExecutionContext\n  ): InitializeHandler<InputType, OutputType>;\n}\n\n/**\n * Data and helper objects that are not expected to change from one execution of\n * a composed handler to another.\n */\nexport interface HandlerExecutionContext {\n  /**\n   * A logger that may be invoked by any handler during execution of an\n   * operation.\n   */\n  logger?: Logger;\n\n  /**\n   * Additional user agent that inferred by middleware. It can be used to save\n   * the internal user agent sections without overriding the `customUserAgent`\n   * config in clients.\n   */\n  userAgent?: UserAgent;\n\n  [key: string]: any;\n}\n\nexport interface Pluggable<Input extends object, Output extends object> {\n  /**\n   * A function that mutate the passed in middleware stack. Functions implementing\n   * this interface can add, remove, modify existing middleware stack from clients\n   * or commands\n   */\n  applyToStack: (stack: MiddlewareStack<Input, Output>) => void;\n}\n"]}

@@ -1,2 +0,1 @@

import { HeaderBag } from "./http";
export interface ResponseMetadata {

@@ -8,6 +7,2 @@ /**

/**
* The headers of the last HTTP response received for this operation.
*/
httpHeaders?: HeaderBag;
/**
* A unique identifier for the last request sent for this operation. Often

@@ -14,0 +9,0 @@ * requested by AWS service teams to aid in debugging.

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzcG9uc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVzcG9uc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhlYWRlckJhZyB9IGZyb20gXCIuL2h0dHBcIjtcblxuZXhwb3J0IGludGVyZmFjZSBSZXNwb25zZU1ldGFkYXRhIHtcbiAgLyoqXG4gICAqIFRoZSBzdGF0dXMgY29kZSBvZiB0aGUgbGFzdCBIVFRQIHJlc3BvbnNlIHJlY2VpdmVkIGZvciB0aGlzIG9wZXJhdGlvbi5cbiAgICovXG4gIGh0dHBTdGF0dXNDb2RlPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBUaGUgaGVhZGVycyBvZiB0aGUgbGFzdCBIVFRQIHJlc3BvbnNlIHJlY2VpdmVkIGZvciB0aGlzIG9wZXJhdGlvbi5cbiAgICovXG4gIGh0dHBIZWFkZXJzPzogSGVhZGVyQmFnO1xuXG4gIC8qKlxuICAgKiBBIHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGUgbGFzdCByZXF1ZXN0IHNlbnQgZm9yIHRoaXMgb3BlcmF0aW9uLiBPZnRlblxuICAgKiByZXF1ZXN0ZWQgYnkgQVdTIHNlcnZpY2UgdGVhbXMgdG8gYWlkIGluIGRlYnVnZ2luZy5cbiAgICovXG4gIHJlcXVlc3RJZD86IHN0cmluZztcblxuICAvKipcbiAgICogQSBzZWNvbmRhcnkgaWRlbnRpZmllciBmb3IgdGhlIGxhc3QgcmVxdWVzdCBzZW50LiBVc2VkIGZvciBkZWJ1Z2dpbmcuXG4gICAqL1xuICBleHRlbmRlZFJlcXVlc3RJZD86IHN0cmluZztcblxuICAvKipcbiAgICogQSB0ZXJ0aWFyeSBpZGVudGlmaWVyIGZvciB0aGUgbGFzdCByZXF1ZXN0IHNlbnQuIFVzZWQgZm9yIGRlYnVnZ2luZy5cbiAgICovXG4gIGNmSWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBudW1iZXIgb2YgdGltZXMgdGhpcyBvcGVyYXRpb24gd2FzIGF0dGVtcHRlZC5cbiAgICovXG4gIGF0dGVtcHRzPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBUaGUgdG90YWwgYW1vdW50IG9mIHRpbWUgKGluIG1pbGxpc2Vjb25kcykgdGhhdCB3YXMgc3BlbnQgd2FpdGluZyBiZXR3ZWVuXG4gICAqIHJldHJ5IGF0dGVtcHRzLlxuICAgKi9cbiAgdG90YWxSZXRyeURlbGF5PzogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1ldGFkYXRhQmVhcmVyIHtcbiAgLyoqXG4gICAqIE1ldGFkYXRhIHBlcnRhaW5pbmcgdG8gdGhpcyByZXF1ZXN0LlxuICAgKi9cbiAgJG1ldGFkYXRhOiBSZXNwb25zZU1ldGFkYXRhO1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzcG9uc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVzcG9uc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUmVzcG9uc2VNZXRhZGF0YSB7XG4gIC8qKlxuICAgKiBUaGUgc3RhdHVzIGNvZGUgb2YgdGhlIGxhc3QgSFRUUCByZXNwb25zZSByZWNlaXZlZCBmb3IgdGhpcyBvcGVyYXRpb24uXG4gICAqL1xuICBodHRwU3RhdHVzQ29kZT86IG51bWJlcjtcblxuICAvKipcbiAgICogQSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGxhc3QgcmVxdWVzdCBzZW50IGZvciB0aGlzIG9wZXJhdGlvbi4gT2Z0ZW5cbiAgICogcmVxdWVzdGVkIGJ5IEFXUyBzZXJ2aWNlIHRlYW1zIHRvIGFpZCBpbiBkZWJ1Z2dpbmcuXG4gICAqL1xuICByZXF1ZXN0SWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgc2Vjb25kYXJ5IGlkZW50aWZpZXIgZm9yIHRoZSBsYXN0IHJlcXVlc3Qgc2VudC4gVXNlZCBmb3IgZGVidWdnaW5nLlxuICAgKi9cbiAgZXh0ZW5kZWRSZXF1ZXN0SWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgdGVydGlhcnkgaWRlbnRpZmllciBmb3IgdGhlIGxhc3QgcmVxdWVzdCBzZW50LiBVc2VkIGZvciBkZWJ1Z2dpbmcuXG4gICAqL1xuICBjZklkPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgbnVtYmVyIG9mIHRpbWVzIHRoaXMgb3BlcmF0aW9uIHdhcyBhdHRlbXB0ZWQuXG4gICAqL1xuICBhdHRlbXB0cz86IG51bWJlcjtcblxuICAvKipcbiAgICogVGhlIHRvdGFsIGFtb3VudCBvZiB0aW1lIChpbiBtaWxsaXNlY29uZHMpIHRoYXQgd2FzIHNwZW50IHdhaXRpbmcgYmV0d2VlblxuICAgKiByZXRyeSBhdHRlbXB0cy5cbiAgICovXG4gIHRvdGFsUmV0cnlEZWxheT86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNZXRhZGF0YUJlYXJlciB7XG4gIC8qKlxuICAgKiBNZXRhZGF0YSBwZXJ0YWluaW5nIHRvIHRoaXMgcmVxdWVzdC5cbiAgICovXG4gICRtZXRhZGF0YTogUmVzcG9uc2VNZXRhZGF0YTtcbn1cbiJdfQ==

@@ -52,2 +52,6 @@ import { Endpoint } from "./http";

/**
* The retry mode describing how the retry strategy control the traffic flow.
*/
mode?: string;
/**
* the retry behavior the will invoke the next handler and handle the retry accordingly.

@@ -85,1 +89,11 @@ * This function should also update the $metadata from the response accordingly.

}
/**
* A tuple that represents an API name and optional version
* of a library built using the AWS SDK.
*/
export declare type UserAgentPair = [name: string, version?: string];
/**
* User agent data that to be put into the request's user
* agent.
*/
export declare type UserAgent = UserAgentPair[];
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbmRwb2ludCB9IGZyb20gXCIuL2h0dHBcIjtcbmltcG9ydCB7IEZpbmFsaXplSGFuZGxlciwgRmluYWxpemVIYW5kbGVyQXJndW1lbnRzLCBGaW5hbGl6ZUhhbmRsZXJPdXRwdXQgfSBmcm9tIFwiLi9taWRkbGV3YXJlXCI7XG5pbXBvcnQgeyBNZXRhZGF0YUJlYXJlciB9IGZyb20gXCIuL3Jlc3BvbnNlXCI7XG5cbi8qKlxuICogQSBmdW5jdGlvbiB0aGF0LCBnaXZlbiBhIFR5cGVkQXJyYXkgb2YgYnl0ZXMsIGNhbiBwcm9kdWNlIGEgc3RyaW5nXG4gKiByZXByZXNlbnRhdGlvbiB0aGVyZW9mLlxuICpcbiAqIEBleGFtcGxlIEFuIGVuY29kZXIgZnVuY3Rpb24gdGhhdCBjb252ZXJ0cyBieXRlcyB0byBoZXhhZGVjaW1hbFxuICogcmVwcmVzZW50YXRpb24gd291bGQgcmV0dXJuIGAnZGVhZGJlZWYnYCB3aGVuIGdpdmVuIGBuZXdcbiAqIFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRW5jb2RlciB7XG4gIChpbnB1dDogVWludDhBcnJheSk6IHN0cmluZztcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIGdpdmVuIGEgc3RyaW5nLCBjYW4gZGVyaXZlIHRoZSBieXRlcyByZXByZXNlbnRlZCBieSB0aGF0XG4gKiBzdHJpbmcuXG4gKlxuICogQGV4YW1wbGUgQSBkZWNvZGVyIGZ1bmN0aW9uIHRoYXQgY29udmVydHMgYnl0ZXMgdG8gaGV4YWRlY2ltYWxcbiAqIHJlcHJlc2VudGF0aW9uIHdvdWxkIHJldHVybiBgbmV3IFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAgd2hlblxuICogZ2l2ZW4gdGhlIHN0cmluZyBgJ2RlYWRiZWVmJ2AuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGVjb2RlciB7XG4gIChpbnB1dDogc3RyaW5nKTogVWludDhBcnJheTtcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIHdoZW4gaW52b2tlZCwgcmV0dXJucyBhIHByb21pc2UgdGhhdCB3aWxsIGJlIGZ1bGZpbGxlZCB3aXRoXG4gKiBhIHZhbHVlIG9mIHR5cGUgVC5cbiAqXG4gKiBAZXhhbXBsZSBBIGZ1bmN0aW9uIHRoYXQgcmVhZHMgY3JlZGVudGlhbHMgZnJvbSBzaGFyZWQgU0RLIGNvbmZpZ3VyYXRpb25cbiAqIGZpbGVzLCBhc3N1bWluZyByb2xlcyBhbmQgY29sbGVjdGluZyBNRkEgdG9rZW5zIGFzIG5lY2Vzc2FyeS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQcm92aWRlcjxUPiB7XG4gICgpOiBQcm9taXNlPFQ+O1xufVxuXG4vKipcbiAqIEEgZnVuY3Rpb24gdGhhdCwgZ2l2ZW4gYSByZXF1ZXN0IGJvZHksIGRldGVybWluZXMgdGhlXG4gKiBsZW5ndGggb2YgdGhlIGJvZHkuIFRoaXMgaXMgdXNlZCB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtTGVuZ3RoXG4gKiB0aGF0IHNob3VsZCBiZSBzZW50IHdpdGggYSByZXF1ZXN0LlxuICpcbiAqIEBleGFtcGxlIEEgZnVuY3Rpb24gdGhhdCByZWFkcyBhIGZpbGUgc3RyZWFtIGFuZCBjYWxjdWxhdGVzXG4gKiB0aGUgc2l6ZSBvZiB0aGUgZmlsZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCb2R5TGVuZ3RoQ2FsY3VsYXRvciB7XG4gIChib2R5OiBhbnkpOiBudW1iZXIgfCB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogSW50ZXJmYWNlIHRoYXQgc3BlY2lmaWVzIHRoZSByZXRyeSBiZWhhdmlvclxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJldHJ5U3RyYXRlZ3kge1xuICAvKipcbiAgICogdGhlIHJldHJ5IGJlaGF2aW9yIHRoZSB3aWxsIGludm9rZSB0aGUgbmV4dCBoYW5kbGVyIGFuZCBoYW5kbGUgdGhlIHJldHJ5IGFjY29yZGluZ2x5LlxuICAgKiBUaGlzIGZ1bmN0aW9uIHNob3VsZCBhbHNvIHVwZGF0ZSB0aGUgJG1ldGFkYXRhIGZyb20gdGhlIHJlc3BvbnNlIGFjY29yZGluZ2x5LlxuICAgKiBAc2VlIHtAbGluayBSZXNwb25zZU1ldGFkYXRhfVxuICAgKi9cbiAgcmV0cnk6IDxJbnB1dCBleHRlbmRzIG9iamVjdCwgT3V0cHV0IGV4dGVuZHMgTWV0YWRhdGFCZWFyZXI+KFxuICAgIG5leHQ6IEZpbmFsaXplSGFuZGxlcjxJbnB1dCwgT3V0cHV0PixcbiAgICBhcmdzOiBGaW5hbGl6ZUhhbmRsZXJBcmd1bWVudHM8SW5wdXQ+XG4gICkgPT4gUHJvbWlzZTxGaW5hbGl6ZUhhbmRsZXJPdXRwdXQ8T3V0cHV0Pj47XG59XG5cbi8qKlxuICogUGFyc2VzIGEgVVJMIGluIHN0cmluZyBmb3JtIGludG8gYW4gRW5kcG9pbnQgb2JqZWN0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFVybFBhcnNlciB7XG4gICh1cmw6IHN0cmluZyk6IEVuZHBvaW50O1xufVxuXG4vKipcbiAqIE9iamVjdCBjb250YWluaW5nIHJlZ2lvbmFsaXphdGlvbiBpbmZvcm1hdGlvbiBvZlxuICogQVdTIHNlcnZpY2VzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlZ2lvbkluZm8ge1xuICBob3N0bmFtZTogc3RyaW5nO1xuICBwYXJ0aXRpb246IHN0cmluZztcbiAgcGF0aD86IHN0cmluZztcbiAgc2lnbmluZ1NlcnZpY2U/OiBzdHJpbmc7XG4gIHNpZ25pbmdSZWdpb24/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogRnVuY3Rpb24gcmV0dXJucyBkZXNpZ25hdGVkIHNlcnZpY2UncyByZWdpb25hbGl6YXRpb25cbiAqIGluZm9ybWF0aW9uIGZyb20gZ2l2ZW4gcmVnaW9uLiBFYWNoIHNlcnZpY2UgY2xpZW50XG4gKiBjb21lcyB3aXRoIGl0cyByZWdpb25hbGl6YXRpb24gcHJvdmlkZXIuIGl0IHNlcnZlc1xuICogdG8gcHJvdmlkZSB0aGUgZGVmYXVsdCB2YWx1ZXMgb2YgcmVsYXRlZCBjb25maWd1cmF0aW9uc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlZ2lvbkluZm9Qcm92aWRlciB7XG4gIChyZWdpb246IHN0cmluZywgb3B0aW9ucz86IGFueSk6IFByb21pc2U8UmVnaW9uSW5mbyB8IHVuZGVmaW5lZD47XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbmRwb2ludCB9IGZyb20gXCIuL2h0dHBcIjtcbmltcG9ydCB7XG4gIEZpbmFsaXplSGFuZGxlcixcbiAgRmluYWxpemVIYW5kbGVyQXJndW1lbnRzLFxuICBGaW5hbGl6ZUhhbmRsZXJPdXRwdXQsXG4gIEhhbmRsZXJFeGVjdXRpb25Db250ZXh0LFxufSBmcm9tIFwiLi9taWRkbGV3YXJlXCI7XG5pbXBvcnQgeyBNZXRhZGF0YUJlYXJlciB9IGZyb20gXCIuL3Jlc3BvbnNlXCI7XG5cbi8qKlxuICogQSBmdW5jdGlvbiB0aGF0LCBnaXZlbiBhIFR5cGVkQXJyYXkgb2YgYnl0ZXMsIGNhbiBwcm9kdWNlIGEgc3RyaW5nXG4gKiByZXByZXNlbnRhdGlvbiB0aGVyZW9mLlxuICpcbiAqIEBleGFtcGxlIEFuIGVuY29kZXIgZnVuY3Rpb24gdGhhdCBjb252ZXJ0cyBieXRlcyB0byBoZXhhZGVjaW1hbFxuICogcmVwcmVzZW50YXRpb24gd291bGQgcmV0dXJuIGAnZGVhZGJlZWYnYCB3aGVuIGdpdmVuIGBuZXdcbiAqIFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRW5jb2RlciB7XG4gIChpbnB1dDogVWludDhBcnJheSk6IHN0cmluZztcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIGdpdmVuIGEgc3RyaW5nLCBjYW4gZGVyaXZlIHRoZSBieXRlcyByZXByZXNlbnRlZCBieSB0aGF0XG4gKiBzdHJpbmcuXG4gKlxuICogQGV4YW1wbGUgQSBkZWNvZGVyIGZ1bmN0aW9uIHRoYXQgY29udmVydHMgYnl0ZXMgdG8gaGV4YWRlY2ltYWxcbiAqIHJlcHJlc2VudGF0aW9uIHdvdWxkIHJldHVybiBgbmV3IFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAgd2hlblxuICogZ2l2ZW4gdGhlIHN0cmluZyBgJ2RlYWRiZWVmJ2AuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGVjb2RlciB7XG4gIChpbnB1dDogc3RyaW5nKTogVWludDhBcnJheTtcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIHdoZW4gaW52b2tlZCwgcmV0dXJucyBhIHByb21pc2UgdGhhdCB3aWxsIGJlIGZ1bGZpbGxlZCB3aXRoXG4gKiBhIHZhbHVlIG9mIHR5cGUgVC5cbiAqXG4gKiBAZXhhbXBsZSBBIGZ1bmN0aW9uIHRoYXQgcmVhZHMgY3JlZGVudGlhbHMgZnJvbSBzaGFyZWQgU0RLIGNvbmZpZ3VyYXRpb25cbiAqIGZpbGVzLCBhc3N1bWluZyByb2xlcyBhbmQgY29sbGVjdGluZyBNRkEgdG9rZW5zIGFzIG5lY2Vzc2FyeS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQcm92aWRlcjxUPiB7XG4gICgpOiBQcm9taXNlPFQ+O1xufVxuXG4vKipcbiAqIEEgZnVuY3Rpb24gdGhhdCwgZ2l2ZW4gYSByZXF1ZXN0IGJvZHksIGRldGVybWluZXMgdGhlXG4gKiBsZW5ndGggb2YgdGhlIGJvZHkuIFRoaXMgaXMgdXNlZCB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtTGVuZ3RoXG4gKiB0aGF0IHNob3VsZCBiZSBzZW50IHdpdGggYSByZXF1ZXN0LlxuICpcbiAqIEBleGFtcGxlIEEgZnVuY3Rpb24gdGhhdCByZWFkcyBhIGZpbGUgc3RyZWFtIGFuZCBjYWxjdWxhdGVzXG4gKiB0aGUgc2l6ZSBvZiB0aGUgZmlsZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCb2R5TGVuZ3RoQ2FsY3VsYXRvciB7XG4gIChib2R5OiBhbnkpOiBudW1iZXIgfCB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogSW50ZXJmYWNlIHRoYXQgc3BlY2lmaWVzIHRoZSByZXRyeSBiZWhhdmlvclxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJldHJ5U3RyYXRlZ3kge1xuICAvKipcbiAgICogVGhlIHJldHJ5IG1vZGUgZGVzY3JpYmluZyBob3cgdGhlIHJldHJ5IHN0cmF0ZWd5IGNvbnRyb2wgdGhlIHRyYWZmaWMgZmxvdy5cbiAgICovXG4gIG1vZGU/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiB0aGUgcmV0cnkgYmVoYXZpb3IgdGhlIHdpbGwgaW52b2tlIHRoZSBuZXh0IGhhbmRsZXIgYW5kIGhhbmRsZSB0aGUgcmV0cnkgYWNjb3JkaW5nbHkuXG4gICAqIFRoaXMgZnVuY3Rpb24gc2hvdWxkIGFsc28gdXBkYXRlIHRoZSAkbWV0YWRhdGEgZnJvbSB0aGUgcmVzcG9uc2UgYWNjb3JkaW5nbHkuXG4gICAqIEBzZWUge0BsaW5rIFJlc3BvbnNlTWV0YWRhdGF9XG4gICAqL1xuICByZXRyeTogPElucHV0IGV4dGVuZHMgb2JqZWN0LCBPdXRwdXQgZXh0ZW5kcyBNZXRhZGF0YUJlYXJlcj4oXG4gICAgbmV4dDogRmluYWxpemVIYW5kbGVyPElucHV0LCBPdXRwdXQ+LFxuICAgIGFyZ3M6IEZpbmFsaXplSGFuZGxlckFyZ3VtZW50czxJbnB1dD5cbiAgKSA9PiBQcm9taXNlPEZpbmFsaXplSGFuZGxlck91dHB1dDxPdXRwdXQ+Pjtcbn1cblxuLyoqXG4gKiBQYXJzZXMgYSBVUkwgaW4gc3RyaW5nIGZvcm0gaW50byBhbiBFbmRwb2ludCBvYmplY3QuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVXJsUGFyc2VyIHtcbiAgKHVybDogc3RyaW5nKTogRW5kcG9pbnQ7XG59XG5cbi8qKlxuICogT2JqZWN0IGNvbnRhaW5pbmcgcmVnaW9uYWxpemF0aW9uIGluZm9ybWF0aW9uIG9mXG4gKiBBV1Mgc2VydmljZXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVnaW9uSW5mbyB7XG4gIGhvc3RuYW1lOiBzdHJpbmc7XG4gIHBhcnRpdGlvbjogc3RyaW5nO1xuICBwYXRoPzogc3RyaW5nO1xuICBzaWduaW5nU2VydmljZT86IHN0cmluZztcbiAgc2lnbmluZ1JlZ2lvbj86IHN0cmluZztcbn1cblxuLyoqXG4gKiBGdW5jdGlvbiByZXR1cm5zIGRlc2lnbmF0ZWQgc2VydmljZSdzIHJlZ2lvbmFsaXphdGlvblxuICogaW5mb3JtYXRpb24gZnJvbSBnaXZlbiByZWdpb24uIEVhY2ggc2VydmljZSBjbGllbnRcbiAqIGNvbWVzIHdpdGggaXRzIHJlZ2lvbmFsaXphdGlvbiBwcm92aWRlci4gaXQgc2VydmVzXG4gKiB0byBwcm92aWRlIHRoZSBkZWZhdWx0IHZhbHVlcyBvZiByZWxhdGVkIGNvbmZpZ3VyYXRpb25zXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVnaW9uSW5mb1Byb3ZpZGVyIHtcbiAgKHJlZ2lvbjogc3RyaW5nLCBvcHRpb25zPzogYW55KTogUHJvbWlzZTxSZWdpb25JbmZvIHwgdW5kZWZpbmVkPjtcbn1cblxuLyoqXG4gKiBBIHR1cGxlIHRoYXQgcmVwcmVzZW50cyBhbiBBUEkgbmFtZSBhbmQgb3B0aW9uYWwgdmVyc2lvblxuICogb2YgYSBsaWJyYXJ5IGJ1aWx0IHVzaW5nIHRoZSBBV1MgU0RLLlxuICovXG5leHBvcnQgdHlwZSBVc2VyQWdlbnRQYWlyID0gW25hbWU6IHN0cmluZywgdmVyc2lvbj86IHN0cmluZ107XG5cbi8qKlxuICogVXNlciBhZ2VudCBkYXRhIHRoYXQgdG8gYmUgcHV0IGludG8gdGhlIHJlcXVlc3QncyB1c2VyXG4gKiBhZ2VudC5cbiAqL1xuZXhwb3J0IHR5cGUgVXNlckFnZW50ID0gVXNlckFnZW50UGFpcltdO1xuIl19
import { Logger } from "./logger";
import { UserAgent } from "./util";
export interface InitializeHandlerArguments<Input extends object> {

@@ -316,2 +317,8 @@ /**

logger?: Logger;
/**
* Additional user agent that inferred by middleware. It can be used to save
* the internal user agent sections without overriding the `customUserAgent`
* config in clients.
*/
userAgent?: UserAgent;
[key: string]: any;

@@ -318,0 +325,0 @@ }

export {};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../src/middleware.ts"],"names":[],"mappings":"","sourcesContent":["import { Logger } from \"./logger\";\n\nexport interface InitializeHandlerArguments<Input extends object> {\n  /**\n   * User input to a command. Reflects the userland representation of the\n   * union of data types the command can effectively handle.\n   */\n  input: Input;\n}\n\nexport interface InitializeHandlerOutput<Output extends object> extends DeserializeHandlerOutput<Output> {\n  output: Output;\n}\n\nexport interface SerializeHandlerArguments<Input extends object> extends InitializeHandlerArguments<Input> {\n  /**\n   * The user input serialized as a request object. The request object is unknown,\n   * so you cannot modify it directly. When work with request, you need to guard its\n   * type to e.g. HttpRequest with 'instanceof' operand\n   *\n   * During the build phase of the execution of a middleware stack, a built\n   * request may or may not be available.\n   */\n  request?: unknown;\n}\n\nexport interface SerializeHandlerOutput<Output extends object> extends InitializeHandlerOutput<Output> {}\n\nexport interface BuildHandlerArguments<Input extends object> extends FinalizeHandlerArguments<Input> {}\n\nexport interface BuildHandlerOutput<Output extends object> extends InitializeHandlerOutput<Output> {}\n\nexport interface FinalizeHandlerArguments<Input extends object> extends SerializeHandlerArguments<Input> {\n  /**\n   * The user input serialized as a request.\n   */\n  request: unknown;\n}\n\nexport interface FinalizeHandlerOutput<Output extends object> extends InitializeHandlerOutput<Output> {}\n\nexport interface DeserializeHandlerArguments<Input extends object> extends FinalizeHandlerArguments<Input> {}\n\nexport interface DeserializeHandlerOutput<Output extends object> {\n  /**\n   * The raw response object from runtime is deserialized to structured output object.\n   * The response object is unknown so you cannot modify it directly. When work with\n   * response, you need to guard its type to e.g. HttpResponse with 'instanceof' operand.\n   *\n   * During the deserialize phase of the execution of a middleware stack, a deserialized\n   * response may or may not be available\n   */\n  response: unknown;\n  output?: Output;\n}\n\nexport interface InitializeHandler<Input extends object, Output extends object> {\n  /**\n   * Asynchronously converts an input object into an output object.\n   *\n   * @param args  An object containing a input to the command as well as any\n   *              associated or previously generated execution artifacts.\n   */\n  (args: InitializeHandlerArguments<Input>): Promise<InitializeHandlerOutput<Output>>;\n}\n\nexport type Handler<Input extends object, Output extends object> = InitializeHandler<Input, Output>;\n\nexport interface SerializeHandler<Input extends object, Output extends object> {\n  /**\n   * Asynchronously converts an input object into an output object.\n   *\n   * @param args  An object containing a input to the command as well as any\n   *              associated or previously generated execution artifacts.\n   */\n  (args: SerializeHandlerArguments<Input>): Promise<SerializeHandlerOutput<Output>>;\n}\n\nexport interface FinalizeHandler<Input extends object, Output extends object> {\n  /**\n   * Asynchronously converts an input object into an output object.\n   *\n   * @param args  An object containing a input to the command as well as any\n   *              associated or previously generated execution artifacts.\n   */\n  (args: FinalizeHandlerArguments<Input>): Promise<FinalizeHandlerOutput<Output>>;\n}\n\nexport interface BuildHandler<Input extends object, Output extends object> {\n  (args: BuildHandlerArguments<Input>): Promise<BuildHandlerOutput<Output>>;\n}\n\nexport interface DeserializeHandler<Input extends object, Output extends object> {\n  (args: DeserializeHandlerArguments<Input>): Promise<DeserializeHandlerOutput<Output>>;\n}\n\n/**\n * A factory function that creates functions implementing the {Handler}\n * interface.\n */\nexport interface InitializeMiddleware<Input extends object, Output extends object> {\n  /**\n   * @param next The handler to invoke after this middleware has operated on\n   * the user input and before this middleware operates on the output.\n   *\n   * @param context Invariant data and functions for use by the handler.\n   */\n  (next: InitializeHandler<Input, Output>, context: HandlerExecutionContext): InitializeHandler<Input, Output>;\n}\n\n/**\n * A factory function that creates functions implementing the {BuildHandler}\n * interface.\n */\nexport interface SerializeMiddleware<Input extends object, Output extends object> {\n  /**\n   * @param next The handler to invoke after this middleware has operated on\n   * the user input and before this middleware operates on the output.\n   *\n   * @param context Invariant data and functions for use by the handler.\n   */\n  (next: SerializeHandler<Input, Output>, context: HandlerExecutionContext): SerializeHandler<Input, Output>;\n}\n\n/**\n * A factory function that creates functions implementing the {FinalizeHandler}\n * interface.\n */\nexport interface FinalizeRequestMiddleware<Input extends object, Output extends object> {\n  /**\n   * @param next The handler to invoke after this middleware has operated on\n   * the user input and before this middleware operates on the output.\n   *\n   * @param context Invariant data and functions for use by the handler.\n   */\n  (next: FinalizeHandler<Input, Output>, context: HandlerExecutionContext): FinalizeHandler<Input, Output>;\n}\n\nexport interface BuildMiddleware<Input extends object, Output extends object> {\n  (next: BuildHandler<Input, Output>, context: HandlerExecutionContext): BuildHandler<Input, Output>;\n}\n\nexport interface DeserializeMiddleware<Input extends object, Output extends object> {\n  (next: DeserializeHandler<Input, Output>, context: HandlerExecutionContext): DeserializeHandler<Input, Output>;\n}\n\nexport type MiddlewareType<Input extends object, Output extends object> =\n  | InitializeMiddleware<Input, Output>\n  | SerializeMiddleware<Input, Output>\n  | BuildMiddleware<Input, Output>\n  | FinalizeRequestMiddleware<Input, Output>\n  | DeserializeMiddleware<Input, Output>;\n\n/**\n * A factory function that creates the terminal handler atop which a middleware\n * stack sits.\n */\nexport interface Terminalware {\n  <Input extends object, Output extends object>(context: HandlerExecutionContext): DeserializeHandler<Input, Output>;\n}\n\nexport type Step = \"initialize\" | \"serialize\" | \"build\" | \"finalizeRequest\" | \"deserialize\";\n\nexport type Priority = \"high\" | \"normal\" | \"low\";\n\nexport interface HandlerOptions {\n  /**\n   * Handlers are ordered using a \"step\" that describes the stage of command\n   * execution at which the handler will be executed. The available steps are:\n   *\n   * - initialize: The input is being prepared. Examples of typical\n   *      initialization tasks include injecting default options computing\n   *      derived parameters.\n   * - serialize: The input is complete and ready to be serialized. Examples\n   *      of typical serialization tasks include input validation and building\n   *      an HTTP request from user input.\n   * - build: The input has been serialized into an HTTP request, but that\n   *      request may require further modification. Any request alterations\n   *      will be applied to all retries. Examples of typical build tasks\n   *      include injecting HTTP headers that describe a stable aspect of the\n   *      request, such as `Content-Length` or a body checksum.\n   * - finalizeRequest: The request is being prepared to be sent over the wire. The\n   *      request in this stage should already be semantically complete and\n   *      should therefore only be altered as match the recipient's\n   *      expectations. Examples of typical finalization tasks include request\n   *      signing and injecting hop-by-hop headers.\n   * - deserialize: The response has arrived, the middleware here will deserialize\n   *      the raw response object to structured response\n   *\n   *      Unlike initialization and build handlers, which are executed once\n   *      per operation execution, finalization and deserialize handlers will be\n   *      executed foreach HTTP request sent.\n   *\n   * @default 'initialize'\n   */\n  step?: Step;\n\n  /**\n   * A list of strings to any that identify the general purpose or important\n   * characteristics of a given handler.\n   */\n  tags?: Array<string>;\n\n  /**\n   * A unique name to refer to a middleware\n   */\n  name?: string;\n}\nexport interface AbsoluteLocation {\n  /**\n   * By default middleware will be added to individual step in un-guaranteed order.\n   * In the case that\n   *\n   * @default 'normal'\n   */\n  priority?: Priority;\n}\n\nexport type Relation = \"before\" | \"after\";\n\nexport interface RelativeLocation {\n  /**\n   * Specify the relation to be before or after a know middleware.\n   */\n  relation: Relation;\n\n  /**\n   * A known middleware name to indicate inserting middleware's location.\n   */\n  toMiddleware: string;\n}\n\nexport type RelativeMiddlewareOptions = RelativeLocation & Omit<HandlerOptions, \"step\">;\n\nexport interface InitializeHandlerOptions extends HandlerOptions {\n  step?: \"initialize\";\n}\n\nexport interface SerializeHandlerOptions extends HandlerOptions {\n  step: \"serialize\";\n}\n\nexport interface BuildHandlerOptions extends HandlerOptions {\n  step: \"build\";\n}\n\nexport interface FinalizeRequestHandlerOptions extends HandlerOptions {\n  step: \"finalizeRequest\";\n}\n\nexport interface DeserializeHandlerOptions extends HandlerOptions {\n  step: \"deserialize\";\n}\n\n/**\n * A stack storing middleware. It can be resolved into a handler. It supports 2\n * approaches for adding middleware:\n * 1. Adding middleware to specific step with `add()`. The order of middleware\n *    added into same step is determined by order of adding them. If one middleware\n *    needs to be executed at the front of the step or at the end of step, set\n *    `priority` options to `high` or `low`.\n * 2. Adding middleware to location relative to known middleware with `addRelativeTo()`.\n *    This is useful when given middleware must be executed before or after specific\n *    middleware(`toMiddleware`). You can add a middleware relatively to another\n *    middleware which also added relatively. But eventually, this relative middleware\n *    chain **must** be 'anchored' by a middleware that added using `add()` API\n *    with absolute `step` and `priority`. This mothod will throw if specified\n *    `toMiddleware` is not found.\n */\nexport interface MiddlewareStack<Input extends object, Output extends object> extends Pluggable<Input, Output> {\n  /**\n   * Add middleware to the stack to be executed during the \"initialize\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: InitializeMiddleware<Input, Output>, options?: InitializeHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"serialize\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: SerializeMiddleware<Input, Output>, options: SerializeHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"build\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: BuildMiddleware<Input, Output>, options: BuildHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"finalizeRequest\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(\n    middleware: FinalizeRequestMiddleware<Input, Output>,\n    options: FinalizeRequestHandlerOptions & AbsoluteLocation\n  ): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"deserialize\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: DeserializeMiddleware<Input, Output>, options: DeserializeHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to a stack position before or after a known middleware，optionally\n   * specifying name and tags.\n   */\n  addRelativeTo(middleware: MiddlewareType<Input, Output>, options: RelativeMiddlewareOptions): void;\n\n  /**\n   * Apply a customization function to mutate the middleware stack, often\n   * used for customizations that requires mutating multiple middleware.\n   */\n  use(pluggable: Pluggable<Input, Output>): void;\n\n  /**\n   * Create a shallow clone of this stack. Step bindings and handler priorities\n   * and tags are preserved in the copy.\n   */\n  clone(): MiddlewareStack<Input, Output>;\n\n  /**\n   * Removes middleware from the stack.\n   *\n   * If a string is provided, it will be treated as middleware name. If a middleware\n   * is inserted with the given name, it will be removed.\n   *\n   * If a middleware class is provided, all usages thereof will be removed.\n   */\n  remove(toRemove: MiddlewareType<Input, Output> | string): boolean;\n\n  /**\n   * Removes middleware that contains given tag\n   *\n   * Multiple middleware will potentially be removed\n   */\n  removeByTag(toRemove: string): boolean;\n\n  /**\n   * Create a stack containing the middlewares in this stack as well as the\n   * middlewares in the `from` stack. Neither source is modified, and step\n   * bindings and handler priorities and tags are preserved in the copy.\n   */\n  concat<InputType extends Input, OutputType extends Output>(\n    from: MiddlewareStack<InputType, OutputType>\n  ): MiddlewareStack<InputType, OutputType>;\n\n  /**\n   * Builds a single handler function from zero or more middleware classes and\n   * a core handler. The core handler is meant to send command objects to AWS\n   * services and return promises that will resolve with the operation result\n   * or be rejected with an error.\n   *\n   * When a composed handler is invoked, the arguments will pass through all\n   * middleware in a defined order, and the return from the innermost handler\n   * will pass through all middleware in the reverse of that order.\n   */\n  resolve<InputType extends Input, OutputType extends Output>(\n    handler: DeserializeHandler<InputType, OutputType>,\n    context: HandlerExecutionContext\n  ): InitializeHandler<InputType, OutputType>;\n}\n\n/**\n * Data and helper objects that are not expected to change from one execution of\n * a composed handler to another.\n */\nexport interface HandlerExecutionContext {\n  /**\n   * A logger that may be invoked by any handler during execution of an\n   * operation.\n   */\n  logger?: Logger;\n\n  [key: string]: any;\n}\n\nexport interface Pluggable<Input extends object, Output extends object> {\n  /**\n   * A function that mutate the passed in middleware stack. Functions implementing\n   * this interface can add, remove, modify existing middleware stack from clients\n   * or commands\n   */\n  applyToStack: (stack: MiddlewareStack<Input, Output>) => void;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../src/middleware.ts"],"names":[],"mappings":"","sourcesContent":["import { Logger } from \"./logger\";\nimport { UserAgent } from \"./util\";\n\nexport interface InitializeHandlerArguments<Input extends object> {\n  /**\n   * User input to a command. Reflects the userland representation of the\n   * union of data types the command can effectively handle.\n   */\n  input: Input;\n}\n\nexport interface InitializeHandlerOutput<Output extends object> extends DeserializeHandlerOutput<Output> {\n  output: Output;\n}\n\nexport interface SerializeHandlerArguments<Input extends object> extends InitializeHandlerArguments<Input> {\n  /**\n   * The user input serialized as a request object. The request object is unknown,\n   * so you cannot modify it directly. When work with request, you need to guard its\n   * type to e.g. HttpRequest with 'instanceof' operand\n   *\n   * During the build phase of the execution of a middleware stack, a built\n   * request may or may not be available.\n   */\n  request?: unknown;\n}\n\nexport interface SerializeHandlerOutput<Output extends object> extends InitializeHandlerOutput<Output> {}\n\nexport interface BuildHandlerArguments<Input extends object> extends FinalizeHandlerArguments<Input> {}\n\nexport interface BuildHandlerOutput<Output extends object> extends InitializeHandlerOutput<Output> {}\n\nexport interface FinalizeHandlerArguments<Input extends object> extends SerializeHandlerArguments<Input> {\n  /**\n   * The user input serialized as a request.\n   */\n  request: unknown;\n}\n\nexport interface FinalizeHandlerOutput<Output extends object> extends InitializeHandlerOutput<Output> {}\n\nexport interface DeserializeHandlerArguments<Input extends object> extends FinalizeHandlerArguments<Input> {}\n\nexport interface DeserializeHandlerOutput<Output extends object> {\n  /**\n   * The raw response object from runtime is deserialized to structured output object.\n   * The response object is unknown so you cannot modify it directly. When work with\n   * response, you need to guard its type to e.g. HttpResponse with 'instanceof' operand.\n   *\n   * During the deserialize phase of the execution of a middleware stack, a deserialized\n   * response may or may not be available\n   */\n  response: unknown;\n  output?: Output;\n}\n\nexport interface InitializeHandler<Input extends object, Output extends object> {\n  /**\n   * Asynchronously converts an input object into an output object.\n   *\n   * @param args  An object containing a input to the command as well as any\n   *              associated or previously generated execution artifacts.\n   */\n  (args: InitializeHandlerArguments<Input>): Promise<InitializeHandlerOutput<Output>>;\n}\n\nexport type Handler<Input extends object, Output extends object> = InitializeHandler<Input, Output>;\n\nexport interface SerializeHandler<Input extends object, Output extends object> {\n  /**\n   * Asynchronously converts an input object into an output object.\n   *\n   * @param args  An object containing a input to the command as well as any\n   *              associated or previously generated execution artifacts.\n   */\n  (args: SerializeHandlerArguments<Input>): Promise<SerializeHandlerOutput<Output>>;\n}\n\nexport interface FinalizeHandler<Input extends object, Output extends object> {\n  /**\n   * Asynchronously converts an input object into an output object.\n   *\n   * @param args  An object containing a input to the command as well as any\n   *              associated or previously generated execution artifacts.\n   */\n  (args: FinalizeHandlerArguments<Input>): Promise<FinalizeHandlerOutput<Output>>;\n}\n\nexport interface BuildHandler<Input extends object, Output extends object> {\n  (args: BuildHandlerArguments<Input>): Promise<BuildHandlerOutput<Output>>;\n}\n\nexport interface DeserializeHandler<Input extends object, Output extends object> {\n  (args: DeserializeHandlerArguments<Input>): Promise<DeserializeHandlerOutput<Output>>;\n}\n\n/**\n * A factory function that creates functions implementing the {Handler}\n * interface.\n */\nexport interface InitializeMiddleware<Input extends object, Output extends object> {\n  /**\n   * @param next The handler to invoke after this middleware has operated on\n   * the user input and before this middleware operates on the output.\n   *\n   * @param context Invariant data and functions for use by the handler.\n   */\n  (next: InitializeHandler<Input, Output>, context: HandlerExecutionContext): InitializeHandler<Input, Output>;\n}\n\n/**\n * A factory function that creates functions implementing the {BuildHandler}\n * interface.\n */\nexport interface SerializeMiddleware<Input extends object, Output extends object> {\n  /**\n   * @param next The handler to invoke after this middleware has operated on\n   * the user input and before this middleware operates on the output.\n   *\n   * @param context Invariant data and functions for use by the handler.\n   */\n  (next: SerializeHandler<Input, Output>, context: HandlerExecutionContext): SerializeHandler<Input, Output>;\n}\n\n/**\n * A factory function that creates functions implementing the {FinalizeHandler}\n * interface.\n */\nexport interface FinalizeRequestMiddleware<Input extends object, Output extends object> {\n  /**\n   * @param next The handler to invoke after this middleware has operated on\n   * the user input and before this middleware operates on the output.\n   *\n   * @param context Invariant data and functions for use by the handler.\n   */\n  (next: FinalizeHandler<Input, Output>, context: HandlerExecutionContext): FinalizeHandler<Input, Output>;\n}\n\nexport interface BuildMiddleware<Input extends object, Output extends object> {\n  (next: BuildHandler<Input, Output>, context: HandlerExecutionContext): BuildHandler<Input, Output>;\n}\n\nexport interface DeserializeMiddleware<Input extends object, Output extends object> {\n  (next: DeserializeHandler<Input, Output>, context: HandlerExecutionContext): DeserializeHandler<Input, Output>;\n}\n\nexport type MiddlewareType<Input extends object, Output extends object> =\n  | InitializeMiddleware<Input, Output>\n  | SerializeMiddleware<Input, Output>\n  | BuildMiddleware<Input, Output>\n  | FinalizeRequestMiddleware<Input, Output>\n  | DeserializeMiddleware<Input, Output>;\n\n/**\n * A factory function that creates the terminal handler atop which a middleware\n * stack sits.\n */\nexport interface Terminalware {\n  <Input extends object, Output extends object>(context: HandlerExecutionContext): DeserializeHandler<Input, Output>;\n}\n\nexport type Step = \"initialize\" | \"serialize\" | \"build\" | \"finalizeRequest\" | \"deserialize\";\n\nexport type Priority = \"high\" | \"normal\" | \"low\";\n\nexport interface HandlerOptions {\n  /**\n   * Handlers are ordered using a \"step\" that describes the stage of command\n   * execution at which the handler will be executed. The available steps are:\n   *\n   * - initialize: The input is being prepared. Examples of typical\n   *      initialization tasks include injecting default options computing\n   *      derived parameters.\n   * - serialize: The input is complete and ready to be serialized. Examples\n   *      of typical serialization tasks include input validation and building\n   *      an HTTP request from user input.\n   * - build: The input has been serialized into an HTTP request, but that\n   *      request may require further modification. Any request alterations\n   *      will be applied to all retries. Examples of typical build tasks\n   *      include injecting HTTP headers that describe a stable aspect of the\n   *      request, such as `Content-Length` or a body checksum.\n   * - finalizeRequest: The request is being prepared to be sent over the wire. The\n   *      request in this stage should already be semantically complete and\n   *      should therefore only be altered as match the recipient's\n   *      expectations. Examples of typical finalization tasks include request\n   *      signing and injecting hop-by-hop headers.\n   * - deserialize: The response has arrived, the middleware here will deserialize\n   *      the raw response object to structured response\n   *\n   *      Unlike initialization and build handlers, which are executed once\n   *      per operation execution, finalization and deserialize handlers will be\n   *      executed foreach HTTP request sent.\n   *\n   * @default 'initialize'\n   */\n  step?: Step;\n\n  /**\n   * A list of strings to any that identify the general purpose or important\n   * characteristics of a given handler.\n   */\n  tags?: Array<string>;\n\n  /**\n   * A unique name to refer to a middleware\n   */\n  name?: string;\n}\nexport interface AbsoluteLocation {\n  /**\n   * By default middleware will be added to individual step in un-guaranteed order.\n   * In the case that\n   *\n   * @default 'normal'\n   */\n  priority?: Priority;\n}\n\nexport type Relation = \"before\" | \"after\";\n\nexport interface RelativeLocation {\n  /**\n   * Specify the relation to be before or after a know middleware.\n   */\n  relation: Relation;\n\n  /**\n   * A known middleware name to indicate inserting middleware's location.\n   */\n  toMiddleware: string;\n}\n\nexport type RelativeMiddlewareOptions = RelativeLocation & Omit<HandlerOptions, \"step\">;\n\nexport interface InitializeHandlerOptions extends HandlerOptions {\n  step?: \"initialize\";\n}\n\nexport interface SerializeHandlerOptions extends HandlerOptions {\n  step: \"serialize\";\n}\n\nexport interface BuildHandlerOptions extends HandlerOptions {\n  step: \"build\";\n}\n\nexport interface FinalizeRequestHandlerOptions extends HandlerOptions {\n  step: \"finalizeRequest\";\n}\n\nexport interface DeserializeHandlerOptions extends HandlerOptions {\n  step: \"deserialize\";\n}\n\n/**\n * A stack storing middleware. It can be resolved into a handler. It supports 2\n * approaches for adding middleware:\n * 1. Adding middleware to specific step with `add()`. The order of middleware\n *    added into same step is determined by order of adding them. If one middleware\n *    needs to be executed at the front of the step or at the end of step, set\n *    `priority` options to `high` or `low`.\n * 2. Adding middleware to location relative to known middleware with `addRelativeTo()`.\n *    This is useful when given middleware must be executed before or after specific\n *    middleware(`toMiddleware`). You can add a middleware relatively to another\n *    middleware which also added relatively. But eventually, this relative middleware\n *    chain **must** be 'anchored' by a middleware that added using `add()` API\n *    with absolute `step` and `priority`. This mothod will throw if specified\n *    `toMiddleware` is not found.\n */\nexport interface MiddlewareStack<Input extends object, Output extends object> extends Pluggable<Input, Output> {\n  /**\n   * Add middleware to the stack to be executed during the \"initialize\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: InitializeMiddleware<Input, Output>, options?: InitializeHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"serialize\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: SerializeMiddleware<Input, Output>, options: SerializeHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"build\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: BuildMiddleware<Input, Output>, options: BuildHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"finalizeRequest\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(\n    middleware: FinalizeRequestMiddleware<Input, Output>,\n    options: FinalizeRequestHandlerOptions & AbsoluteLocation\n  ): void;\n\n  /**\n   * Add middleware to the stack to be executed during the \"deserialize\" step,\n   * optionally specifying a priority, tags and name\n   */\n  add(middleware: DeserializeMiddleware<Input, Output>, options: DeserializeHandlerOptions & AbsoluteLocation): void;\n\n  /**\n   * Add middleware to a stack position before or after a known middleware，optionally\n   * specifying name and tags.\n   */\n  addRelativeTo(middleware: MiddlewareType<Input, Output>, options: RelativeMiddlewareOptions): void;\n\n  /**\n   * Apply a customization function to mutate the middleware stack, often\n   * used for customizations that requires mutating multiple middleware.\n   */\n  use(pluggable: Pluggable<Input, Output>): void;\n\n  /**\n   * Create a shallow clone of this stack. Step bindings and handler priorities\n   * and tags are preserved in the copy.\n   */\n  clone(): MiddlewareStack<Input, Output>;\n\n  /**\n   * Removes middleware from the stack.\n   *\n   * If a string is provided, it will be treated as middleware name. If a middleware\n   * is inserted with the given name, it will be removed.\n   *\n   * If a middleware class is provided, all usages thereof will be removed.\n   */\n  remove(toRemove: MiddlewareType<Input, Output> | string): boolean;\n\n  /**\n   * Removes middleware that contains given tag\n   *\n   * Multiple middleware will potentially be removed\n   */\n  removeByTag(toRemove: string): boolean;\n\n  /**\n   * Create a stack containing the middlewares in this stack as well as the\n   * middlewares in the `from` stack. Neither source is modified, and step\n   * bindings and handler priorities and tags are preserved in the copy.\n   */\n  concat<InputType extends Input, OutputType extends Output>(\n    from: MiddlewareStack<InputType, OutputType>\n  ): MiddlewareStack<InputType, OutputType>;\n\n  /**\n   * Builds a single handler function from zero or more middleware classes and\n   * a core handler. The core handler is meant to send command objects to AWS\n   * services and return promises that will resolve with the operation result\n   * or be rejected with an error.\n   *\n   * When a composed handler is invoked, the arguments will pass through all\n   * middleware in a defined order, and the return from the innermost handler\n   * will pass through all middleware in the reverse of that order.\n   */\n  resolve<InputType extends Input, OutputType extends Output>(\n    handler: DeserializeHandler<InputType, OutputType>,\n    context: HandlerExecutionContext\n  ): InitializeHandler<InputType, OutputType>;\n}\n\n/**\n * Data and helper objects that are not expected to change from one execution of\n * a composed handler to another.\n */\nexport interface HandlerExecutionContext {\n  /**\n   * A logger that may be invoked by any handler during execution of an\n   * operation.\n   */\n  logger?: Logger;\n\n  /**\n   * Additional user agent that inferred by middleware. It can be used to save\n   * the internal user agent sections without overriding the `customUserAgent`\n   * config in clients.\n   */\n  userAgent?: UserAgent;\n\n  [key: string]: any;\n}\n\nexport interface Pluggable<Input extends object, Output extends object> {\n  /**\n   * A function that mutate the passed in middleware stack. Functions implementing\n   * this interface can add, remove, modify existing middleware stack from clients\n   * or commands\n   */\n  applyToStack: (stack: MiddlewareStack<Input, Output>) => void;\n}\n"]}

@@ -1,2 +0,1 @@

import { HeaderBag } from "./http";
export interface ResponseMetadata {

@@ -8,6 +7,2 @@ /**

/**
* The headers of the last HTTP response received for this operation.
*/
httpHeaders?: HeaderBag;
/**
* A unique identifier for the last request sent for this operation. Often

@@ -14,0 +9,0 @@ * requested by AWS service teams to aid in debugging.

export {};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzcG9uc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVzcG9uc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhlYWRlckJhZyB9IGZyb20gXCIuL2h0dHBcIjtcblxuZXhwb3J0IGludGVyZmFjZSBSZXNwb25zZU1ldGFkYXRhIHtcbiAgLyoqXG4gICAqIFRoZSBzdGF0dXMgY29kZSBvZiB0aGUgbGFzdCBIVFRQIHJlc3BvbnNlIHJlY2VpdmVkIGZvciB0aGlzIG9wZXJhdGlvbi5cbiAgICovXG4gIGh0dHBTdGF0dXNDb2RlPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBUaGUgaGVhZGVycyBvZiB0aGUgbGFzdCBIVFRQIHJlc3BvbnNlIHJlY2VpdmVkIGZvciB0aGlzIG9wZXJhdGlvbi5cbiAgICovXG4gIGh0dHBIZWFkZXJzPzogSGVhZGVyQmFnO1xuXG4gIC8qKlxuICAgKiBBIHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGUgbGFzdCByZXF1ZXN0IHNlbnQgZm9yIHRoaXMgb3BlcmF0aW9uLiBPZnRlblxuICAgKiByZXF1ZXN0ZWQgYnkgQVdTIHNlcnZpY2UgdGVhbXMgdG8gYWlkIGluIGRlYnVnZ2luZy5cbiAgICovXG4gIHJlcXVlc3RJZD86IHN0cmluZztcblxuICAvKipcbiAgICogQSBzZWNvbmRhcnkgaWRlbnRpZmllciBmb3IgdGhlIGxhc3QgcmVxdWVzdCBzZW50LiBVc2VkIGZvciBkZWJ1Z2dpbmcuXG4gICAqL1xuICBleHRlbmRlZFJlcXVlc3RJZD86IHN0cmluZztcblxuICAvKipcbiAgICogQSB0ZXJ0aWFyeSBpZGVudGlmaWVyIGZvciB0aGUgbGFzdCByZXF1ZXN0IHNlbnQuIFVzZWQgZm9yIGRlYnVnZ2luZy5cbiAgICovXG4gIGNmSWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBudW1iZXIgb2YgdGltZXMgdGhpcyBvcGVyYXRpb24gd2FzIGF0dGVtcHRlZC5cbiAgICovXG4gIGF0dGVtcHRzPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBUaGUgdG90YWwgYW1vdW50IG9mIHRpbWUgKGluIG1pbGxpc2Vjb25kcykgdGhhdCB3YXMgc3BlbnQgd2FpdGluZyBiZXR3ZWVuXG4gICAqIHJldHJ5IGF0dGVtcHRzLlxuICAgKi9cbiAgdG90YWxSZXRyeURlbGF5PzogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1ldGFkYXRhQmVhcmVyIHtcbiAgLyoqXG4gICAqIE1ldGFkYXRhIHBlcnRhaW5pbmcgdG8gdGhpcyByZXF1ZXN0LlxuICAgKi9cbiAgJG1ldGFkYXRhOiBSZXNwb25zZU1ldGFkYXRhO1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzcG9uc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVzcG9uc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUmVzcG9uc2VNZXRhZGF0YSB7XG4gIC8qKlxuICAgKiBUaGUgc3RhdHVzIGNvZGUgb2YgdGhlIGxhc3QgSFRUUCByZXNwb25zZSByZWNlaXZlZCBmb3IgdGhpcyBvcGVyYXRpb24uXG4gICAqL1xuICBodHRwU3RhdHVzQ29kZT86IG51bWJlcjtcblxuICAvKipcbiAgICogQSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGxhc3QgcmVxdWVzdCBzZW50IGZvciB0aGlzIG9wZXJhdGlvbi4gT2Z0ZW5cbiAgICogcmVxdWVzdGVkIGJ5IEFXUyBzZXJ2aWNlIHRlYW1zIHRvIGFpZCBpbiBkZWJ1Z2dpbmcuXG4gICAqL1xuICByZXF1ZXN0SWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgc2Vjb25kYXJ5IGlkZW50aWZpZXIgZm9yIHRoZSBsYXN0IHJlcXVlc3Qgc2VudC4gVXNlZCBmb3IgZGVidWdnaW5nLlxuICAgKi9cbiAgZXh0ZW5kZWRSZXF1ZXN0SWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgdGVydGlhcnkgaWRlbnRpZmllciBmb3IgdGhlIGxhc3QgcmVxdWVzdCBzZW50LiBVc2VkIGZvciBkZWJ1Z2dpbmcuXG4gICAqL1xuICBjZklkPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgbnVtYmVyIG9mIHRpbWVzIHRoaXMgb3BlcmF0aW9uIHdhcyBhdHRlbXB0ZWQuXG4gICAqL1xuICBhdHRlbXB0cz86IG51bWJlcjtcblxuICAvKipcbiAgICogVGhlIHRvdGFsIGFtb3VudCBvZiB0aW1lIChpbiBtaWxsaXNlY29uZHMpIHRoYXQgd2FzIHNwZW50IHdhaXRpbmcgYmV0d2VlblxuICAgKiByZXRyeSBhdHRlbXB0cy5cbiAgICovXG4gIHRvdGFsUmV0cnlEZWxheT86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNZXRhZGF0YUJlYXJlciB7XG4gIC8qKlxuICAgKiBNZXRhZGF0YSBwZXJ0YWluaW5nIHRvIHRoaXMgcmVxdWVzdC5cbiAgICovXG4gICRtZXRhZGF0YTogUmVzcG9uc2VNZXRhZGF0YTtcbn1cbiJdfQ==

@@ -52,2 +52,6 @@ import { Endpoint } from "./http";

/**
* The retry mode describing how the retry strategy control the traffic flow.
*/
mode?: string;
/**
* the retry behavior the will invoke the next handler and handle the retry accordingly.

@@ -85,1 +89,11 @@ * This function should also update the $metadata from the response accordingly.

}
/**
* A tuple that represents an API name and optional version
* of a library built using the AWS SDK.
*/
export declare type UserAgentPair = [name: string, version?: string];
/**
* User agent data that to be put into the request's user
* agent.
*/
export declare type UserAgent = UserAgentPair[];
export {};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbmRwb2ludCB9IGZyb20gXCIuL2h0dHBcIjtcbmltcG9ydCB7IEZpbmFsaXplSGFuZGxlciwgRmluYWxpemVIYW5kbGVyQXJndW1lbnRzLCBGaW5hbGl6ZUhhbmRsZXJPdXRwdXQgfSBmcm9tIFwiLi9taWRkbGV3YXJlXCI7XG5pbXBvcnQgeyBNZXRhZGF0YUJlYXJlciB9IGZyb20gXCIuL3Jlc3BvbnNlXCI7XG5cbi8qKlxuICogQSBmdW5jdGlvbiB0aGF0LCBnaXZlbiBhIFR5cGVkQXJyYXkgb2YgYnl0ZXMsIGNhbiBwcm9kdWNlIGEgc3RyaW5nXG4gKiByZXByZXNlbnRhdGlvbiB0aGVyZW9mLlxuICpcbiAqIEBleGFtcGxlIEFuIGVuY29kZXIgZnVuY3Rpb24gdGhhdCBjb252ZXJ0cyBieXRlcyB0byBoZXhhZGVjaW1hbFxuICogcmVwcmVzZW50YXRpb24gd291bGQgcmV0dXJuIGAnZGVhZGJlZWYnYCB3aGVuIGdpdmVuIGBuZXdcbiAqIFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRW5jb2RlciB7XG4gIChpbnB1dDogVWludDhBcnJheSk6IHN0cmluZztcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIGdpdmVuIGEgc3RyaW5nLCBjYW4gZGVyaXZlIHRoZSBieXRlcyByZXByZXNlbnRlZCBieSB0aGF0XG4gKiBzdHJpbmcuXG4gKlxuICogQGV4YW1wbGUgQSBkZWNvZGVyIGZ1bmN0aW9uIHRoYXQgY29udmVydHMgYnl0ZXMgdG8gaGV4YWRlY2ltYWxcbiAqIHJlcHJlc2VudGF0aW9uIHdvdWxkIHJldHVybiBgbmV3IFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAgd2hlblxuICogZ2l2ZW4gdGhlIHN0cmluZyBgJ2RlYWRiZWVmJ2AuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGVjb2RlciB7XG4gIChpbnB1dDogc3RyaW5nKTogVWludDhBcnJheTtcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIHdoZW4gaW52b2tlZCwgcmV0dXJucyBhIHByb21pc2UgdGhhdCB3aWxsIGJlIGZ1bGZpbGxlZCB3aXRoXG4gKiBhIHZhbHVlIG9mIHR5cGUgVC5cbiAqXG4gKiBAZXhhbXBsZSBBIGZ1bmN0aW9uIHRoYXQgcmVhZHMgY3JlZGVudGlhbHMgZnJvbSBzaGFyZWQgU0RLIGNvbmZpZ3VyYXRpb25cbiAqIGZpbGVzLCBhc3N1bWluZyByb2xlcyBhbmQgY29sbGVjdGluZyBNRkEgdG9rZW5zIGFzIG5lY2Vzc2FyeS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQcm92aWRlcjxUPiB7XG4gICgpOiBQcm9taXNlPFQ+O1xufVxuXG4vKipcbiAqIEEgZnVuY3Rpb24gdGhhdCwgZ2l2ZW4gYSByZXF1ZXN0IGJvZHksIGRldGVybWluZXMgdGhlXG4gKiBsZW5ndGggb2YgdGhlIGJvZHkuIFRoaXMgaXMgdXNlZCB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtTGVuZ3RoXG4gKiB0aGF0IHNob3VsZCBiZSBzZW50IHdpdGggYSByZXF1ZXN0LlxuICpcbiAqIEBleGFtcGxlIEEgZnVuY3Rpb24gdGhhdCByZWFkcyBhIGZpbGUgc3RyZWFtIGFuZCBjYWxjdWxhdGVzXG4gKiB0aGUgc2l6ZSBvZiB0aGUgZmlsZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCb2R5TGVuZ3RoQ2FsY3VsYXRvciB7XG4gIChib2R5OiBhbnkpOiBudW1iZXIgfCB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogSW50ZXJmYWNlIHRoYXQgc3BlY2lmaWVzIHRoZSByZXRyeSBiZWhhdmlvclxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJldHJ5U3RyYXRlZ3kge1xuICAvKipcbiAgICogdGhlIHJldHJ5IGJlaGF2aW9yIHRoZSB3aWxsIGludm9rZSB0aGUgbmV4dCBoYW5kbGVyIGFuZCBoYW5kbGUgdGhlIHJldHJ5IGFjY29yZGluZ2x5LlxuICAgKiBUaGlzIGZ1bmN0aW9uIHNob3VsZCBhbHNvIHVwZGF0ZSB0aGUgJG1ldGFkYXRhIGZyb20gdGhlIHJlc3BvbnNlIGFjY29yZGluZ2x5LlxuICAgKiBAc2VlIHtAbGluayBSZXNwb25zZU1ldGFkYXRhfVxuICAgKi9cbiAgcmV0cnk6IDxJbnB1dCBleHRlbmRzIG9iamVjdCwgT3V0cHV0IGV4dGVuZHMgTWV0YWRhdGFCZWFyZXI+KFxuICAgIG5leHQ6IEZpbmFsaXplSGFuZGxlcjxJbnB1dCwgT3V0cHV0PixcbiAgICBhcmdzOiBGaW5hbGl6ZUhhbmRsZXJBcmd1bWVudHM8SW5wdXQ+XG4gICkgPT4gUHJvbWlzZTxGaW5hbGl6ZUhhbmRsZXJPdXRwdXQ8T3V0cHV0Pj47XG59XG5cbi8qKlxuICogUGFyc2VzIGEgVVJMIGluIHN0cmluZyBmb3JtIGludG8gYW4gRW5kcG9pbnQgb2JqZWN0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFVybFBhcnNlciB7XG4gICh1cmw6IHN0cmluZyk6IEVuZHBvaW50O1xufVxuXG4vKipcbiAqIE9iamVjdCBjb250YWluaW5nIHJlZ2lvbmFsaXphdGlvbiBpbmZvcm1hdGlvbiBvZlxuICogQVdTIHNlcnZpY2VzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlZ2lvbkluZm8ge1xuICBob3N0bmFtZTogc3RyaW5nO1xuICBwYXJ0aXRpb246IHN0cmluZztcbiAgcGF0aD86IHN0cmluZztcbiAgc2lnbmluZ1NlcnZpY2U/OiBzdHJpbmc7XG4gIHNpZ25pbmdSZWdpb24/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogRnVuY3Rpb24gcmV0dXJucyBkZXNpZ25hdGVkIHNlcnZpY2UncyByZWdpb25hbGl6YXRpb25cbiAqIGluZm9ybWF0aW9uIGZyb20gZ2l2ZW4gcmVnaW9uLiBFYWNoIHNlcnZpY2UgY2xpZW50XG4gKiBjb21lcyB3aXRoIGl0cyByZWdpb25hbGl6YXRpb24gcHJvdmlkZXIuIGl0IHNlcnZlc1xuICogdG8gcHJvdmlkZSB0aGUgZGVmYXVsdCB2YWx1ZXMgb2YgcmVsYXRlZCBjb25maWd1cmF0aW9uc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlZ2lvbkluZm9Qcm92aWRlciB7XG4gIChyZWdpb246IHN0cmluZywgb3B0aW9ucz86IGFueSk6IFByb21pc2U8UmVnaW9uSW5mbyB8IHVuZGVmaW5lZD47XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbmRwb2ludCB9IGZyb20gXCIuL2h0dHBcIjtcbmltcG9ydCB7XG4gIEZpbmFsaXplSGFuZGxlcixcbiAgRmluYWxpemVIYW5kbGVyQXJndW1lbnRzLFxuICBGaW5hbGl6ZUhhbmRsZXJPdXRwdXQsXG4gIEhhbmRsZXJFeGVjdXRpb25Db250ZXh0LFxufSBmcm9tIFwiLi9taWRkbGV3YXJlXCI7XG5pbXBvcnQgeyBNZXRhZGF0YUJlYXJlciB9IGZyb20gXCIuL3Jlc3BvbnNlXCI7XG5cbi8qKlxuICogQSBmdW5jdGlvbiB0aGF0LCBnaXZlbiBhIFR5cGVkQXJyYXkgb2YgYnl0ZXMsIGNhbiBwcm9kdWNlIGEgc3RyaW5nXG4gKiByZXByZXNlbnRhdGlvbiB0aGVyZW9mLlxuICpcbiAqIEBleGFtcGxlIEFuIGVuY29kZXIgZnVuY3Rpb24gdGhhdCBjb252ZXJ0cyBieXRlcyB0byBoZXhhZGVjaW1hbFxuICogcmVwcmVzZW50YXRpb24gd291bGQgcmV0dXJuIGAnZGVhZGJlZWYnYCB3aGVuIGdpdmVuIGBuZXdcbiAqIFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRW5jb2RlciB7XG4gIChpbnB1dDogVWludDhBcnJheSk6IHN0cmluZztcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIGdpdmVuIGEgc3RyaW5nLCBjYW4gZGVyaXZlIHRoZSBieXRlcyByZXByZXNlbnRlZCBieSB0aGF0XG4gKiBzdHJpbmcuXG4gKlxuICogQGV4YW1wbGUgQSBkZWNvZGVyIGZ1bmN0aW9uIHRoYXQgY29udmVydHMgYnl0ZXMgdG8gaGV4YWRlY2ltYWxcbiAqIHJlcHJlc2VudGF0aW9uIHdvdWxkIHJldHVybiBgbmV3IFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAgd2hlblxuICogZ2l2ZW4gdGhlIHN0cmluZyBgJ2RlYWRiZWVmJ2AuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGVjb2RlciB7XG4gIChpbnB1dDogc3RyaW5nKTogVWludDhBcnJheTtcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIHdoZW4gaW52b2tlZCwgcmV0dXJucyBhIHByb21pc2UgdGhhdCB3aWxsIGJlIGZ1bGZpbGxlZCB3aXRoXG4gKiBhIHZhbHVlIG9mIHR5cGUgVC5cbiAqXG4gKiBAZXhhbXBsZSBBIGZ1bmN0aW9uIHRoYXQgcmVhZHMgY3JlZGVudGlhbHMgZnJvbSBzaGFyZWQgU0RLIGNvbmZpZ3VyYXRpb25cbiAqIGZpbGVzLCBhc3N1bWluZyByb2xlcyBhbmQgY29sbGVjdGluZyBNRkEgdG9rZW5zIGFzIG5lY2Vzc2FyeS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQcm92aWRlcjxUPiB7XG4gICgpOiBQcm9taXNlPFQ+O1xufVxuXG4vKipcbiAqIEEgZnVuY3Rpb24gdGhhdCwgZ2l2ZW4gYSByZXF1ZXN0IGJvZHksIGRldGVybWluZXMgdGhlXG4gKiBsZW5ndGggb2YgdGhlIGJvZHkuIFRoaXMgaXMgdXNlZCB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtTGVuZ3RoXG4gKiB0aGF0IHNob3VsZCBiZSBzZW50IHdpdGggYSByZXF1ZXN0LlxuICpcbiAqIEBleGFtcGxlIEEgZnVuY3Rpb24gdGhhdCByZWFkcyBhIGZpbGUgc3RyZWFtIGFuZCBjYWxjdWxhdGVzXG4gKiB0aGUgc2l6ZSBvZiB0aGUgZmlsZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCb2R5TGVuZ3RoQ2FsY3VsYXRvciB7XG4gIChib2R5OiBhbnkpOiBudW1iZXIgfCB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogSW50ZXJmYWNlIHRoYXQgc3BlY2lmaWVzIHRoZSByZXRyeSBiZWhhdmlvclxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJldHJ5U3RyYXRlZ3kge1xuICAvKipcbiAgICogVGhlIHJldHJ5IG1vZGUgZGVzY3JpYmluZyBob3cgdGhlIHJldHJ5IHN0cmF0ZWd5IGNvbnRyb2wgdGhlIHRyYWZmaWMgZmxvdy5cbiAgICovXG4gIG1vZGU/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiB0aGUgcmV0cnkgYmVoYXZpb3IgdGhlIHdpbGwgaW52b2tlIHRoZSBuZXh0IGhhbmRsZXIgYW5kIGhhbmRsZSB0aGUgcmV0cnkgYWNjb3JkaW5nbHkuXG4gICAqIFRoaXMgZnVuY3Rpb24gc2hvdWxkIGFsc28gdXBkYXRlIHRoZSAkbWV0YWRhdGEgZnJvbSB0aGUgcmVzcG9uc2UgYWNjb3JkaW5nbHkuXG4gICAqIEBzZWUge0BsaW5rIFJlc3BvbnNlTWV0YWRhdGF9XG4gICAqL1xuICByZXRyeTogPElucHV0IGV4dGVuZHMgb2JqZWN0LCBPdXRwdXQgZXh0ZW5kcyBNZXRhZGF0YUJlYXJlcj4oXG4gICAgbmV4dDogRmluYWxpemVIYW5kbGVyPElucHV0LCBPdXRwdXQ+LFxuICAgIGFyZ3M6IEZpbmFsaXplSGFuZGxlckFyZ3VtZW50czxJbnB1dD5cbiAgKSA9PiBQcm9taXNlPEZpbmFsaXplSGFuZGxlck91dHB1dDxPdXRwdXQ+Pjtcbn1cblxuLyoqXG4gKiBQYXJzZXMgYSBVUkwgaW4gc3RyaW5nIGZvcm0gaW50byBhbiBFbmRwb2ludCBvYmplY3QuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVXJsUGFyc2VyIHtcbiAgKHVybDogc3RyaW5nKTogRW5kcG9pbnQ7XG59XG5cbi8qKlxuICogT2JqZWN0IGNvbnRhaW5pbmcgcmVnaW9uYWxpemF0aW9uIGluZm9ybWF0aW9uIG9mXG4gKiBBV1Mgc2VydmljZXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVnaW9uSW5mbyB7XG4gIGhvc3RuYW1lOiBzdHJpbmc7XG4gIHBhcnRpdGlvbjogc3RyaW5nO1xuICBwYXRoPzogc3RyaW5nO1xuICBzaWduaW5nU2VydmljZT86IHN0cmluZztcbiAgc2lnbmluZ1JlZ2lvbj86IHN0cmluZztcbn1cblxuLyoqXG4gKiBGdW5jdGlvbiByZXR1cm5zIGRlc2lnbmF0ZWQgc2VydmljZSdzIHJlZ2lvbmFsaXphdGlvblxuICogaW5mb3JtYXRpb24gZnJvbSBnaXZlbiByZWdpb24uIEVhY2ggc2VydmljZSBjbGllbnRcbiAqIGNvbWVzIHdpdGggaXRzIHJlZ2lvbmFsaXphdGlvbiBwcm92aWRlci4gaXQgc2VydmVzXG4gKiB0byBwcm92aWRlIHRoZSBkZWZhdWx0IHZhbHVlcyBvZiByZWxhdGVkIGNvbmZpZ3VyYXRpb25zXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVnaW9uSW5mb1Byb3ZpZGVyIHtcbiAgKHJlZ2lvbjogc3RyaW5nLCBvcHRpb25zPzogYW55KTogUHJvbWlzZTxSZWdpb25JbmZvIHwgdW5kZWZpbmVkPjtcbn1cblxuLyoqXG4gKiBBIHR1cGxlIHRoYXQgcmVwcmVzZW50cyBhbiBBUEkgbmFtZSBhbmQgb3B0aW9uYWwgdmVyc2lvblxuICogb2YgYSBsaWJyYXJ5IGJ1aWx0IHVzaW5nIHRoZSBBV1MgU0RLLlxuICovXG5leHBvcnQgdHlwZSBVc2VyQWdlbnRQYWlyID0gW25hbWU6IHN0cmluZywgdmVyc2lvbj86IHN0cmluZ107XG5cbi8qKlxuICogVXNlciBhZ2VudCBkYXRhIHRoYXQgdG8gYmUgcHV0IGludG8gdGhlIHJlcXVlc3QncyB1c2VyXG4gKiBhZ2VudC5cbiAqL1xuZXhwb3J0IHR5cGUgVXNlckFnZW50ID0gVXNlckFnZW50UGFpcltdO1xuIl19
{
"name": "@aws-sdk/types",
"version": "3.0.0",
"version": "3.1.0",
"main": "./dist/cjs/index.js",

@@ -5,0 +5,0 @@ "module": "./dist/es/index.js",

# @aws-sdk/types
[![NPM version](https://img.shields.io/npm/v/@aws-sdk/types/rc.svg)](https://www.npmjs.com/package/@aws-sdk/types)
[![NPM version](https://img.shields.io/npm/v/@aws-sdk/types/latest.svg)](https://www.npmjs.com/package/@aws-sdk/types)
[![NPM downloads](https://img.shields.io/npm/dm/@aws-sdk/types.svg)](https://www.npmjs.com/package/@aws-sdk/types)
import { Logger } from "./logger";
import { UserAgent } from "./util";

@@ -375,2 +376,9 @@ export interface InitializeHandlerArguments<Input extends object> {

/**
* Additional user agent that inferred by middleware. It can be used to save
* the internal user agent sections without overriding the `customUserAgent`
* config in clients.
*/
userAgent?: UserAgent;
[key: string]: any;

@@ -377,0 +385,0 @@ }

@@ -1,3 +0,1 @@

import { HeaderBag } from "./http";
export interface ResponseMetadata {

@@ -10,7 +8,2 @@ /**

/**
* The headers of the last HTTP response received for this operation.
*/
httpHeaders?: HeaderBag;
/**
* A unique identifier for the last request sent for this operation. Often

@@ -17,0 +10,0 @@ * requested by AWS service teams to aid in debugging.

import { Endpoint } from "./http";
import { FinalizeHandler, FinalizeHandlerArguments, FinalizeHandlerOutput } from "./middleware";
import {
FinalizeHandler,
FinalizeHandlerArguments,
FinalizeHandlerOutput,
HandlerExecutionContext,
} from "./middleware";
import { MetadataBearer } from "./response";

@@ -57,2 +62,6 @@

/**
* The retry mode describing how the retry strategy control the traffic flow.
*/
mode?: string;
/**
* the retry behavior the will invoke the next handler and handle the retry accordingly.

@@ -96,1 +105,13 @@ * This function should also update the $metadata from the response accordingly.

}
/**
* A tuple that represents an API name and optional version
* of a library built using the AWS SDK.
*/
export type UserAgentPair = [name: string, version?: string];
/**
* User agent data that to be put into the request's user
* agent.
*/
export type UserAgent = UserAgentPair[];

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc