@aws-sdk/types 1.0.0-rc.8 → 3.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/CHANGELOG.md +56 -0
  2. package/README.md +1 -1
  3. package/dist/cjs/middleware.js +1 -1
  4. package/dist/cjs/pagination.js +1 -1
  5. package/dist/cjs/response.js +1 -1
  6. package/dist/cjs/util.js +1 -1
  7. package/dist/es/middleware.js +1 -1
  8. package/dist/es/pagination.js +1 -1
  9. package/dist/es/response.js +1 -1
  10. package/dist/es/util.js +1 -1
  11. package/package.json +10 -2
  12. package/src/middleware.ts +15 -0
  13. package/src/pagination.ts +1 -1
  14. package/src/response.ts +0 -7
  15. package/src/util.ts +22 -1
  16. package/tsconfig.cjs.json +1 -0
  17. package/tsconfig.es.json +1 -0
  18. package/{dist/cjs → types}/abort.d.ts +0 -0
  19. package/{dist/cjs → types}/client.d.ts +0 -0
  20. package/{dist/cjs → types}/command.d.ts +0 -0
  21. package/{dist/cjs → types}/credentials.d.ts +0 -0
  22. package/{dist/cjs → types}/crypto.d.ts +0 -0
  23. package/{dist/cjs → types}/eventStream.d.ts +0 -0
  24. package/{dist/cjs → types}/http.d.ts +0 -0
  25. package/{dist/cjs → types}/index.d.ts +0 -0
  26. package/{dist/cjs → types}/logger.d.ts +0 -0
  27. package/{dist/cjs → types}/middleware.d.ts +13 -0
  28. package/{dist/cjs → types}/pagination.d.ts +1 -1
  29. package/{dist/cjs → types}/response.d.ts +0 -5
  30. package/{dist/cjs → types}/serde.d.ts +0 -0
  31. package/{dist/cjs → types}/signature.d.ts +0 -0
  32. package/{dist/cjs → types}/transfer.d.ts +0 -0
  33. package/{dist/es → types/ts3.4}/abort.d.ts +42 -42
  34. package/{dist/es → types/ts3.4}/client.d.ts +23 -23
  35. package/{dist/es → types/ts3.4}/command.d.ts +7 -7
  36. package/{dist/es → types/ts3.4}/credentials.d.ts +24 -24
  37. package/{dist/es → types/ts3.4}/crypto.d.ts +47 -47
  38. package/{dist/es → types/ts3.4}/eventStream.d.ts +84 -84
  39. package/{dist/es → types/ts3.4}/http.d.ts +92 -92
  40. package/{dist/es → types/ts3.4}/index.d.ts +15 -15
  41. package/{dist/es → types/ts3.4}/logger.d.ts +26 -26
  42. package/{dist/es → types/ts3.4}/middleware.d.ts +338 -325
  43. package/{dist/es → types/ts3.4}/pagination.d.ts +14 -14
  44. package/{dist/es → types/ts3.4}/response.d.ts +34 -39
  45. package/{dist/es → types/ts3.4}/serde.d.ts +49 -49
  46. package/{dist/es → types/ts3.4}/signature.d.ts +100 -100
  47. package/{dist/es → types/ts3.4}/transfer.d.ts +16 -16
  48. package/{dist/es → types/ts3.4}/util.d.ts +100 -83
  49. package/{dist/cjs → types}/util.d.ts +14 -0
package/CHANGELOG.md CHANGED
@@ -3,6 +3,62 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ ## [3.4.1](https://github.com/aws/aws-sdk-js-v3/compare/v3.4.0...v3.4.1) (2021-01-29)
7
+
8
+
9
+ ### Bug Fixes
10
+
11
+ * **clients:** use TS 3.4 compatible types for TS 3.9 ([#1978](https://github.com/aws/aws-sdk-js-v3/issues/1978)) ([8bced5c](https://github.com/aws/aws-sdk-js-v3/commit/8bced5c32b9dbc68f1065054d796cb0b8b87bcc4))
12
+
13
+
14
+
15
+
16
+
17
+ # [3.4.0](https://github.com/aws/aws-sdk-js-v3/compare/v3.3.0...v3.4.0) (2021-01-28)
18
+
19
+
20
+ ### Features
21
+
22
+ * **middleware-stack:** allow adding middleware to override an existing one ([#1964](https://github.com/aws/aws-sdk-js-v3/issues/1964)) ([9c21f14](https://github.com/aws/aws-sdk-js-v3/commit/9c21f14412f2b1f591422f3c67dedbe886db723b)), closes [#1883](https://github.com/aws/aws-sdk-js-v3/issues/1883)
23
+ * use downlevel-dts to generate TS 3.4 compatible types ([#1943](https://github.com/aws/aws-sdk-js-v3/issues/1943)) ([63ad215](https://github.com/aws/aws-sdk-js-v3/commit/63ad2151c8bb7be32ea8838a9b0974806ed3906b))
24
+
25
+
26
+
27
+
28
+
29
+ # [3.1.0](https://github.com/aws/aws-sdk-js-v3/compare/v3.0.0...v3.1.0) (2020-12-23)
30
+
31
+
32
+ ### Features
33
+
34
+ * standardize user agent value ([#1775](https://github.com/aws/aws-sdk-js-v3/issues/1775)) ([388b180](https://github.com/aws/aws-sdk-js-v3/commit/388b18071146171b42d283a93f9590cb23956e1a))
35
+
36
+
37
+
38
+
39
+
40
+ # [3.0.0](https://github.com/aws/aws-sdk-js-v3/compare/v1.0.0-rc.10...v3.0.0) (2020-12-15)
41
+
42
+
43
+ ### Features
44
+
45
+ * bump version to 3.0.0 ([#1793](https://github.com/aws/aws-sdk-js-v3/issues/1793)) ([d8475f8](https://github.com/aws/aws-sdk-js-v3/commit/d8475f8d972d28fbc15cd7e23abfe18f9eab0644))
46
+
47
+
48
+
49
+
50
+
51
+ # [1.0.0-rc.10](https://github.com/aws/aws-sdk-js-v3/compare/v1.0.0-rc.9...v1.0.0-rc.10) (2020-12-15)
52
+
53
+
54
+ ### Features
55
+
56
+ * update clients as of 12/12/2020 with model fixes ([#1774](https://github.com/aws/aws-sdk-js-v3/issues/1774)) ([54e8715](https://github.com/aws/aws-sdk-js-v3/commit/54e87151877dd5cf9a5f256698c088cc7a856225))
57
+
58
+
59
+
60
+
61
+
6
62
  # [1.0.0-rc.8](https://github.com/aws/aws-sdk-js-v3/compare/v1.0.0-rc.7...v1.0.0-rc.8) (2020-12-05)
7
63
 
8
64
 
package/README.md CHANGED
@@ -1,4 +1,4 @@
1
1
  # @aws-sdk/types
2
2
 
3
- [![NPM version](https://img.shields.io/npm/v/@aws-sdk/types/rc.svg)](https://www.npmjs.com/package/@aws-sdk/types)
3
+ [![NPM version](https://img.shields.io/npm/v/@aws-sdk/types/latest.svg)](https://www.npmjs.com/package/@aws-sdk/types)
4
4
  [![NPM downloads](https://img.shields.io/npm/dm/@aws-sdk/types.svg)](https://www.npmjs.com/package/@aws-sdk/types)
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# 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"]}
3
+ //# 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\n  /**\n   * A flag to override the existing middleware with the same name. Without\n   * setting it, adding middleware with duplicated name will throw an exception.\n   * @internal\n   */\n  override?: boolean;\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,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wYWdpbmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDbGllbnQgfSBmcm9tIFwiLi9jbGllbnRcIjtcblxuLyoqXG4gKiBFeHBlY3RlZCB0eXBlIGRlZmluaXRpb24gb2YgYSBwYWdpbmF0b3IuXG4gKi9cbmV4cG9ydCB0eXBlIFBhZ2luYXRvcjxUPiA9IEFzeW5jR2VuZXJhdG9yPFQsIFQsIHVua25vd24+O1xuXG4vKipcbiAqIEV4cGVjdGVkIHBhZ2luYXRvciBjb25maWd1cmF0aW9uIHBhc3NlZCB0byBhbiBvcGVyYXRpb24uIFNlcnZpY2VzIHdpbGwgZXh0ZW5kXG4gKiB0aGlzIGludGVyZmFjZSBkZWZpbml0aW9uIGFuZCBtYXkgdHlwZSBjbGllbnQgZnVydGhlci5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQYWdpbmF0aW9uQ29uZmlndXJhdGlvbiB7XG4gIGNsaWVudDogQ2xpZW50PGFueSwgYW55LCBhbnk+O1xuICBwYWdlU2l6ZT86IG51bWJlcjtcbiAgc3RhcnRpbmdUb2tlbj86IHN0cmluZztcbn1cbiJdfQ==
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wYWdpbmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDbGllbnQgfSBmcm9tIFwiLi9jbGllbnRcIjtcblxuLyoqXG4gKiBFeHBlY3RlZCB0eXBlIGRlZmluaXRpb24gb2YgYSBwYWdpbmF0b3IuXG4gKi9cbmV4cG9ydCB0eXBlIFBhZ2luYXRvcjxUPiA9IEFzeW5jR2VuZXJhdG9yPFQsIFQsIHVua25vd24+O1xuXG4vKipcbiAqIEV4cGVjdGVkIHBhZ2luYXRvciBjb25maWd1cmF0aW9uIHBhc3NlZCB0byBhbiBvcGVyYXRpb24uIFNlcnZpY2VzIHdpbGwgZXh0ZW5kXG4gKiB0aGlzIGludGVyZmFjZSBkZWZpbml0aW9uIGFuZCBtYXkgdHlwZSBjbGllbnQgZnVydGhlci5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQYWdpbmF0aW9uQ29uZmlndXJhdGlvbiB7XG4gIGNsaWVudDogQ2xpZW50PGFueSwgYW55LCBhbnk+O1xuICBwYWdlU2l6ZT86IG51bWJlcjtcbiAgc3RhcnRpbmdUb2tlbj86IGFueTtcbn1cbiJdfQ==
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzcG9uc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVzcG9uc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhlYWRlckJhZyB9IGZyb20gXCIuL2h0dHBcIjtcblxuZXhwb3J0IGludGVyZmFjZSBSZXNwb25zZU1ldGFkYXRhIHtcbiAgLyoqXG4gICAqIFRoZSBzdGF0dXMgY29kZSBvZiB0aGUgbGFzdCBIVFRQIHJlc3BvbnNlIHJlY2VpdmVkIGZvciB0aGlzIG9wZXJhdGlvbi5cbiAgICovXG4gIGh0dHBTdGF0dXNDb2RlPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBUaGUgaGVhZGVycyBvZiB0aGUgbGFzdCBIVFRQIHJlc3BvbnNlIHJlY2VpdmVkIGZvciB0aGlzIG9wZXJhdGlvbi5cbiAgICovXG4gIGh0dHBIZWFkZXJzPzogSGVhZGVyQmFnO1xuXG4gIC8qKlxuICAgKiBBIHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGUgbGFzdCByZXF1ZXN0IHNlbnQgZm9yIHRoaXMgb3BlcmF0aW9uLiBPZnRlblxuICAgKiByZXF1ZXN0ZWQgYnkgQVdTIHNlcnZpY2UgdGVhbXMgdG8gYWlkIGluIGRlYnVnZ2luZy5cbiAgICovXG4gIHJlcXVlc3RJZD86IHN0cmluZztcblxuICAvKipcbiAgICogQSBzZWNvbmRhcnkgaWRlbnRpZmllciBmb3IgdGhlIGxhc3QgcmVxdWVzdCBzZW50LiBVc2VkIGZvciBkZWJ1Z2dpbmcuXG4gICAqL1xuICBleHRlbmRlZFJlcXVlc3RJZD86IHN0cmluZztcblxuICAvKipcbiAgICogQSB0ZXJ0aWFyeSBpZGVudGlmaWVyIGZvciB0aGUgbGFzdCByZXF1ZXN0IHNlbnQuIFVzZWQgZm9yIGRlYnVnZ2luZy5cbiAgICovXG4gIGNmSWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBudW1iZXIgb2YgdGltZXMgdGhpcyBvcGVyYXRpb24gd2FzIGF0dGVtcHRlZC5cbiAgICovXG4gIGF0dGVtcHRzPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBUaGUgdG90YWwgYW1vdW50IG9mIHRpbWUgKGluIG1pbGxpc2Vjb25kcykgdGhhdCB3YXMgc3BlbnQgd2FpdGluZyBiZXR3ZWVuXG4gICAqIHJldHJ5IGF0dGVtcHRzLlxuICAgKi9cbiAgdG90YWxSZXRyeURlbGF5PzogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1ldGFkYXRhQmVhcmVyIHtcbiAgLyoqXG4gICAqIE1ldGFkYXRhIHBlcnRhaW5pbmcgdG8gdGhpcyByZXF1ZXN0LlxuICAgKi9cbiAgJG1ldGFkYXRhOiBSZXNwb25zZU1ldGFkYXRhO1xufVxuIl19
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzcG9uc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVzcG9uc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUmVzcG9uc2VNZXRhZGF0YSB7XG4gIC8qKlxuICAgKiBUaGUgc3RhdHVzIGNvZGUgb2YgdGhlIGxhc3QgSFRUUCByZXNwb25zZSByZWNlaXZlZCBmb3IgdGhpcyBvcGVyYXRpb24uXG4gICAqL1xuICBodHRwU3RhdHVzQ29kZT86IG51bWJlcjtcblxuICAvKipcbiAgICogQSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGxhc3QgcmVxdWVzdCBzZW50IGZvciB0aGlzIG9wZXJhdGlvbi4gT2Z0ZW5cbiAgICogcmVxdWVzdGVkIGJ5IEFXUyBzZXJ2aWNlIHRlYW1zIHRvIGFpZCBpbiBkZWJ1Z2dpbmcuXG4gICAqL1xuICByZXF1ZXN0SWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgc2Vjb25kYXJ5IGlkZW50aWZpZXIgZm9yIHRoZSBsYXN0IHJlcXVlc3Qgc2VudC4gVXNlZCBmb3IgZGVidWdnaW5nLlxuICAgKi9cbiAgZXh0ZW5kZWRSZXF1ZXN0SWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgdGVydGlhcnkgaWRlbnRpZmllciBmb3IgdGhlIGxhc3QgcmVxdWVzdCBzZW50LiBVc2VkIGZvciBkZWJ1Z2dpbmcuXG4gICAqL1xuICBjZklkPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgbnVtYmVyIG9mIHRpbWVzIHRoaXMgb3BlcmF0aW9uIHdhcyBhdHRlbXB0ZWQuXG4gICAqL1xuICBhdHRlbXB0cz86IG51bWJlcjtcblxuICAvKipcbiAgICogVGhlIHRvdGFsIGFtb3VudCBvZiB0aW1lIChpbiBtaWxsaXNlY29uZHMpIHRoYXQgd2FzIHNwZW50IHdhaXRpbmcgYmV0d2VlblxuICAgKiByZXRyeSBhdHRlbXB0cy5cbiAgICovXG4gIHRvdGFsUmV0cnlEZWxheT86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNZXRhZGF0YUJlYXJlciB7XG4gIC8qKlxuICAgKiBNZXRhZGF0YSBwZXJ0YWluaW5nIHRvIHRoaXMgcmVxdWVzdC5cbiAgICovXG4gICRtZXRhZGF0YTogUmVzcG9uc2VNZXRhZGF0YTtcbn1cbiJdfQ==
package/dist/cjs/util.js CHANGED
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbmRwb2ludCB9IGZyb20gXCIuL2h0dHBcIjtcbmltcG9ydCB7IEZpbmFsaXplSGFuZGxlciwgRmluYWxpemVIYW5kbGVyQXJndW1lbnRzLCBGaW5hbGl6ZUhhbmRsZXJPdXRwdXQgfSBmcm9tIFwiLi9taWRkbGV3YXJlXCI7XG5pbXBvcnQgeyBNZXRhZGF0YUJlYXJlciB9IGZyb20gXCIuL3Jlc3BvbnNlXCI7XG5cbi8qKlxuICogQSBmdW5jdGlvbiB0aGF0LCBnaXZlbiBhIFR5cGVkQXJyYXkgb2YgYnl0ZXMsIGNhbiBwcm9kdWNlIGEgc3RyaW5nXG4gKiByZXByZXNlbnRhdGlvbiB0aGVyZW9mLlxuICpcbiAqIEBleGFtcGxlIEFuIGVuY29kZXIgZnVuY3Rpb24gdGhhdCBjb252ZXJ0cyBieXRlcyB0byBoZXhhZGVjaW1hbFxuICogcmVwcmVzZW50YXRpb24gd291bGQgcmV0dXJuIGAnZGVhZGJlZWYnYCB3aGVuIGdpdmVuIGBuZXdcbiAqIFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRW5jb2RlciB7XG4gIChpbnB1dDogVWludDhBcnJheSk6IHN0cmluZztcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIGdpdmVuIGEgc3RyaW5nLCBjYW4gZGVyaXZlIHRoZSBieXRlcyByZXByZXNlbnRlZCBieSB0aGF0XG4gKiBzdHJpbmcuXG4gKlxuICogQGV4YW1wbGUgQSBkZWNvZGVyIGZ1bmN0aW9uIHRoYXQgY29udmVydHMgYnl0ZXMgdG8gaGV4YWRlY2ltYWxcbiAqIHJlcHJlc2VudGF0aW9uIHdvdWxkIHJldHVybiBgbmV3IFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAgd2hlblxuICogZ2l2ZW4gdGhlIHN0cmluZyBgJ2RlYWRiZWVmJ2AuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGVjb2RlciB7XG4gIChpbnB1dDogc3RyaW5nKTogVWludDhBcnJheTtcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIHdoZW4gaW52b2tlZCwgcmV0dXJucyBhIHByb21pc2UgdGhhdCB3aWxsIGJlIGZ1bGZpbGxlZCB3aXRoXG4gKiBhIHZhbHVlIG9mIHR5cGUgVC5cbiAqXG4gKiBAZXhhbXBsZSBBIGZ1bmN0aW9uIHRoYXQgcmVhZHMgY3JlZGVudGlhbHMgZnJvbSBzaGFyZWQgU0RLIGNvbmZpZ3VyYXRpb25cbiAqIGZpbGVzLCBhc3N1bWluZyByb2xlcyBhbmQgY29sbGVjdGluZyBNRkEgdG9rZW5zIGFzIG5lY2Vzc2FyeS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQcm92aWRlcjxUPiB7XG4gICgpOiBQcm9taXNlPFQ+O1xufVxuXG4vKipcbiAqIEEgZnVuY3Rpb24gdGhhdCwgZ2l2ZW4gYSByZXF1ZXN0IGJvZHksIGRldGVybWluZXMgdGhlXG4gKiBsZW5ndGggb2YgdGhlIGJvZHkuIFRoaXMgaXMgdXNlZCB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtTGVuZ3RoXG4gKiB0aGF0IHNob3VsZCBiZSBzZW50IHdpdGggYSByZXF1ZXN0LlxuICpcbiAqIEBleGFtcGxlIEEgZnVuY3Rpb24gdGhhdCByZWFkcyBhIGZpbGUgc3RyZWFtIGFuZCBjYWxjdWxhdGVzXG4gKiB0aGUgc2l6ZSBvZiB0aGUgZmlsZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCb2R5TGVuZ3RoQ2FsY3VsYXRvciB7XG4gIChib2R5OiBhbnkpOiBudW1iZXIgfCB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogSW50ZXJmYWNlIHRoYXQgc3BlY2lmaWVzIHRoZSByZXRyeSBiZWhhdmlvclxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJldHJ5U3RyYXRlZ3kge1xuICAvKipcbiAgICogdGhlIHJldHJ5IGJlaGF2aW9yIHRoZSB3aWxsIGludm9rZSB0aGUgbmV4dCBoYW5kbGVyIGFuZCBoYW5kbGUgdGhlIHJldHJ5IGFjY29yZGluZ2x5LlxuICAgKiBUaGlzIGZ1bmN0aW9uIHNob3VsZCBhbHNvIHVwZGF0ZSB0aGUgJG1ldGFkYXRhIGZyb20gdGhlIHJlc3BvbnNlIGFjY29yZGluZ2x5LlxuICAgKiBAc2VlIHtAbGluayBSZXNwb25zZU1ldGFkYXRhfVxuICAgKi9cbiAgcmV0cnk6IDxJbnB1dCBleHRlbmRzIG9iamVjdCwgT3V0cHV0IGV4dGVuZHMgTWV0YWRhdGFCZWFyZXI+KFxuICAgIG5leHQ6IEZpbmFsaXplSGFuZGxlcjxJbnB1dCwgT3V0cHV0PixcbiAgICBhcmdzOiBGaW5hbGl6ZUhhbmRsZXJBcmd1bWVudHM8SW5wdXQ+XG4gICkgPT4gUHJvbWlzZTxGaW5hbGl6ZUhhbmRsZXJPdXRwdXQ8T3V0cHV0Pj47XG59XG5cbi8qKlxuICogUGFyc2VzIGEgVVJMIGluIHN0cmluZyBmb3JtIGludG8gYW4gRW5kcG9pbnQgb2JqZWN0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFVybFBhcnNlciB7XG4gICh1cmw6IHN0cmluZyk6IEVuZHBvaW50O1xufVxuXG4vKipcbiAqIE9iamVjdCBjb250YWluaW5nIHJlZ2lvbmFsaXphdGlvbiBpbmZvcm1hdGlvbiBvZlxuICogQVdTIHNlcnZpY2VzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlZ2lvbkluZm8ge1xuICBob3N0bmFtZTogc3RyaW5nO1xuICBwYXJ0aXRpb246IHN0cmluZztcbiAgcGF0aD86IHN0cmluZztcbiAgc2lnbmluZ1NlcnZpY2U/OiBzdHJpbmc7XG4gIHNpZ25pbmdSZWdpb24/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogRnVuY3Rpb24gcmV0dXJucyBkZXNpZ25hdGVkIHNlcnZpY2UncyByZWdpb25hbGl6YXRpb25cbiAqIGluZm9ybWF0aW9uIGZyb20gZ2l2ZW4gcmVnaW9uLiBFYWNoIHNlcnZpY2UgY2xpZW50XG4gKiBjb21lcyB3aXRoIGl0cyByZWdpb25hbGl6YXRpb24gcHJvdmlkZXIuIGl0IHNlcnZlc1xuICogdG8gcHJvdmlkZSB0aGUgZGVmYXVsdCB2YWx1ZXMgb2YgcmVsYXRlZCBjb25maWd1cmF0aW9uc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlZ2lvbkluZm9Qcm92aWRlciB7XG4gIChyZWdpb246IHN0cmluZywgb3B0aW9ucz86IGFueSk6IFByb21pc2U8UmVnaW9uSW5mbyB8IHVuZGVmaW5lZD47XG59XG4iXX0=
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbmRwb2ludCB9IGZyb20gXCIuL2h0dHBcIjtcbmltcG9ydCB7XG4gIEZpbmFsaXplSGFuZGxlcixcbiAgRmluYWxpemVIYW5kbGVyQXJndW1lbnRzLFxuICBGaW5hbGl6ZUhhbmRsZXJPdXRwdXQsXG4gIEhhbmRsZXJFeGVjdXRpb25Db250ZXh0LFxufSBmcm9tIFwiLi9taWRkbGV3YXJlXCI7XG5pbXBvcnQgeyBNZXRhZGF0YUJlYXJlciB9IGZyb20gXCIuL3Jlc3BvbnNlXCI7XG5cbi8qKlxuICogQSBmdW5jdGlvbiB0aGF0LCBnaXZlbiBhIFR5cGVkQXJyYXkgb2YgYnl0ZXMsIGNhbiBwcm9kdWNlIGEgc3RyaW5nXG4gKiByZXByZXNlbnRhdGlvbiB0aGVyZW9mLlxuICpcbiAqIEBleGFtcGxlIEFuIGVuY29kZXIgZnVuY3Rpb24gdGhhdCBjb252ZXJ0cyBieXRlcyB0byBoZXhhZGVjaW1hbFxuICogcmVwcmVzZW50YXRpb24gd291bGQgcmV0dXJuIGAnZGVhZGJlZWYnYCB3aGVuIGdpdmVuIGBuZXdcbiAqIFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRW5jb2RlciB7XG4gIChpbnB1dDogVWludDhBcnJheSk6IHN0cmluZztcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIGdpdmVuIGEgc3RyaW5nLCBjYW4gZGVyaXZlIHRoZSBieXRlcyByZXByZXNlbnRlZCBieSB0aGF0XG4gKiBzdHJpbmcuXG4gKlxuICogQGV4YW1wbGUgQSBkZWNvZGVyIGZ1bmN0aW9uIHRoYXQgY29udmVydHMgYnl0ZXMgdG8gaGV4YWRlY2ltYWxcbiAqIHJlcHJlc2VudGF0aW9uIHdvdWxkIHJldHVybiBgbmV3IFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAgd2hlblxuICogZ2l2ZW4gdGhlIHN0cmluZyBgJ2RlYWRiZWVmJ2AuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGVjb2RlciB7XG4gIChpbnB1dDogc3RyaW5nKTogVWludDhBcnJheTtcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIHdoZW4gaW52b2tlZCwgcmV0dXJucyBhIHByb21pc2UgdGhhdCB3aWxsIGJlIGZ1bGZpbGxlZCB3aXRoXG4gKiBhIHZhbHVlIG9mIHR5cGUgVC5cbiAqXG4gKiBAZXhhbXBsZSBBIGZ1bmN0aW9uIHRoYXQgcmVhZHMgY3JlZGVudGlhbHMgZnJvbSBzaGFyZWQgU0RLIGNvbmZpZ3VyYXRpb25cbiAqIGZpbGVzLCBhc3N1bWluZyByb2xlcyBhbmQgY29sbGVjdGluZyBNRkEgdG9rZW5zIGFzIG5lY2Vzc2FyeS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQcm92aWRlcjxUPiB7XG4gICgpOiBQcm9taXNlPFQ+O1xufVxuXG4vKipcbiAqIEEgZnVuY3Rpb24gdGhhdCwgZ2l2ZW4gYSByZXF1ZXN0IGJvZHksIGRldGVybWluZXMgdGhlXG4gKiBsZW5ndGggb2YgdGhlIGJvZHkuIFRoaXMgaXMgdXNlZCB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtTGVuZ3RoXG4gKiB0aGF0IHNob3VsZCBiZSBzZW50IHdpdGggYSByZXF1ZXN0LlxuICpcbiAqIEBleGFtcGxlIEEgZnVuY3Rpb24gdGhhdCByZWFkcyBhIGZpbGUgc3RyZWFtIGFuZCBjYWxjdWxhdGVzXG4gKiB0aGUgc2l6ZSBvZiB0aGUgZmlsZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCb2R5TGVuZ3RoQ2FsY3VsYXRvciB7XG4gIChib2R5OiBhbnkpOiBudW1iZXIgfCB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogSW50ZXJmYWNlIHRoYXQgc3BlY2lmaWVzIHRoZSByZXRyeSBiZWhhdmlvclxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJldHJ5U3RyYXRlZ3kge1xuICAvKipcbiAgICogVGhlIHJldHJ5IG1vZGUgZGVzY3JpYmluZyBob3cgdGhlIHJldHJ5IHN0cmF0ZWd5IGNvbnRyb2wgdGhlIHRyYWZmaWMgZmxvdy5cbiAgICovXG4gIG1vZGU/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiB0aGUgcmV0cnkgYmVoYXZpb3IgdGhlIHdpbGwgaW52b2tlIHRoZSBuZXh0IGhhbmRsZXIgYW5kIGhhbmRsZSB0aGUgcmV0cnkgYWNjb3JkaW5nbHkuXG4gICAqIFRoaXMgZnVuY3Rpb24gc2hvdWxkIGFsc28gdXBkYXRlIHRoZSAkbWV0YWRhdGEgZnJvbSB0aGUgcmVzcG9uc2UgYWNjb3JkaW5nbHkuXG4gICAqIEBzZWUge0BsaW5rIFJlc3BvbnNlTWV0YWRhdGF9XG4gICAqL1xuICByZXRyeTogPElucHV0IGV4dGVuZHMgb2JqZWN0LCBPdXRwdXQgZXh0ZW5kcyBNZXRhZGF0YUJlYXJlcj4oXG4gICAgbmV4dDogRmluYWxpemVIYW5kbGVyPElucHV0LCBPdXRwdXQ+LFxuICAgIGFyZ3M6IEZpbmFsaXplSGFuZGxlckFyZ3VtZW50czxJbnB1dD5cbiAgKSA9PiBQcm9taXNlPEZpbmFsaXplSGFuZGxlck91dHB1dDxPdXRwdXQ+Pjtcbn1cblxuLyoqXG4gKiBQYXJzZXMgYSBVUkwgaW4gc3RyaW5nIGZvcm0gaW50byBhbiBFbmRwb2ludCBvYmplY3QuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVXJsUGFyc2VyIHtcbiAgKHVybDogc3RyaW5nKTogRW5kcG9pbnQ7XG59XG5cbi8qKlxuICogT2JqZWN0IGNvbnRhaW5pbmcgcmVnaW9uYWxpemF0aW9uIGluZm9ybWF0aW9uIG9mXG4gKiBBV1Mgc2VydmljZXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVnaW9uSW5mbyB7XG4gIGhvc3RuYW1lOiBzdHJpbmc7XG4gIHBhcnRpdGlvbjogc3RyaW5nO1xuICBwYXRoPzogc3RyaW5nO1xuICBzaWduaW5nU2VydmljZT86IHN0cmluZztcbiAgc2lnbmluZ1JlZ2lvbj86IHN0cmluZztcbn1cblxuLyoqXG4gKiBGdW5jdGlvbiByZXR1cm5zIGRlc2lnbmF0ZWQgc2VydmljZSdzIHJlZ2lvbmFsaXphdGlvblxuICogaW5mb3JtYXRpb24gZnJvbSBnaXZlbiByZWdpb24uIEVhY2ggc2VydmljZSBjbGllbnRcbiAqIGNvbWVzIHdpdGggaXRzIHJlZ2lvbmFsaXphdGlvbiBwcm92aWRlci4gaXQgc2VydmVzXG4gKiB0byBwcm92aWRlIHRoZSBkZWZhdWx0IHZhbHVlcyBvZiByZWxhdGVkIGNvbmZpZ3VyYXRpb25zXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVnaW9uSW5mb1Byb3ZpZGVyIHtcbiAgKHJlZ2lvbjogc3RyaW5nLCBvcHRpb25zPzogYW55KTogUHJvbWlzZTxSZWdpb25JbmZvIHwgdW5kZWZpbmVkPjtcbn1cblxuLyoqXG4gKiBBIHR1cGxlIHRoYXQgcmVwcmVzZW50cyBhbiBBUEkgbmFtZSBhbmQgb3B0aW9uYWwgdmVyc2lvblxuICogb2YgYSBsaWJyYXJ5IGJ1aWx0IHVzaW5nIHRoZSBBV1MgU0RLLlxuICovXG5leHBvcnQgdHlwZSBVc2VyQWdlbnRQYWlyID0gW25hbWU6IHN0cmluZywgdmVyc2lvbj86IHN0cmluZ107XG5cbi8qKlxuICogVXNlciBhZ2VudCBkYXRhIHRoYXQgdG8gYmUgcHV0IGludG8gdGhlIHJlcXVlc3QncyB1c2VyXG4gKiBhZ2VudC5cbiAqL1xuZXhwb3J0IHR5cGUgVXNlckFnZW50ID0gVXNlckFnZW50UGFpcltdO1xuIl19
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# 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"]}
2
+ //# 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\n  /**\n   * A flag to override the existing middleware with the same name. Without\n   * setting it, adding middleware with duplicated name will throw an exception.\n   * @internal\n   */\n  override?: boolean;\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 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wYWdpbmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDbGllbnQgfSBmcm9tIFwiLi9jbGllbnRcIjtcblxuLyoqXG4gKiBFeHBlY3RlZCB0eXBlIGRlZmluaXRpb24gb2YgYSBwYWdpbmF0b3IuXG4gKi9cbmV4cG9ydCB0eXBlIFBhZ2luYXRvcjxUPiA9IEFzeW5jR2VuZXJhdG9yPFQsIFQsIHVua25vd24+O1xuXG4vKipcbiAqIEV4cGVjdGVkIHBhZ2luYXRvciBjb25maWd1cmF0aW9uIHBhc3NlZCB0byBhbiBvcGVyYXRpb24uIFNlcnZpY2VzIHdpbGwgZXh0ZW5kXG4gKiB0aGlzIGludGVyZmFjZSBkZWZpbml0aW9uIGFuZCBtYXkgdHlwZSBjbGllbnQgZnVydGhlci5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQYWdpbmF0aW9uQ29uZmlndXJhdGlvbiB7XG4gIGNsaWVudDogQ2xpZW50PGFueSwgYW55LCBhbnk+O1xuICBwYWdlU2l6ZT86IG51bWJlcjtcbiAgc3RhcnRpbmdUb2tlbj86IHN0cmluZztcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wYWdpbmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDbGllbnQgfSBmcm9tIFwiLi9jbGllbnRcIjtcblxuLyoqXG4gKiBFeHBlY3RlZCB0eXBlIGRlZmluaXRpb24gb2YgYSBwYWdpbmF0b3IuXG4gKi9cbmV4cG9ydCB0eXBlIFBhZ2luYXRvcjxUPiA9IEFzeW5jR2VuZXJhdG9yPFQsIFQsIHVua25vd24+O1xuXG4vKipcbiAqIEV4cGVjdGVkIHBhZ2luYXRvciBjb25maWd1cmF0aW9uIHBhc3NlZCB0byBhbiBvcGVyYXRpb24uIFNlcnZpY2VzIHdpbGwgZXh0ZW5kXG4gKiB0aGlzIGludGVyZmFjZSBkZWZpbml0aW9uIGFuZCBtYXkgdHlwZSBjbGllbnQgZnVydGhlci5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQYWdpbmF0aW9uQ29uZmlndXJhdGlvbiB7XG4gIGNsaWVudDogQ2xpZW50PGFueSwgYW55LCBhbnk+O1xuICBwYWdlU2l6ZT86IG51bWJlcjtcbiAgc3RhcnRpbmdUb2tlbj86IGFueTtcbn1cbiJdfQ==
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzcG9uc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVzcG9uc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhlYWRlckJhZyB9IGZyb20gXCIuL2h0dHBcIjtcblxuZXhwb3J0IGludGVyZmFjZSBSZXNwb25zZU1ldGFkYXRhIHtcbiAgLyoqXG4gICAqIFRoZSBzdGF0dXMgY29kZSBvZiB0aGUgbGFzdCBIVFRQIHJlc3BvbnNlIHJlY2VpdmVkIGZvciB0aGlzIG9wZXJhdGlvbi5cbiAgICovXG4gIGh0dHBTdGF0dXNDb2RlPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBUaGUgaGVhZGVycyBvZiB0aGUgbGFzdCBIVFRQIHJlc3BvbnNlIHJlY2VpdmVkIGZvciB0aGlzIG9wZXJhdGlvbi5cbiAgICovXG4gIGh0dHBIZWFkZXJzPzogSGVhZGVyQmFnO1xuXG4gIC8qKlxuICAgKiBBIHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGUgbGFzdCByZXF1ZXN0IHNlbnQgZm9yIHRoaXMgb3BlcmF0aW9uLiBPZnRlblxuICAgKiByZXF1ZXN0ZWQgYnkgQVdTIHNlcnZpY2UgdGVhbXMgdG8gYWlkIGluIGRlYnVnZ2luZy5cbiAgICovXG4gIHJlcXVlc3RJZD86IHN0cmluZztcblxuICAvKipcbiAgICogQSBzZWNvbmRhcnkgaWRlbnRpZmllciBmb3IgdGhlIGxhc3QgcmVxdWVzdCBzZW50LiBVc2VkIGZvciBkZWJ1Z2dpbmcuXG4gICAqL1xuICBleHRlbmRlZFJlcXVlc3RJZD86IHN0cmluZztcblxuICAvKipcbiAgICogQSB0ZXJ0aWFyeSBpZGVudGlmaWVyIGZvciB0aGUgbGFzdCByZXF1ZXN0IHNlbnQuIFVzZWQgZm9yIGRlYnVnZ2luZy5cbiAgICovXG4gIGNmSWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBudW1iZXIgb2YgdGltZXMgdGhpcyBvcGVyYXRpb24gd2FzIGF0dGVtcHRlZC5cbiAgICovXG4gIGF0dGVtcHRzPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBUaGUgdG90YWwgYW1vdW50IG9mIHRpbWUgKGluIG1pbGxpc2Vjb25kcykgdGhhdCB3YXMgc3BlbnQgd2FpdGluZyBiZXR3ZWVuXG4gICAqIHJldHJ5IGF0dGVtcHRzLlxuICAgKi9cbiAgdG90YWxSZXRyeURlbGF5PzogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1ldGFkYXRhQmVhcmVyIHtcbiAgLyoqXG4gICAqIE1ldGFkYXRhIHBlcnRhaW5pbmcgdG8gdGhpcyByZXF1ZXN0LlxuICAgKi9cbiAgJG1ldGFkYXRhOiBSZXNwb25zZU1ldGFkYXRhO1xufVxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzcG9uc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVzcG9uc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUmVzcG9uc2VNZXRhZGF0YSB7XG4gIC8qKlxuICAgKiBUaGUgc3RhdHVzIGNvZGUgb2YgdGhlIGxhc3QgSFRUUCByZXNwb25zZSByZWNlaXZlZCBmb3IgdGhpcyBvcGVyYXRpb24uXG4gICAqL1xuICBodHRwU3RhdHVzQ29kZT86IG51bWJlcjtcblxuICAvKipcbiAgICogQSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGxhc3QgcmVxdWVzdCBzZW50IGZvciB0aGlzIG9wZXJhdGlvbi4gT2Z0ZW5cbiAgICogcmVxdWVzdGVkIGJ5IEFXUyBzZXJ2aWNlIHRlYW1zIHRvIGFpZCBpbiBkZWJ1Z2dpbmcuXG4gICAqL1xuICByZXF1ZXN0SWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgc2Vjb25kYXJ5IGlkZW50aWZpZXIgZm9yIHRoZSBsYXN0IHJlcXVlc3Qgc2VudC4gVXNlZCBmb3IgZGVidWdnaW5nLlxuICAgKi9cbiAgZXh0ZW5kZWRSZXF1ZXN0SWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgdGVydGlhcnkgaWRlbnRpZmllciBmb3IgdGhlIGxhc3QgcmVxdWVzdCBzZW50LiBVc2VkIGZvciBkZWJ1Z2dpbmcuXG4gICAqL1xuICBjZklkPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgbnVtYmVyIG9mIHRpbWVzIHRoaXMgb3BlcmF0aW9uIHdhcyBhdHRlbXB0ZWQuXG4gICAqL1xuICBhdHRlbXB0cz86IG51bWJlcjtcblxuICAvKipcbiAgICogVGhlIHRvdGFsIGFtb3VudCBvZiB0aW1lIChpbiBtaWxsaXNlY29uZHMpIHRoYXQgd2FzIHNwZW50IHdhaXRpbmcgYmV0d2VlblxuICAgKiByZXRyeSBhdHRlbXB0cy5cbiAgICovXG4gIHRvdGFsUmV0cnlEZWxheT86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNZXRhZGF0YUJlYXJlciB7XG4gIC8qKlxuICAgKiBNZXRhZGF0YSBwZXJ0YWluaW5nIHRvIHRoaXMgcmVxdWVzdC5cbiAgICovXG4gICRtZXRhZGF0YTogUmVzcG9uc2VNZXRhZGF0YTtcbn1cbiJdfQ==
package/dist/es/util.js CHANGED
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbmRwb2ludCB9IGZyb20gXCIuL2h0dHBcIjtcbmltcG9ydCB7IEZpbmFsaXplSGFuZGxlciwgRmluYWxpemVIYW5kbGVyQXJndW1lbnRzLCBGaW5hbGl6ZUhhbmRsZXJPdXRwdXQgfSBmcm9tIFwiLi9taWRkbGV3YXJlXCI7XG5pbXBvcnQgeyBNZXRhZGF0YUJlYXJlciB9IGZyb20gXCIuL3Jlc3BvbnNlXCI7XG5cbi8qKlxuICogQSBmdW5jdGlvbiB0aGF0LCBnaXZlbiBhIFR5cGVkQXJyYXkgb2YgYnl0ZXMsIGNhbiBwcm9kdWNlIGEgc3RyaW5nXG4gKiByZXByZXNlbnRhdGlvbiB0aGVyZW9mLlxuICpcbiAqIEBleGFtcGxlIEFuIGVuY29kZXIgZnVuY3Rpb24gdGhhdCBjb252ZXJ0cyBieXRlcyB0byBoZXhhZGVjaW1hbFxuICogcmVwcmVzZW50YXRpb24gd291bGQgcmV0dXJuIGAnZGVhZGJlZWYnYCB3aGVuIGdpdmVuIGBuZXdcbiAqIFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRW5jb2RlciB7XG4gIChpbnB1dDogVWludDhBcnJheSk6IHN0cmluZztcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIGdpdmVuIGEgc3RyaW5nLCBjYW4gZGVyaXZlIHRoZSBieXRlcyByZXByZXNlbnRlZCBieSB0aGF0XG4gKiBzdHJpbmcuXG4gKlxuICogQGV4YW1wbGUgQSBkZWNvZGVyIGZ1bmN0aW9uIHRoYXQgY29udmVydHMgYnl0ZXMgdG8gaGV4YWRlY2ltYWxcbiAqIHJlcHJlc2VudGF0aW9uIHdvdWxkIHJldHVybiBgbmV3IFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAgd2hlblxuICogZ2l2ZW4gdGhlIHN0cmluZyBgJ2RlYWRiZWVmJ2AuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGVjb2RlciB7XG4gIChpbnB1dDogc3RyaW5nKTogVWludDhBcnJheTtcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIHdoZW4gaW52b2tlZCwgcmV0dXJucyBhIHByb21pc2UgdGhhdCB3aWxsIGJlIGZ1bGZpbGxlZCB3aXRoXG4gKiBhIHZhbHVlIG9mIHR5cGUgVC5cbiAqXG4gKiBAZXhhbXBsZSBBIGZ1bmN0aW9uIHRoYXQgcmVhZHMgY3JlZGVudGlhbHMgZnJvbSBzaGFyZWQgU0RLIGNvbmZpZ3VyYXRpb25cbiAqIGZpbGVzLCBhc3N1bWluZyByb2xlcyBhbmQgY29sbGVjdGluZyBNRkEgdG9rZW5zIGFzIG5lY2Vzc2FyeS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQcm92aWRlcjxUPiB7XG4gICgpOiBQcm9taXNlPFQ+O1xufVxuXG4vKipcbiAqIEEgZnVuY3Rpb24gdGhhdCwgZ2l2ZW4gYSByZXF1ZXN0IGJvZHksIGRldGVybWluZXMgdGhlXG4gKiBsZW5ndGggb2YgdGhlIGJvZHkuIFRoaXMgaXMgdXNlZCB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtTGVuZ3RoXG4gKiB0aGF0IHNob3VsZCBiZSBzZW50IHdpdGggYSByZXF1ZXN0LlxuICpcbiAqIEBleGFtcGxlIEEgZnVuY3Rpb24gdGhhdCByZWFkcyBhIGZpbGUgc3RyZWFtIGFuZCBjYWxjdWxhdGVzXG4gKiB0aGUgc2l6ZSBvZiB0aGUgZmlsZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCb2R5TGVuZ3RoQ2FsY3VsYXRvciB7XG4gIChib2R5OiBhbnkpOiBudW1iZXIgfCB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogSW50ZXJmYWNlIHRoYXQgc3BlY2lmaWVzIHRoZSByZXRyeSBiZWhhdmlvclxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJldHJ5U3RyYXRlZ3kge1xuICAvKipcbiAgICogdGhlIHJldHJ5IGJlaGF2aW9yIHRoZSB3aWxsIGludm9rZSB0aGUgbmV4dCBoYW5kbGVyIGFuZCBoYW5kbGUgdGhlIHJldHJ5IGFjY29yZGluZ2x5LlxuICAgKiBUaGlzIGZ1bmN0aW9uIHNob3VsZCBhbHNvIHVwZGF0ZSB0aGUgJG1ldGFkYXRhIGZyb20gdGhlIHJlc3BvbnNlIGFjY29yZGluZ2x5LlxuICAgKiBAc2VlIHtAbGluayBSZXNwb25zZU1ldGFkYXRhfVxuICAgKi9cbiAgcmV0cnk6IDxJbnB1dCBleHRlbmRzIG9iamVjdCwgT3V0cHV0IGV4dGVuZHMgTWV0YWRhdGFCZWFyZXI+KFxuICAgIG5leHQ6IEZpbmFsaXplSGFuZGxlcjxJbnB1dCwgT3V0cHV0PixcbiAgICBhcmdzOiBGaW5hbGl6ZUhhbmRsZXJBcmd1bWVudHM8SW5wdXQ+XG4gICkgPT4gUHJvbWlzZTxGaW5hbGl6ZUhhbmRsZXJPdXRwdXQ8T3V0cHV0Pj47XG59XG5cbi8qKlxuICogUGFyc2VzIGEgVVJMIGluIHN0cmluZyBmb3JtIGludG8gYW4gRW5kcG9pbnQgb2JqZWN0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFVybFBhcnNlciB7XG4gICh1cmw6IHN0cmluZyk6IEVuZHBvaW50O1xufVxuXG4vKipcbiAqIE9iamVjdCBjb250YWluaW5nIHJlZ2lvbmFsaXphdGlvbiBpbmZvcm1hdGlvbiBvZlxuICogQVdTIHNlcnZpY2VzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlZ2lvbkluZm8ge1xuICBob3N0bmFtZTogc3RyaW5nO1xuICBwYXJ0aXRpb246IHN0cmluZztcbiAgcGF0aD86IHN0cmluZztcbiAgc2lnbmluZ1NlcnZpY2U/OiBzdHJpbmc7XG4gIHNpZ25pbmdSZWdpb24/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogRnVuY3Rpb24gcmV0dXJucyBkZXNpZ25hdGVkIHNlcnZpY2UncyByZWdpb25hbGl6YXRpb25cbiAqIGluZm9ybWF0aW9uIGZyb20gZ2l2ZW4gcmVnaW9uLiBFYWNoIHNlcnZpY2UgY2xpZW50XG4gKiBjb21lcyB3aXRoIGl0cyByZWdpb25hbGl6YXRpb24gcHJvdmlkZXIuIGl0IHNlcnZlc1xuICogdG8gcHJvdmlkZSB0aGUgZGVmYXVsdCB2YWx1ZXMgb2YgcmVsYXRlZCBjb25maWd1cmF0aW9uc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlZ2lvbkluZm9Qcm92aWRlciB7XG4gIChyZWdpb246IHN0cmluZywgb3B0aW9ucz86IGFueSk6IFByb21pc2U8UmVnaW9uSW5mbyB8IHVuZGVmaW5lZD47XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbmRwb2ludCB9IGZyb20gXCIuL2h0dHBcIjtcbmltcG9ydCB7XG4gIEZpbmFsaXplSGFuZGxlcixcbiAgRmluYWxpemVIYW5kbGVyQXJndW1lbnRzLFxuICBGaW5hbGl6ZUhhbmRsZXJPdXRwdXQsXG4gIEhhbmRsZXJFeGVjdXRpb25Db250ZXh0LFxufSBmcm9tIFwiLi9taWRkbGV3YXJlXCI7XG5pbXBvcnQgeyBNZXRhZGF0YUJlYXJlciB9IGZyb20gXCIuL3Jlc3BvbnNlXCI7XG5cbi8qKlxuICogQSBmdW5jdGlvbiB0aGF0LCBnaXZlbiBhIFR5cGVkQXJyYXkgb2YgYnl0ZXMsIGNhbiBwcm9kdWNlIGEgc3RyaW5nXG4gKiByZXByZXNlbnRhdGlvbiB0aGVyZW9mLlxuICpcbiAqIEBleGFtcGxlIEFuIGVuY29kZXIgZnVuY3Rpb24gdGhhdCBjb252ZXJ0cyBieXRlcyB0byBoZXhhZGVjaW1hbFxuICogcmVwcmVzZW50YXRpb24gd291bGQgcmV0dXJuIGAnZGVhZGJlZWYnYCB3aGVuIGdpdmVuIGBuZXdcbiAqIFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRW5jb2RlciB7XG4gIChpbnB1dDogVWludDhBcnJheSk6IHN0cmluZztcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIGdpdmVuIGEgc3RyaW5nLCBjYW4gZGVyaXZlIHRoZSBieXRlcyByZXByZXNlbnRlZCBieSB0aGF0XG4gKiBzdHJpbmcuXG4gKlxuICogQGV4YW1wbGUgQSBkZWNvZGVyIGZ1bmN0aW9uIHRoYXQgY29udmVydHMgYnl0ZXMgdG8gaGV4YWRlY2ltYWxcbiAqIHJlcHJlc2VudGF0aW9uIHdvdWxkIHJldHVybiBgbmV3IFVpbnQ4QXJyYXkoWzB4ZGUsIDB4YWQsIDB4YmUsIDB4ZWZdKWAgd2hlblxuICogZ2l2ZW4gdGhlIHN0cmluZyBgJ2RlYWRiZWVmJ2AuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGVjb2RlciB7XG4gIChpbnB1dDogc3RyaW5nKTogVWludDhBcnJheTtcbn1cblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRoYXQsIHdoZW4gaW52b2tlZCwgcmV0dXJucyBhIHByb21pc2UgdGhhdCB3aWxsIGJlIGZ1bGZpbGxlZCB3aXRoXG4gKiBhIHZhbHVlIG9mIHR5cGUgVC5cbiAqXG4gKiBAZXhhbXBsZSBBIGZ1bmN0aW9uIHRoYXQgcmVhZHMgY3JlZGVudGlhbHMgZnJvbSBzaGFyZWQgU0RLIGNvbmZpZ3VyYXRpb25cbiAqIGZpbGVzLCBhc3N1bWluZyByb2xlcyBhbmQgY29sbGVjdGluZyBNRkEgdG9rZW5zIGFzIG5lY2Vzc2FyeS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQcm92aWRlcjxUPiB7XG4gICgpOiBQcm9taXNlPFQ+O1xufVxuXG4vKipcbiAqIEEgZnVuY3Rpb24gdGhhdCwgZ2l2ZW4gYSByZXF1ZXN0IGJvZHksIGRldGVybWluZXMgdGhlXG4gKiBsZW5ndGggb2YgdGhlIGJvZHkuIFRoaXMgaXMgdXNlZCB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtTGVuZ3RoXG4gKiB0aGF0IHNob3VsZCBiZSBzZW50IHdpdGggYSByZXF1ZXN0LlxuICpcbiAqIEBleGFtcGxlIEEgZnVuY3Rpb24gdGhhdCByZWFkcyBhIGZpbGUgc3RyZWFtIGFuZCBjYWxjdWxhdGVzXG4gKiB0aGUgc2l6ZSBvZiB0aGUgZmlsZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCb2R5TGVuZ3RoQ2FsY3VsYXRvciB7XG4gIChib2R5OiBhbnkpOiBudW1iZXIgfCB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogSW50ZXJmYWNlIHRoYXQgc3BlY2lmaWVzIHRoZSByZXRyeSBiZWhhdmlvclxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJldHJ5U3RyYXRlZ3kge1xuICAvKipcbiAgICogVGhlIHJldHJ5IG1vZGUgZGVzY3JpYmluZyBob3cgdGhlIHJldHJ5IHN0cmF0ZWd5IGNvbnRyb2wgdGhlIHRyYWZmaWMgZmxvdy5cbiAgICovXG4gIG1vZGU/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiB0aGUgcmV0cnkgYmVoYXZpb3IgdGhlIHdpbGwgaW52b2tlIHRoZSBuZXh0IGhhbmRsZXIgYW5kIGhhbmRsZSB0aGUgcmV0cnkgYWNjb3JkaW5nbHkuXG4gICAqIFRoaXMgZnVuY3Rpb24gc2hvdWxkIGFsc28gdXBkYXRlIHRoZSAkbWV0YWRhdGEgZnJvbSB0aGUgcmVzcG9uc2UgYWNjb3JkaW5nbHkuXG4gICAqIEBzZWUge0BsaW5rIFJlc3BvbnNlTWV0YWRhdGF9XG4gICAqL1xuICByZXRyeTogPElucHV0IGV4dGVuZHMgb2JqZWN0LCBPdXRwdXQgZXh0ZW5kcyBNZXRhZGF0YUJlYXJlcj4oXG4gICAgbmV4dDogRmluYWxpemVIYW5kbGVyPElucHV0LCBPdXRwdXQ+LFxuICAgIGFyZ3M6IEZpbmFsaXplSGFuZGxlckFyZ3VtZW50czxJbnB1dD5cbiAgKSA9PiBQcm9taXNlPEZpbmFsaXplSGFuZGxlck91dHB1dDxPdXRwdXQ+Pjtcbn1cblxuLyoqXG4gKiBQYXJzZXMgYSBVUkwgaW4gc3RyaW5nIGZvcm0gaW50byBhbiBFbmRwb2ludCBvYmplY3QuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVXJsUGFyc2VyIHtcbiAgKHVybDogc3RyaW5nKTogRW5kcG9pbnQ7XG59XG5cbi8qKlxuICogT2JqZWN0IGNvbnRhaW5pbmcgcmVnaW9uYWxpemF0aW9uIGluZm9ybWF0aW9uIG9mXG4gKiBBV1Mgc2VydmljZXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVnaW9uSW5mbyB7XG4gIGhvc3RuYW1lOiBzdHJpbmc7XG4gIHBhcnRpdGlvbjogc3RyaW5nO1xuICBwYXRoPzogc3RyaW5nO1xuICBzaWduaW5nU2VydmljZT86IHN0cmluZztcbiAgc2lnbmluZ1JlZ2lvbj86IHN0cmluZztcbn1cblxuLyoqXG4gKiBGdW5jdGlvbiByZXR1cm5zIGRlc2lnbmF0ZWQgc2VydmljZSdzIHJlZ2lvbmFsaXphdGlvblxuICogaW5mb3JtYXRpb24gZnJvbSBnaXZlbiByZWdpb24uIEVhY2ggc2VydmljZSBjbGllbnRcbiAqIGNvbWVzIHdpdGggaXRzIHJlZ2lvbmFsaXphdGlvbiBwcm92aWRlci4gaXQgc2VydmVzXG4gKiB0byBwcm92aWRlIHRoZSBkZWZhdWx0IHZhbHVlcyBvZiByZWxhdGVkIGNvbmZpZ3VyYXRpb25zXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVnaW9uSW5mb1Byb3ZpZGVyIHtcbiAgKHJlZ2lvbjogc3RyaW5nLCBvcHRpb25zPzogYW55KTogUHJvbWlzZTxSZWdpb25JbmZvIHwgdW5kZWZpbmVkPjtcbn1cblxuLyoqXG4gKiBBIHR1cGxlIHRoYXQgcmVwcmVzZW50cyBhbiBBUEkgbmFtZSBhbmQgb3B0aW9uYWwgdmVyc2lvblxuICogb2YgYSBsaWJyYXJ5IGJ1aWx0IHVzaW5nIHRoZSBBV1MgU0RLLlxuICovXG5leHBvcnQgdHlwZSBVc2VyQWdlbnRQYWlyID0gW25hbWU6IHN0cmluZywgdmVyc2lvbj86IHN0cmluZ107XG5cbi8qKlxuICogVXNlciBhZ2VudCBkYXRhIHRoYXQgdG8gYmUgcHV0IGludG8gdGhlIHJlcXVlc3QncyB1c2VyXG4gKiBhZ2VudC5cbiAqL1xuZXhwb3J0IHR5cGUgVXNlckFnZW50ID0gVXNlckFnZW50UGFpcltdO1xuIl19
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@aws-sdk/types",
3
- "version": "1.0.0-rc.8",
3
+ "version": "3.4.1",
4
4
  "main": "./dist/cjs/index.js",
5
5
  "module": "./dist/es/index.js",
6
- "types": "./dist/cjs/index.d.ts",
6
+ "types": "./types/index.d.ts",
7
7
  "description": "Types for the AWS SDK",
8
8
  "devDependencies": {
9
9
  "typescript": "~4.1.2"
@@ -14,6 +14,7 @@
14
14
  "build:cjs": "tsc -p tsconfig.cjs.json",
15
15
  "build:es": "tsc -p tsconfig.es.json",
16
16
  "build": "yarn build:es && yarn build:cjs",
17
+ "postbuild": "downlevel-dts types types/ts3.4",
17
18
  "test": "exit 0"
18
19
  },
19
20
  "author": {
@@ -24,6 +25,13 @@
24
25
  "engines": {
25
26
  "node": ">= 10.0.0"
26
27
  },
28
+ "typesVersions": {
29
+ "<4.0": {
30
+ "types/*": [
31
+ "types/ts3.4/*"
32
+ ]
33
+ }
34
+ },
27
35
  "homepage": "https://github.com/aws/aws-sdk-js-v3/tree/master/packages/types",
28
36
  "repository": {
29
37
  "type": "git",
package/src/middleware.ts CHANGED
@@ -1,4 +1,5 @@
1
1
  import { Logger } from "./logger";
2
+ import { UserAgent } from "./util";
2
3
 
3
4
  export interface InitializeHandlerArguments<Input extends object> {
4
5
  /**
@@ -205,6 +206,13 @@ export interface HandlerOptions {
205
206
  * A unique name to refer to a middleware
206
207
  */
207
208
  name?: string;
209
+
210
+ /**
211
+ * A flag to override the existing middleware with the same name. Without
212
+ * setting it, adding middleware with duplicated name will throw an exception.
213
+ * @internal
214
+ */
215
+ override?: boolean;
208
216
  }
209
217
  export interface AbsoluteLocation {
210
218
  /**
@@ -372,6 +380,13 @@ export interface HandlerExecutionContext {
372
380
  */
373
381
  logger?: Logger;
374
382
 
383
+ /**
384
+ * Additional user agent that inferred by middleware. It can be used to save
385
+ * the internal user agent sections without overriding the `customUserAgent`
386
+ * config in clients.
387
+ */
388
+ userAgent?: UserAgent;
389
+
375
390
  [key: string]: any;
376
391
  }
377
392
 
package/src/pagination.ts CHANGED
@@ -12,5 +12,5 @@ export type Paginator<T> = AsyncGenerator<T, T, unknown>;
12
12
  export interface PaginationConfiguration {
13
13
  client: Client<any, any, any>;
14
14
  pageSize?: number;
15
- startingToken?: string;
15
+ startingToken?: any;
16
16
  }
package/src/response.ts CHANGED
@@ -1,16 +1,9 @@
1
- import { HeaderBag } from "./http";
2
-
3
1
  export interface ResponseMetadata {
4
2
  /**
5
3
  * The status code of the last HTTP response received for this operation.
6
4
  */
7
5
  httpStatusCode?: number;
8
6
 
9
- /**
10
- * The headers of the last HTTP response received for this operation.
11
- */
12
- httpHeaders?: HeaderBag;
13
-
14
7
  /**
15
8
  * A unique identifier for the last request sent for this operation. Often
16
9
  * requested by AWS service teams to aid in debugging.
package/src/util.ts CHANGED
@@ -1,5 +1,10 @@
1
1
  import { Endpoint } from "./http";
2
- import { FinalizeHandler, FinalizeHandlerArguments, FinalizeHandlerOutput } from "./middleware";
2
+ import {
3
+ FinalizeHandler,
4
+ FinalizeHandlerArguments,
5
+ FinalizeHandlerOutput,
6
+ HandlerExecutionContext,
7
+ } from "./middleware";
3
8
  import { MetadataBearer } from "./response";
4
9
 
5
10
  /**
@@ -53,6 +58,10 @@ export interface BodyLengthCalculator {
53
58
  * Interface that specifies the retry behavior
54
59
  */
55
60
  export interface RetryStrategy {
61
+ /**
62
+ * The retry mode describing how the retry strategy control the traffic flow.
63
+ */
64
+ mode?: string;
56
65
  /**
57
66
  * the retry behavior the will invoke the next handler and handle the retry accordingly.
58
67
  * This function should also update the $metadata from the response accordingly.
@@ -92,3 +101,15 @@ export interface RegionInfo {
92
101
  export interface RegionInfoProvider {
93
102
  (region: string, options?: any): Promise<RegionInfo | undefined>;
94
103
  }
104
+
105
+ /**
106
+ * A tuple that represents an API name and optional version
107
+ * of a library built using the AWS SDK.
108
+ */
109
+ export type UserAgentPair = [name: string, version?: string];
110
+
111
+ /**
112
+ * User agent data that to be put into the request's user
113
+ * agent.
114
+ */
115
+ export type UserAgent = UserAgentPair[];
package/tsconfig.cjs.json CHANGED
@@ -1,5 +1,6 @@
1
1
  {
2
2
  "compilerOptions": {
3
+ "declarationDir": "./types",
3
4
  "rootDir": "./src",
4
5
  "outDir": "./dist/cjs",
5
6
  "baseUrl": "."
package/tsconfig.es.json CHANGED
@@ -1,6 +1,7 @@
1
1
  {
2
2
  "compilerOptions": {
3
3
  "lib": ["es5", "es2015.promise", "es2015.collection", "es2015.iterable", "es2015.symbol.wellknown"],
4
+ "declarationDir": "./types",
4
5
  "rootDir": "./src",
5
6
  "outDir": "./dist/es",
6
7
  "baseUrl": "."
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
@@ -1,4 +1,5 @@
1
1
  import { Logger } from "./logger";
2
+ import { UserAgent } from "./util";
2
3
  export interface InitializeHandlerArguments<Input extends object> {
3
4
  /**
4
5
  * User input to a command. Reflects the userland representation of the
@@ -177,6 +178,12 @@ export interface HandlerOptions {
177
178
  * A unique name to refer to a middleware
178
179
  */
179
180
  name?: string;
181
+ /**
182
+ * A flag to override the existing middleware with the same name. Without
183
+ * setting it, adding middleware with duplicated name will throw an exception.
184
+ * @internal
185
+ */
186
+ override?: boolean;
180
187
  }
181
188
  export interface AbsoluteLocation {
182
189
  /**
@@ -313,6 +320,12 @@ export interface HandlerExecutionContext {
313
320
  * operation.
314
321
  */
315
322
  logger?: Logger;
323
+ /**
324
+ * Additional user agent that inferred by middleware. It can be used to save
325
+ * the internal user agent sections without overriding the `customUserAgent`
326
+ * config in clients.
327
+ */
328
+ userAgent?: UserAgent;
316
329
  [key: string]: any;
317
330
  }
318
331
  export interface Pluggable<Input extends object, Output extends object> {
@@ -10,5 +10,5 @@ export declare type Paginator<T> = AsyncGenerator<T, T, unknown>;
10
10
  export interface PaginationConfiguration {
11
11
  client: Client<any, any, any>;
12
12
  pageSize?: number;
13
- startingToken?: string;
13
+ startingToken?: any;
14
14
  }
@@ -1,13 +1,8 @@
1
- import { HeaderBag } from "./http";
2
1
  export interface ResponseMetadata {
3
2
  /**
4
3
  * The status code of the last HTTP response received for this operation.
5
4
  */
6
5
  httpStatusCode?: number;
7
- /**
8
- * The headers of the last HTTP response received for this operation.
9
- */
10
- httpHeaders?: HeaderBag;
11
6
  /**
12
7
  * A unique identifier for the last request sent for this operation. Often
13
8
  * requested by AWS service teams to aid in debugging.
File without changes
File without changes
File without changes