Socket
Socket
Sign inDemoInstall

@aws-sdk/middleware-stack

Package Overview
Dependencies
Maintainers
5
Versions
120
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-sdk/middleware-stack - npm Package Compare versions

Comparing version 1.0.0-gamma.4 to 1.0.0-gamma.5

dist/es/index.d.ts

17

CHANGELOG.md

@@ -6,2 +6,19 @@ # Change Log

# [1.0.0-gamma.5](https://github.com/aws/aws-sdk-js-v3/compare/@aws-sdk/middleware-stack@1.0.0-gamma.4...@aws-sdk/middleware-stack@1.0.0-gamma.5) (2020-08-04)
### Features
* build command ([#1407](https://github.com/aws/aws-sdk-js-v3/issues/1407)) ([81b2e87](https://github.com/aws/aws-sdk-js-v3/commit/81b2e87067642a8cea8649cbdb2c342ca9fb6ac6))
* refactor middleware stack ([#1398](https://github.com/aws/aws-sdk-js-v3/issues/1398)) ([9fedaa9](https://github.com/aws/aws-sdk-js-v3/commit/9fedaa9696ff1ecf5d1e92b28b34d573583a7842))
### BREAKING CHANGES
* addRelativeTo() now doesn't require step in options. The middleware will be injected to the same step as the toMiddleware
# [1.0.0-gamma.4](https://github.com/aws/aws-sdk-js-v3/compare/@aws-sdk/middleware-stack@1.0.0-gamma.3...@aws-sdk/middleware-stack@1.0.0-gamma.4) (2020-07-21)

@@ -8,0 +25,0 @@

53

dist/cjs/MiddlewareStack.d.ts

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

import { AbsoluteLocation, BuildHandlerOptions, BuildMiddleware, DeserializeHandler, DeserializeHandlerOptions, DeserializeMiddleware, FinalizeRequestHandlerOptions, FinalizeRequestMiddleware, Handler, HandlerExecutionContext, InitializeHandlerOptions, InitializeMiddleware, MiddlewareStack as IMiddlewareStack, MiddlewareType, Pluggable, RelativeLocation, SerializeHandlerOptions, SerializeMiddleware } from "@aws-sdk/types";
export interface MiddlewareStack<Input extends object, Output extends object> extends IMiddlewareStack<Input, Output> {
}
export declare class MiddlewareStack<Input extends object, Output extends object> {
private readonly absoluteEntries;
private readonly relativeEntries;
private entriesNameMap;
add(middleware: InitializeMiddleware<Input, Output>, options?: InitializeHandlerOptions & AbsoluteLocation): void;
add(middleware: SerializeMiddleware<Input, Output>, options: SerializeHandlerOptions & AbsoluteLocation): void;
add(middleware: BuildMiddleware<Input, Output>, options: BuildHandlerOptions & AbsoluteLocation): void;
add(middleware: FinalizeRequestMiddleware<Input, Output>, options: FinalizeRequestHandlerOptions & AbsoluteLocation): void;
add(middleware: DeserializeMiddleware<Input, Output>, options: DeserializeHandlerOptions & AbsoluteLocation): void;
addRelativeTo(middleware: InitializeMiddleware<Input, Output>, options: InitializeHandlerOptions & RelativeLocation<Input, Output>): void;
addRelativeTo(middleware: SerializeMiddleware<Input, Output>, options: SerializeHandlerOptions & RelativeLocation<Input, Output>): void;
addRelativeTo(middleware: BuildMiddleware<Input, Output>, options: BuildHandlerOptions & RelativeLocation<Input, Output>): void;
addRelativeTo(middleware: FinalizeRequestMiddleware<Input, Output>, options: FinalizeRequestHandlerOptions & RelativeLocation<Input, Output>): void;
addRelativeTo(middleware: DeserializeMiddleware<Input, Output>, options: DeserializeHandlerOptions & RelativeLocation<Input, Output>): void;
private sort;
clone(): IMiddlewareStack<Input, Output>;
concat<InputType extends Input, OutputType extends Output>(from: IMiddlewareStack<InputType, OutputType>): MiddlewareStack<InputType, OutputType>;
remove(toRemove: MiddlewareType<Input, Output> | string): boolean;
private removeByName;
private removeByReference;
removeByTag(toRemove: string): boolean;
use(plugin: Pluggable<Input, Output>): void;
/**
* Resolve relative middleware entries to multiple double linked lists
* depicting the relative location of middleware. Only middleware that have
* direct or transitive relation will form a linked list.
*
* This function normalizes relative middleware into 2 categories of linked
* lists. (1) linked list that have absolute-located middleware on one end.
* These middleware will be resolved accordingly before or after the absolute-
* located middleware. (2) Linked list that have no absolute-located middleware
* on any end. They will be resolved to corresponding step with normal priority
*
* The 2 types of linked list will return as a tuple
*/
private normalizeRelativeEntries;
/**
* Get a final list of middleware in the order of being executed in the resolved handler.
* If relative entries list is not empty, those entries will be added to final middleware
* list with rules below:
* 1. if `toMiddleware` exists in the specific `step`, the middleware will be inserted before
* or after the specified `toMiddleware`
* 2. if `toMiddleware` doesn't exist in the specific `step`, the middleware will be appended
* to specific `step` with priority of `normal`
*/
private getMiddlewareList;
resolve<InputType extends Input, OutputType extends Output>(handler: DeserializeHandler<InputType, OutputType>, context: HandlerExecutionContext): Handler<InputType, OutputType>;
}
import { MiddlewareStack } from "@aws-sdk/types";
export declare const constructStack: <Input extends object, Output extends object>() => MiddlewareStack<Input, Output>;
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.MiddlewareStack = void 0;
exports.constructStack = void 0;
var tslib_1 = require("tslib");
var MiddlewareStack = /** @class */ (function () {
function MiddlewareStack() {
this.absoluteEntries = [];
this.relativeEntries = [];
this.entriesNameMap = {};
}
MiddlewareStack.prototype.add = function (middleware, options) {
if (options === void 0) { options = {}; }
var name = options.name, _a = options.step, step = _a === void 0 ? "initialize" : _a, tags = options.tags, _b = options.priority, priority = _b === void 0 ? "normal" : _b;
var entry = {
name: name,
step: step,
tags: tags,
priority: priority,
middleware: middleware,
};
if (name) {
if (Object.prototype.hasOwnProperty.call(this.entriesNameMap, name)) {
throw new Error("Duplicated middleware name '" + name + "'");
}
this.entriesNameMap[name] = entry;
}
this.absoluteEntries.push(entry);
};
MiddlewareStack.prototype.addRelativeTo = function (middleware, options) {
var _a = options.step, step = _a === void 0 ? "initialize" : _a, name = options.name, tags = options.tags, relation = options.relation, toMiddleware = options.toMiddleware;
var entry = {
middleware: middleware,
step: step,
name: name,
tags: tags,
next: relation === "before" ? toMiddleware : undefined,
prev: relation === "after" ? toMiddleware : undefined,
};
if (name) {
if (Object.prototype.hasOwnProperty.call(this.entriesNameMap, name)) {
throw new Error("Duplicated middleware name '" + name + "'");
}
this.entriesNameMap[name] = entry;
}
this.relativeEntries.push(entry);
};
MiddlewareStack.prototype.sort = function (entries) {
//reverse before sorting so that middleware of same step will execute in
//the order of being added
exports.constructStack = function () {
var absoluteEntries = [];
var relativeEntries = [];
var entriesNameSet = new Set();
var sort = function (entries) {
return entries.sort(function (a, b) {

@@ -55,282 +15,181 @@ return stepWeights[b.step] - stepWeights[a.step] ||

};
MiddlewareStack.prototype.clone = function () {
var _a, _b;
var clone = new MiddlewareStack();
(_a = clone.absoluteEntries).push.apply(_a, tslib_1.__spread(this.absoluteEntries));
(_b = clone.relativeEntries).push.apply(_b, tslib_1.__spread(this.relativeEntries));
clone.entriesNameMap = tslib_1.__assign({}, this.entriesNameMap);
return clone;
var removeByName = function (toRemove) {
var isRemoved = false;
var filterCb = function (entry) {
if (entry.name && entry.name === toRemove) {
isRemoved = true;
entriesNameSet.delete(toRemove);
return false;
}
return true;
};
absoluteEntries = absoluteEntries.filter(filterCb);
relativeEntries = relativeEntries.filter(filterCb);
return isRemoved;
};
MiddlewareStack.prototype.concat = function (from) {
var _a, _b;
var clone = new MiddlewareStack();
clone.entriesNameMap = tslib_1.__assign({}, this.entriesNameMap);
// IMiddlewareStack interface doesn't contain private members variables
// like `entriesNameMap`, but in fact the function expects `MiddlewareStack`
// class instance. So here we cast it.
var _from = from;
for (var name in _from.entriesNameMap) {
if (clone.entriesNameMap[name]) {
throw new Error("Duplicated middleware name '" + name + "'");
var removeByReference = function (toRemove) {
var isRemoved = false;
var filterCb = function (entry) {
if (entry.middleware === toRemove) {
isRemoved = true;
if (entry.name)
entriesNameSet.delete(entry.name);
return false;
}
clone.entriesNameMap[name] = _from.entriesNameMap[name];
}
(_a = clone.absoluteEntries).push.apply(_a, tslib_1.__spread(this.absoluteEntries, _from.absoluteEntries));
(_b = clone.relativeEntries).push.apply(_b, tslib_1.__spread(this.relativeEntries, _from.relativeEntries));
return clone;
return true;
};
absoluteEntries = absoluteEntries.filter(filterCb);
relativeEntries = relativeEntries.filter(filterCb);
return isRemoved;
};
MiddlewareStack.prototype.remove = function (toRemove) {
if (typeof toRemove === "string")
return this.removeByName(toRemove);
else
return this.removeByReference(toRemove);
var cloneTo = function (toStack) {
absoluteEntries.forEach(function (entry) {
//@ts-ignore
toStack.add(entry.middleware, tslib_1.__assign({}, entry));
});
relativeEntries.forEach(function (entry) {
//@ts-ignore
toStack.addRelativeTo(entry.middleware, tslib_1.__assign({}, entry));
});
return toStack;
};
MiddlewareStack.prototype.removeByName = function (toRemove) {
for (var i = this.absoluteEntries.length - 1; i >= 0; i--) {
if (this.absoluteEntries[i].name && this.absoluteEntries[i].name === toRemove) {
this.absoluteEntries.splice(i, 1);
delete this.entriesNameMap[toRemove];
return true;
var expandRelativeMiddlewareList = function (from) {
var expandedMiddlewareList = [];
from.before.forEach(function (entry) {
if (entry.before.length === 0 && entry.after.length === 0) {
expandedMiddlewareList.push(entry);
}
}
for (var i = this.relativeEntries.length - 1; i >= 0; i--) {
if (this.relativeEntries[i].name && this.relativeEntries[i].name === toRemove) {
this.relativeEntries.splice(i, 1);
delete this.entriesNameMap[toRemove];
return true;
else {
expandedMiddlewareList.push.apply(expandedMiddlewareList, tslib_1.__spread(expandRelativeMiddlewareList(entry)));
}
}
return false;
};
MiddlewareStack.prototype.removeByReference = function (toRemove) {
for (var i = this.absoluteEntries.length - 1; i >= 0; i--) {
if (this.absoluteEntries[i].middleware === toRemove) {
var name = this.absoluteEntries[i].name;
if (name)
delete this.entriesNameMap[name];
this.absoluteEntries.splice(i, 1);
return true;
});
expandedMiddlewareList.push(from);
from.after.reverse().forEach(function (entry) {
if (entry.before.length === 0 && entry.after.length === 0) {
expandedMiddlewareList.push(entry);
}
}
for (var i = this.relativeEntries.length - 1; i >= 0; i--) {
if (this.relativeEntries[i].middleware === toRemove) {
var name = this.relativeEntries[i].name;
if (name)
delete this.entriesNameMap[name];
this.relativeEntries.splice(i, 1);
return true;
else {
expandedMiddlewareList.push.apply(expandedMiddlewareList, tslib_1.__spread(expandRelativeMiddlewareList(entry)));
}
}
return false;
});
return expandedMiddlewareList;
};
MiddlewareStack.prototype.removeByTag = function (toRemove) {
var removed = false;
for (var i = this.absoluteEntries.length - 1; i >= 0; i--) {
var _a = this.absoluteEntries[i], tags = _a.tags, name = _a.name;
if (tags && tags.indexOf(toRemove) > -1) {
this.absoluteEntries.splice(i, 1);
if (name)
delete this.entriesNameMap[name];
removed = true;
}
}
for (var i = this.relativeEntries.length - 1; i >= 0; i--) {
var _b = this.relativeEntries[i], tags = _b.tags, name = _b.name;
if (tags && tags.indexOf(toRemove) > -1) {
this.relativeEntries.splice(i, 1);
if (name)
delete this.entriesNameMap[name];
removed = true;
}
}
return removed;
};
MiddlewareStack.prototype.use = function (plugin) {
plugin.applyToStack(this);
};
/**
* Resolve relative middleware entries to multiple double linked lists
* depicting the relative location of middleware. Only middleware that have
* direct or transitive relation will form a linked list.
*
* This function normalizes relative middleware into 2 categories of linked
* lists. (1) linked list that have absolute-located middleware on one end.
* These middleware will be resolved accordingly before or after the absolute-
* located middleware. (2) Linked list that have no absolute-located middleware
* on any end. They will be resolved to corresponding step with normal priority
*
* The 2 types of linked list will return as a tuple
* Get a final list of middleware in the order of being executed in the resolved handler.
*/
MiddlewareStack.prototype.normalizeRelativeEntries = function () {
var e_1, _a;
var absoluteMiddlewareNamesMap = this.absoluteEntries
.filter(function (entry) { return entry.name; })
.reduce(function (accumulator, entry) {
accumulator[entry.name] = entry;
return accumulator;
}, {});
var normalized = this.relativeEntries.map(function (entry) {
return (tslib_1.__assign(tslib_1.__assign({}, entry), { priority: null, next: undefined, prev: undefined }));
var getMiddlewareList = function () {
var normalizedAbsoluteEntries = [];
var normalizedRelativeEntries = [];
var normalizedEntriesNameMap = {};
absoluteEntries.forEach(function (entry) {
var normalizedEntry = tslib_1.__assign(tslib_1.__assign({}, entry), { before: [], after: [] });
if (normalizedEntry.name)
normalizedEntriesNameMap[normalizedEntry.name] = normalizedEntry;
normalizedAbsoluteEntries.push(normalizedEntry);
});
var relativeMiddlewareNamesMap = normalized
.filter(function (entry) { return entry.name; })
.reduce(function (accumulator, entry) {
accumulator[entry.name] = entry;
return accumulator;
}, {});
var anchors = {};
for (var i = 0; i < this.relativeEntries.length; i++) {
var _b = this.relativeEntries[i], prev = _b.prev, next = _b.next;
var resolvedCurr = normalized[i];
//either prev or next is set
if (prev) {
if (absoluteMiddlewareNamesMap[prev] && absoluteMiddlewareNamesMap[prev].step === resolvedCurr.step) {
if (!anchors[prev])
anchors[prev] = {};
resolvedCurr.next = anchors[prev].next;
if (anchors[prev].next)
anchors[prev].next.prev = resolvedCurr;
anchors[prev].next = resolvedCurr;
relativeEntries.forEach(function (entry) {
var normalizedEntry = tslib_1.__assign(tslib_1.__assign({}, entry), { before: [], after: [] });
if (normalizedEntry.name)
normalizedEntriesNameMap[normalizedEntry.name] = normalizedEntry;
normalizedRelativeEntries.push(normalizedEntry);
});
normalizedRelativeEntries.forEach(function (entry) {
if (entry.toMiddleware) {
var toMiddleware = normalizedEntriesNameMap[entry.toMiddleware];
if (toMiddleware === undefined) {
throw new Error(entry.toMiddleware + " is not found when adding " + (entry.name || "anonymous") + " middleware " + entry.relation + " " + entry.toMiddleware);
}
else if (relativeMiddlewareNamesMap[prev] && relativeMiddlewareNamesMap[prev].step === resolvedCurr.step) {
var resolvedPrev = relativeMiddlewareNamesMap[prev];
if (resolvedPrev.next === resolvedCurr)
continue;
resolvedCurr.next = resolvedPrev.next;
resolvedPrev.next = resolvedCurr;
if (resolvedCurr.next)
resolvedCurr.next.prev = resolvedCurr;
resolvedCurr.prev = resolvedPrev;
if (entry.relation === "after") {
toMiddleware.after.push(entry);
}
if (entry.relation === "before") {
toMiddleware.before.push(entry);
}
}
else if (next) {
if (absoluteMiddlewareNamesMap[next] && absoluteMiddlewareNamesMap[next].step === resolvedCurr.step) {
if (!anchors[next])
anchors[next] = {};
resolvedCurr.prev = anchors[next].prev;
if (anchors[next].prev)
anchors[next].prev.next = resolvedCurr;
anchors[next].prev = resolvedCurr;
});
var mainChain = sort(normalizedAbsoluteEntries)
.map(expandRelativeMiddlewareList)
.reduce(function (wholeList, expendedMiddlewareList) {
// TODO: Replace it with Array.flat();
wholeList.push.apply(wholeList, tslib_1.__spread(expendedMiddlewareList));
return wholeList;
}, []);
return mainChain.map(function (entry) { return entry.middleware; });
};
var stack = {
add: function (middleware, options) {
if (options === void 0) { options = {}; }
var name = options.name;
var entry = tslib_1.__assign({ step: "initialize", priority: "normal", middleware: middleware }, options);
if (name) {
if (entriesNameSet.has(name)) {
throw new Error("Duplicate middleware name '" + name + "'");
}
else if (relativeMiddlewareNamesMap[next] && relativeMiddlewareNamesMap[next].step === resolvedCurr.step) {
var resolvedNext = relativeMiddlewareNamesMap[next];
if (resolvedNext.prev === resolvedCurr)
continue;
resolvedCurr.prev = resolvedNext.prev;
resolvedNext.prev = resolvedCurr;
if (resolvedCurr.prev)
resolvedCurr.prev.next = resolvedCurr;
resolvedCurr.next = resolvedNext;
entriesNameSet.add(name);
}
absoluteEntries.push(entry);
},
addRelativeTo: function (middleware, options) {
var name = options.name;
var entry = tslib_1.__assign({ middleware: middleware }, options);
if (name) {
if (entriesNameSet.has(name)) {
throw new Error("Duplicated middleware name '" + name + "'");
}
entriesNameSet.add(name);
}
}
// get the head of the relative middleware linked list that have
// no transitive relation to absolute middleware.
var orphanedRelativeEntries = [];
var visited = new WeakSet();
try {
for (var _c = tslib_1.__values(Object.keys(anchors)), _d = _c.next(); !_d.done; _d = _c.next()) {
var anchorName = _d.value;
var _e = anchors[anchorName], prev = _e.prev, next = _e.next;
while (prev) {
visited.add(prev);
prev = prev.prev;
relativeEntries.push(entry);
},
clone: function () { return cloneTo(exports.constructStack()); },
use: function (plugin) {
plugin.applyToStack(stack);
},
remove: function (toRemove) {
if (typeof toRemove === "string")
return removeByName(toRemove);
else
return removeByReference(toRemove);
},
removeByTag: function (toRemove) {
var isRemoved = false;
var filterCb = function (entry) {
var tags = entry.tags, name = entry.name;
if (tags && tags.includes(toRemove)) {
if (name)
entriesNameSet.delete(name);
isRemoved = true;
return false;
}
while (next) {
visited.add(next);
next = next.next;
return true;
};
absoluteEntries = absoluteEntries.filter(filterCb);
relativeEntries = relativeEntries.filter(filterCb);
return isRemoved;
},
concat: function (from) {
var cloned = cloneTo(exports.constructStack());
cloned.use(from);
return cloned;
},
applyToStack: cloneTo,
resolve: function (handler, context) {
var e_1, _a;
try {
for (var _b = tslib_1.__values(getMiddlewareList().reverse()), _c = _b.next(); !_c.done; _c = _b.next()) {
var middleware = _c.value;
handler = middleware(handler, context);
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
}
finally { if (e_1) throw e_1.error; }
}
for (var i = 0; i < normalized.length; i++) {
var entry = normalized[i];
if (visited.has(entry))
continue;
if (!entry.prev)
orphanedRelativeEntries.push(entry);
while (entry && !visited.has(entry)) {
visited.add(entry);
entry = entry.next;
}
}
return [orphanedRelativeEntries, anchors];
};
/**
* Get a final list of middleware in the order of being executed in the resolved handler.
* If relative entries list is not empty, those entries will be added to final middleware
* list with rules below:
* 1. if `toMiddleware` exists in the specific `step`, the middleware will be inserted before
* or after the specified `toMiddleware`
* 2. if `toMiddleware` doesn't exist in the specific `step`, the middleware will be appended
* to specific `step` with priority of `normal`
*/
MiddlewareStack.prototype.getMiddlewareList = function () {
var e_2, _a;
var middlewareList = [];
var _b = tslib_1.__read(this.normalizeRelativeEntries(), 2), orphanedRelativeEntries = _b[0], anchors = _b[1];
var entryList = tslib_1.__spread(this.absoluteEntries, orphanedRelativeEntries);
entryList = this.sort(entryList);
try {
for (var entryList_1 = tslib_1.__values(entryList), entryList_1_1 = entryList_1.next(); !entryList_1_1.done; entryList_1_1 = entryList_1.next()) {
var entry = entryList_1_1.value;
var defaultAnchorValue = { prev: undefined, next: undefined };
var _c = entry.name ? anchors[entry.name] || defaultAnchorValue : defaultAnchorValue, prev = _c.prev, next = _c.next;
var relativeEntry = prev;
//reverse relative entry linked list and add to ordered handler list
while (relativeEntry === null || relativeEntry === void 0 ? void 0 : relativeEntry.prev) {
relativeEntry = relativeEntry.prev;
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
while (relativeEntry) {
middlewareList.push(relativeEntry.middleware);
relativeEntry = relativeEntry.next;
}
middlewareList.push(entry.middleware);
var orphanedEntry = entry;
while (orphanedEntry.next) {
middlewareList.push(orphanedEntry.next.middleware);
orphanedEntry = orphanedEntry.next;
}
relativeEntry = next;
while (relativeEntry) {
middlewareList.push(relativeEntry.middleware);
relativeEntry = relativeEntry.next;
}
finally { if (e_1) throw e_1.error; }
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (entryList_1_1 && !entryList_1_1.done && (_a = entryList_1.return)) _a.call(entryList_1);
}
finally { if (e_2) throw e_2.error; }
}
return middlewareList.reverse();
return handler;
},
};
MiddlewareStack.prototype.resolve = function (handler, context) {
var e_3, _a;
try {
for (var _b = tslib_1.__values(this.getMiddlewareList()), _c = _b.next(); !_c.done; _c = _b.next()) {
var middleware = _c.value;
handler = middleware(handler, context);
}
}
catch (e_3_1) { e_3 = { error: e_3_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_3) throw e_3.error; }
}
return handler;
};
return MiddlewareStack;
}());
exports.MiddlewareStack = MiddlewareStack;
return stack;
};
var stepWeights = {

@@ -348,2 +207,2 @@ initialize: 5,

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MiddlewareStack.js","sourceRoot":"","sources":["../../src/MiddlewareStack.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AbsoluteLocation,\n  BuildHandlerOptions,\n  BuildMiddleware,\n  DeserializeHandler,\n  DeserializeHandlerOptions,\n  DeserializeMiddleware,\n  FinalizeRequestHandlerOptions,\n  FinalizeRequestMiddleware,\n  Handler,\n  HandlerExecutionContext,\n  HandlerOptions,\n  InitializeHandlerOptions,\n  InitializeMiddleware,\n  MiddlewareStack as IMiddlewareStack,\n  MiddlewareType,\n  Pluggable,\n  Priority,\n  RelativeLocation,\n  SerializeHandlerOptions,\n  SerializeMiddleware,\n  Step,\n} from \"@aws-sdk/types\";\n\nimport {\n  MiddlewareEntry,\n  NamedMiddlewareEntriesMap,\n  NamedRelativeEntriesMap,\n  NormalizedRelativeEntry,\n  NormalizingEntryResult,\n  RelativeMiddlewareAnchor,\n  RelativeMiddlewareEntry,\n} from \"./types\";\n\nexport interface MiddlewareStack<Input extends object, Output extends object> extends IMiddlewareStack<Input, Output> {}\n\nexport class MiddlewareStack<Input extends object, Output extends object> {\n  private readonly absoluteEntries: Array<MiddlewareEntry<Input, Output>> = [];\n  private readonly relativeEntries: Array<RelativeMiddlewareEntry<Input, Output>> = [];\n  private entriesNameMap: {\n    [middlewareName: string]: MiddlewareEntry<Input, Output> | RelativeMiddlewareEntry<Input, Output>;\n  } = {};\n\n  add(middleware: InitializeMiddleware<Input, Output>, options?: InitializeHandlerOptions & AbsoluteLocation): void;\n\n  add(middleware: SerializeMiddleware<Input, Output>, options: SerializeHandlerOptions & AbsoluteLocation): void;\n\n  add(middleware: BuildMiddleware<Input, Output>, options: BuildHandlerOptions & AbsoluteLocation): void;\n\n  add(\n    middleware: FinalizeRequestMiddleware<Input, Output>,\n    options: FinalizeRequestHandlerOptions & AbsoluteLocation\n  ): void;\n\n  add(middleware: DeserializeMiddleware<Input, Output>, options: DeserializeHandlerOptions & AbsoluteLocation): void;\n\n  add(middleware: MiddlewareType<Input, Output>, options: HandlerOptions & AbsoluteLocation = {}): void {\n    const { name, step = \"initialize\", tags, priority = \"normal\" } = options;\n    const entry: MiddlewareEntry<Input, Output> = {\n      name,\n      step,\n      tags,\n      priority,\n      middleware,\n    };\n    if (name) {\n      if (Object.prototype.hasOwnProperty.call(this.entriesNameMap, name)) {\n        throw new Error(`Duplicated middleware name '${name}'`);\n      }\n      this.entriesNameMap[name] = entry;\n    }\n    this.absoluteEntries.push(entry);\n  }\n\n  addRelativeTo(\n    middleware: InitializeMiddleware<Input, Output>,\n    options: InitializeHandlerOptions & RelativeLocation<Input, Output>\n  ): void;\n\n  addRelativeTo(\n    middleware: SerializeMiddleware<Input, Output>,\n    options: SerializeHandlerOptions & RelativeLocation<Input, Output>\n  ): void;\n\n  addRelativeTo(\n    middleware: BuildMiddleware<Input, Output>,\n    options: BuildHandlerOptions & RelativeLocation<Input, Output>\n  ): void;\n\n  addRelativeTo(\n    middleware: FinalizeRequestMiddleware<Input, Output>,\n    options: FinalizeRequestHandlerOptions & RelativeLocation<Input, Output>\n  ): void;\n\n  addRelativeTo(\n    middleware: DeserializeMiddleware<Input, Output>,\n    options: DeserializeHandlerOptions & RelativeLocation<Input, Output>\n  ): void;\n\n  addRelativeTo(\n    middleware: MiddlewareType<Input, Output>,\n    options: HandlerOptions & RelativeLocation<Input, Output>\n  ): void {\n    const { step = \"initialize\", name, tags, relation, toMiddleware } = options;\n    const entry: RelativeMiddlewareEntry<Input, Output> = {\n      middleware,\n      step,\n      name,\n      tags,\n      next: relation === \"before\" ? toMiddleware : undefined,\n      prev: relation === \"after\" ? toMiddleware : undefined,\n    };\n    if (name) {\n      if (Object.prototype.hasOwnProperty.call(this.entriesNameMap, name)) {\n        throw new Error(`Duplicated middleware name '${name}'`);\n      }\n      this.entriesNameMap[name] = entry;\n    }\n    this.relativeEntries.push(entry);\n  }\n\n  private sort(\n    entries: Array<MiddlewareEntry<Input, Output> | NormalizedRelativeEntry<Input, Output>>\n  ): Array<MiddlewareEntry<Input, Output> | NormalizedRelativeEntry<Input, Output>> {\n    //reverse before sorting so that middleware of same step will execute in\n    //the order of being added\n    return entries.sort(\n      (a, b) =>\n        stepWeights[b.step] - stepWeights[a.step] ||\n        priorityWeights[b.priority || \"normal\"] - priorityWeights[a.priority || \"normal\"]\n    );\n  }\n\n  clone(): IMiddlewareStack<Input, Output> {\n    const clone = new MiddlewareStack<Input, Output>();\n    clone.absoluteEntries.push(...this.absoluteEntries);\n    clone.relativeEntries.push(...this.relativeEntries);\n    clone.entriesNameMap = { ...this.entriesNameMap };\n    return clone;\n  }\n\n  concat<InputType extends Input, OutputType extends Output>(\n    from: IMiddlewareStack<InputType, OutputType>\n  ): MiddlewareStack<InputType, OutputType> {\n    const clone = new MiddlewareStack<InputType, OutputType>();\n    clone.entriesNameMap = { ...(this.entriesNameMap as any) };\n    // IMiddlewareStack interface doesn't contain private members variables\n    // like `entriesNameMap`, but in fact the function expects `MiddlewareStack`\n    // class instance. So here we cast it.\n    const _from = from as MiddlewareStack<InputType, OutputType>;\n    for (const name in _from.entriesNameMap) {\n      if (clone.entriesNameMap[name]) {\n        throw new Error(`Duplicated middleware name '${name}'`);\n      }\n      clone.entriesNameMap[name] = _from.entriesNameMap[name];\n    }\n    clone.absoluteEntries.push(...(this.absoluteEntries as any), ..._from.absoluteEntries);\n    clone.relativeEntries.push(...(this.relativeEntries as any), ..._from.relativeEntries);\n    return clone;\n  }\n\n  remove(toRemove: MiddlewareType<Input, Output> | string): boolean {\n    if (typeof toRemove === \"string\") return this.removeByName(toRemove);\n    else return this.removeByReference(toRemove);\n  }\n\n  private removeByName(toRemove: string): boolean {\n    for (let i = this.absoluteEntries.length - 1; i >= 0; i--) {\n      if (this.absoluteEntries[i].name && this.absoluteEntries[i].name === toRemove) {\n        this.absoluteEntries.splice(i, 1);\n        delete this.entriesNameMap[toRemove];\n        return true;\n      }\n    }\n    for (let i = this.relativeEntries.length - 1; i >= 0; i--) {\n      if (this.relativeEntries[i].name && this.relativeEntries[i].name === toRemove) {\n        this.relativeEntries.splice(i, 1);\n        delete this.entriesNameMap[toRemove];\n        return true;\n      }\n    }\n    return false;\n  }\n\n  private removeByReference(toRemove: MiddlewareType<Input, Output>): boolean {\n    for (let i = this.absoluteEntries.length - 1; i >= 0; i--) {\n      if (this.absoluteEntries[i].middleware === toRemove) {\n        const { name } = this.absoluteEntries[i];\n        if (name) delete this.entriesNameMap[name];\n        this.absoluteEntries.splice(i, 1);\n        return true;\n      }\n    }\n    for (let i = this.relativeEntries.length - 1; i >= 0; i--) {\n      if (this.relativeEntries[i].middleware === toRemove) {\n        const { name } = this.relativeEntries[i];\n        if (name) delete this.entriesNameMap[name];\n        this.relativeEntries.splice(i, 1);\n        return true;\n      }\n    }\n    return false;\n  }\n\n  removeByTag(toRemove: string): boolean {\n    let removed = false;\n    for (let i = this.absoluteEntries.length - 1; i >= 0; i--) {\n      const { tags, name } = this.absoluteEntries[i];\n      if (tags && tags.indexOf(toRemove) > -1) {\n        this.absoluteEntries.splice(i, 1);\n        if (name) delete this.entriesNameMap[name];\n        removed = true;\n      }\n    }\n    for (let i = this.relativeEntries.length - 1; i >= 0; i--) {\n      const { tags, name } = this.relativeEntries[i];\n      if (tags && tags.indexOf(toRemove) > -1) {\n        this.relativeEntries.splice(i, 1);\n        if (name) delete this.entriesNameMap[name];\n        removed = true;\n      }\n    }\n    return removed;\n  }\n\n  use(plugin: Pluggable<Input, Output>) {\n    plugin.applyToStack(this);\n  }\n\n  /**\n   * Resolve relative middleware entries to multiple double linked lists\n   * depicting the relative location of middleware. Only middleware that have\n   * direct or transitive relation will form a linked list.\n   *\n   * This function normalizes relative middleware into 2 categories of linked\n   * lists. (1) linked list that have absolute-located middleware on one end.\n   * These middleware will be resolved accordingly before or after the absolute-\n   * located middleware. (2) Linked list that have no absolute-located middleware\n   * on any end. They will be resolved to corresponding step with normal priority\n   *\n   * The 2 types of linked list will return as a tuple\n   */\n  private normalizeRelativeEntries(): NormalizingEntryResult<Input, Output> {\n    const absoluteMiddlewareNamesMap = this.absoluteEntries\n      .filter((entry) => entry.name)\n      .reduce((accumulator, entry) => {\n        accumulator[entry.name!] = entry;\n        return accumulator;\n      }, {} as NamedMiddlewareEntriesMap<Input, Output>);\n    const normalized = this.relativeEntries.map(\n      (entry) =>\n        ({\n          ...entry,\n          priority: null,\n          next: undefined,\n          prev: undefined,\n        } as NormalizedRelativeEntry<Input, Output>)\n    );\n    const relativeMiddlewareNamesMap = normalized\n      .filter((entry) => entry.name)\n      .reduce((accumulator, entry) => {\n        accumulator[entry.name!] = entry;\n        return accumulator;\n      }, {} as NamedRelativeEntriesMap<Input, Output>);\n\n    const anchors: RelativeMiddlewareAnchor<Input, Output> = {};\n    for (let i = 0; i < this.relativeEntries.length; i++) {\n      const { prev, next } = this.relativeEntries[i];\n      const resolvedCurr = normalized[i];\n      //either prev or next is set\n      if (prev) {\n        if (absoluteMiddlewareNamesMap[prev] && absoluteMiddlewareNamesMap[prev].step === resolvedCurr.step) {\n          if (!anchors[prev]) anchors[prev] = {};\n          resolvedCurr.next = anchors[prev].next;\n          if (anchors[prev].next) anchors[prev].next!.prev = resolvedCurr;\n          anchors[prev].next = resolvedCurr;\n        } else if (relativeMiddlewareNamesMap[prev] && relativeMiddlewareNamesMap[prev].step === resolvedCurr.step) {\n          const resolvedPrev = relativeMiddlewareNamesMap[prev];\n          if (resolvedPrev.next === resolvedCurr) continue;\n          resolvedCurr.next = resolvedPrev.next;\n          resolvedPrev.next = resolvedCurr;\n          if (resolvedCurr.next) resolvedCurr.next.prev = resolvedCurr;\n          resolvedCurr.prev = resolvedPrev;\n        }\n      } else if (next) {\n        if (absoluteMiddlewareNamesMap[next] && absoluteMiddlewareNamesMap[next].step === resolvedCurr.step) {\n          if (!anchors[next]) anchors[next] = {};\n          resolvedCurr.prev = anchors[next].prev;\n          if (anchors[next].prev) anchors[next].prev!.next = resolvedCurr;\n          anchors[next].prev = resolvedCurr;\n        } else if (relativeMiddlewareNamesMap[next] && relativeMiddlewareNamesMap[next].step === resolvedCurr.step) {\n          const resolvedNext = relativeMiddlewareNamesMap[next];\n          if (resolvedNext.prev === resolvedCurr) continue;\n          resolvedCurr.prev = resolvedNext.prev;\n          resolvedNext.prev = resolvedCurr;\n          if (resolvedCurr.prev) resolvedCurr.prev.next = resolvedCurr;\n          resolvedCurr.next = resolvedNext;\n        }\n      }\n    }\n    // get the head of the relative middleware linked list that have\n    // no transitive relation to absolute middleware.\n    const orphanedRelativeEntries: Array<NormalizedRelativeEntry<Input, Output>> = [];\n    const visited: WeakSet<NormalizedRelativeEntry<Input, Output>> = new WeakSet();\n    for (const anchorName of Object.keys(anchors)) {\n      let { prev, next } = anchors[anchorName];\n      while (prev) {\n        visited.add(prev);\n        prev = prev.prev;\n      }\n      while (next) {\n        visited.add(next);\n        next = next.next;\n      }\n    }\n    for (let i = 0; i < normalized.length; i++) {\n      let entry: NormalizedRelativeEntry<Input, Output> | undefined = normalized[i];\n      if (visited.has(entry)) continue;\n      if (!entry.prev) orphanedRelativeEntries.push(entry);\n      while (entry && !visited.has(entry)) {\n        visited.add(entry);\n        entry = entry.next;\n      }\n    }\n    return [orphanedRelativeEntries, anchors];\n  }\n\n  /**\n   * Get a final list of middleware in the order of being executed in the resolved handler.\n   * If relative entries list is not empty, those entries will be added to final middleware\n   * list with rules below:\n   * 1. if `toMiddleware` exists in the specific `step`, the middleware will be inserted before\n   *     or after the specified `toMiddleware`\n   * 2. if `toMiddleware` doesn't exist in the specific `step`, the middleware will be appended\n   *     to specific `step` with priority of `normal`\n   */\n  private getMiddlewareList(): Array<MiddlewareType<Input, Output>> {\n    const middlewareList: Array<MiddlewareType<Input, Output>> = [];\n    const [orphanedRelativeEntries, anchors] = this.normalizeRelativeEntries();\n    let entryList = [...this.absoluteEntries, ...orphanedRelativeEntries];\n    entryList = this.sort(entryList);\n    for (const entry of entryList) {\n      const defaultAnchorValue = { prev: undefined, next: undefined };\n      const { prev, next } = entry.name ? anchors[entry.name] || defaultAnchorValue : defaultAnchorValue;\n      let relativeEntry = prev;\n      //reverse relative entry linked list and add to ordered handler list\n      while (relativeEntry?.prev) {\n        relativeEntry = relativeEntry.prev;\n      }\n      while (relativeEntry) {\n        middlewareList.push(relativeEntry.middleware);\n        relativeEntry = relativeEntry.next;\n      }\n      middlewareList.push(entry.middleware);\n      let orphanedEntry = entry as any;\n      while ((orphanedEntry as any).next) {\n        middlewareList.push((orphanedEntry as any).next.middleware);\n        orphanedEntry = (orphanedEntry as any).next;\n      }\n      relativeEntry = next;\n      while (relativeEntry) {\n        middlewareList.push(relativeEntry.middleware);\n        relativeEntry = relativeEntry.next;\n      }\n    }\n    return middlewareList.reverse();\n  }\n\n  resolve<InputType extends Input, OutputType extends Output>(\n    handler: DeserializeHandler<InputType, OutputType>,\n    context: HandlerExecutionContext\n  ): Handler<InputType, OutputType> {\n    for (const middleware of this.getMiddlewareList()) {\n      handler = middleware(handler as Handler<Input, OutputType>, context) as any;\n    }\n\n    return handler as Handler<InputType, OutputType>;\n  }\n}\n\nconst stepWeights: { [key in Step]: number } = {\n  initialize: 5,\n  serialize: 4,\n  build: 3,\n  finalizeRequest: 2,\n  deserialize: 1,\n};\n\nconst priorityWeights: { [key in Priority]: number } = {\n  high: 3,\n  normal: 2,\n  low: 1,\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MiddlewareStack.js","sourceRoot":"","sources":["../../src/MiddlewareStack.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AbsoluteLocation,\n  DeserializeHandler,\n  Handler,\n  HandlerExecutionContext,\n  HandlerOptions,\n  MiddlewareStack,\n  MiddlewareType,\n  Pluggable,\n  Priority,\n  RelativeLocation,\n  Step,\n} from \"@aws-sdk/types\";\n\nimport { AbsoluteMiddlewareEntry, MiddlewareEntry, Normalized, RelativeMiddlewareEntry } from \"./types\";\n\nexport const constructStack = <Input extends object, Output extends object>(): MiddlewareStack<Input, Output> => {\n  let absoluteEntries: AbsoluteMiddlewareEntry<Input, Output>[] = [];\n  let relativeEntries: RelativeMiddlewareEntry<Input, Output>[] = [];\n  const entriesNameSet: Set<string> = new Set();\n\n  const sort = <T extends AbsoluteMiddlewareEntry<Input, Output>>(entries: T[]): T[] =>\n    entries.sort(\n      (a, b) =>\n        stepWeights[b.step] - stepWeights[a.step] ||\n        priorityWeights[b.priority || \"normal\"] - priorityWeights[a.priority || \"normal\"]\n    );\n\n  const removeByName = (toRemove: string): boolean => {\n    let isRemoved = false;\n    const filterCb = (entry: MiddlewareEntry<Input, Output>): boolean => {\n      if (entry.name && entry.name === toRemove) {\n        isRemoved = true;\n        entriesNameSet.delete(toRemove);\n        return false;\n      }\n      return true;\n    };\n    absoluteEntries = absoluteEntries.filter(filterCb);\n    relativeEntries = relativeEntries.filter(filterCb);\n    return isRemoved;\n  };\n\n  const removeByReference = (toRemove: MiddlewareType<Input, Output>): boolean => {\n    let isRemoved = false;\n    const filterCb = (entry: MiddlewareEntry<Input, Output>): boolean => {\n      if (entry.middleware === toRemove) {\n        isRemoved = true;\n        if (entry.name) entriesNameSet.delete(entry.name);\n        return false;\n      }\n      return true;\n    };\n    absoluteEntries = absoluteEntries.filter(filterCb);\n    relativeEntries = relativeEntries.filter(filterCb);\n    return isRemoved;\n  };\n\n  const cloneTo = <InputType extends Input, OutputType extends Output>(\n    toStack: MiddlewareStack<InputType, OutputType>\n  ): MiddlewareStack<InputType, OutputType> => {\n    absoluteEntries.forEach((entry) => {\n      //@ts-ignore\n      toStack.add(entry.middleware, { ...entry });\n    });\n    relativeEntries.forEach((entry) => {\n      //@ts-ignore\n      toStack.addRelativeTo(entry.middleware, { ...entry });\n    });\n    return toStack;\n  };\n\n  const expandRelativeMiddlewareList = (\n    from: Normalized<MiddlewareEntry<Input, Output>, Input, Output>\n  ): MiddlewareEntry<Input, Output>[] => {\n    const expandedMiddlewareList: MiddlewareEntry<Input, Output>[] = [];\n    from.before.forEach((entry) => {\n      if (entry.before.length === 0 && entry.after.length === 0) {\n        expandedMiddlewareList.push(entry);\n      } else {\n        expandedMiddlewareList.push(...expandRelativeMiddlewareList(entry));\n      }\n    });\n    expandedMiddlewareList.push(from);\n    from.after.reverse().forEach((entry) => {\n      if (entry.before.length === 0 && entry.after.length === 0) {\n        expandedMiddlewareList.push(entry);\n      } else {\n        expandedMiddlewareList.push(...expandRelativeMiddlewareList(entry));\n      }\n    });\n    return expandedMiddlewareList;\n  };\n\n  /**\n   * Get a final list of middleware in the order of being executed in the resolved handler.\n   */\n  const getMiddlewareList = (): Array<MiddlewareType<Input, Output>> => {\n    const normalizedAbsoluteEntries: Normalized<AbsoluteMiddlewareEntry<Input, Output>, Input, Output>[] = [];\n    const normalizedRelativeEntries: Normalized<RelativeMiddlewareEntry<Input, Output>, Input, Output>[] = [];\n    const normalizedEntriesNameMap: {\n      [middlewareName: string]: Normalized<MiddlewareEntry<Input, Output>, Input, Output>;\n    } = {};\n\n    absoluteEntries.forEach((entry) => {\n      const normalizedEntry = {\n        ...entry,\n        before: [],\n        after: [],\n      };\n      if (normalizedEntry.name) normalizedEntriesNameMap[normalizedEntry.name] = normalizedEntry;\n      normalizedAbsoluteEntries.push(normalizedEntry);\n    });\n\n    relativeEntries.forEach((entry) => {\n      const normalizedEntry = {\n        ...entry,\n        before: [],\n        after: [],\n      };\n      if (normalizedEntry.name) normalizedEntriesNameMap[normalizedEntry.name] = normalizedEntry;\n      normalizedRelativeEntries.push(normalizedEntry);\n    });\n\n    normalizedRelativeEntries.forEach((entry) => {\n      if (entry.toMiddleware) {\n        const toMiddleware = normalizedEntriesNameMap[entry.toMiddleware];\n        if (toMiddleware === undefined) {\n          throw new Error(\n            `${entry.toMiddleware} is not found when adding ${entry.name || \"anonymous\"} middleware ${entry.relation} ${\n              entry.toMiddleware\n            }`\n          );\n        }\n        if (entry.relation === \"after\") {\n          toMiddleware.after.push(entry);\n        }\n        if (entry.relation === \"before\") {\n          toMiddleware.before.push(entry);\n        }\n      }\n    });\n\n    const mainChain = sort(normalizedAbsoluteEntries)\n      .map(expandRelativeMiddlewareList)\n      .reduce((wholeList, expendedMiddlewareList) => {\n        // TODO: Replace it with Array.flat();\n        wholeList.push(...expendedMiddlewareList);\n        return wholeList;\n      }, [] as MiddlewareEntry<Input, Output>[]);\n    return mainChain.map((entry) => entry.middleware);\n  };\n\n  const stack = {\n    add: (middleware: MiddlewareType<Input, Output>, options: HandlerOptions & AbsoluteLocation = {}) => {\n      const { name } = options;\n      const entry: AbsoluteMiddlewareEntry<Input, Output> = {\n        step: \"initialize\",\n        priority: \"normal\",\n        middleware,\n        ...options,\n      };\n      if (name) {\n        if (entriesNameSet.has(name)) {\n          throw new Error(`Duplicate middleware name '${name}'`);\n        }\n        entriesNameSet.add(name);\n      }\n      absoluteEntries.push(entry);\n    },\n\n    addRelativeTo: (middleware: MiddlewareType<Input, Output>, options: HandlerOptions & RelativeLocation) => {\n      const { name } = options;\n      const entry: RelativeMiddlewareEntry<Input, Output> = {\n        middleware,\n        ...options,\n      };\n      if (name) {\n        if (entriesNameSet.has(name)) {\n          throw new Error(`Duplicated middleware name '${name}'`);\n        }\n        entriesNameSet.add(name);\n      }\n      relativeEntries.push(entry);\n    },\n\n    clone: () => cloneTo(constructStack<Input, Output>()),\n\n    use: (plugin: Pluggable<Input, Output>) => {\n      plugin.applyToStack(stack);\n    },\n\n    remove: (toRemove: MiddlewareType<Input, Output> | string): boolean => {\n      if (typeof toRemove === \"string\") return removeByName(toRemove);\n      else return removeByReference(toRemove);\n    },\n\n    removeByTag: (toRemove: string): boolean => {\n      let isRemoved = false;\n      const filterCb = (entry: MiddlewareEntry<Input, Output>): boolean => {\n        const { tags, name } = entry;\n        if (tags && tags.includes(toRemove)) {\n          if (name) entriesNameSet.delete(name);\n          isRemoved = true;\n          return false;\n        }\n        return true;\n      };\n      absoluteEntries = absoluteEntries.filter(filterCb);\n      relativeEntries = relativeEntries.filter(filterCb);\n      return isRemoved;\n    },\n\n    concat: <InputType extends Input, OutputType extends Output>(\n      from: MiddlewareStack<InputType, OutputType>\n    ): MiddlewareStack<InputType, OutputType> => {\n      const cloned = cloneTo(constructStack<InputType, OutputType>());\n      cloned.use(from);\n      return cloned;\n    },\n\n    applyToStack: cloneTo,\n\n    resolve: <InputType extends Input, OutputType extends Output>(\n      handler: DeserializeHandler<InputType, OutputType>,\n      context: HandlerExecutionContext\n    ): Handler<InputType, OutputType> => {\n      for (const middleware of getMiddlewareList().reverse()) {\n        handler = middleware(handler as Handler<Input, OutputType>, context) as any;\n      }\n      return handler as Handler<InputType, OutputType>;\n    },\n  };\n  return stack;\n};\n\nconst stepWeights: { [key in Step]: number } = {\n  initialize: 5,\n  serialize: 4,\n  build: 3,\n  finalizeRequest: 2,\n  deserialize: 1,\n};\n\nconst priorityWeights: { [key in Priority]: number } = {\n  high: 3,\n  normal: 2,\n  low: 1,\n};\n"]}

@@ -1,13 +0,15 @@

import { HandlerOptions, MiddlewareType, Priority, Step } from "@aws-sdk/types";
import { AbsoluteLocation, HandlerOptions, MiddlewareType, Priority, RelativeLocation, Step } from "@aws-sdk/types";
export interface MiddlewareEntry<Input extends object, Output extends object> extends HandlerOptions {
step: Step;
middleware: MiddlewareType<Input, Output>;
priority: Priority;
}
export interface RelativeMiddlewareEntry<Input extends object, Output extends object> extends HandlerOptions {
export interface AbsoluteMiddlewareEntry<Input extends object, Output extends object> extends MiddlewareEntry<Input, Output>, AbsoluteLocation {
step: Step;
middleware: MiddlewareType<Input, Output>;
next?: string;
prev?: string;
priority: Priority;
}
export interface RelativeMiddlewareEntry<Input extends object, Output extends object> extends MiddlewareEntry<Input, Output>, RelativeLocation {
}
export declare type Normalized<T extends MiddlewareEntry<Input, Output>, Input extends object = {}, Output extends object = {}> = T & {
after: Normalized<RelativeMiddlewareEntry<Input, Output>, Input, Output>[];
before: Normalized<RelativeMiddlewareEntry<Input, Output>, Input, Output>[];
};
export interface NormalizedRelativeEntry<Input extends object, Output extends object> extends HandlerOptions {

@@ -23,11 +25,1 @@ step: Step;

};
export declare type NamedRelativeEntriesMap<Input extends object, Output extends object> = {
[key: string]: NormalizedRelativeEntry<Input, Output>;
};
export declare type RelativeMiddlewareAnchor<Input extends object, Output extends object> = {
[name: string]: {
prev?: NormalizedRelativeEntry<Input, Output>;
next?: NormalizedRelativeEntry<Input, Output>;
};
};
export declare type NormalizingEntryResult<Input extends object, Output extends object> = [Array<NormalizedRelativeEntry<Input, Output>>, RelativeMiddlewareAnchor<Input, Output>];
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhhbmRsZXJPcHRpb25zLCBNaWRkbGV3YXJlVHlwZSwgUHJpb3JpdHksIFN0ZXAgfSBmcm9tIFwiQGF3cy1zZGsvdHlwZXNcIjtcbmV4cG9ydCBpbnRlcmZhY2UgTWlkZGxld2FyZUVudHJ5PElucHV0IGV4dGVuZHMgb2JqZWN0LCBPdXRwdXQgZXh0ZW5kcyBvYmplY3Q+IGV4dGVuZHMgSGFuZGxlck9wdGlvbnMge1xuICBzdGVwOiBTdGVwO1xuICBtaWRkbGV3YXJlOiBNaWRkbGV3YXJlVHlwZTxJbnB1dCwgT3V0cHV0PjtcbiAgcHJpb3JpdHk6IFByaW9yaXR5O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlbGF0aXZlTWlkZGxld2FyZUVudHJ5PElucHV0IGV4dGVuZHMgb2JqZWN0LCBPdXRwdXQgZXh0ZW5kcyBvYmplY3Q+IGV4dGVuZHMgSGFuZGxlck9wdGlvbnMge1xuICBzdGVwOiBTdGVwO1xuICBtaWRkbGV3YXJlOiBNaWRkbGV3YXJlVHlwZTxJbnB1dCwgT3V0cHV0PjtcbiAgbmV4dD86IHN0cmluZztcbiAgcHJldj86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBOb3JtYWxpemVkUmVsYXRpdmVFbnRyeTxJbnB1dCBleHRlbmRzIG9iamVjdCwgT3V0cHV0IGV4dGVuZHMgb2JqZWN0PiBleHRlbmRzIEhhbmRsZXJPcHRpb25zIHtcbiAgc3RlcDogU3RlcDtcbiAgbWlkZGxld2FyZTogTWlkZGxld2FyZVR5cGU8SW5wdXQsIE91dHB1dD47XG4gIG5leHQ/OiBOb3JtYWxpemVkUmVsYXRpdmVFbnRyeTxJbnB1dCwgT3V0cHV0PjtcbiAgcHJldj86IE5vcm1hbGl6ZWRSZWxhdGl2ZUVudHJ5PElucHV0LCBPdXRwdXQ+O1xuICBwcmlvcml0eTogbnVsbDtcbn1cblxuZXhwb3J0IHR5cGUgTmFtZWRNaWRkbGV3YXJlRW50cmllc01hcDxJbnB1dCBleHRlbmRzIG9iamVjdCwgT3V0cHV0IGV4dGVuZHMgb2JqZWN0PiA9IHtcbiAgW2tleTogc3RyaW5nXTogTWlkZGxld2FyZUVudHJ5PElucHV0LCBPdXRwdXQ+O1xufTtcblxuZXhwb3J0IHR5cGUgTmFtZWRSZWxhdGl2ZUVudHJpZXNNYXA8SW5wdXQgZXh0ZW5kcyBvYmplY3QsIE91dHB1dCBleHRlbmRzIG9iamVjdD4gPSB7XG4gIFtrZXk6IHN0cmluZ106IE5vcm1hbGl6ZWRSZWxhdGl2ZUVudHJ5PElucHV0LCBPdXRwdXQ+O1xufTtcblxuZXhwb3J0IHR5cGUgUmVsYXRpdmVNaWRkbGV3YXJlQW5jaG9yPElucHV0IGV4dGVuZHMgb2JqZWN0LCBPdXRwdXQgZXh0ZW5kcyBvYmplY3Q+ID0ge1xuICBbbmFtZTogc3RyaW5nXToge1xuICAgIHByZXY/OiBOb3JtYWxpemVkUmVsYXRpdmVFbnRyeTxJbnB1dCwgT3V0cHV0PjtcbiAgICBuZXh0PzogTm9ybWFsaXplZFJlbGF0aXZlRW50cnk8SW5wdXQsIE91dHB1dD47XG4gIH07XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemluZ0VudHJ5UmVzdWx0PElucHV0IGV4dGVuZHMgb2JqZWN0LCBPdXRwdXQgZXh0ZW5kcyBvYmplY3Q+ID0gW1xuICBBcnJheTxOb3JtYWxpemVkUmVsYXRpdmVFbnRyeTxJbnB1dCwgT3V0cHV0Pj4sXG4gIFJlbGF0aXZlTWlkZGxld2FyZUFuY2hvcjxJbnB1dCwgT3V0cHV0PlxuXTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFic29sdXRlTG9jYXRpb24sIEhhbmRsZXJPcHRpb25zLCBNaWRkbGV3YXJlVHlwZSwgUHJpb3JpdHksIFJlbGF0aXZlTG9jYXRpb24sIFN0ZXAgfSBmcm9tIFwiQGF3cy1zZGsvdHlwZXNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBNaWRkbGV3YXJlRW50cnk8SW5wdXQgZXh0ZW5kcyBvYmplY3QsIE91dHB1dCBleHRlbmRzIG9iamVjdD4gZXh0ZW5kcyBIYW5kbGVyT3B0aW9ucyB7XG4gIG1pZGRsZXdhcmU6IE1pZGRsZXdhcmVUeXBlPElucHV0LCBPdXRwdXQ+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFic29sdXRlTWlkZGxld2FyZUVudHJ5PElucHV0IGV4dGVuZHMgb2JqZWN0LCBPdXRwdXQgZXh0ZW5kcyBvYmplY3Q+XG4gIGV4dGVuZHMgTWlkZGxld2FyZUVudHJ5PElucHV0LCBPdXRwdXQ+LFxuICAgIEFic29sdXRlTG9jYXRpb24ge1xuICBzdGVwOiBTdGVwO1xuICBwcmlvcml0eTogUHJpb3JpdHk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVsYXRpdmVNaWRkbGV3YXJlRW50cnk8SW5wdXQgZXh0ZW5kcyBvYmplY3QsIE91dHB1dCBleHRlbmRzIG9iamVjdD5cbiAgZXh0ZW5kcyBNaWRkbGV3YXJlRW50cnk8SW5wdXQsIE91dHB1dD4sXG4gICAgUmVsYXRpdmVMb2NhdGlvbiB7fVxuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVkPFxuICBUIGV4dGVuZHMgTWlkZGxld2FyZUVudHJ5PElucHV0LCBPdXRwdXQ+LFxuICBJbnB1dCBleHRlbmRzIG9iamVjdCA9IHt9LFxuICBPdXRwdXQgZXh0ZW5kcyBvYmplY3QgPSB7fVxuPiA9IFQgJiB7XG4gIGFmdGVyOiBOb3JtYWxpemVkPFJlbGF0aXZlTWlkZGxld2FyZUVudHJ5PElucHV0LCBPdXRwdXQ+LCBJbnB1dCwgT3V0cHV0PltdO1xuICBiZWZvcmU6IE5vcm1hbGl6ZWQ8UmVsYXRpdmVNaWRkbGV3YXJlRW50cnk8SW5wdXQsIE91dHB1dD4sIElucHV0LCBPdXRwdXQ+W107XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIE5vcm1hbGl6ZWRSZWxhdGl2ZUVudHJ5PElucHV0IGV4dGVuZHMgb2JqZWN0LCBPdXRwdXQgZXh0ZW5kcyBvYmplY3Q+IGV4dGVuZHMgSGFuZGxlck9wdGlvbnMge1xuICBzdGVwOiBTdGVwO1xuICBtaWRkbGV3YXJlOiBNaWRkbGV3YXJlVHlwZTxJbnB1dCwgT3V0cHV0PjtcbiAgbmV4dD86IE5vcm1hbGl6ZWRSZWxhdGl2ZUVudHJ5PElucHV0LCBPdXRwdXQ+O1xuICBwcmV2PzogTm9ybWFsaXplZFJlbGF0aXZlRW50cnk8SW5wdXQsIE91dHB1dD47XG4gIHByaW9yaXR5OiBudWxsO1xufVxuXG5leHBvcnQgdHlwZSBOYW1lZE1pZGRsZXdhcmVFbnRyaWVzTWFwPElucHV0IGV4dGVuZHMgb2JqZWN0LCBPdXRwdXQgZXh0ZW5kcyBvYmplY3Q+ID0ge1xuICBba2V5OiBzdHJpbmddOiBNaWRkbGV3YXJlRW50cnk8SW5wdXQsIE91dHB1dD47XG59O1xuIl19
{
"name": "@aws-sdk/middleware-stack",
"version": "1.0.0-gamma.4",
"version": "1.0.0-gamma.5",
"description": "Provides a means for composing multiple middleware functions into a single handler",

@@ -10,2 +10,3 @@ "scripts": {

"build:es": "tsc -p tsconfig.es.json",
"build": "yarn build:es && yarn build:cjs",
"test": "jest"

@@ -23,3 +24,3 @@ },

"dependencies": {
"@aws-sdk/types": "1.0.0-gamma.3",
"@aws-sdk/types": "1.0.0-gamma.4",
"tslib": "^1.8.0"

@@ -26,0 +27,0 @@ },

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc