@aws-sdk/signature-v4-crt 3.34.0 → 3.35.0
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.
- package/CHANGELOG.md +8 -0
- package/dist-cjs/CrtSignerV4.js +124 -0
- package/dist-cjs/constants.js +47 -0
- package/dist-cjs/headerUtil.js +33 -0
- package/{dist/cjs → dist-cjs}/index.js +1 -1
- package/dist-cjs/suite.fixture.js +387 -0
- package/dist-es/CrtSignerV4.js +219 -0
- package/dist-es/constants.js +44 -0
- package/dist-es/headerUtil.js +61 -0
- package/dist-es/index.js +2 -0
- package/dist-es/suite.fixture.js +384 -0
- package/{dist/types → dist-types}/CrtSignerV4.d.ts +0 -0
- package/{dist/types → dist-types}/constants.d.ts +0 -0
- package/{dist/types → dist-types}/headerUtil.d.ts +0 -0
- package/{dist/types → dist-types}/index.d.ts +0 -0
- package/{dist/types → dist-types}/suite.fixture.d.ts +0 -0
- package/{dist/types → dist-types}/ts3.4/CrtSignerV4.d.ts +0 -0
- package/{dist/types → dist-types}/ts3.4/constants.d.ts +0 -0
- package/{dist/types → dist-types}/ts3.4/headerUtil.d.ts +0 -0
- package/{dist/types → dist-types}/ts3.4/index.d.ts +0 -0
- package/{dist/types → dist-types}/ts3.4/suite.fixture.d.ts +0 -0
- package/package.json +13 -13
- package/tsconfig.cjs.json +1 -1
- package/tsconfig.cjs.tsbuildinfo +1 -0
- package/tsconfig.es.json +2 -6
- package/tsconfig.es.tsbuildinfo +1 -0
- package/tsconfig.types.json +1 -1
- package/tsconfig.types.tsbuildinfo +1 -1
- package/dist/cjs/CrtSignerV4.js +0 -124
- package/dist/cjs/constants.js +0 -47
- package/dist/cjs/headerUtil.js +0 -33
- package/dist/cjs/suite.fixture.js +0 -387
- package/dist/es/CrtSignerV4.js +0 -254
- package/dist/es/constants.js +0 -44
- package/dist/es/headerUtil.js +0 -63
- package/dist/es/index.js +0 -2
- package/dist/es/suite.fixture.js +0 -404
- package/dist/tsconfig.cjs.tsbuildinfo +0 -1
- package/dist/tsconfig.es.tsbuildinfo +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,14 @@
|
|
|
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.35.0](https://github.com/aws/aws-sdk-js-v3/compare/v3.34.0...v3.35.0) (2021-10-04)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package @aws-sdk/signature-v4-crt
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
6
14
|
# [3.34.0](https://github.com/aws/aws-sdk-js-v3/compare/v3.33.0...v3.34.0) (2021-09-24)
|
|
7
15
|
|
|
8
16
|
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CrtSignerV4 = void 0;
|
|
4
|
+
const querystring_parser_1 = require("@aws-sdk/querystring-parser");
|
|
5
|
+
const signature_v4_1 = require("@aws-sdk/signature-v4");
|
|
6
|
+
const aws_crt_1 = require("aws-crt");
|
|
7
|
+
const constants_1 = require("./constants");
|
|
8
|
+
const headerUtil_1 = require("./headerUtil");
|
|
9
|
+
function sdkHttpRequest2crtHttpRequest(sdkRequest) {
|
|
10
|
+
headerUtil_1.deleteHeader(constants_1.SHA256_HEADER, sdkRequest.headers);
|
|
11
|
+
const headersArray = Object.entries(sdkRequest.headers);
|
|
12
|
+
const crtHttpHeaders = new aws_crt_1.http.HttpHeaders(headersArray);
|
|
13
|
+
const queryString = signature_v4_1.getCanonicalQuery(sdkRequest);
|
|
14
|
+
return new aws_crt_1.http.HttpRequest(sdkRequest.method, sdkRequest.path + "?" + queryString, crtHttpHeaders);
|
|
15
|
+
}
|
|
16
|
+
class CrtSignerV4 {
|
|
17
|
+
constructor({ credentials, region, service, sha256, applyChecksum = true, uriEscapePath = true, signingAlgorithm = aws_crt_1.auth.AwsSigningAlgorithm.SigV4, }) {
|
|
18
|
+
this.service = service;
|
|
19
|
+
this.sha256 = sha256;
|
|
20
|
+
this.uriEscapePath = uriEscapePath;
|
|
21
|
+
this.signingAlgorithm = signingAlgorithm;
|
|
22
|
+
this.applyChecksum = applyChecksum;
|
|
23
|
+
this.regionProvider = signature_v4_1.normalizeRegionProvider(region);
|
|
24
|
+
this.credentialProvider = signature_v4_1.normalizeCredentialsProvider(credentials);
|
|
25
|
+
aws_crt_1.io.enable_logging(aws_crt_1.io.LogLevel.ERROR);
|
|
26
|
+
}
|
|
27
|
+
async options2crtConfigure({ signingDate = new Date(), signableHeaders, unsignableHeaders, signingRegion, signingService, } = {}, viaHeader, payloadHash, expiresIn) {
|
|
28
|
+
const credentials = await this.credentialProvider();
|
|
29
|
+
const region = signingRegion !== null && signingRegion !== void 0 ? signingRegion : (await this.regionProvider());
|
|
30
|
+
const service = signingService !== null && signingService !== void 0 ? signingService : this.service;
|
|
31
|
+
if ((signableHeaders === null || signableHeaders === void 0 ? void 0 : signableHeaders.has("x-amzn-trace-id")) || (signableHeaders === null || signableHeaders === void 0 ? void 0 : signableHeaders.has("user-agent"))) {
|
|
32
|
+
throw new Error("internal check (x-amzn-trace-id, user-agent) is not supported to be included to sign with CRT.");
|
|
33
|
+
}
|
|
34
|
+
const headersUnsignable = getHeadersUnsignable(unsignableHeaders, signableHeaders);
|
|
35
|
+
return {
|
|
36
|
+
algorithm: this.signingAlgorithm,
|
|
37
|
+
signature_type: viaHeader
|
|
38
|
+
? aws_crt_1.auth.AwsSignatureType.HttpRequestViaHeaders
|
|
39
|
+
: aws_crt_1.auth.AwsSignatureType.HttpRequestViaQueryParams,
|
|
40
|
+
provider: sdk2crtCredentialsProvider(credentials),
|
|
41
|
+
region: region,
|
|
42
|
+
service: service,
|
|
43
|
+
date: new Date(signingDate),
|
|
44
|
+
header_blacklist: headersUnsignable,
|
|
45
|
+
use_double_uri_encode: this.uriEscapePath,
|
|
46
|
+
signed_body_value: payloadHash,
|
|
47
|
+
signed_body_header: this.applyChecksum && viaHeader
|
|
48
|
+
? aws_crt_1.auth.AwsSignedBodyHeaderType.XAmzContentSha256
|
|
49
|
+
: aws_crt_1.auth.AwsSignedBodyHeaderType.None,
|
|
50
|
+
expiration_in_seconds: expiresIn,
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
async presign(originalRequest, options = {}) {
|
|
54
|
+
if (options.expiresIn && options.expiresIn > constants_1.MAX_PRESIGNED_TTL) {
|
|
55
|
+
return Promise.reject("Signature version 4 presigned URLs" + " must have an expiration date less than one week in" + " the future");
|
|
56
|
+
}
|
|
57
|
+
const request = signature_v4_1.moveHeadersToQuery(signature_v4_1.prepareRequest(originalRequest));
|
|
58
|
+
const crtSignedRequest = await this.signRequest(request, await this.options2crtConfigure(options, false, await signature_v4_1.getPayloadHash(originalRequest, this.sha256), options.expiresIn ? options.expiresIn : 3600));
|
|
59
|
+
request.query = this.getQueryParam(crtSignedRequest.path);
|
|
60
|
+
return request;
|
|
61
|
+
}
|
|
62
|
+
async sign(toSign, options) {
|
|
63
|
+
const request = signature_v4_1.prepareRequest(toSign);
|
|
64
|
+
const crtSignedRequest = await this.signRequest(request, await this.options2crtConfigure(options, true, await signature_v4_1.getPayloadHash(toSign, this.sha256)));
|
|
65
|
+
request.headers = crtSignedRequest.headers._flatten().reduce((acc, [key, value]) => ({ ...acc, [key]: value }), {});
|
|
66
|
+
return request;
|
|
67
|
+
}
|
|
68
|
+
getQueryParam(crtPath) {
|
|
69
|
+
const start = crtPath.search(/\?/);
|
|
70
|
+
const startHash = crtPath.search(/\#/);
|
|
71
|
+
const end = startHash == -1 ? undefined : startHash;
|
|
72
|
+
const queryParam = {};
|
|
73
|
+
if (start == -1) {
|
|
74
|
+
return queryParam;
|
|
75
|
+
}
|
|
76
|
+
const queryString = crtPath.slice(start + 1, end);
|
|
77
|
+
return querystring_parser_1.parseQueryString(queryString);
|
|
78
|
+
}
|
|
79
|
+
async signRequest(requestToSign, crtConfig) {
|
|
80
|
+
const request = sdkHttpRequest2crtHttpRequest(requestToSign);
|
|
81
|
+
try {
|
|
82
|
+
return await aws_crt_1.auth.aws_sign_request(request, crtConfig);
|
|
83
|
+
}
|
|
84
|
+
catch (error) {
|
|
85
|
+
throw new Error(error);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
async verifySigv4aSigning(request, signature, expectedCanonicalRequest, eccPubKeyX, eccPubKeyY, options = {}) {
|
|
89
|
+
const sdkRequest = signature_v4_1.prepareRequest(request);
|
|
90
|
+
const crtRequest = sdkHttpRequest2crtHttpRequest(sdkRequest);
|
|
91
|
+
const payloadHash = await signature_v4_1.getPayloadHash(request, this.sha256);
|
|
92
|
+
const crtConfig = await this.options2crtConfigure(options, true, payloadHash);
|
|
93
|
+
return aws_crt_1.auth.aws_verify_sigv4a_signing(crtRequest, crtConfig, expectedCanonicalRequest, signature, eccPubKeyX, eccPubKeyY);
|
|
94
|
+
}
|
|
95
|
+
async verifySigv4aPreSigning(request, signature, expectedCanonicalRequest, eccPubKeyX, eccPubKeyY, options = {}) {
|
|
96
|
+
if (typeof signature != "string") {
|
|
97
|
+
return false;
|
|
98
|
+
}
|
|
99
|
+
const sdkRequest = signature_v4_1.prepareRequest(request);
|
|
100
|
+
const crtRequest = sdkHttpRequest2crtHttpRequest(sdkRequest);
|
|
101
|
+
const crtConfig = await this.options2crtConfigure(options, false, await signature_v4_1.getPayloadHash(request, this.sha256), options.expiresIn ? options.expiresIn : 3600);
|
|
102
|
+
return aws_crt_1.auth.aws_verify_sigv4a_signing(crtRequest, crtConfig, expectedCanonicalRequest, signature, eccPubKeyX, eccPubKeyY);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
exports.CrtSignerV4 = CrtSignerV4;
|
|
106
|
+
function sdk2crtCredentialsProvider(credentials) {
|
|
107
|
+
return aws_crt_1.auth.AwsCredentialsProvider.newStatic(credentials.accessKeyId, credentials.secretAccessKey, credentials.sessionToken);
|
|
108
|
+
}
|
|
109
|
+
function getHeadersUnsignable(unsignableHeaders, signableHeaders) {
|
|
110
|
+
if (!unsignableHeaders) {
|
|
111
|
+
return [];
|
|
112
|
+
}
|
|
113
|
+
if (!signableHeaders) {
|
|
114
|
+
return [...unsignableHeaders];
|
|
115
|
+
}
|
|
116
|
+
const result = new Set([...unsignableHeaders]);
|
|
117
|
+
for (let it = signableHeaders.values(), val = null; (val = it.next().value);) {
|
|
118
|
+
if (result.has(val)) {
|
|
119
|
+
result.delete(val);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
return [...result];
|
|
123
|
+
}
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CrtSignerV4.js","sourceRoot":"","sources":["../src/CrtSignerV4.ts"],"names":[],"mappings":"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","sourcesContent":["import { parseQueryString } from \"@aws-sdk/querystring-parser\";\nimport {\n  getCanonicalQuery,\n  getPayloadHash,\n  moveHeadersToQuery,\n  normalizeCredentialsProvider,\n  normalizeRegionProvider,\n  prepareRequest,\n  SignatureV4CryptoInit,\n  SignatureV4Init,\n} from \"@aws-sdk/signature-v4\";\nimport {\n  Credentials,\n  HttpRequest,\n  Provider,\n  QueryParameterBag,\n  RequestPresigner,\n  RequestPresigningArguments,\n  RequestSigner,\n  RequestSigningArguments,\n} from \"@aws-sdk/types\";\nimport { auth as crtAuth, http as crtHttp, io as crtIO } from \"aws-crt\";\n\nimport { MAX_PRESIGNED_TTL, SHA256_HEADER } from \"./constants\";\nimport { deleteHeader } from \"./headerUtil\";\n\nexport type AwsSigningAlgorithm = crtAuth.AwsSigningAlgorithm;\n\n/* private function to convert sdk Http request to crt Http request */\nfunction sdkHttpRequest2crtHttpRequest(sdkRequest: HttpRequest): crtHttp.HttpRequest {\n  /* Remove the x-amz-content-sha256 header, if exists */\n  deleteHeader(SHA256_HEADER, sdkRequest.headers);\n  const headersArray = Object.entries(sdkRequest.headers);\n  const crtHttpHeaders = new crtHttp.HttpHeaders(headersArray);\n  const queryString = getCanonicalQuery(sdkRequest);\n\n  /**\n   * Not converting the body to the crtRequest. For now, it's better to get the payload Hash from SDK.\n   * The body value will be set from config.\n   */\n  return new crtHttp.HttpRequest(sdkRequest.method, sdkRequest.path + \"?\" + queryString, crtHttpHeaders);\n}\n\nexport interface CrtSignerV4Init extends SignatureV4Init {\n  /**\n   * The Algorithm used for the signer. Includes: SigV4, SigV4Asymmetric.\n   *\n   * @default [SigV4]\n   */\n  signingAlgorithm?: AwsSigningAlgorithm;\n}\n\n/**\n * Based aws-crt, with the same API as signing the request from SignatureV4, compatible with request Signer from SDK.\n * The difference between them is CrtSignerV4 only supports signing/presigning the request. The behavior of two signers\n * are slightly different, includes the case of headers name after signing and the CrtSignerV4 does NOT support overwrite\n * the internal check against (x-amzn-trace-id, user-agent), which will always be skipped.\n * Most importantly, CrtSignerV4 supports Signature V4 Asymmetric.\n *\n * Note: aws-crt that supports SigV4A is still a private repo https://github.com/awslabs/aws-crt-nodejs-staging/tree/sigv4a-binding\n */\nexport class CrtSignerV4 implements RequestPresigner, RequestSigner {\n  private readonly service: string;\n  private readonly regionProvider: Provider<string>;\n  private readonly credentialProvider: Provider<Credentials>;\n  private readonly sha256: any;\n  private readonly uriEscapePath: boolean;\n  private readonly applyChecksum: boolean;\n  private readonly signingAlgorithm: AwsSigningAlgorithm;\n\n  constructor({\n    credentials,\n    region,\n    service,\n    sha256,\n    applyChecksum = true,\n    uriEscapePath = true,\n    signingAlgorithm = crtAuth.AwsSigningAlgorithm.SigV4,\n  }: CrtSignerV4Init & SignatureV4CryptoInit) {\n    this.service = service;\n    this.sha256 = sha256;\n    this.uriEscapePath = uriEscapePath;\n    this.signingAlgorithm = signingAlgorithm;\n    this.applyChecksum = applyChecksum;\n    this.regionProvider = normalizeRegionProvider(region);\n    this.credentialProvider = normalizeCredentialsProvider(credentials);\n    crtIO.enable_logging(crtIO.LogLevel.ERROR);\n  }\n\n  private async options2crtConfigure(\n    {\n      signingDate = new Date(),\n      signableHeaders,\n      unsignableHeaders,\n      signingRegion,\n      signingService,\n    }: RequestSigningArguments | RequestPresigningArguments | undefined = {},\n    viaHeader: Boolean,\n    payloadHash: string,\n    expiresIn?: number\n  ): Promise<crtAuth.AwsSigningConfig> {\n    const credentials = await this.credentialProvider();\n    const region = signingRegion ?? (await this.regionProvider());\n    const service = signingService ?? this.service;\n    if (signableHeaders?.has(\"x-amzn-trace-id\") || signableHeaders?.has(\"user-agent\")) {\n      throw new Error(\"internal check (x-amzn-trace-id, user-agent) is not supported to be included to sign with CRT.\");\n    }\n    const headersUnsignable = getHeadersUnsignable(unsignableHeaders, signableHeaders);\n    return {\n      algorithm: this.signingAlgorithm,\n      signature_type: viaHeader\n        ? crtAuth.AwsSignatureType.HttpRequestViaHeaders\n        : crtAuth.AwsSignatureType.HttpRequestViaQueryParams,\n      provider: sdk2crtCredentialsProvider(credentials),\n      region: region,\n      service: service,\n      date: new Date(signingDate),\n      header_blacklist: headersUnsignable,\n      use_double_uri_encode: this.uriEscapePath,\n      /* Always set the body value by the result from SDK */\n      signed_body_value: payloadHash,\n      signed_body_header:\n        this.applyChecksum && viaHeader\n          ? crtAuth.AwsSignedBodyHeaderType.XAmzContentSha256\n          : crtAuth.AwsSignedBodyHeaderType.None,\n      expiration_in_seconds: expiresIn,\n    };\n  }\n\n  public async presign(originalRequest: HttpRequest, options: RequestPresigningArguments = {}): Promise<HttpRequest> {\n    if (options.expiresIn && options.expiresIn > MAX_PRESIGNED_TTL) {\n      return Promise.reject(\n        \"Signature version 4 presigned URLs\" + \" must have an expiration date less than one week in\" + \" the future\"\n      );\n    }\n    const request = moveHeadersToQuery(prepareRequest(originalRequest));\n\n    const crtSignedRequest = await this.signRequest(\n      request,\n      await this.options2crtConfigure(\n        options,\n        false /* viaHeader */,\n        await getPayloadHash(originalRequest, this.sha256),\n        options.expiresIn ? options.expiresIn : 3600\n      )\n    );\n    request.query = this.getQueryParam(crtSignedRequest.path);\n    return request;\n  }\n\n  public async sign(toSign: HttpRequest, options?: RequestSigningArguments): Promise<HttpRequest> {\n    const request = prepareRequest(toSign);\n    const crtSignedRequest = await this.signRequest(\n      request,\n      await this.options2crtConfigure(options, true /* viaHeader */, await getPayloadHash(toSign, this.sha256))\n    );\n    request.headers = crtSignedRequest.headers._flatten().reduce((acc, [key, value]) => ({ ...acc, [key]: value }), {});\n    return request;\n  }\n\n  /* Get the query parameters from crtPath */\n  private getQueryParam(crtPath: string): QueryParameterBag {\n    const start = crtPath.search(/\\?/);\n    const startHash = crtPath.search(/\\#/);\n    const end = startHash == -1 ? undefined : startHash;\n    const queryParam = {} as QueryParameterBag;\n    if (start == -1) {\n      return queryParam;\n    }\n    const queryString = crtPath.slice(start + 1, end);\n    return parseQueryString(queryString);\n  }\n\n  private async signRequest(\n    requestToSign: HttpRequest,\n    crtConfig: crtAuth.AwsSigningConfig\n  ): Promise<crtHttp.HttpRequest> {\n    const request = sdkHttpRequest2crtHttpRequest(requestToSign);\n    // if (requestToSign.headers[TOKEN_HEADER])\n    try {\n      return await crtAuth.aws_sign_request(request, crtConfig);\n    } catch (error) {\n      throw new Error(error);\n    }\n  }\n\n  /**\n   * Test-only API used for cross-library signing verification tests. Verify sign.\n   *\n   * Verifies:\n   *  (1) The canonical request generated during sigv4a signing of the request matches what is passed in\n   *  (2) The signature passed in is a valid ECDSA signature of the hashed string-to-sign derived from the\n   *  canonical request\n   *\n   * @param request The original request used for signing\n   * @param signature the actual signature computed from a previous signing of the signable\n   * @param expectedCanonicalRequest expected result when building the canonical request\n   * @param eccPubKeyX the x coordinate of the public part of the ecc key to verify the signature\n   * @param eccPubKeyY the y coordinate of the public part of the ecc key to verify the signature\n   * @param options the RequestSigningArguments used for signing\n   *\n   * @return True, if the verification succeed. Otherwise, false.\n   */\n  public async verifySigv4aSigning(\n    request: HttpRequest,\n    signature: string,\n    expectedCanonicalRequest: string,\n    eccPubKeyX: string,\n    eccPubKeyY: string,\n    options: RequestSigningArguments = {}\n  ): Promise<boolean> {\n    const sdkRequest = prepareRequest(request);\n    const crtRequest = sdkHttpRequest2crtHttpRequest(sdkRequest);\n    const payloadHash = await getPayloadHash(request, this.sha256);\n    const crtConfig = await this.options2crtConfigure(options, true /* viaHeader */, payloadHash);\n    return crtAuth.aws_verify_sigv4a_signing(\n      crtRequest,\n      crtConfig,\n      expectedCanonicalRequest,\n      signature,\n      eccPubKeyX,\n      eccPubKeyY\n    );\n  }\n\n  /* Verify presign */\n  public async verifySigv4aPreSigning(\n    request: HttpRequest,\n    signature: string | Array<string> | null,\n    expectedCanonicalRequest: string,\n    eccPubKeyX: string,\n    eccPubKeyY: string,\n    options: RequestPresigningArguments = {}\n  ): Promise<boolean> {\n    if (typeof signature != \"string\") {\n      return false;\n    }\n    const sdkRequest = prepareRequest(request);\n    const crtRequest = sdkHttpRequest2crtHttpRequest(sdkRequest);\n    const crtConfig = await this.options2crtConfigure(\n      options,\n      false /* viaHeader */,\n      await getPayloadHash(request, this.sha256),\n      options.expiresIn ? options.expiresIn : 3600\n    );\n    return crtAuth.aws_verify_sigv4a_signing(\n      crtRequest,\n      crtConfig,\n      expectedCanonicalRequest,\n      signature,\n      eccPubKeyX,\n      eccPubKeyY\n    );\n  }\n}\n\nfunction sdk2crtCredentialsProvider(credentials: Credentials): crtAuth.AwsCredentialsProvider {\n  return crtAuth.AwsCredentialsProvider.newStatic(\n    credentials.accessKeyId,\n    credentials.secretAccessKey,\n    credentials.sessionToken\n  );\n}\n\nfunction getHeadersUnsignable(unsignableHeaders?: Set<string>, signableHeaders?: Set<string>): string[] {\n  if (!unsignableHeaders) {\n    return [];\n  }\n  if (!signableHeaders) {\n    return [...unsignableHeaders];\n  }\n  const result = new Set([...unsignableHeaders]);\n  for (let it = signableHeaders.values(), val = null; (val = it.next().value); ) {\n    if (result.has(val)) {\n      result.delete(val);\n    }\n  }\n  return [...result];\n}\n"]}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MAX_PRESIGNED_TTL = exports.KEY_TYPE_IDENTIFIER = exports.MAX_CACHE_SIZE = exports.UNSIGNED_PAYLOAD = exports.EVENT_ALGORITHM_IDENTIFIER = exports.ALGORITHM_IDENTIFIER_V4A = exports.ALGORITHM_IDENTIFIER = exports.UNSIGNABLE_PATTERNS = exports.SEC_HEADER_PATTERN = exports.PROXY_HEADER_PATTERN = exports.ALWAYS_UNSIGNABLE_HEADERS = exports.HOST_HEADER = exports.TOKEN_HEADER = exports.SHA256_HEADER = exports.SIGNATURE_HEADER = exports.GENERATED_HEADERS = exports.DATE_HEADER = exports.AMZ_DATE_HEADER = exports.AUTH_HEADER = exports.REGION_SET_PARAM = exports.TOKEN_QUERY_PARAM = exports.SIGNATURE_QUERY_PARAM = exports.EXPIRES_QUERY_PARAM = exports.SIGNED_HEADERS_QUERY_PARAM = exports.AMZ_DATE_QUERY_PARAM = exports.CREDENTIAL_QUERY_PARAM = exports.ALGORITHM_QUERY_PARAM = void 0;
|
|
4
|
+
exports.ALGORITHM_QUERY_PARAM = "X-Amz-Algorithm";
|
|
5
|
+
exports.CREDENTIAL_QUERY_PARAM = "X-Amz-Credential";
|
|
6
|
+
exports.AMZ_DATE_QUERY_PARAM = "X-Amz-Date";
|
|
7
|
+
exports.SIGNED_HEADERS_QUERY_PARAM = "X-Amz-SignedHeaders";
|
|
8
|
+
exports.EXPIRES_QUERY_PARAM = "X-Amz-Expires";
|
|
9
|
+
exports.SIGNATURE_QUERY_PARAM = "X-Amz-Signature";
|
|
10
|
+
exports.TOKEN_QUERY_PARAM = "X-Amz-Security-Token";
|
|
11
|
+
exports.REGION_SET_PARAM = "X-Amz-Region-Set";
|
|
12
|
+
exports.AUTH_HEADER = "authorization";
|
|
13
|
+
exports.AMZ_DATE_HEADER = exports.AMZ_DATE_QUERY_PARAM.toLowerCase();
|
|
14
|
+
exports.DATE_HEADER = "date";
|
|
15
|
+
exports.GENERATED_HEADERS = [exports.AUTH_HEADER, exports.AMZ_DATE_HEADER, exports.DATE_HEADER];
|
|
16
|
+
exports.SIGNATURE_HEADER = exports.SIGNATURE_QUERY_PARAM.toLowerCase();
|
|
17
|
+
exports.SHA256_HEADER = "x-amz-content-sha256";
|
|
18
|
+
exports.TOKEN_HEADER = exports.TOKEN_QUERY_PARAM.toLowerCase();
|
|
19
|
+
exports.HOST_HEADER = "host";
|
|
20
|
+
exports.ALWAYS_UNSIGNABLE_HEADERS = {
|
|
21
|
+
authorization: true,
|
|
22
|
+
"cache-control": true,
|
|
23
|
+
connection: true,
|
|
24
|
+
expect: true,
|
|
25
|
+
from: true,
|
|
26
|
+
"keep-alive": true,
|
|
27
|
+
"max-forwards": true,
|
|
28
|
+
pragma: true,
|
|
29
|
+
referer: true,
|
|
30
|
+
te: true,
|
|
31
|
+
trailer: true,
|
|
32
|
+
"transfer-encoding": true,
|
|
33
|
+
upgrade: true,
|
|
34
|
+
"user-agent": true,
|
|
35
|
+
"x-amzn-trace-id": true,
|
|
36
|
+
};
|
|
37
|
+
exports.PROXY_HEADER_PATTERN = /^proxy-/;
|
|
38
|
+
exports.SEC_HEADER_PATTERN = /^sec-/;
|
|
39
|
+
exports.UNSIGNABLE_PATTERNS = [/^proxy-/i, /^sec-/i];
|
|
40
|
+
exports.ALGORITHM_IDENTIFIER = "AWS4-HMAC-SHA256";
|
|
41
|
+
exports.ALGORITHM_IDENTIFIER_V4A = "AWS4-ECDSA-P256-SHA256";
|
|
42
|
+
exports.EVENT_ALGORITHM_IDENTIFIER = "AWS4-HMAC-SHA256-PAYLOAD";
|
|
43
|
+
exports.UNSIGNED_PAYLOAD = "UNSIGNED-PAYLOAD";
|
|
44
|
+
exports.MAX_CACHE_SIZE = 50;
|
|
45
|
+
exports.KEY_TYPE_IDENTIFIER = "aws4_request";
|
|
46
|
+
exports.MAX_PRESIGNED_TTL = 60 * 60 * 24 * 7;
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBYSxRQUFBLHFCQUFxQixHQUFHLGlCQUFpQixDQUFDO0FBQzFDLFFBQUEsc0JBQXNCLEdBQUcsa0JBQWtCLENBQUM7QUFDNUMsUUFBQSxvQkFBb0IsR0FBRyxZQUFZLENBQUM7QUFDcEMsUUFBQSwwQkFBMEIsR0FBRyxxQkFBcUIsQ0FBQztBQUNuRCxRQUFBLG1CQUFtQixHQUFHLGVBQWUsQ0FBQztBQUN0QyxRQUFBLHFCQUFxQixHQUFHLGlCQUFpQixDQUFDO0FBQzFDLFFBQUEsaUJBQWlCLEdBQUcsc0JBQXNCLENBQUM7QUFDM0MsUUFBQSxnQkFBZ0IsR0FBRyxrQkFBa0IsQ0FBQztBQUV0QyxRQUFBLFdBQVcsR0FBRyxlQUFlLENBQUM7QUFDOUIsUUFBQSxlQUFlLEdBQUcsNEJBQW9CLENBQUMsV0FBVyxFQUFFLENBQUM7QUFDckQsUUFBQSxXQUFXLEdBQUcsTUFBTSxDQUFDO0FBQ3JCLFFBQUEsaUJBQWlCLEdBQUcsQ0FBQyxtQkFBVyxFQUFFLHVCQUFlLEVBQUUsbUJBQVcsQ0FBQyxDQUFDO0FBQ2hFLFFBQUEsZ0JBQWdCLEdBQUcsNkJBQXFCLENBQUMsV0FBVyxFQUFFLENBQUM7QUFDdkQsUUFBQSxhQUFhLEdBQUcsc0JBQXNCLENBQUM7QUFDdkMsUUFBQSxZQUFZLEdBQUcseUJBQWlCLENBQUMsV0FBVyxFQUFFLENBQUM7QUFDL0MsUUFBQSxXQUFXLEdBQUcsTUFBTSxDQUFDO0FBRXJCLFFBQUEseUJBQXlCLEdBQUc7SUFDdkMsYUFBYSxFQUFFLElBQUk7SUFDbkIsZUFBZSxFQUFFLElBQUk7SUFDckIsVUFBVSxFQUFFLElBQUk7SUFDaEIsTUFBTSxFQUFFLElBQUk7SUFDWixJQUFJLEVBQUUsSUFBSTtJQUNWLFlBQVksRUFBRSxJQUFJO0lBQ2xCLGNBQWMsRUFBRSxJQUFJO0lBQ3BCLE1BQU0sRUFBRSxJQUFJO0lBQ1osT0FBTyxFQUFFLElBQUk7SUFDYixFQUFFLEVBQUUsSUFBSTtJQUNSLE9BQU8sRUFBRSxJQUFJO0lBQ2IsbUJBQW1CLEVBQUUsSUFBSTtJQUN6QixPQUFPLEVBQUUsSUFBSTtJQUNiLFlBQVksRUFBRSxJQUFJO0lBQ2xCLGlCQUFpQixFQUFFLElBQUk7Q0FDeEIsQ0FBQztBQUVXLFFBQUEsb0JBQW9CLEdBQUcsU0FBUyxDQUFDO0FBRWpDLFFBQUEsa0JBQWtCLEdBQUcsT0FBTyxDQUFDO0FBRTdCLFFBQUEsbUJBQW1CLEdBQUcsQ0FBQyxVQUFVLEVBQUUsUUFBUSxDQUFDLENBQUM7QUFFN0MsUUFBQSxvQkFBb0IsR0FBRyxrQkFBa0IsQ0FBQztBQUMxQyxRQUFBLHdCQUF3QixHQUFHLHdCQUF3QixDQUFDO0FBRXBELFFBQUEsMEJBQTBCLEdBQUcsMEJBQTBCLENBQUM7QUFFeEQsUUFBQSxnQkFBZ0IsR0FBRyxrQkFBa0IsQ0FBQztBQUV0QyxRQUFBLGNBQWMsR0FBRyxFQUFFLENBQUM7QUFDcEIsUUFBQSxtQkFBbUIsR0FBRyxjQUFjLENBQUM7QUFFckMsUUFBQSxpQkFBaUIsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgQUxHT1JJVEhNX1FVRVJZX1BBUkFNID0gXCJYLUFtei1BbGdvcml0aG1cIjtcbmV4cG9ydCBjb25zdCBDUkVERU5USUFMX1FVRVJZX1BBUkFNID0gXCJYLUFtei1DcmVkZW50aWFsXCI7XG5leHBvcnQgY29uc3QgQU1aX0RBVEVfUVVFUllfUEFSQU0gPSBcIlgtQW16LURhdGVcIjtcbmV4cG9ydCBjb25zdCBTSUdORURfSEVBREVSU19RVUVSWV9QQVJBTSA9IFwiWC1BbXotU2lnbmVkSGVhZGVyc1wiO1xuZXhwb3J0IGNvbnN0IEVYUElSRVNfUVVFUllfUEFSQU0gPSBcIlgtQW16LUV4cGlyZXNcIjtcbmV4cG9ydCBjb25zdCBTSUdOQVRVUkVfUVVFUllfUEFSQU0gPSBcIlgtQW16LVNpZ25hdHVyZVwiO1xuZXhwb3J0IGNvbnN0IFRPS0VOX1FVRVJZX1BBUkFNID0gXCJYLUFtei1TZWN1cml0eS1Ub2tlblwiO1xuZXhwb3J0IGNvbnN0IFJFR0lPTl9TRVRfUEFSQU0gPSBcIlgtQW16LVJlZ2lvbi1TZXRcIjtcblxuZXhwb3J0IGNvbnN0IEFVVEhfSEVBREVSID0gXCJhdXRob3JpemF0aW9uXCI7XG5leHBvcnQgY29uc3QgQU1aX0RBVEVfSEVBREVSID0gQU1aX0RBVEVfUVVFUllfUEFSQU0udG9Mb3dlckNhc2UoKTtcbmV4cG9ydCBjb25zdCBEQVRFX0hFQURFUiA9IFwiZGF0ZVwiO1xuZXhwb3J0IGNvbnN0IEdFTkVSQVRFRF9IRUFERVJTID0gW0FVVEhfSEVBREVSLCBBTVpfREFURV9IRUFERVIsIERBVEVfSEVBREVSXTtcbmV4cG9ydCBjb25zdCBTSUdOQVRVUkVfSEVBREVSID0gU0lHTkFUVVJFX1FVRVJZX1BBUkFNLnRvTG93ZXJDYXNlKCk7XG5leHBvcnQgY29uc3QgU0hBMjU2X0hFQURFUiA9IFwieC1hbXotY29udGVudC1zaGEyNTZcIjtcbmV4cG9ydCBjb25zdCBUT0tFTl9IRUFERVIgPSBUT0tFTl9RVUVSWV9QQVJBTS50b0xvd2VyQ2FzZSgpO1xuZXhwb3J0IGNvbnN0IEhPU1RfSEVBREVSID0gXCJob3N0XCI7XG5cbmV4cG9ydCBjb25zdCBBTFdBWVNfVU5TSUdOQUJMRV9IRUFERVJTID0ge1xuICBhdXRob3JpemF0aW9uOiB0cnVlLFxuICBcImNhY2hlLWNvbnRyb2xcIjogdHJ1ZSxcbiAgY29ubmVjdGlvbjogdHJ1ZSxcbiAgZXhwZWN0OiB0cnVlLFxuICBmcm9tOiB0cnVlLFxuICBcImtlZXAtYWxpdmVcIjogdHJ1ZSxcbiAgXCJtYXgtZm9yd2FyZHNcIjogdHJ1ZSxcbiAgcHJhZ21hOiB0cnVlLFxuICByZWZlcmVyOiB0cnVlLFxuICB0ZTogdHJ1ZSxcbiAgdHJhaWxlcjogdHJ1ZSxcbiAgXCJ0cmFuc2Zlci1lbmNvZGluZ1wiOiB0cnVlLFxuICB1cGdyYWRlOiB0cnVlLFxuICBcInVzZXItYWdlbnRcIjogdHJ1ZSxcbiAgXCJ4LWFtem4tdHJhY2UtaWRcIjogdHJ1ZSxcbn07XG5cbmV4cG9ydCBjb25zdCBQUk9YWV9IRUFERVJfUEFUVEVSTiA9IC9ecHJveHktLztcblxuZXhwb3J0IGNvbnN0IFNFQ19IRUFERVJfUEFUVEVSTiA9IC9ec2VjLS87XG5cbmV4cG9ydCBjb25zdCBVTlNJR05BQkxFX1BBVFRFUk5TID0gWy9ecHJveHktL2ksIC9ec2VjLS9pXTtcblxuZXhwb3J0IGNvbnN0IEFMR09SSVRITV9JREVOVElGSUVSID0gXCJBV1M0LUhNQUMtU0hBMjU2XCI7XG5leHBvcnQgY29uc3QgQUxHT1JJVEhNX0lERU5USUZJRVJfVjRBID0gXCJBV1M0LUVDRFNBLVAyNTYtU0hBMjU2XCI7XG5cbmV4cG9ydCBjb25zdCBFVkVOVF9BTEdPUklUSE1fSURFTlRJRklFUiA9IFwiQVdTNC1ITUFDLVNIQTI1Ni1QQVlMT0FEXCI7XG5cbmV4cG9ydCBjb25zdCBVTlNJR05FRF9QQVlMT0FEID0gXCJVTlNJR05FRC1QQVlMT0FEXCI7XG5cbmV4cG9ydCBjb25zdCBNQVhfQ0FDSEVfU0laRSA9IDUwO1xuZXhwb3J0IGNvbnN0IEtFWV9UWVBFX0lERU5USUZJRVIgPSBcImF3czRfcmVxdWVzdFwiO1xuXG5leHBvcnQgY29uc3QgTUFYX1BSRVNJR05FRF9UVEwgPSA2MCAqIDYwICogMjQgKiA3O1xuIl19
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.deleteHeader = exports.getHeaderValue = exports.hasHeader = void 0;
|
|
4
|
+
function hasHeader(soughtHeader, headers) {
|
|
5
|
+
soughtHeader = soughtHeader.toLowerCase();
|
|
6
|
+
for (const headerName of Object.keys(headers)) {
|
|
7
|
+
if (soughtHeader === headerName.toLowerCase()) {
|
|
8
|
+
return true;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
return false;
|
|
12
|
+
}
|
|
13
|
+
exports.hasHeader = hasHeader;
|
|
14
|
+
function getHeaderValue(soughtHeader, headers) {
|
|
15
|
+
soughtHeader = soughtHeader.toLowerCase();
|
|
16
|
+
for (const headerName of Object.keys(headers)) {
|
|
17
|
+
if (soughtHeader === headerName.toLowerCase()) {
|
|
18
|
+
return headers[headerName];
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return undefined;
|
|
22
|
+
}
|
|
23
|
+
exports.getHeaderValue = getHeaderValue;
|
|
24
|
+
function deleteHeader(soughtHeader, headers) {
|
|
25
|
+
soughtHeader = soughtHeader.toLowerCase();
|
|
26
|
+
for (const headerName of Object.keys(headers)) {
|
|
27
|
+
if (soughtHeader === headerName.toLowerCase()) {
|
|
28
|
+
delete headers[headerName];
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
exports.deleteHeader = deleteHeader;
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyVXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9oZWFkZXJVdGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLFNBQWdCLFNBQVMsQ0FBQyxZQUFvQixFQUFFLE9BQWtCO0lBQ2hFLFlBQVksR0FBRyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDMUMsS0FBSyxNQUFNLFVBQVUsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQzdDLElBQUksWUFBWSxLQUFLLFVBQVUsQ0FBQyxXQUFXLEVBQUUsRUFBRTtZQUM3QyxPQUFPLElBQUksQ0FBQztTQUNiO0tBQ0Y7SUFFRCxPQUFPLEtBQUssQ0FBQztBQUNmLENBQUM7QUFURCw4QkFTQztBQUdELFNBQWdCLGNBQWMsQ0FBQyxZQUFvQixFQUFFLE9BQWtCO0lBQ3JFLFlBQVksR0FBRyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDMUMsS0FBSyxNQUFNLFVBQVUsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQzdDLElBQUksWUFBWSxLQUFLLFVBQVUsQ0FBQyxXQUFXLEVBQUUsRUFBRTtZQUM3QyxPQUFPLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQztTQUM1QjtLQUNGO0lBRUQsT0FBTyxTQUFTLENBQUM7QUFDbkIsQ0FBQztBQVRELHdDQVNDO0FBR0QsU0FBZ0IsWUFBWSxDQUFDLFlBQW9CLEVBQUUsT0FBa0I7SUFDbkUsWUFBWSxHQUFHLFlBQVksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUMxQyxLQUFLLE1BQU0sVUFBVSxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEVBQUU7UUFDN0MsSUFBSSxZQUFZLEtBQUssVUFBVSxDQUFDLFdBQVcsRUFBRSxFQUFFO1lBQzdDLE9BQU8sT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1NBQzVCO0tBQ0Y7QUFDSCxDQUFDO0FBUEQsb0NBT0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIZWFkZXJCYWcgfSBmcm9tIFwiQGF3cy1zZGsvdHlwZXNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGhhc0hlYWRlcihzb3VnaHRIZWFkZXI6IHN0cmluZywgaGVhZGVyczogSGVhZGVyQmFnKTogYm9vbGVhbiB7XG4gIHNvdWdodEhlYWRlciA9IHNvdWdodEhlYWRlci50b0xvd2VyQ2FzZSgpO1xuICBmb3IgKGNvbnN0IGhlYWRlck5hbWUgb2YgT2JqZWN0LmtleXMoaGVhZGVycykpIHtcbiAgICBpZiAoc291Z2h0SGVhZGVyID09PSBoZWFkZXJOYW1lLnRvTG93ZXJDYXNlKCkpIHtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBmYWxzZTtcbn1cblxuLyogR2V0IHRoZSB2YWx1ZSBvZiBvbmUgcmVxdWVzdCBoZWFkZXIsIGlnbm9yZSB0aGUgY2FzZS4gUmV0dXJuIHN0cmluZyBpZiBoZWFkZXIgaXMgaW4gdGhlIGhlYWRlcnMsIGVsc2UgcmV0dXJuIHVuZGVmaW5lZCAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldEhlYWRlclZhbHVlKHNvdWdodEhlYWRlcjogc3RyaW5nLCBoZWFkZXJzOiBIZWFkZXJCYWcpOiBzdHJpbmcgfCB1bmRlZmluZWQge1xuICBzb3VnaHRIZWFkZXIgPSBzb3VnaHRIZWFkZXIudG9Mb3dlckNhc2UoKTtcbiAgZm9yIChjb25zdCBoZWFkZXJOYW1lIG9mIE9iamVjdC5rZXlzKGhlYWRlcnMpKSB7XG4gICAgaWYgKHNvdWdodEhlYWRlciA9PT0gaGVhZGVyTmFtZS50b0xvd2VyQ2FzZSgpKSB7XG4gICAgICByZXR1cm4gaGVhZGVyc1toZWFkZXJOYW1lXTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gdW5kZWZpbmVkO1xufVxuXG4vKiBEZWxldGUgdGhlIG9uZSByZXF1ZXN0IGhlYWRlciwgaWdub3JlIHRoZSBjYXNlLiBEbyBub3RoaW5nIGlmIGl0J3Mgbm90IHRoZXJlICovXG5leHBvcnQgZnVuY3Rpb24gZGVsZXRlSGVhZGVyKHNvdWdodEhlYWRlcjogc3RyaW5nLCBoZWFkZXJzOiBIZWFkZXJCYWcpIHtcbiAgc291Z2h0SGVhZGVyID0gc291Z2h0SGVhZGVyLnRvTG93ZXJDYXNlKCk7XG4gIGZvciAoY29uc3QgaGVhZGVyTmFtZSBvZiBPYmplY3Qua2V5cyhoZWFkZXJzKSkge1xuICAgIGlmIChzb3VnaHRIZWFkZXIgPT09IGhlYWRlck5hbWUudG9Mb3dlckNhc2UoKSkge1xuICAgICAgZGVsZXRlIGhlYWRlcnNbaGVhZGVyTmFtZV07XG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -2,4 +2,4 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const tslib_1 = require("tslib");
|
|
4
4
|
tslib_1.__exportStar(require("./CrtSignerV4"), exports);
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsd0RBQThCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vQ3J0U2lnbmVyVjRcIjtcbiJdfQ==
|