@liflig/cdk-cloudfront-auth 1.5.43 → 1.6.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/dist/check-auth/index.js +1 -1
- package/dist/generate-secret/index.js +1 -1
- package/dist/http-headers/index.js +1 -1
- package/dist/parse-auth/index.js +1 -1
- package/dist/refresh-auth/index.js +1 -1
- package/dist/sign-out/index.js +1 -1
- package/lib/client-secret.js +6 -32
- package/lib/client-update.js +5 -32
- package/lib/cloudfront-auth.js +55 -69
- package/lib/generate-secret.js +17 -39
- package/lib/handlers/util/axios.js +6 -12
- package/lib/handlers/util/base64.js +3 -7
- package/lib/handlers/util/cloudfront.js +13 -24
- package/lib/handlers/util/config.js +12 -35
- package/lib/handlers/util/cookies.js +11 -15
- package/lib/handlers/util/jwt.js +8 -15
- package/lib/handlers/util/logger.js +6 -9
- package/lib/handlers/util/nonce.js +8 -14
- package/lib/index.js +3 -19
- package/lib/lambdas.js +23 -40
- package/package.json +13 -11
|
@@ -1,14 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.redirectTo = redirectTo;
|
|
7
|
-
exports.staticPage = staticPage;
|
|
8
|
-
exports.createRequestHandler = createRequestHandler;
|
|
9
|
-
exports.createResponseHandler = createResponseHandler;
|
|
10
|
-
const template_html_1 = __importDefault(require("../error-page/template.html"));
|
|
11
|
-
const config_1 = require("./config");
|
|
1
|
+
import html from "../error-page/template.html";
|
|
2
|
+
import { getConfig } from "./config";
|
|
12
3
|
function asCloudFrontHeaders(headers) {
|
|
13
4
|
return Object.entries(headers).reduce((reduced, [key, value]) => Object.assign(reduced, {
|
|
14
5
|
[key.toLowerCase()]: [
|
|
@@ -19,8 +10,8 @@ function asCloudFrontHeaders(headers) {
|
|
|
19
10
|
],
|
|
20
11
|
}), {});
|
|
21
12
|
}
|
|
22
|
-
function redirectTo(path, props) {
|
|
23
|
-
const headers =
|
|
13
|
+
export function redirectTo(path, props) {
|
|
14
|
+
const headers = props?.cookies
|
|
24
15
|
? {
|
|
25
16
|
"set-cookie": props.cookies.map((value) => ({
|
|
26
17
|
key: "set-cookie",
|
|
@@ -42,11 +33,10 @@ function redirectTo(path, props) {
|
|
|
42
33
|
},
|
|
43
34
|
};
|
|
44
35
|
}
|
|
45
|
-
function staticPage(props) {
|
|
46
|
-
var _a;
|
|
36
|
+
export function staticPage(props) {
|
|
47
37
|
return {
|
|
48
38
|
body: createErrorHtml(props),
|
|
49
|
-
status:
|
|
39
|
+
status: props.statusCode ?? "500",
|
|
50
40
|
headers: {
|
|
51
41
|
"content-type": [
|
|
52
42
|
{
|
|
@@ -59,26 +49,25 @@ function staticPage(props) {
|
|
|
59
49
|
}
|
|
60
50
|
function createErrorHtml(props) {
|
|
61
51
|
const params = { ...props, region: process.env.AWS_REGION };
|
|
62
|
-
return
|
|
52
|
+
return html.replace(/\${([^}]*)}/g, (_, v) => params[v] || "");
|
|
63
53
|
}
|
|
64
54
|
function addCloudFrontHeaders(config, response) {
|
|
65
|
-
var _a;
|
|
66
55
|
if (!response) {
|
|
67
56
|
throw new Error("Expected response value");
|
|
68
57
|
}
|
|
69
58
|
return {
|
|
70
59
|
...response,
|
|
71
60
|
headers: {
|
|
72
|
-
...(
|
|
61
|
+
...(response.headers ?? {}),
|
|
73
62
|
...asCloudFrontHeaders(config.httpHeaders),
|
|
74
63
|
},
|
|
75
64
|
};
|
|
76
65
|
}
|
|
77
|
-
function createRequestHandler(inner) {
|
|
66
|
+
export function createRequestHandler(inner) {
|
|
78
67
|
let config;
|
|
79
68
|
return async (event) => {
|
|
80
69
|
if (!config) {
|
|
81
|
-
config =
|
|
70
|
+
config = getConfig();
|
|
82
71
|
}
|
|
83
72
|
config.logger.debug("Handling event:", event);
|
|
84
73
|
const response = addCloudFrontHeaders(config, await inner(config, event));
|
|
@@ -86,11 +75,11 @@ function createRequestHandler(inner) {
|
|
|
86
75
|
return response;
|
|
87
76
|
};
|
|
88
77
|
}
|
|
89
|
-
function createResponseHandler(inner) {
|
|
78
|
+
export function createResponseHandler(inner) {
|
|
90
79
|
let config;
|
|
91
80
|
return async (event) => {
|
|
92
81
|
if (!config) {
|
|
93
|
-
config =
|
|
82
|
+
config = getConfig();
|
|
94
83
|
}
|
|
95
84
|
config.logger.debug("Handling event:", event);
|
|
96
85
|
const response = addCloudFrontHeaders(config, await inner(config, event));
|
|
@@ -98,4 +87,4 @@ function createResponseHandler(inner) {
|
|
|
98
87
|
return response;
|
|
99
88
|
};
|
|
100
89
|
}
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloudfront.js","sourceRoot":"","sources":["../../../src/handlers/util/cloudfront.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  CloudFrontHeaders,\n  CloudFrontRequestEvent,\n  CloudFrontRequestHandler,\n  CloudFrontRequestResult,\n  CloudFrontResponseEvent,\n  CloudFrontResponseHandler,\n  CloudFrontResponseResult,\n} from \"aws-lambda\"\nimport html from \"../error-page/template.html\"\nimport { Config, getConfig } from \"./config\"\n\nexport type HttpHeaders = Record<string, string>\n\nfunction asCloudFrontHeaders(headers: HttpHeaders): CloudFrontHeaders {\n  return Object.entries(headers).reduce(\n    (reduced, [key, value]) =>\n      Object.assign(reduced, {\n        [key.toLowerCase()]: [\n          {\n            key,\n            value,\n          },\n        ],\n      }),\n    {} as CloudFrontHeaders,\n  )\n}\n\nexport function redirectTo(\n  path: string,\n  props?: {\n    cookies?: string[]\n  },\n): CloudFrontResponseResult {\n  const headers: CloudFrontHeaders = props?.cookies\n    ? {\n        \"set-cookie\": props.cookies.map((value) => ({\n          key: \"set-cookie\",\n          value,\n        })),\n      }\n    : {}\n\n  return {\n    status: \"307\",\n    statusDescription: \"Temporary Redirect\",\n    headers: {\n      location: [\n        {\n          key: \"location\",\n          value: path,\n        },\n      ],\n      ...headers,\n    },\n  }\n}\n\nexport function staticPage(props: {\n  title: string\n  message: string\n  details: string\n  linkHref: string\n  linkText: string\n  statusCode?: string\n}): CloudFrontResponseResult {\n  return {\n    body: createErrorHtml(props),\n    status: props.statusCode ?? \"500\",\n    headers: {\n      \"content-type\": [\n        {\n          key: \"Content-Type\",\n          value: \"text/html; charset=UTF-8\",\n        },\n      ],\n    },\n  }\n}\n\nfunction createErrorHtml(props: {\n  title: string\n  message: string\n  details: string\n  linkHref: string\n  linkText: string\n}): string {\n  const params = { ...props, region: process.env.AWS_REGION }\n  return html.replace(\n    /\\${([^}]*)}/g,\n    (_, v: keyof typeof params) => params[v] || \"\",\n  )\n}\n\nfunction addCloudFrontHeaders<\n  T extends CloudFrontRequestResult | CloudFrontResponseResult,\n>(config: Config, response: T): T {\n  if (!response) {\n    throw new Error(\"Expected response value\")\n  }\n\n  return {\n    ...response,\n    headers: {\n      ...(response.headers ?? {}),\n      ...asCloudFrontHeaders(config.httpHeaders),\n    },\n  }\n}\n\nexport type RequestHandler = (\n  config: Config,\n  event: CloudFrontRequestEvent,\n) => Promise<CloudFrontRequestResult>\n\nexport function createRequestHandler(\n  inner: RequestHandler,\n): CloudFrontRequestHandler {\n  let config: Config\n\n  return async (event) => {\n    if (!config) {\n      config = getConfig()\n    }\n\n    config.logger.debug(\"Handling event:\", event)\n\n    const response = addCloudFrontHeaders(config, await inner(config, event))\n\n    config.logger.debug(\"Returning response:\", response)\n    return response\n  }\n}\n\nexport function createResponseHandler(\n  inner: (\n    config: Config,\n    event: CloudFrontResponseEvent,\n  ) => Promise<CloudFrontResponseResult>,\n): CloudFrontResponseHandler {\n  let config: Config\n\n  return async (event) => {\n    if (!config) {\n      config = getConfig()\n    }\n\n    config.logger.debug(\"Handling event:\", event)\n\n    const response = addCloudFrontHeaders(config, await inner(config, event))\n\n    config.logger.debug(\"Returning response:\", response)\n    return response\n  }\n}\n"]}
|
|
@@ -1,47 +1,24 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.getConfig = getConfig;
|
|
27
|
-
const cookie_1 = require("cookie");
|
|
28
|
-
const fs_1 = require("fs");
|
|
29
|
-
const path = __importStar(require("path"));
|
|
30
|
-
const logger_1 = require("./logger");
|
|
31
|
-
function getConfig() {
|
|
32
|
-
const config = JSON.parse((0, fs_1.readFileSync)(path.join(__dirname, "/config.json"), "utf-8"));
|
|
1
|
+
import { parse } from "cookie";
|
|
2
|
+
import { readFileSync } from "fs";
|
|
3
|
+
import * as path from "path";
|
|
4
|
+
import { Logger, LogLevel } from "./logger";
|
|
5
|
+
import { fileURLToPath } from "url";
|
|
6
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
7
|
+
const __dirname = path.dirname(__filename);
|
|
8
|
+
export function getConfig() {
|
|
9
|
+
const config = JSON.parse(readFileSync(path.join(__dirname, "/config.json"), "utf-8"));
|
|
33
10
|
// Derive the issuer and JWKS uri all JWT's will be signed with from
|
|
34
11
|
// the User Pool's ID and region.
|
|
35
12
|
const userPoolRegion = /^(\S+?)_\S+$/.exec(config.userPoolId)[1];
|
|
36
13
|
const tokenIssuer = `https://cognito-idp.${userPoolRegion}.amazonaws.com/${config.userPoolId}`;
|
|
37
14
|
const tokenJwksUri = `${tokenIssuer}/.well-known/jwks.json`;
|
|
38
15
|
return {
|
|
39
|
-
nonceMaxAge: parseInt(
|
|
16
|
+
nonceMaxAge: parseInt(parse(config.cookieSettings.nonce.toLowerCase())["max-age"]) ||
|
|
40
17
|
60 * 60 * 24,
|
|
41
18
|
...config,
|
|
42
19
|
tokenIssuer,
|
|
43
20
|
tokenJwksUri,
|
|
44
|
-
logger: new
|
|
21
|
+
logger: new Logger(LogLevel[config.logLevel]),
|
|
45
22
|
};
|
|
46
23
|
}
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2hhbmRsZXJzL3V0aWwvY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxRQUFRLENBQUE7QUFDOUIsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLElBQUksQ0FBQTtBQUNqQyxPQUFPLEtBQUssSUFBSSxNQUFNLE1BQU0sQ0FBQTtBQUc1QixPQUFPLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxNQUFNLFVBQVUsQ0FBQTtBQUMzQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sS0FBSyxDQUFBO0FBRW5DLE1BQU0sVUFBVSxHQUFHLGFBQWEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFBO0FBQ2pELE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLENBQUE7QUEwQjFDLE1BQU0sVUFBVSxTQUFTO0lBQ3ZCLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQ3ZCLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxjQUFjLENBQUMsRUFBRSxPQUFPLENBQUMsQ0FDNUMsQ0FBQTtJQUVqQixvRUFBb0U7SUFDcEUsaUNBQWlDO0lBQ2pDLE1BQU0sY0FBYyxHQUFHLGNBQWMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBRSxDQUFDLENBQUMsQ0FBQyxDQUFBO0lBQ2pFLE1BQU0sV0FBVyxHQUFHLHVCQUF1QixjQUFjLGtCQUFrQixNQUFNLENBQUMsVUFBVSxFQUFFLENBQUE7SUFDOUYsTUFBTSxZQUFZLEdBQUcsR0FBRyxXQUFXLHdCQUF3QixDQUFBO0lBRTNELE9BQU87UUFDTCxXQUFXLEVBQ1QsUUFBUSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ3JFLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRTtRQUNkLEdBQUcsTUFBTTtRQUNULFdBQVc7UUFDWCxZQUFZO1FBQ1osTUFBTSxFQUFFLElBQUksTUFBTSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7S0FDOUMsQ0FBQTtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBwYXJzZSB9IGZyb20gXCJjb29raWVcIlxuaW1wb3J0IHsgcmVhZEZpbGVTeW5jIH0gZnJvbSBcImZzXCJcbmltcG9ydCAqIGFzIHBhdGggZnJvbSBcInBhdGhcIlxuaW1wb3J0IHsgSHR0cEhlYWRlcnMgfSBmcm9tIFwiLi9jbG91ZGZyb250XCJcbmltcG9ydCB7IENvb2tpZVNldHRpbmdzIH0gZnJvbSBcIi4vY29va2llc1wiXG5pbXBvcnQgeyBMb2dnZXIsIExvZ0xldmVsIH0gZnJvbSBcIi4vbG9nZ2VyXCJcbmltcG9ydCB7IGZpbGVVUkxUb1BhdGggfSBmcm9tIFwidXJsXCJcblxuY29uc3QgX19maWxlbmFtZSA9IGZpbGVVUkxUb1BhdGgoaW1wb3J0Lm1ldGEudXJsKVxuY29uc3QgX19kaXJuYW1lID0gcGF0aC5kaXJuYW1lKF9fZmlsZW5hbWUpXG5cbmV4cG9ydCBpbnRlcmZhY2UgU3RvcmVkQ29uZmlnIHtcbiAgdXNlclBvb2xJZDogc3RyaW5nXG4gIGNsaWVudElkOiBzdHJpbmdcbiAgb2F1dGhTY29wZXM6IHN0cmluZ1tdXG4gIGNvZ25pdG9BdXRoRG9tYWluOiBzdHJpbmdcbiAgY2FsbGJhY2tQYXRoOiBzdHJpbmdcbiAgc2lnbk91dFJlZGlyZWN0VG86IHN0cmluZ1xuICBzaWduT3V0UGF0aDogc3RyaW5nXG4gIHJlZnJlc2hBdXRoUGF0aDogc3RyaW5nXG4gIGNvb2tpZVNldHRpbmdzOiBDb29raWVTZXR0aW5nc1xuICBodHRwSGVhZGVyczogSHR0cEhlYWRlcnNcbiAgY2xpZW50U2VjcmV0OiBzdHJpbmdcbiAgbm9uY2VTaWduaW5nU2VjcmV0OiBzdHJpbmdcbiAgbG9nTGV2ZWw6IGtleW9mIHR5cGVvZiBMb2dMZXZlbFxuICByZXF1aXJlR3JvdXBBbnlPZj86IHN0cmluZ1tdIHwgbnVsbFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvbmZpZyBleHRlbmRzIFN0b3JlZENvbmZpZyB7XG4gIHRva2VuSXNzdWVyOiBzdHJpbmdcbiAgdG9rZW5Kd2tzVXJpOiBzdHJpbmdcbiAgbG9nZ2VyOiBMb2dnZXJcbiAgbm9uY2VNYXhBZ2U6IG51bWJlclxufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0Q29uZmlnKCk6IENvbmZpZyB7XG4gIGNvbnN0IGNvbmZpZyA9IEpTT04ucGFyc2UoXG4gICAgcmVhZEZpbGVTeW5jKHBhdGguam9pbihfX2Rpcm5hbWUsIFwiL2NvbmZpZy5qc29uXCIpLCBcInV0Zi04XCIpLFxuICApIGFzIFN0b3JlZENvbmZpZ1xuXG4gIC8vIERlcml2ZSB0aGUgaXNzdWVyIGFuZCBKV0tTIHVyaSBhbGwgSldUJ3Mgd2lsbCBiZSBzaWduZWQgd2l0aCBmcm9tXG4gIC8vIHRoZSBVc2VyIFBvb2wncyBJRCBhbmQgcmVnaW9uLlxuICBjb25zdCB1c2VyUG9vbFJlZ2lvbiA9IC9eKFxcUys/KV9cXFMrJC8uZXhlYyhjb25maWcudXNlclBvb2xJZCkhWzFdXG4gIGNvbnN0IHRva2VuSXNzdWVyID0gYGh0dHBzOi8vY29nbml0by1pZHAuJHt1c2VyUG9vbFJlZ2lvbn0uYW1hem9uYXdzLmNvbS8ke2NvbmZpZy51c2VyUG9vbElkfWBcbiAgY29uc3QgdG9rZW5Kd2tzVXJpID0gYCR7dG9rZW5Jc3N1ZXJ9Ly53ZWxsLWtub3duL2p3a3MuanNvbmBcblxuICByZXR1cm4ge1xuICAgIG5vbmNlTWF4QWdlOlxuICAgICAgcGFyc2VJbnQocGFyc2UoY29uZmlnLmNvb2tpZVNldHRpbmdzLm5vbmNlLnRvTG93ZXJDYXNlKCkpW1wibWF4LWFnZVwiXSkgfHxcbiAgICAgIDYwICogNjAgKiAyNCxcbiAgICAuLi5jb25maWcsXG4gICAgdG9rZW5Jc3N1ZXIsXG4gICAgdG9rZW5Kd2tzVXJpLFxuICAgIGxvZ2dlcjogbmV3IExvZ2dlcihMb2dMZXZlbFtjb25maWcubG9nTGV2ZWxdKSxcbiAgfVxufVxuIl19
|
|
@@ -1,9 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
exports.extractAndParseCookies = extractAndParseCookies;
|
|
4
|
-
exports.generateCookies = generateCookies;
|
|
5
|
-
const cookie_1 = require("cookie");
|
|
6
|
-
const jwt_1 = require("./jwt");
|
|
1
|
+
import { parse } from "cookie";
|
|
2
|
+
import { decodeIdToken } from "./jwt";
|
|
7
3
|
/**
|
|
8
4
|
* Cookies are present in the HTTP header "Cookie" that may be present
|
|
9
5
|
* multiple times. This utility function parses occurrences of that
|
|
@@ -17,7 +13,7 @@ function extractCookiesFromHeaders(headers) {
|
|
|
17
13
|
}
|
|
18
14
|
const cookies = headers["cookie"].reduce((reduced, header) => ({
|
|
19
15
|
...reduced,
|
|
20
|
-
...
|
|
16
|
+
...parse(header.value),
|
|
21
17
|
}), {});
|
|
22
18
|
return cookies;
|
|
23
19
|
}
|
|
@@ -28,7 +24,7 @@ function withCookieDomain(distributionDomainName, cookieSettings) {
|
|
|
28
24
|
}
|
|
29
25
|
return cookieSettings;
|
|
30
26
|
}
|
|
31
|
-
function extractAndParseCookies(headers, clientId) {
|
|
27
|
+
export function extractAndParseCookies(headers, clientId) {
|
|
32
28
|
const cookies = extractCookiesFromHeaders(headers);
|
|
33
29
|
if (!cookies) {
|
|
34
30
|
return {};
|
|
@@ -37,19 +33,19 @@ function extractAndParseCookies(headers, clientId) {
|
|
|
37
33
|
const tokenUserName = cookies[`${keyPrefix}.LastAuthUser`];
|
|
38
34
|
return {
|
|
39
35
|
tokenUserName,
|
|
40
|
-
idToken: cookies[`${keyPrefix}.${tokenUserName
|
|
41
|
-
accessToken: cookies[`${keyPrefix}.${tokenUserName
|
|
42
|
-
refreshToken: cookies[`${keyPrefix}.${tokenUserName
|
|
43
|
-
scopes: cookies[`${keyPrefix}.${tokenUserName
|
|
36
|
+
idToken: cookies[`${keyPrefix}.${tokenUserName ?? ""}.idToken`],
|
|
37
|
+
accessToken: cookies[`${keyPrefix}.${tokenUserName ?? ""}.accessToken`],
|
|
38
|
+
refreshToken: cookies[`${keyPrefix}.${tokenUserName ?? ""}.refreshToken`],
|
|
39
|
+
scopes: cookies[`${keyPrefix}.${tokenUserName ?? ""}.tokenScopesString`],
|
|
44
40
|
nonce: cookies["spa-auth-edge-nonce"],
|
|
45
41
|
nonceHmac: cookies["spa-auth-edge-nonce-hmac"],
|
|
46
42
|
pkce: cookies["spa-auth-edge-pkce"],
|
|
47
43
|
};
|
|
48
44
|
}
|
|
49
|
-
function generateCookies(param) {
|
|
45
|
+
export function generateCookies(param) {
|
|
50
46
|
// Set cookies with the exact names and values Amplify uses
|
|
51
47
|
// for seamless interoperability with Amplify.
|
|
52
|
-
const decodedIdToken =
|
|
48
|
+
const decodedIdToken = decodeIdToken(param.tokens.idToken);
|
|
53
49
|
const tokenUserName = decodedIdToken["cognito:username"];
|
|
54
50
|
const keyPrefix = `CognitoIdentityServiceProvider.${param.clientId}`;
|
|
55
51
|
const idTokenKey = `${keyPrefix}.${tokenUserName}.idToken`;
|
|
@@ -111,4 +107,4 @@ function expireCookie(cookie = "") {
|
|
|
111
107
|
// First part is the cookie value, which we'll clear.
|
|
112
108
|
return ["", ...cookieParts.slice(1), expires].join("; ");
|
|
113
109
|
}
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cookies.js","sourceRoot":"","sources":["../../../src/handlers/util/cookies.ts"],"names":[],"mappings":"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","sourcesContent":["import { CloudFrontHeaders } from \"aws-lambda\"\nimport { parse } from \"cookie\"\nimport { decodeIdToken } from \"./jwt\"\n\ntype Cookies = Record<string, string | undefined>\n\nexport interface CookieSettings {\n  idToken: string\n  accessToken: string\n  refreshToken: string\n  nonce: string\n}\n\n/**\n * Cookies are present in the HTTP header \"Cookie\" that may be present\n * multiple times. This utility function parses occurrences  of that\n * header and splits out all the cookies and their values.\n * A simple object is returned that allows easy access by cookie\n * name: e.g. cookies[\"nonce\"].\n */\nfunction extractCookiesFromHeaders(headers: CloudFrontHeaders): Cookies {\n  if (!headers[\"cookie\"]) {\n    return {}\n  }\n  const cookies = headers[\"cookie\"].reduce<Cookies>(\n    (reduced, header) => ({\n      ...reduced,\n      ...(parse(header.value) as Cookies),\n    }),\n    {},\n  )\n\n  return cookies\n}\n\nfunction withCookieDomain(\n  distributionDomainName: string,\n  cookieSettings: string,\n) {\n  if (cookieSettings.toLowerCase().indexOf(\"domain\") === -1) {\n    // Add leading dot for compatibility with Amplify (or js-cookie really).\n    return `${cookieSettings}; Domain=.${distributionDomainName}`\n  }\n  return cookieSettings\n}\n\nexport function extractAndParseCookies(\n  headers: CloudFrontHeaders,\n  clientId: string,\n): {\n  tokenUserName?: string\n  idToken?: string\n  accessToken?: string\n  refreshToken?: string\n  scopes?: string\n  nonce?: string\n  nonceHmac?: string\n  pkce?: string\n} {\n  const cookies = extractCookiesFromHeaders(headers)\n  if (!cookies) {\n    return {}\n  }\n\n  const keyPrefix = `CognitoIdentityServiceProvider.${clientId}`\n  const tokenUserName = cookies[`${keyPrefix}.LastAuthUser`]\n\n  return {\n    tokenUserName,\n    idToken: cookies[`${keyPrefix}.${tokenUserName ?? \"\"}.idToken`],\n    accessToken: cookies[`${keyPrefix}.${tokenUserName ?? \"\"}.accessToken`],\n    refreshToken: cookies[`${keyPrefix}.${tokenUserName ?? \"\"}.refreshToken`],\n    scopes: cookies[`${keyPrefix}.${tokenUserName ?? \"\"}.tokenScopesString`],\n    nonce: cookies[\"spa-auth-edge-nonce\"],\n    nonceHmac: cookies[\"spa-auth-edge-nonce-hmac\"],\n    pkce: cookies[\"spa-auth-edge-pkce\"],\n  }\n}\n\nexport function generateCookies(param: {\n  event: \"newTokens\" | \"signOut\" | \"refreshFailed\"\n  clientId: string\n  oauthScopes: string[]\n  domainName: string\n  cookieSettings: CookieSettings\n  tokens: {\n    idToken: string\n    accessToken: string\n    refreshToken: string\n  }\n}): string[] {\n  // Set cookies with the exact names and values Amplify uses\n  // for seamless interoperability with Amplify.\n  const decodedIdToken = decodeIdToken(param.tokens.idToken)\n  const tokenUserName = decodedIdToken[\"cognito:username\"] as string\n  const keyPrefix = `CognitoIdentityServiceProvider.${param.clientId}`\n  const idTokenKey = `${keyPrefix}.${tokenUserName}.idToken`\n  const accessTokenKey = `${keyPrefix}.${tokenUserName}.accessToken`\n  const refreshTokenKey = `${keyPrefix}.${tokenUserName}.refreshToken`\n  const lastUserKey = `${keyPrefix}.LastAuthUser`\n  const scopeKey = `${keyPrefix}.${tokenUserName}.tokenScopesString`\n  const scopesString = param.oauthScopes.join(\" \")\n  const userDataKey = `${keyPrefix}.${tokenUserName}.userData`\n  const userData = JSON.stringify({\n    UserAttributes: [\n      {\n        Name: \"sub\",\n        Value: decodedIdToken[\"sub\"],\n      },\n      {\n        Name: \"email\",\n        Value: decodedIdToken[\"email\"],\n      },\n    ],\n    Username: tokenUserName,\n  })\n\n  // Construct object with the cookies\n  const cookies = {\n    [idTokenKey]: `${param.tokens.idToken}; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.idToken,\n    )}`,\n    [accessTokenKey]: `${param.tokens.accessToken}; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.accessToken,\n    )}`,\n    [refreshTokenKey]: `${param.tokens.refreshToken}; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.refreshToken,\n    )}`,\n    [lastUserKey]: `${tokenUserName}; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.idToken,\n    )}`,\n    [scopeKey]: `${scopesString}; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.accessToken,\n    )}`,\n    [userDataKey]: `${encodeURIComponent(userData)}; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.idToken,\n    )}`,\n    \"amplify-signin-with-hostedUI\": `true; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.accessToken,\n    )}`,\n  }\n\n  if (param.event === \"signOut\") {\n    // Expire all cookies\n    Object.keys(cookies).forEach(\n      (key) => (cookies[key] = expireCookie(cookies[key])),\n    )\n  } else if (param.event === \"refreshFailed\") {\n    // Expire refresh token (so the browser will not send it in vain again)\n    cookies[refreshTokenKey] = expireCookie(cookies[refreshTokenKey])\n  }\n\n  // Nonce, nonceHmac and pkce are only used during login phase.\n  ;[\n    \"spa-auth-edge-nonce\",\n    \"spa-auth-edge-nonce-hmac\",\n    \"spa-auth-edge-pkce\",\n  ].forEach((key) => {\n    cookies[key] = expireCookie(cookies[key])\n  })\n\n  return Object.entries(cookies).map(([k, v]) => `${k}=${v}`)\n}\n\nfunction expireCookie(cookie = \"\") {\n  const cookieParts = cookie\n    .split(\";\")\n    .map((part) => part.trim())\n    .filter((part) => !part.toLowerCase().startsWith(\"max-age\"))\n    .filter((part) => !part.toLowerCase().startsWith(\"expires\"))\n  const expires = `Expires=${new Date(0).toUTCString()}`\n  // First part is the cookie value, which we'll clear.\n  return [\"\", ...cookieParts.slice(1), expires].join(\"; \")\n}\n"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cookies.js","sourceRoot":"","sources":["../../../src/handlers/util/cookies.ts"],"names":[],"mappings":"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","sourcesContent":["import { CloudFrontHeaders } from \"aws-lambda\"\nimport { parse } from \"cookie\"\nimport { decodeIdToken } from \"./jwt\"\n\ntype Cookies = Record<string, string | undefined>\n\nexport interface CookieSettings {\n  idToken: string\n  accessToken: string\n  refreshToken: string\n  nonce: string\n}\n\n/**\n * Cookies are present in the HTTP header \"Cookie\" that may be present\n * multiple times. This utility function parses occurrences  of that\n * header and splits out all the cookies and their values.\n * A simple object is returned that allows easy access by cookie\n * name: e.g. cookies[\"nonce\"].\n */\nfunction extractCookiesFromHeaders(headers: CloudFrontHeaders): Cookies {\n  if (!headers[\"cookie\"]) {\n    return {}\n  }\n  const cookies = headers[\"cookie\"].reduce<Cookies>(\n    (reduced, header) => ({\n      ...reduced,\n      ...(parse(header.value) as Cookies),\n    }),\n    {},\n  )\n\n  return cookies\n}\n\nfunction withCookieDomain(\n  distributionDomainName: string,\n  cookieSettings: string,\n) {\n  if (cookieSettings.toLowerCase().indexOf(\"domain\") === -1) {\n    // Add leading dot for compatibility with Amplify (or js-cookie really).\n    return `${cookieSettings}; Domain=.${distributionDomainName}`\n  }\n  return cookieSettings\n}\n\nexport function extractAndParseCookies(\n  headers: CloudFrontHeaders,\n  clientId: string,\n): {\n  tokenUserName?: string\n  idToken?: string\n  accessToken?: string\n  refreshToken?: string\n  scopes?: string\n  nonce?: string\n  nonceHmac?: string\n  pkce?: string\n} {\n  const cookies = extractCookiesFromHeaders(headers)\n  if (!cookies) {\n    return {}\n  }\n\n  const keyPrefix = `CognitoIdentityServiceProvider.${clientId}`\n  const tokenUserName = cookies[`${keyPrefix}.LastAuthUser`]\n\n  return {\n    tokenUserName,\n    idToken: cookies[`${keyPrefix}.${tokenUserName ?? \"\"}.idToken`],\n    accessToken: cookies[`${keyPrefix}.${tokenUserName ?? \"\"}.accessToken`],\n    refreshToken: cookies[`${keyPrefix}.${tokenUserName ?? \"\"}.refreshToken`],\n    scopes: cookies[`${keyPrefix}.${tokenUserName ?? \"\"}.tokenScopesString`],\n    nonce: cookies[\"spa-auth-edge-nonce\"],\n    nonceHmac: cookies[\"spa-auth-edge-nonce-hmac\"],\n    pkce: cookies[\"spa-auth-edge-pkce\"],\n  }\n}\n\nexport function generateCookies(param: {\n  event: \"newTokens\" | \"signOut\" | \"refreshFailed\"\n  clientId: string\n  oauthScopes: string[]\n  domainName: string\n  cookieSettings: CookieSettings\n  tokens: {\n    idToken: string\n    accessToken: string\n    refreshToken: string\n  }\n}): string[] {\n  // Set cookies with the exact names and values Amplify uses\n  // for seamless interoperability with Amplify.\n  const decodedIdToken = decodeIdToken(param.tokens.idToken)\n  const tokenUserName = decodedIdToken[\"cognito:username\"]\n  const keyPrefix = `CognitoIdentityServiceProvider.${param.clientId}`\n  const idTokenKey = `${keyPrefix}.${tokenUserName}.idToken`\n  const accessTokenKey = `${keyPrefix}.${tokenUserName}.accessToken`\n  const refreshTokenKey = `${keyPrefix}.${tokenUserName}.refreshToken`\n  const lastUserKey = `${keyPrefix}.LastAuthUser`\n  const scopeKey = `${keyPrefix}.${tokenUserName}.tokenScopesString`\n  const scopesString = param.oauthScopes.join(\" \")\n  const userDataKey = `${keyPrefix}.${tokenUserName}.userData`\n  const userData = JSON.stringify({\n    UserAttributes: [\n      {\n        Name: \"sub\",\n        Value: decodedIdToken[\"sub\"],\n      },\n      {\n        Name: \"email\",\n        Value: decodedIdToken[\"email\"],\n      },\n    ],\n    Username: tokenUserName,\n  })\n\n  // Construct object with the cookies\n  const cookies = {\n    [idTokenKey]: `${param.tokens.idToken}; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.idToken,\n    )}`,\n    [accessTokenKey]: `${param.tokens.accessToken}; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.accessToken,\n    )}`,\n    [refreshTokenKey]: `${param.tokens.refreshToken}; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.refreshToken,\n    )}`,\n    [lastUserKey]: `${tokenUserName}; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.idToken,\n    )}`,\n    [scopeKey]: `${scopesString}; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.accessToken,\n    )}`,\n    [userDataKey]: `${encodeURIComponent(userData)}; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.idToken,\n    )}`,\n    \"amplify-signin-with-hostedUI\": `true; ${withCookieDomain(\n      param.domainName,\n      param.cookieSettings.accessToken,\n    )}`,\n  }\n\n  if (param.event === \"signOut\") {\n    // Expire all cookies\n    Object.keys(cookies).forEach(\n      (key) => (cookies[key] = expireCookie(cookies[key])),\n    )\n  } else if (param.event === \"refreshFailed\") {\n    // Expire refresh token (so the browser will not send it in vain again)\n    cookies[refreshTokenKey] = expireCookie(cookies[refreshTokenKey])\n  }\n\n  // Nonce, nonceHmac and pkce are only used during login phase.\n  ;[\n    \"spa-auth-edge-nonce\",\n    \"spa-auth-edge-nonce-hmac\",\n    \"spa-auth-edge-pkce\",\n  ].forEach((key) => {\n    cookies[key] = expireCookie(cookies[key])\n  })\n\n  return Object.entries(cookies).map(([k, v]) => `${k}=${v}`)\n}\n\nfunction expireCookie(cookie = \"\") {\n  const cookieParts = cookie\n    .split(\";\")\n    .map((part) => part.trim())\n    .filter((part) => !part.toLowerCase().startsWith(\"max-age\"))\n    .filter((part) => !part.toLowerCase().startsWith(\"expires\"))\n  const expires = `Expires=${new Date(0).toUTCString()}`\n  // First part is the cookie value, which we'll clear.\n  return [\"\", ...cookieParts.slice(1), expires].join(\"; \")\n}\n"]}
|
package/lib/handlers/util/jwt.js
CHANGED
|
@@ -1,12 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.validate = validate;
|
|
7
|
-
exports.decodeIdToken = decodeIdToken;
|
|
8
|
-
const jsonwebtoken_1 = require("jsonwebtoken");
|
|
9
|
-
const jwks_rsa_1 = __importDefault(require("jwks-rsa"));
|
|
1
|
+
import jwt from "jsonwebtoken";
|
|
2
|
+
import jwksClient from "jwks-rsa";
|
|
10
3
|
// jwks client is cached at this scope so it can be reused
|
|
11
4
|
// across Lambda invocations.
|
|
12
5
|
let jwksRsa;
|
|
@@ -19,13 +12,13 @@ function isRsaSigningKey(key) {
|
|
|
19
12
|
*/
|
|
20
13
|
async function getSigningKey(jwksUri, kid) {
|
|
21
14
|
if (!jwksRsa) {
|
|
22
|
-
jwksRsa = (
|
|
15
|
+
jwksRsa = jwksClient({ cache: true, rateLimit: true, jwksUri });
|
|
23
16
|
}
|
|
24
17
|
const jwk = await jwksRsa.getSigningKey(kid);
|
|
25
18
|
return isRsaSigningKey(jwk) ? jwk.rsaPublicKey : jwk.publicKey;
|
|
26
19
|
}
|
|
27
|
-
async function validate(jwtToken, jwksUri, issuer, audience) {
|
|
28
|
-
const decodedToken =
|
|
20
|
+
export async function validate(jwtToken, jwksUri, issuer, audience) {
|
|
21
|
+
const decodedToken = jwt.decode(jwtToken, { complete: true });
|
|
29
22
|
if (!decodedToken || typeof decodedToken === "string") {
|
|
30
23
|
return {
|
|
31
24
|
validationError: new Error("Cannot parse JWT token"),
|
|
@@ -46,13 +39,13 @@ async function validate(jwtToken, jwksUri, issuer, audience) {
|
|
|
46
39
|
issuer,
|
|
47
40
|
ignoreExpiration: false,
|
|
48
41
|
};
|
|
49
|
-
return new Promise((resolve) =>
|
|
42
|
+
return new Promise((resolve) => jwt.verify(jwtToken, jwk, verificationOptions, (err) => err ? resolve({ validationError: err }) : resolve(undefined)));
|
|
50
43
|
}
|
|
51
44
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
52
|
-
function decodeIdToken(jwt) {
|
|
45
|
+
export function decodeIdToken(jwt) {
|
|
53
46
|
const tokenBody = jwt.split(".")[1];
|
|
54
47
|
const decodableTokenBody = tokenBody.replace(/-/g, "+").replace(/_/g, "/");
|
|
55
48
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
|
|
56
49
|
return JSON.parse(Buffer.from(decodableTokenBody, "base64").toString());
|
|
57
50
|
}
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiand0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2hhbmRsZXJzL3V0aWwvand0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sR0FBRyxNQUFNLGNBQWMsQ0FBQTtBQUM5QixPQUFPLFVBQXlDLE1BQU0sVUFBVSxDQUFBO0FBZ0JoRSwwREFBMEQ7QUFDMUQsNkJBQTZCO0FBQzdCLElBQUksT0FBOEIsQ0FBQTtBQUVsQyxTQUFTLGVBQWUsQ0FBQyxHQUFlO0lBQ3RDLE9BQU8sY0FBYyxJQUFJLEdBQUcsQ0FBQTtBQUM5QixDQUFDO0FBRUQ7OztHQUdHO0FBQ0gsS0FBSyxVQUFVLGFBQWEsQ0FDMUIsT0FBZSxFQUNmLEdBQVc7SUFFWCxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDYixPQUFPLEdBQUcsVUFBVSxDQUFDLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUE7SUFDakUsQ0FBQztJQUNELE1BQU0sR0FBRyxHQUFHLE1BQU0sT0FBTyxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsQ0FBQTtJQUM1QyxPQUFPLGVBQWUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQTtBQUNoRSxDQUFDO0FBRUQsTUFBTSxDQUFDLEtBQUssVUFBVSxRQUFRLENBQzVCLFFBQWdCLEVBQ2hCLE9BQWUsRUFDZixNQUFjLEVBQ2QsUUFBZ0I7SUFFaEIsTUFBTSxZQUFZLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQTtJQUM3RCxJQUFJLENBQUMsWUFBWSxJQUFJLE9BQU8sWUFBWSxLQUFLLFFBQVEsRUFBRSxDQUFDO1FBQ3RELE9BQU87WUFDTCxlQUFlLEVBQUUsSUFBSSxLQUFLLENBQUMsd0JBQXdCLENBQUM7U0FDckQsQ0FBQTtJQUNILENBQUM7SUFFRCwrREFBK0Q7SUFDL0QsOEJBQThCO0lBQzlCLHNFQUFzRTtJQUN0RSxNQUFNLEdBQUcsR0FBRyxZQUFZLENBQUMsUUFBUSxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUE7SUFDekMsTUFBTSxHQUFHLEdBQUcsTUFBTSxhQUFhLENBQUMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxDQUFBO0lBQzdDLElBQUksR0FBRyxZQUFZLEtBQUssRUFBRSxDQUFDO1FBQ3pCLE9BQU8sRUFBRSxlQUFlLEVBQUUsR0FBRyxFQUFFLENBQUE7SUFDakMsQ0FBQztJQUVELGtCQUFrQjtJQUNsQixnRUFBZ0U7SUFDaEUsTUFBTSxtQkFBbUIsR0FBRztRQUMxQixRQUFRO1FBQ1IsTUFBTTtRQUNOLGdCQUFnQixFQUFFLEtBQUs7S0FDeEIsQ0FBQTtJQUVELE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUM3QixHQUFHLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRSxHQUFHLEVBQUUsbUJBQW1CLEVBQUUsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUNyRCxHQUFHLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxFQUFFLGVBQWUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQzdELENBQ0YsQ0FBQTtBQUNILENBQUM7QUFFRCw4REFBOEQ7QUFDOUQsTUFBTSxVQUFVLGFBQWEsQ0FBQyxHQUFXO0lBQ3ZDLE1BQU0sU0FBUyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDbkMsTUFBTSxrQkFBa0IsR0FBRyxTQUFTLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLEdBQUcsQ0FBQyxDQUFBO0lBQzFFLCtEQUErRDtJQUMvRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxRQUFRLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFBO0FBQ3pFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgand0IGZyb20gXCJqc29ud2VidG9rZW5cIlxuaW1wb3J0IGp3a3NDbGllbnQsIHsgUnNhU2lnbmluZ0tleSwgU2lnbmluZ0tleSB9IGZyb20gXCJqd2tzLXJzYVwiXG5cbmV4cG9ydCBpbnRlcmZhY2UgSWRUb2tlblBheWxvYWQge1xuICBzdWI6IHN0cmluZ1xuICBcImNvZ25pdG86Z3JvdXBzXCI/OiBzdHJpbmdbXVxuICBcImNvZ25pdG86dXNlcm5hbWVcIj86IHN0cmluZ1xuICBnaXZlbl9uYW1lPzogc3RyaW5nXG4gIGF1ZDogc3RyaW5nXG4gIHRva2VuX3VzZTogXCJpZFwiXG4gIGF1dGhfdGltZTogbnVtYmVyXG4gIG5hbWU/OiBzdHJpbmdcbiAgZXhwOiBudW1iZXJcbiAgaWF0OiBudW1iZXJcbiAgZW1haWw/OiBzdHJpbmdcbn1cblxuLy8gandrcyBjbGllbnQgaXMgY2FjaGVkIGF0IHRoaXMgc2NvcGUgc28gaXQgY2FuIGJlIHJldXNlZFxuLy8gYWNyb3NzIExhbWJkYSBpbnZvY2F0aW9ucy5cbmxldCBqd2tzUnNhOiBqd2tzQ2xpZW50Lkp3a3NDbGllbnRcblxuZnVuY3Rpb24gaXNSc2FTaWduaW5nS2V5KGtleTogU2lnbmluZ0tleSk6IGtleSBpcyBSc2FTaWduaW5nS2V5IHtcbiAgcmV0dXJuIFwicnNhUHVibGljS2V5XCIgaW4ga2V5XG59XG5cbi8qKlxuICogUmV0cmlldmVzIHRoZSBwdWJsaWMga2V5IHRoYXQgY29ycmVzcG9uZHMgdG8gdGhlIHByaXZhdGUga2V5IHdpdGhcbiAqIHdoaWNoIHRoZSB0b2tlbiB3YXMgc2lnbmVkLlxuICovXG5hc3luYyBmdW5jdGlvbiBnZXRTaWduaW5nS2V5KFxuICBqd2tzVXJpOiBzdHJpbmcsXG4gIGtpZDogc3RyaW5nLFxuKTogUHJvbWlzZTxzdHJpbmcgfCBFcnJvcj4ge1xuICBpZiAoIWp3a3NSc2EpIHtcbiAgICBqd2tzUnNhID0gandrc0NsaWVudCh7IGNhY2hlOiB0cnVlLCByYXRlTGltaXQ6IHRydWUsIGp3a3NVcmkgfSlcbiAgfVxuICBjb25zdCBqd2sgPSBhd2FpdCBqd2tzUnNhLmdldFNpZ25pbmdLZXkoa2lkKVxuICByZXR1cm4gaXNSc2FTaWduaW5nS2V5KGp3aykgPyBqd2sucnNhUHVibGljS2V5IDogandrLnB1YmxpY0tleVxufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gdmFsaWRhdGUoXG4gIGp3dFRva2VuOiBzdHJpbmcsXG4gIGp3a3NVcmk6IHN0cmluZyxcbiAgaXNzdWVyOiBzdHJpbmcsXG4gIGF1ZGllbmNlOiBzdHJpbmcsXG4pOiBQcm9taXNlPHsgdmFsaWRhdGlvbkVycm9yOiBFcnJvciB9IHwgdW5kZWZpbmVkPiB7XG4gIGNvbnN0IGRlY29kZWRUb2tlbiA9IGp3dC5kZWNvZGUoand0VG9rZW4sIHsgY29tcGxldGU6IHRydWUgfSlcbiAgaWYgKCFkZWNvZGVkVG9rZW4gfHwgdHlwZW9mIGRlY29kZWRUb2tlbiA9PT0gXCJzdHJpbmdcIikge1xuICAgIHJldHVybiB7XG4gICAgICB2YWxpZGF0aW9uRXJyb3I6IG5ldyBFcnJvcihcIkNhbm5vdCBwYXJzZSBKV1QgdG9rZW5cIiksXG4gICAgfVxuICB9XG5cbiAgLy8gVGhlIEpXVCBjb250YWlucyBhIFwia2lkXCIgY2xhaW0sIGtleSBpZCwgdGhhdCB0ZWxscyB3aGljaCBrZXlcbiAgLy8gd2FzIHVzZWQgdG8gc2lnbiB0aGUgdG9rZW4uXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW5zYWZlLW1lbWJlci1hY2Nlc3NcbiAgY29uc3Qga2lkID0gZGVjb2RlZFRva2VuW1wiaGVhZGVyXCJdW1wia2lkXCJdXG4gIGNvbnN0IGp3ayA9IGF3YWl0IGdldFNpZ25pbmdLZXkoandrc1VyaSwga2lkKVxuICBpZiAoandrIGluc3RhbmNlb2YgRXJyb3IpIHtcbiAgICByZXR1cm4geyB2YWxpZGF0aW9uRXJyb3I6IGp3ayB9XG4gIH1cblxuICAvLyBWZXJpZnkgdGhlIEpXVC5cbiAgLy8gVGhpcyBlaXRoZXIgcmVqZWN0cyAoSldUIG5vdCB2YWxpZCksIG9yIHJlc29sdmVzIChKV1QgdmFsaWQpLlxuICBjb25zdCB2ZXJpZmljYXRpb25PcHRpb25zID0ge1xuICAgIGF1ZGllbmNlLFxuICAgIGlzc3VlcixcbiAgICBpZ25vcmVFeHBpcmF0aW9uOiBmYWxzZSxcbiAgfVxuXG4gIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSkgPT5cbiAgICBqd3QudmVyaWZ5KGp3dFRva2VuLCBqd2ssIHZlcmlmaWNhdGlvbk9wdGlvbnMsIChlcnIpID0+XG4gICAgICBlcnIgPyByZXNvbHZlKHsgdmFsaWRhdGlvbkVycm9yOiBlcnIgfSkgOiByZXNvbHZlKHVuZGVmaW5lZCksXG4gICAgKSxcbiAgKVxufVxuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuZXhwb3J0IGZ1bmN0aW9uIGRlY29kZUlkVG9rZW4oand0OiBzdHJpbmcpOiBJZFRva2VuUGF5bG9hZCB7XG4gIGNvbnN0IHRva2VuQm9keSA9IGp3dC5zcGxpdChcIi5cIilbMV1cbiAgY29uc3QgZGVjb2RhYmxlVG9rZW5Cb2R5ID0gdG9rZW5Cb2R5LnJlcGxhY2UoLy0vZywgXCIrXCIpLnJlcGxhY2UoL18vZywgXCIvXCIpXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW5zYWZlLXJldHVyblxuICByZXR1cm4gSlNPTi5wYXJzZShCdWZmZXIuZnJvbShkZWNvZGFibGVUb2tlbkJvZHksIFwiYmFzZTY0XCIpLnRvU3RyaW5nKCkpXG59XG4iXX0=
|
|
@@ -1,19 +1,17 @@
|
|
|
1
|
-
"use strict";
|
|
2
1
|
/* eslint-disable @typescript-eslint/no-unsafe-argument */
|
|
3
2
|
/* eslint-disable @typescript-eslint/no-unsafe-return */
|
|
4
3
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
5
4
|
/* eslint-disable @typescript-eslint/explicit-module-boundary-types */
|
|
6
|
-
|
|
7
|
-
exports.Logger = exports.LogLevel = void 0;
|
|
8
|
-
var LogLevel;
|
|
5
|
+
export var LogLevel;
|
|
9
6
|
(function (LogLevel) {
|
|
10
7
|
LogLevel[LogLevel["none"] = 0] = "none";
|
|
11
8
|
LogLevel[LogLevel["error"] = 10] = "error";
|
|
12
9
|
LogLevel[LogLevel["warn"] = 20] = "warn";
|
|
13
10
|
LogLevel[LogLevel["info"] = 30] = "info";
|
|
14
11
|
LogLevel[LogLevel["debug"] = 40] = "debug";
|
|
15
|
-
})(LogLevel || (
|
|
16
|
-
class Logger {
|
|
12
|
+
})(LogLevel || (LogLevel = {}));
|
|
13
|
+
export class Logger {
|
|
14
|
+
logLevel;
|
|
17
15
|
constructor(logLevel) {
|
|
18
16
|
this.logLevel = logLevel;
|
|
19
17
|
}
|
|
@@ -23,7 +21,7 @@ class Logger {
|
|
|
23
21
|
try {
|
|
24
22
|
return JSON.stringify(arg);
|
|
25
23
|
}
|
|
26
|
-
catch
|
|
24
|
+
catch {
|
|
27
25
|
return arg;
|
|
28
26
|
}
|
|
29
27
|
}
|
|
@@ -51,5 +49,4 @@ class Logger {
|
|
|
51
49
|
}
|
|
52
50
|
}
|
|
53
51
|
}
|
|
54
|
-
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2hhbmRsZXJzL3V0aWwvbG9nZ2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSwwREFBMEQ7QUFDMUQsd0RBQXdEO0FBQ3hELHVEQUF1RDtBQUN2RCxzRUFBc0U7OztBQUV0RSxJQUFZLFFBTVg7QUFORCxXQUFZLFFBQVE7SUFDbEIsdUNBQVUsQ0FBQTtJQUNWLDBDQUFZLENBQUE7SUFDWix3Q0FBVyxDQUFBO0lBQ1gsd0NBQVcsQ0FBQTtJQUNYLDBDQUFZLENBQUE7QUFDZCxDQUFDLEVBTlcsUUFBUSx3QkFBUixRQUFRLFFBTW5CO0FBRUQsTUFBYSxNQUFNO0lBQ2pCLFlBQW9CLFFBQWtCO1FBQWxCLGFBQVEsR0FBUixRQUFRLENBQVU7SUFBRyxDQUFDO0lBRWxDLE9BQU8sQ0FBQyxJQUFXO1FBQ3pCLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQVEsRUFBTyxFQUFFO1lBQ2hDLElBQUksT0FBTyxHQUFHLEtBQUssUUFBUSxFQUFFLENBQUM7Z0JBQzVCLElBQUksQ0FBQztvQkFDSCxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUE7Z0JBQzVCLENBQUM7Z0JBQUMsV0FBTSxDQUFDO29CQUNQLE9BQU8sR0FBRyxDQUFBO2dCQUNaLENBQUM7WUFDSCxDQUFDO1lBQ0QsT0FBTyxHQUFHLENBQUE7UUFDWixDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7SUFDTSxJQUFJLENBQUMsR0FBRyxJQUFTO1FBQ3RCLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDbkMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQTtRQUNwQyxDQUFDO0lBQ0gsQ0FBQztJQUNNLElBQUksQ0FBQyxHQUFHLElBQVM7UUFDdEIsSUFBSSxJQUFJLENBQUMsUUFBUSxJQUFJLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNuQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFBO1FBQ3JDLENBQUM7SUFDSCxDQUFDO0lBQ00sS0FBSyxDQUFDLEdBQUcsSUFBUztRQUN2QixJQUFJLElBQUksQ0FBQyxRQUFRLElBQUksUUFBUSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ3BDLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUE7UUFDdEMsQ0FBQztJQUNILENBQUM7SUFDTSxLQUFLLENBQUMsR0FBRyxJQUFTO1FBQ3ZCLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxRQUFRLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDcEMsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQTtRQUN0QyxDQUFDO0lBQ0gsQ0FBQztDQUNGO0FBbkNELHdCQW1DQyIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnNhZmUtYXJndW1lbnQgKi9cbi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnNhZmUtcmV0dXJuICovXG4vKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55ICovXG4vKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5cbmV4cG9ydCBlbnVtIExvZ0xldmVsIHtcbiAgXCJub25lXCIgPSAwLFxuICBcImVycm9yXCIgPSAxMCxcbiAgXCJ3YXJuXCIgPSAyMCxcbiAgXCJpbmZvXCIgPSAzMCxcbiAgXCJkZWJ1Z1wiID0gNDAsXG59XG5cbmV4cG9ydCBjbGFzcyBMb2dnZXIge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGxvZ0xldmVsOiBMb2dMZXZlbCkge31cblxuICBwcml2YXRlIGpzb25pZnkoYXJnczogYW55W10pIHtcbiAgICByZXR1cm4gYXJncy5tYXAoKGFyZzogYW55KTogYW55ID0+IHtcbiAgICAgIGlmICh0eXBlb2YgYXJnID09PSBcIm9iamVjdFwiKSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgcmV0dXJuIEpTT04uc3RyaW5naWZ5KGFyZylcbiAgICAgICAgfSBjYXRjaCB7XG4gICAgICAgICAgcmV0dXJuIGFyZ1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICByZXR1cm4gYXJnXG4gICAgfSlcbiAgfVxuICBwdWJsaWMgaW5mbyguLi5hcmdzOiBhbnkpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5sb2dMZXZlbCA+PSBMb2dMZXZlbC5pbmZvKSB7XG4gICAgICBjb25zb2xlLmxvZyguLi50aGlzLmpzb25pZnkoYXJncykpXG4gICAgfVxuICB9XG4gIHB1YmxpYyB3YXJuKC4uLmFyZ3M6IGFueSk6IHZvaWQge1xuICAgIGlmICh0aGlzLmxvZ0xldmVsID49IExvZ0xldmVsLndhcm4pIHtcbiAgICAgIGNvbnNvbGUud2FybiguLi50aGlzLmpzb25pZnkoYXJncykpXG4gICAgfVxuICB9XG4gIHB1YmxpYyBlcnJvciguLi5hcmdzOiBhbnkpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5sb2dMZXZlbCA+PSBMb2dMZXZlbC5lcnJvcikge1xuICAgICAgY29uc29sZS5lcnJvciguLi50aGlzLmpzb25pZnkoYXJncykpXG4gICAgfVxuICB9XG4gIHB1YmxpYyBkZWJ1ZyguLi5hcmdzOiBhbnkpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5sb2dMZXZlbCA+PSBMb2dMZXZlbC5kZWJ1Zykge1xuICAgICAgY29uc29sZS50cmFjZSguLi50aGlzLmpzb25pZnkoYXJncykpXG4gICAgfVxuICB9XG59XG4iXX0=
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2hhbmRsZXJzL3V0aWwvbG9nZ2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDBEQUEwRDtBQUMxRCx3REFBd0Q7QUFDeEQsdURBQXVEO0FBQ3ZELHNFQUFzRTtBQUV0RSxNQUFNLENBQU4sSUFBWSxRQU1YO0FBTkQsV0FBWSxRQUFRO0lBQ2xCLHVDQUFVLENBQUE7SUFDViwwQ0FBWSxDQUFBO0lBQ1osd0NBQVcsQ0FBQTtJQUNYLHdDQUFXLENBQUE7SUFDWCwwQ0FBWSxDQUFBO0FBQ2QsQ0FBQyxFQU5XLFFBQVEsS0FBUixRQUFRLFFBTW5CO0FBRUQsTUFBTSxPQUFPLE1BQU07SUFDRztJQUFwQixZQUFvQixRQUFrQjtRQUFsQixhQUFRLEdBQVIsUUFBUSxDQUFVO0lBQUcsQ0FBQztJQUVsQyxPQUFPLENBQUMsSUFBVztRQUN6QixPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFRLEVBQU8sRUFBRTtZQUNoQyxJQUFJLE9BQU8sR0FBRyxLQUFLLFFBQVEsRUFBRSxDQUFDO2dCQUM1QixJQUFJLENBQUM7b0JBQ0gsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxDQUFBO2dCQUM1QixDQUFDO2dCQUFDLE1BQU0sQ0FBQztvQkFDUCxPQUFPLEdBQUcsQ0FBQTtnQkFDWixDQUFDO1lBQ0gsQ0FBQztZQUNELE9BQU8sR0FBRyxDQUFBO1FBQ1osQ0FBQyxDQUFDLENBQUE7SUFDSixDQUFDO0lBQ00sSUFBSSxDQUFDLEdBQUcsSUFBUztRQUN0QixJQUFJLElBQUksQ0FBQyxRQUFRLElBQUksUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ25DLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUE7UUFDcEMsQ0FBQztJQUNILENBQUM7SUFDTSxJQUFJLENBQUMsR0FBRyxJQUFTO1FBQ3RCLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDbkMsT0FBTyxDQUFDLElBQUksQ0FBQyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQTtRQUNyQyxDQUFDO0lBQ0gsQ0FBQztJQUNNLEtBQUssQ0FBQyxHQUFHLElBQVM7UUFDdkIsSUFBSSxJQUFJLENBQUMsUUFBUSxJQUFJLFFBQVEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNwQyxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFBO1FBQ3RDLENBQUM7SUFDSCxDQUFDO0lBQ00sS0FBSyxDQUFDLEdBQUcsSUFBUztRQUN2QixJQUFJLElBQUksQ0FBQyxRQUFRLElBQUksUUFBUSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ3BDLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUE7UUFDdEMsQ0FBQztJQUNILENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnNhZmUtYXJndW1lbnQgKi9cbi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnNhZmUtcmV0dXJuICovXG4vKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55ICovXG4vKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzICovXG5cbmV4cG9ydCBlbnVtIExvZ0xldmVsIHtcbiAgXCJub25lXCIgPSAwLFxuICBcImVycm9yXCIgPSAxMCxcbiAgXCJ3YXJuXCIgPSAyMCxcbiAgXCJpbmZvXCIgPSAzMCxcbiAgXCJkZWJ1Z1wiID0gNDAsXG59XG5cbmV4cG9ydCBjbGFzcyBMb2dnZXIge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGxvZ0xldmVsOiBMb2dMZXZlbCkge31cblxuICBwcml2YXRlIGpzb25pZnkoYXJnczogYW55W10pIHtcbiAgICByZXR1cm4gYXJncy5tYXAoKGFyZzogYW55KTogYW55ID0+IHtcbiAgICAgIGlmICh0eXBlb2YgYXJnID09PSBcIm9iamVjdFwiKSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgcmV0dXJuIEpTT04uc3RyaW5naWZ5KGFyZylcbiAgICAgICAgfSBjYXRjaCB7XG4gICAgICAgICAgcmV0dXJuIGFyZ1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICByZXR1cm4gYXJnXG4gICAgfSlcbiAgfVxuICBwdWJsaWMgaW5mbyguLi5hcmdzOiBhbnkpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5sb2dMZXZlbCA+PSBMb2dMZXZlbC5pbmZvKSB7XG4gICAgICBjb25zb2xlLmxvZyguLi50aGlzLmpzb25pZnkoYXJncykpXG4gICAgfVxuICB9XG4gIHB1YmxpYyB3YXJuKC4uLmFyZ3M6IGFueSk6IHZvaWQge1xuICAgIGlmICh0aGlzLmxvZ0xldmVsID49IExvZ0xldmVsLndhcm4pIHtcbiAgICAgIGNvbnNvbGUud2FybiguLi50aGlzLmpzb25pZnkoYXJncykpXG4gICAgfVxuICB9XG4gIHB1YmxpYyBlcnJvciguLi5hcmdzOiBhbnkpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5sb2dMZXZlbCA+PSBMb2dMZXZlbC5lcnJvcikge1xuICAgICAgY29uc29sZS5lcnJvciguLi50aGlzLmpzb25pZnkoYXJncykpXG4gICAgfVxuICB9XG4gIHB1YmxpYyBkZWJ1ZyguLi5hcmdzOiBhbnkpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5sb2dMZXZlbCA+PSBMb2dMZXZlbC5kZWJ1Zykge1xuICAgICAgY29uc29sZS50cmFjZSguLi50aGlzLmpzb25pZnkoYXJncykpXG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -1,11 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
exports.checkNonceAge = checkNonceAge;
|
|
4
|
-
exports.validateNonce = validateNonce;
|
|
5
|
-
exports.generateNonce = generateNonce;
|
|
6
|
-
exports.createNonceHmac = createNonceHmac;
|
|
7
|
-
const crypto_1 = require("crypto");
|
|
8
|
-
function checkNonceAge(nonce, maxAge) {
|
|
1
|
+
import { createHmac, randomBytes } from "crypto";
|
|
2
|
+
export function checkNonceAge(nonce, maxAge) {
|
|
9
3
|
// Nonce should not be too old.
|
|
10
4
|
const timestamp = parseInt(nonce.slice(0, nonce.indexOf("T")));
|
|
11
5
|
if (isNaN(timestamp)) {
|
|
@@ -19,7 +13,7 @@ function checkNonceAge(nonce, maxAge) {
|
|
|
19
13
|
};
|
|
20
14
|
}
|
|
21
15
|
}
|
|
22
|
-
function validateNonce(nonce, providedHmac, config) {
|
|
16
|
+
export function validateNonce(nonce, providedHmac, config) {
|
|
23
17
|
const res1 = checkNonceAge(nonce, config.nonceMaxAge);
|
|
24
18
|
if (res1) {
|
|
25
19
|
return res1;
|
|
@@ -31,16 +25,16 @@ function validateNonce(nonce, providedHmac, config) {
|
|
|
31
25
|
};
|
|
32
26
|
}
|
|
33
27
|
}
|
|
34
|
-
function generateNonce() {
|
|
35
|
-
const randomString =
|
|
28
|
+
export function generateNonce() {
|
|
29
|
+
const randomString = randomBytes(16).toString("hex");
|
|
36
30
|
return `${timestampInSeconds()}T${randomString}`;
|
|
37
31
|
}
|
|
38
|
-
function createNonceHmac(nonce, config) {
|
|
39
|
-
return
|
|
32
|
+
export function createNonceHmac(nonce, config) {
|
|
33
|
+
return createHmac("sha256", config.nonceSigningSecret)
|
|
40
34
|
.update(nonce)
|
|
41
35
|
.digest("hex");
|
|
42
36
|
}
|
|
43
37
|
function timestampInSeconds() {
|
|
44
38
|
return (Date.now() / 1000) | 0;
|
|
45
39
|
}
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9uY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvaGFuZGxlcnMvdXRpbC9ub25jZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxNQUFNLFFBQVEsQ0FBQTtBQUdoRCxNQUFNLFVBQVUsYUFBYSxDQUMzQixLQUFhLEVBQ2IsTUFBYztJQUVkLCtCQUErQjtJQUMvQixNQUFNLFNBQVMsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDOUQsSUFBSSxLQUFLLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQztRQUNyQixPQUFPO1lBQ0wsV0FBVyxFQUFFLGVBQWU7U0FDN0IsQ0FBQTtJQUNILENBQUM7SUFFRCxJQUFJLGtCQUFrQixFQUFFLEdBQUcsU0FBUyxHQUFHLE1BQU0sRUFBRSxDQUFDO1FBQzlDLE9BQU87WUFDTCxXQUFXLEVBQUUsbUNBQW1DLElBQUksSUFBSSxDQUN0RCxTQUFTLEdBQUcsSUFBSSxDQUNqQixDQUFDLFdBQVcsRUFBRSxHQUFHO1NBQ25CLENBQUE7SUFDSCxDQUFDO0FBQ0gsQ0FBQztBQUVELE1BQU0sVUFBVSxhQUFhLENBQzNCLEtBQWEsRUFDYixZQUFvQixFQUNwQixNQUFjO0lBRWQsTUFBTSxJQUFJLEdBQUcsYUFBYSxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUE7SUFDckQsSUFBSSxJQUFJLEVBQUUsQ0FBQztRQUNULE9BQU8sSUFBSSxDQUFBO0lBQ2IsQ0FBQztJQUVELE1BQU0sY0FBYyxHQUFHLGVBQWUsQ0FBQyxLQUFLLEVBQUUsTUFBTSxDQUFDLENBQUE7SUFDckQsSUFBSSxjQUFjLEtBQUssWUFBWSxFQUFFLENBQUM7UUFDcEMsT0FBTztZQUNMLFdBQVcsRUFBRSxzQ0FBc0MsY0FBYyxZQUFZLFlBQVksRUFBRTtTQUM1RixDQUFBO0lBQ0gsQ0FBQztBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsYUFBYTtJQUMzQixNQUFNLFlBQVksR0FBRyxXQUFXLENBQUMsRUFBRSxDQUFDLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFBO0lBQ3BELE9BQU8sR0FBRyxrQkFBa0IsRUFBRSxJQUFJLFlBQVksRUFBRSxDQUFBO0FBQ2xELENBQUM7QUFFRCxNQUFNLFVBQVUsZUFBZSxDQUFDLEtBQWEsRUFBRSxNQUFjO0lBQzNELE9BQU8sVUFBVSxDQUFDLFFBQVEsRUFBRSxNQUFNLENBQUMsa0JBQWtCLENBQUM7U0FDbkQsTUFBTSxDQUFDLEtBQUssQ0FBQztTQUNiLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQTtBQUNsQixDQUFDO0FBRUQsU0FBUyxrQkFBa0I7SUFDekIsT0FBTyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUE7QUFDaEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZUhtYWMsIHJhbmRvbUJ5dGVzIH0gZnJvbSBcImNyeXB0b1wiXG5pbXBvcnQgeyBDb25maWcgfSBmcm9tIFwiLi9jb25maWdcIlxuXG5leHBvcnQgZnVuY3Rpb24gY2hlY2tOb25jZUFnZShcbiAgbm9uY2U6IHN0cmluZyxcbiAgbWF4QWdlOiBudW1iZXIsXG4pOiB7IGNsaWVudEVycm9yOiBzdHJpbmcgfSB8IHVuZGVmaW5lZCB7XG4gIC8vIE5vbmNlIHNob3VsZCBub3QgYmUgdG9vIG9sZC5cbiAgY29uc3QgdGltZXN0YW1wID0gcGFyc2VJbnQobm9uY2Uuc2xpY2UoMCwgbm9uY2UuaW5kZXhPZihcIlRcIikpKVxuICBpZiAoaXNOYU4odGltZXN0YW1wKSkge1xuICAgIHJldHVybiB7XG4gICAgICBjbGllbnRFcnJvcjogXCJJbnZhbGlkIG5vbmNlXCIsXG4gICAgfVxuICB9XG5cbiAgaWYgKHRpbWVzdGFtcEluU2Vjb25kcygpIC0gdGltZXN0YW1wID4gbWF4QWdlKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGNsaWVudEVycm9yOiBgTm9uY2UgaXMgdG9vIG9sZCAobm9uY2UgaXMgZnJvbSAke25ldyBEYXRlKFxuICAgICAgICB0aW1lc3RhbXAgKiAxMDAwLFxuICAgICAgKS50b0lTT1N0cmluZygpfSlgLFxuICAgIH1cbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gdmFsaWRhdGVOb25jZShcbiAgbm9uY2U6IHN0cmluZyxcbiAgcHJvdmlkZWRIbWFjOiBzdHJpbmcsXG4gIGNvbmZpZzogQ29uZmlnLFxuKTogeyBjbGllbnRFcnJvcjogc3RyaW5nIH0gfCB1bmRlZmluZWQge1xuICBjb25zdCByZXMxID0gY2hlY2tOb25jZUFnZShub25jZSwgY29uZmlnLm5vbmNlTWF4QWdlKVxuICBpZiAocmVzMSkge1xuICAgIHJldHVybiByZXMxXG4gIH1cblxuICBjb25zdCBjYWxjdWxhdGVkSG1hYyA9IGNyZWF0ZU5vbmNlSG1hYyhub25jZSwgY29uZmlnKVxuICBpZiAoY2FsY3VsYXRlZEhtYWMgIT09IHByb3ZpZGVkSG1hYykge1xuICAgIHJldHVybiB7XG4gICAgICBjbGllbnRFcnJvcjogYE5vbmNlIHNpZ25hdHVyZSBtaXNtYXRjaCEgRXhwZWN0ZWQgJHtjYWxjdWxhdGVkSG1hY30gYnV0IGdvdCAke3Byb3ZpZGVkSG1hY31gLFxuICAgIH1cbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2VuZXJhdGVOb25jZSgpOiBzdHJpbmcge1xuICBjb25zdCByYW5kb21TdHJpbmcgPSByYW5kb21CeXRlcygxNikudG9TdHJpbmcoXCJoZXhcIilcbiAgcmV0dXJuIGAke3RpbWVzdGFtcEluU2Vjb25kcygpfVQke3JhbmRvbVN0cmluZ31gXG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVOb25jZUhtYWMobm9uY2U6IHN0cmluZywgY29uZmlnOiBDb25maWcpOiBzdHJpbmcge1xuICByZXR1cm4gY3JlYXRlSG1hYyhcInNoYTI1NlwiLCBjb25maWcubm9uY2VTaWduaW5nU2VjcmV0KVxuICAgIC51cGRhdGUobm9uY2UpXG4gICAgLmRpZ2VzdChcImhleFwiKVxufVxuXG5mdW5jdGlvbiB0aW1lc3RhbXBJblNlY29uZHMoKSB7XG4gIHJldHVybiAoRGF0ZS5ub3coKSAvIDEwMDApIHwgMFxufVxuIl19
|
package/lib/index.js
CHANGED
|
@@ -1,19 +1,3 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./cloudfront-auth"), exports);
|
|
18
|
-
__exportStar(require("./lambdas"), exports);
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLG9EQUFpQztBQUNqQyw0Q0FBeUIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9jbG91ZGZyb250LWF1dGhcIlxuZXhwb3J0ICogZnJvbSBcIi4vbGFtYmRhc1wiXG4iXX0=
|
|
1
|
+
export * from "./cloudfront-auth";
|
|
2
|
+
export * from "./lambdas";
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQTtBQUNqQyxjQUFjLFdBQVcsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2Nsb3VkZnJvbnQtYXV0aFwiXG5leHBvcnQgKiBmcm9tIFwiLi9sYW1iZGFzXCJcbiJdfQ==
|