@nsshunt/stsutils 1.16.30 → 1.16.32

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/stsutils.mjs CHANGED
@@ -22,8 +22,10 @@ var __privateSet = (obj, member, value, setter) => {
22
22
  setter ? setter.call(obj, value) : member.set(obj, value);
23
23
  return value;
24
24
  };
25
- var _options;
25
+ var _options, _debug;
26
26
  import Ajv from "ajv/dist/jtd.js";
27
+ import Transport from "/home/runner/work/stsutils/stsutils/node_modules/winston-transport/dist/index.js";
28
+ import debugModule from "/home/runner/work/stsutils/stsutils/node_modules/debug/src/browser.js";
27
29
  function GetErrorPayload(errorCode, details = null) {
28
30
  return {
29
31
  error: errorCode.code,
@@ -167,6 +169,21 @@ function compareParameterTypes(source1, source2, authParameterTypes) {
167
169
  }
168
170
  return errors;
169
171
  }
172
+ class STSWinstonTransport extends Transport {
173
+ constructor(opts) {
174
+ super(opts);
175
+ __privateAdd(this, _debug, void 0);
176
+ __privateSet(this, _debug, debugModule(`proc:${process.pid}:${opts.stsContext}`));
177
+ }
178
+ log(info, callback) {
179
+ if (info[Symbol.for("level")] == "debug") {
180
+ __privateGet(this, _debug).call(this, info.message);
181
+ }
182
+ this.emit("logged", info);
183
+ callback();
184
+ }
185
+ }
186
+ _debug = new WeakMap();
170
187
  var ModelDelimeter = /* @__PURE__ */ ((ModelDelimeter2) => {
171
188
  ModelDelimeter2["ROOT"] = "_";
172
189
  ModelDelimeter2["SEPERATOR"] = "|";
@@ -201,6 +218,7 @@ export {
201
218
  OIDCAddressClaim,
202
219
  OIDCStandardClaim,
203
220
  STSOptionsBase,
221
+ STSWinstonTransport,
204
222
  Sleep,
205
223
  Validate,
206
224
  compareParameterTypes
@@ -1 +1 @@
1
- {"version":3,"file":"stsutils.mjs","sources":["../src/errorhandling.ts","../src/validate.ts","../src/stsoptionsbase.ts","../src/sleep.ts","../src/oauth2terms.ts","../src/index.ts"],"sourcesContent":["export type errorCode = {\n\tcode: string\n\tdescription: string\n}\n\nexport type errorPayload = {\n\terror: string,\n\terror_description: string,\n\ttimestamp: number,\n\t//trace_id: \"255d1aef-8c98-452f-ac51-23d051240864\", //@@\n\t//correlation_id: \"fb3d2015-bc17-4bb9-bb85-30c5cf1aaaa7\", //@@\n\tdetails?: unknown\n}\n\nexport function GetErrorPayload(errorCode: errorCode, details: unknown = null): errorPayload {\n return {\n error: errorCode.code,\n error_description: errorCode.description,\n timestamp: Date.now(),\n //trace_id: \"255d1aef-8c98-452f-ac51-23d051240864\", //@@\n //correlation_id: \"fb3d2015-bc17-4bb9-bb85-30c5cf1aaaa7\", //@@\n details: details\n }\n}\n","import Ajv, { Schema } from 'ajv/dist/jtd.js'\nimport { AnyValidateFunction } from 'ajv/dist/core.js';\n\nimport { JSONObject } from './index'\n\nconst ajv = new Ajv();\n\nconst _Validate = (validator: AnyValidateFunction<unknown>, payload: JSONObject): unknown | null => {\n const valid: boolean = validator(payload) as boolean;\n if (!valid) {\n return validator.errors;\n } else {\n return null;\n }\n /*\n\t\tconsole.error(validator.errors);\n\t\tconsole.trace('Invalid Schema');\n\t\tconsole.log('Payload:-');\n\t\tconsole.log(JSON.stringify(payload));\n\t\tprocess.exit(1);\n\t\t*/\n};\n\nexport function AddSchema(name: string, schema: Schema): void {\n ajv.addSchema(schema, name);\n /*\n\treturn (payload) => {\n\t\tconst validator = ajv.getSchema(name)\n\t\t_Validate(validator, payload)\n\t}*/\n\n}\n\nexport function Validate(name: string, payload: JSONObject): unknown {\n const validator: AnyValidateFunction<unknown> | undefined = ajv.getSchema(name)\n if (validator) {\n return _Validate(validator, payload);\n }\n}\n","import { Validate } from './validate.js'\n\nimport { JSONObject } from './index'\n\nexport class STSOptionsBase\n{\n #options: JSONObject | null;\n\n constructor(options: JSONObject | null = null)\n {\n this.#options = options;\n\n if (options !== null) {\n if (typeof options.validator === 'undefined') {\n //console.log(JSON.stringify(options));\n //console.trace(\"Options Here ------------------------------------------------------------------------------------------\")\n } else {\n Validate(options.validator as string, options);\n }\n }\n }\n\n get options()\n {\n return this.#options;\n }\n}\n","export async function Sleep(milliseconds = 1000): Promise<void> { \n return new Promise(resolve => setTimeout(resolve, milliseconds))\n}\n \n// poolsleep is required to avoid JEST reporting unclosed handles during shutdown of all tests\nexport async function JestSleep(): Promise<void> {\n return Sleep(100);\n}\n","import { errorCode, errorPayload } from './errorhandling'\n\n// Ref: https://datatracker.ietf.org/doc/html/rfc6749#appendix-A\nexport enum OAuth2ParameterType {\n\tAUDIENCE = 'AUDIENCE', // STS Extension\n\tCLIENT_ID = 'client_id',\n\tCLIENT_SECRET = 'client_secret',\n\tRESPONSE_TYPE = 'response_type',\n\tSCOPE = 'scope',\n\tSTATE = 'state',\n\tREDIRECT_URI = 'redirect_uri',\n\tERROR = 'error',\n\tERROR_DESCRIPTION = 'error_description',\n\tERROR_CODES = 'error_codes', // STS Extension\n\tERROR_URI = 'error_uri',\n\tGRANT_TYPE = 'grant_type',\n\tCODE = 'code',\n\tACCESS_TOKEN = 'access_token',\n\tTOKEN_TYPE = 'token_type',\n\tEXPIRES_IN = 'expires_in',\n\tUSERNAME = 'username',\n\tPASSWORD = 'password',\n\tREFRESH_TOKEN = 'refresh_token',\n\tRESPONSE_MODE = 'response_mode', // STS Extension\n\tTIMESTAMP = 'timestamp', // STS Extension\n\tTRACE_ID = 'trace_id', // STS Extension\n\tCORRELATION_ID = 'correlation_id' // STS Extension\n}\n\n// OIDC Standard Claims\n// Ref: https://openid.net/specs/openid-connect-core-1_0.html#Claims\nexport enum OIDCStandardClaim {\n\tSUB = 'sub',\n\tNAME = 'name',\n\tGIVEN_NAME = 'given_name',\n\tFAMILY_NAME = 'family_name',\n\tMIDDLE_NAME = 'middle_name',\n\tNICKNAME = 'nickname',\n\tPREFERRED_USERNAME = 'preferred_username',\n\tPROFILE = 'profile',\n\tPICTURE = 'picture',\n\tWEBSITE = 'website',\n\tEMAIL = 'email',\n\tEMAIL_VERIFIED = 'email_verified',\n\tGENDER = 'gender',\n\tBIRTHDATE = 'birthdate',\n\tZONEINFO = 'zoneinfo',\n\tLOCALE = 'locale',\n\tPHONE_NUMBER = 'phone_number',\n\tPHONE_NUMBER_VERIFIED = 'phone_number_verified',\n\tADDRESS = 'address',\n\tCLIENT_SECRET = 'client_secret',\n\tNONCE = 'nonce' // STS Extension\n}\n\nexport enum OIDCAddressClaim {\n\tFORMATTED = 'formatted',\n\tSTREET_ADDRESS = 'street_address',\n\tLOCALITY = 'locality',\n\tREGION = 'region',\n\tCOUNTRY = 'country'\n}\n\nexport class OAuth2ParameterErrorType {\n static readonly NOT_EQUAL: errorCode = {\n code: 'STS_OAUTH2_ERR_0001',\n description: 'Parameter values not equal.'\n }\n static readonly NOT_PRESENT: errorCode = {\n code: 'STS_OAUTH2_ERR_0002',\n description: 'Parameter not provided.'\n }\n static readonly INVALID_FORMAT: errorCode = {\n code: 'STS_OAUTH2_ERR_0003',\n description: 'Parameter value format invalid.'\n }\n static readonly EXPIRED: errorCode = {\n code: 'STS_OAUTH2_ERR_0004',\n description: 'Parameter value expired.'\n }\n}\n\nexport function compareParameterTypes(source1: string[], source2: string[], authParameterTypes: OAuth2ParameterType[]): errorPayload[] {\n const errors: errorPayload[] = [ ];\n for (let i=0 ; i < authParameterTypes.length; i++) {\n const authParameterType = authParameterTypes[i];\n if (source1[i].localeCompare(source2[i]) !== 0) {\n const error: errorPayload = {\n error: OAuth2ParameterErrorType.NOT_EQUAL.code,\n error_description: OAuth2ParameterErrorType.NOT_EQUAL.description,\n timestamp: Date.now(),\n details: `${OAuth2ParameterErrorType.NOT_EQUAL.description}: Parameter: [${authParameterType}]`\n }\n errors.push(error);\n }\n }\n return errors;\n}\n","/*\nexport interface JSONObject {\n [x: string]: string | number | boolean | string[] | number[] | boolean[] | Array<JSONObject> | JSONObject | ((p: any) => any) | undefined\n}\n// This also works :-\n//interface JSONObject2 extends Record<string, string | number | string[] | Array<JSONObject2> | JSONObject2> {};\n*/\n\nexport interface JSONObject {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [x: string]: any | JSONObject | undefined\n}\n\nexport * from './errorhandling'\nexport * from './stsoptionsbase'\nexport * from './sleep'\nexport * from './validate'\nexport * from './oauth2terms'\n\nexport enum ModelDelimeter {\n\tROOT = '_',\n\tSEPERATOR = '|',\n\tCOMPONENT_SEPERATOR = '@',\n\tNID_SEPERATOR = '^' // This seperator splits the static and dynamic part of a context string (nid). Used for creating payload header for size optimisation.\n}\n\nexport const CheckValidChar = (checkParams: string[][]): void => {\n const invalidChars = [ \n ModelDelimeter.ROOT, \n ModelDelimeter.SEPERATOR, \n ModelDelimeter.COMPONENT_SEPERATOR, \n ModelDelimeter.NID_SEPERATOR\n ];\n\n checkParams.forEach(param => {\n invalidChars.forEach(char => {\n if (param[1].includes(char)) {\n throw new Error(`Invalid character inside [${param[0]}:${param[1]}], no [${char}] allowed`);\n }\n });\n });\n}\n\n/* Below is legacy code used as a global record container. No longer required.\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const $stsgd: Record<string, any> = { };\n\nexport function $stsgdf<T>(): Record<string, T> {\n return $stsgd as Record<string, T>;\n}\n*/\n"],"names":["OAuth2ParameterType","OIDCStandardClaim","OIDCAddressClaim","ModelDelimeter"],"mappings":"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"}
1
+ {"version":3,"file":"stsutils.mjs","sources":["../src/errorhandling.ts","../src/validate.ts","../src/stsoptionsbase.ts","../src/sleep.ts","../src/oauth2terms.ts","../src/winstonTransport.ts","../src/index.ts"],"sourcesContent":["export type errorCode = {\n\tcode: string\n\tdescription: string\n}\n\nexport type errorPayload = {\n\terror: string,\n\terror_description: string,\n\ttimestamp: number,\n\t//trace_id: \"255d1aef-8c98-452f-ac51-23d051240864\", //@@\n\t//correlation_id: \"fb3d2015-bc17-4bb9-bb85-30c5cf1aaaa7\", //@@\n\tdetails?: unknown\n}\n\nexport function GetErrorPayload(errorCode: errorCode, details: unknown = null): errorPayload {\n return {\n error: errorCode.code,\n error_description: errorCode.description,\n timestamp: Date.now(),\n //trace_id: \"255d1aef-8c98-452f-ac51-23d051240864\", //@@\n //correlation_id: \"fb3d2015-bc17-4bb9-bb85-30c5cf1aaaa7\", //@@\n details: details\n }\n}\n","import Ajv, { Schema } from 'ajv/dist/jtd.js'\nimport { AnyValidateFunction } from 'ajv/dist/core.js';\n\nimport { JSONObject } from './index'\n\nconst ajv = new Ajv();\n\nconst _Validate = (validator: AnyValidateFunction<unknown>, payload: JSONObject): unknown | null => {\n const valid: boolean = validator(payload) as boolean;\n if (!valid) {\n return validator.errors;\n } else {\n return null;\n }\n /*\n\t\tconsole.error(validator.errors);\n\t\tconsole.trace('Invalid Schema');\n\t\tconsole.log('Payload:-');\n\t\tconsole.log(JSON.stringify(payload));\n\t\tprocess.exit(1);\n\t\t*/\n};\n\nexport function AddSchema(name: string, schema: Schema): void {\n ajv.addSchema(schema, name);\n /*\n\treturn (payload) => {\n\t\tconst validator = ajv.getSchema(name)\n\t\t_Validate(validator, payload)\n\t}*/\n\n}\n\nexport function Validate(name: string, payload: JSONObject): unknown {\n const validator: AnyValidateFunction<unknown> | undefined = ajv.getSchema(name)\n if (validator) {\n return _Validate(validator, payload);\n }\n}\n","import { Validate } from './validate.js'\n\nimport { JSONObject } from './index'\n\nexport class STSOptionsBase\n{\n #options: JSONObject | null;\n\n constructor(options: JSONObject | null = null)\n {\n this.#options = options;\n\n if (options !== null) {\n if (typeof options.validator === 'undefined') {\n //console.log(JSON.stringify(options));\n //console.trace(\"Options Here ------------------------------------------------------------------------------------------\")\n } else {\n Validate(options.validator as string, options);\n }\n }\n }\n\n get options()\n {\n return this.#options;\n }\n}\n","export async function Sleep(milliseconds = 1000): Promise<void> { \n return new Promise(resolve => setTimeout(resolve, milliseconds))\n}\n \n// poolsleep is required to avoid JEST reporting unclosed handles during shutdown of all tests\nexport async function JestSleep(): Promise<void> {\n return Sleep(100);\n}\n","import { errorCode, errorPayload } from './errorhandling'\n\n// Ref: https://datatracker.ietf.org/doc/html/rfc6749#appendix-A\nexport enum OAuth2ParameterType {\n\tAUDIENCE = 'AUDIENCE', // STS Extension\n\tCLIENT_ID = 'client_id',\n\tCLIENT_SECRET = 'client_secret',\n\tRESPONSE_TYPE = 'response_type',\n\tSCOPE = 'scope',\n\tSTATE = 'state',\n\tREDIRECT_URI = 'redirect_uri',\n\tERROR = 'error',\n\tERROR_DESCRIPTION = 'error_description',\n\tERROR_CODES = 'error_codes', // STS Extension\n\tERROR_URI = 'error_uri',\n\tGRANT_TYPE = 'grant_type',\n\tCODE = 'code',\n\tACCESS_TOKEN = 'access_token',\n\tTOKEN_TYPE = 'token_type',\n\tEXPIRES_IN = 'expires_in',\n\tUSERNAME = 'username',\n\tPASSWORD = 'password',\n\tREFRESH_TOKEN = 'refresh_token',\n\tRESPONSE_MODE = 'response_mode', // STS Extension\n\tTIMESTAMP = 'timestamp', // STS Extension\n\tTRACE_ID = 'trace_id', // STS Extension\n\tCORRELATION_ID = 'correlation_id' // STS Extension\n}\n\n// OIDC Standard Claims\n// Ref: https://openid.net/specs/openid-connect-core-1_0.html#Claims\nexport enum OIDCStandardClaim {\n\tSUB = 'sub',\n\tNAME = 'name',\n\tGIVEN_NAME = 'given_name',\n\tFAMILY_NAME = 'family_name',\n\tMIDDLE_NAME = 'middle_name',\n\tNICKNAME = 'nickname',\n\tPREFERRED_USERNAME = 'preferred_username',\n\tPROFILE = 'profile',\n\tPICTURE = 'picture',\n\tWEBSITE = 'website',\n\tEMAIL = 'email',\n\tEMAIL_VERIFIED = 'email_verified',\n\tGENDER = 'gender',\n\tBIRTHDATE = 'birthdate',\n\tZONEINFO = 'zoneinfo',\n\tLOCALE = 'locale',\n\tPHONE_NUMBER = 'phone_number',\n\tPHONE_NUMBER_VERIFIED = 'phone_number_verified',\n\tADDRESS = 'address',\n\tCLIENT_SECRET = 'client_secret',\n\tNONCE = 'nonce' // STS Extension\n}\n\nexport enum OIDCAddressClaim {\n\tFORMATTED = 'formatted',\n\tSTREET_ADDRESS = 'street_address',\n\tLOCALITY = 'locality',\n\tREGION = 'region',\n\tCOUNTRY = 'country'\n}\n\nexport class OAuth2ParameterErrorType {\n static readonly NOT_EQUAL: errorCode = {\n code: 'STS_OAUTH2_ERR_0001',\n description: 'Parameter values not equal.'\n }\n static readonly NOT_PRESENT: errorCode = {\n code: 'STS_OAUTH2_ERR_0002',\n description: 'Parameter not provided.'\n }\n static readonly INVALID_FORMAT: errorCode = {\n code: 'STS_OAUTH2_ERR_0003',\n description: 'Parameter value format invalid.'\n }\n static readonly EXPIRED: errorCode = {\n code: 'STS_OAUTH2_ERR_0004',\n description: 'Parameter value expired.'\n }\n}\n\nexport function compareParameterTypes(source1: string[], source2: string[], authParameterTypes: OAuth2ParameterType[]): errorPayload[] {\n const errors: errorPayload[] = [ ];\n for (let i=0 ; i < authParameterTypes.length; i++) {\n const authParameterType = authParameterTypes[i];\n if (source1[i].localeCompare(source2[i]) !== 0) {\n const error: errorPayload = {\n error: OAuth2ParameterErrorType.NOT_EQUAL.code,\n error_description: OAuth2ParameterErrorType.NOT_EQUAL.description,\n timestamp: Date.now(),\n details: `${OAuth2ParameterErrorType.NOT_EQUAL.description}: Parameter: [${authParameterType}]`\n }\n errors.push(error);\n }\n }\n return errors;\n}\n","/* eslint @typescript-eslint/no-explicit-any: 0 */ // --> OFF\nimport Transport, { TransportStreamOptions } from 'winston-transport'\n\nimport debugModule from 'debug'\n\nexport interface ISTSWinstonTransport extends TransportStreamOptions {\n stsContext: string\n}\n\nexport class STSWinstonTransport extends Transport {\n #debug: debugModule.Debugger;\n\n constructor(opts: ISTSWinstonTransport) {\n super(opts);\n this.#debug = debugModule(`proc:${process.pid}:${opts.stsContext}`);\n }\n \n log(info: any, callback: any) {\n if (info[Symbol.for('level')] == 'debug') {\n this.#debug(info.message);\n }\n this.emit('logged', info);\n callback();\n }\n}\n","/*\nexport interface JSONObject {\n [x: string]: string | number | boolean | string[] | number[] | boolean[] | Array<JSONObject> | JSONObject | ((p: any) => any) | undefined\n}\n// This also works :-\n//interface JSONObject2 extends Record<string, string | number | string[] | Array<JSONObject2> | JSONObject2> {};\n*/\n\nexport interface JSONObject {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [x: string]: any | JSONObject | undefined\n}\n\nexport * from './errorhandling'\nexport * from './stsoptionsbase'\nexport * from './sleep'\nexport * from './validate'\nexport * from './oauth2terms'\nexport * from './winstonTransport'\n\nexport enum ModelDelimeter {\n\tROOT = '_',\n\tSEPERATOR = '|',\n\tCOMPONENT_SEPERATOR = '@',\n\tNID_SEPERATOR = '^' // This seperator splits the static and dynamic part of a context string (nid). Used for creating payload header for size optimisation.\n}\n\nexport const CheckValidChar = (checkParams: string[][]): void => {\n const invalidChars = [ \n ModelDelimeter.ROOT, \n ModelDelimeter.SEPERATOR, \n ModelDelimeter.COMPONENT_SEPERATOR, \n ModelDelimeter.NID_SEPERATOR\n ];\n\n checkParams.forEach(param => {\n invalidChars.forEach(char => {\n if (param[1].includes(char)) {\n throw new Error(`Invalid character inside [${param[0]}:${param[1]}], no [${char}] allowed`);\n }\n });\n });\n}\n\n/* Below is legacy code used as a global record container. No longer required.\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const $stsgd: Record<string, any> = { };\n\nexport function $stsgdf<T>(): Record<string, T> {\n return $stsgd as Record<string, T>;\n}\n*/\n"],"names":["OAuth2ParameterType","OIDCStandardClaim","OIDCAddressClaim","ModelDelimeter"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  (function(global, factory) {
2
- typeof exports === "object" && typeof module !== "undefined" ? factory(exports, require("ajv/dist/jtd.js")) : typeof define === "function" && define.amd ? define(["exports", "ajv/dist/jtd.js"], factory) : (global = typeof globalThis !== "undefined" ? globalThis : global || self, factory(global["@nsshunt/stsutils"] = {}, global.Ajv));
3
- })(this, function(exports2, Ajv) {
2
+ typeof exports === "object" && typeof module !== "undefined" ? factory(exports, require("ajv/dist/jtd.js"), require("/home/runner/work/stsutils/stsutils/node_modules/winston-transport/dist/index.js"), require("/home/runner/work/stsutils/stsutils/node_modules/debug/src/browser.js")) : typeof define === "function" && define.amd ? define(["exports", "ajv/dist/jtd.js", "/home/runner/work/stsutils/stsutils/node_modules/winston-transport/dist/index.js", "/home/runner/work/stsutils/stsutils/node_modules/debug/src/browser.js"], factory) : (global = typeof globalThis !== "undefined" ? globalThis : global || self, factory(global["@nsshunt/stsutils"] = {}, global.Ajv, global.Transport, global.debugModule));
3
+ })(this, function(exports2, Ajv, Transport, debugModule) {
4
4
  "use strict";var __defProp = Object.defineProperty;
5
5
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
6
6
  var __publicField = (obj, key, value) => {
@@ -26,7 +26,7 @@ var __privateSet = (obj, member, value, setter) => {
26
26
  return value;
27
27
  };
28
28
 
29
- var _options;
29
+ var _options, _debug;
30
30
  function GetErrorPayload(errorCode, details = null) {
31
31
  return {
32
32
  error: errorCode.code,
@@ -170,6 +170,21 @@ var __privateSet = (obj, member, value, setter) => {
170
170
  }
171
171
  return errors;
172
172
  }
173
+ class STSWinstonTransport extends Transport {
174
+ constructor(opts) {
175
+ super(opts);
176
+ __privateAdd(this, _debug, void 0);
177
+ __privateSet(this, _debug, debugModule(`proc:${process.pid}:${opts.stsContext}`));
178
+ }
179
+ log(info, callback) {
180
+ if (info[Symbol.for("level")] == "debug") {
181
+ __privateGet(this, _debug).call(this, info.message);
182
+ }
183
+ this.emit("logged", info);
184
+ callback();
185
+ }
186
+ }
187
+ _debug = new WeakMap();
173
188
  var ModelDelimeter = /* @__PURE__ */ ((ModelDelimeter2) => {
174
189
  ModelDelimeter2["ROOT"] = "_";
175
190
  ModelDelimeter2["SEPERATOR"] = "|";
@@ -203,6 +218,7 @@ var __privateSet = (obj, member, value, setter) => {
203
218
  exports2.OIDCAddressClaim = OIDCAddressClaim;
204
219
  exports2.OIDCStandardClaim = OIDCStandardClaim;
205
220
  exports2.STSOptionsBase = STSOptionsBase;
221
+ exports2.STSWinstonTransport = STSWinstonTransport;
206
222
  exports2.Sleep = Sleep;
207
223
  exports2.Validate = Validate;
208
224
  exports2.compareParameterTypes = compareParameterTypes;
@@ -1 +1 @@
1
- {"version":3,"file":"stsutils.umd.js","sources":["../src/errorhandling.ts","../src/validate.ts","../src/stsoptionsbase.ts","../src/sleep.ts","../src/oauth2terms.ts","../src/index.ts"],"sourcesContent":["export type errorCode = {\n\tcode: string\n\tdescription: string\n}\n\nexport type errorPayload = {\n\terror: string,\n\terror_description: string,\n\ttimestamp: number,\n\t//trace_id: \"255d1aef-8c98-452f-ac51-23d051240864\", //@@\n\t//correlation_id: \"fb3d2015-bc17-4bb9-bb85-30c5cf1aaaa7\", //@@\n\tdetails?: unknown\n}\n\nexport function GetErrorPayload(errorCode: errorCode, details: unknown = null): errorPayload {\n return {\n error: errorCode.code,\n error_description: errorCode.description,\n timestamp: Date.now(),\n //trace_id: \"255d1aef-8c98-452f-ac51-23d051240864\", //@@\n //correlation_id: \"fb3d2015-bc17-4bb9-bb85-30c5cf1aaaa7\", //@@\n details: details\n }\n}\n","import Ajv, { Schema } from 'ajv/dist/jtd.js'\nimport { AnyValidateFunction } from 'ajv/dist/core.js';\n\nimport { JSONObject } from './index'\n\nconst ajv = new Ajv();\n\nconst _Validate = (validator: AnyValidateFunction<unknown>, payload: JSONObject): unknown | null => {\n const valid: boolean = validator(payload) as boolean;\n if (!valid) {\n return validator.errors;\n } else {\n return null;\n }\n /*\n\t\tconsole.error(validator.errors);\n\t\tconsole.trace('Invalid Schema');\n\t\tconsole.log('Payload:-');\n\t\tconsole.log(JSON.stringify(payload));\n\t\tprocess.exit(1);\n\t\t*/\n};\n\nexport function AddSchema(name: string, schema: Schema): void {\n ajv.addSchema(schema, name);\n /*\n\treturn (payload) => {\n\t\tconst validator = ajv.getSchema(name)\n\t\t_Validate(validator, payload)\n\t}*/\n\n}\n\nexport function Validate(name: string, payload: JSONObject): unknown {\n const validator: AnyValidateFunction<unknown> | undefined = ajv.getSchema(name)\n if (validator) {\n return _Validate(validator, payload);\n }\n}\n","import { Validate } from './validate.js'\n\nimport { JSONObject } from './index'\n\nexport class STSOptionsBase\n{\n #options: JSONObject | null;\n\n constructor(options: JSONObject | null = null)\n {\n this.#options = options;\n\n if (options !== null) {\n if (typeof options.validator === 'undefined') {\n //console.log(JSON.stringify(options));\n //console.trace(\"Options Here ------------------------------------------------------------------------------------------\")\n } else {\n Validate(options.validator as string, options);\n }\n }\n }\n\n get options()\n {\n return this.#options;\n }\n}\n","export async function Sleep(milliseconds = 1000): Promise<void> { \n return new Promise(resolve => setTimeout(resolve, milliseconds))\n}\n \n// poolsleep is required to avoid JEST reporting unclosed handles during shutdown of all tests\nexport async function JestSleep(): Promise<void> {\n return Sleep(100);\n}\n","import { errorCode, errorPayload } from './errorhandling'\n\n// Ref: https://datatracker.ietf.org/doc/html/rfc6749#appendix-A\nexport enum OAuth2ParameterType {\n\tAUDIENCE = 'AUDIENCE', // STS Extension\n\tCLIENT_ID = 'client_id',\n\tCLIENT_SECRET = 'client_secret',\n\tRESPONSE_TYPE = 'response_type',\n\tSCOPE = 'scope',\n\tSTATE = 'state',\n\tREDIRECT_URI = 'redirect_uri',\n\tERROR = 'error',\n\tERROR_DESCRIPTION = 'error_description',\n\tERROR_CODES = 'error_codes', // STS Extension\n\tERROR_URI = 'error_uri',\n\tGRANT_TYPE = 'grant_type',\n\tCODE = 'code',\n\tACCESS_TOKEN = 'access_token',\n\tTOKEN_TYPE = 'token_type',\n\tEXPIRES_IN = 'expires_in',\n\tUSERNAME = 'username',\n\tPASSWORD = 'password',\n\tREFRESH_TOKEN = 'refresh_token',\n\tRESPONSE_MODE = 'response_mode', // STS Extension\n\tTIMESTAMP = 'timestamp', // STS Extension\n\tTRACE_ID = 'trace_id', // STS Extension\n\tCORRELATION_ID = 'correlation_id' // STS Extension\n}\n\n// OIDC Standard Claims\n// Ref: https://openid.net/specs/openid-connect-core-1_0.html#Claims\nexport enum OIDCStandardClaim {\n\tSUB = 'sub',\n\tNAME = 'name',\n\tGIVEN_NAME = 'given_name',\n\tFAMILY_NAME = 'family_name',\n\tMIDDLE_NAME = 'middle_name',\n\tNICKNAME = 'nickname',\n\tPREFERRED_USERNAME = 'preferred_username',\n\tPROFILE = 'profile',\n\tPICTURE = 'picture',\n\tWEBSITE = 'website',\n\tEMAIL = 'email',\n\tEMAIL_VERIFIED = 'email_verified',\n\tGENDER = 'gender',\n\tBIRTHDATE = 'birthdate',\n\tZONEINFO = 'zoneinfo',\n\tLOCALE = 'locale',\n\tPHONE_NUMBER = 'phone_number',\n\tPHONE_NUMBER_VERIFIED = 'phone_number_verified',\n\tADDRESS = 'address',\n\tCLIENT_SECRET = 'client_secret',\n\tNONCE = 'nonce' // STS Extension\n}\n\nexport enum OIDCAddressClaim {\n\tFORMATTED = 'formatted',\n\tSTREET_ADDRESS = 'street_address',\n\tLOCALITY = 'locality',\n\tREGION = 'region',\n\tCOUNTRY = 'country'\n}\n\nexport class OAuth2ParameterErrorType {\n static readonly NOT_EQUAL: errorCode = {\n code: 'STS_OAUTH2_ERR_0001',\n description: 'Parameter values not equal.'\n }\n static readonly NOT_PRESENT: errorCode = {\n code: 'STS_OAUTH2_ERR_0002',\n description: 'Parameter not provided.'\n }\n static readonly INVALID_FORMAT: errorCode = {\n code: 'STS_OAUTH2_ERR_0003',\n description: 'Parameter value format invalid.'\n }\n static readonly EXPIRED: errorCode = {\n code: 'STS_OAUTH2_ERR_0004',\n description: 'Parameter value expired.'\n }\n}\n\nexport function compareParameterTypes(source1: string[], source2: string[], authParameterTypes: OAuth2ParameterType[]): errorPayload[] {\n const errors: errorPayload[] = [ ];\n for (let i=0 ; i < authParameterTypes.length; i++) {\n const authParameterType = authParameterTypes[i];\n if (source1[i].localeCompare(source2[i]) !== 0) {\n const error: errorPayload = {\n error: OAuth2ParameterErrorType.NOT_EQUAL.code,\n error_description: OAuth2ParameterErrorType.NOT_EQUAL.description,\n timestamp: Date.now(),\n details: `${OAuth2ParameterErrorType.NOT_EQUAL.description}: Parameter: [${authParameterType}]`\n }\n errors.push(error);\n }\n }\n return errors;\n}\n","/*\nexport interface JSONObject {\n [x: string]: string | number | boolean | string[] | number[] | boolean[] | Array<JSONObject> | JSONObject | ((p: any) => any) | undefined\n}\n// This also works :-\n//interface JSONObject2 extends Record<string, string | number | string[] | Array<JSONObject2> | JSONObject2> {};\n*/\n\nexport interface JSONObject {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [x: string]: any | JSONObject | undefined\n}\n\nexport * from './errorhandling'\nexport * from './stsoptionsbase'\nexport * from './sleep'\nexport * from './validate'\nexport * from './oauth2terms'\n\nexport enum ModelDelimeter {\n\tROOT = '_',\n\tSEPERATOR = '|',\n\tCOMPONENT_SEPERATOR = '@',\n\tNID_SEPERATOR = '^' // This seperator splits the static and dynamic part of a context string (nid). Used for creating payload header for size optimisation.\n}\n\nexport const CheckValidChar = (checkParams: string[][]): void => {\n const invalidChars = [ \n ModelDelimeter.ROOT, \n ModelDelimeter.SEPERATOR, \n ModelDelimeter.COMPONENT_SEPERATOR, \n ModelDelimeter.NID_SEPERATOR\n ];\n\n checkParams.forEach(param => {\n invalidChars.forEach(char => {\n if (param[1].includes(char)) {\n throw new Error(`Invalid character inside [${param[0]}:${param[1]}], no [${char}] allowed`);\n }\n });\n });\n}\n\n/* Below is legacy code used as a global record container. No longer required.\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const $stsgd: Record<string, any> = { };\n\nexport function $stsgdf<T>(): Record<string, T> {\n return $stsgd as Record<string, T>;\n}\n*/\n"],"names":["OAuth2ParameterType","OIDCStandardClaim","OIDCAddressClaim","ModelDelimeter"],"mappings":"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"}
1
+ {"version":3,"file":"stsutils.umd.js","sources":["../src/errorhandling.ts","../src/validate.ts","../src/stsoptionsbase.ts","../src/sleep.ts","../src/oauth2terms.ts","../src/winstonTransport.ts","../src/index.ts"],"sourcesContent":["export type errorCode = {\n\tcode: string\n\tdescription: string\n}\n\nexport type errorPayload = {\n\terror: string,\n\terror_description: string,\n\ttimestamp: number,\n\t//trace_id: \"255d1aef-8c98-452f-ac51-23d051240864\", //@@\n\t//correlation_id: \"fb3d2015-bc17-4bb9-bb85-30c5cf1aaaa7\", //@@\n\tdetails?: unknown\n}\n\nexport function GetErrorPayload(errorCode: errorCode, details: unknown = null): errorPayload {\n return {\n error: errorCode.code,\n error_description: errorCode.description,\n timestamp: Date.now(),\n //trace_id: \"255d1aef-8c98-452f-ac51-23d051240864\", //@@\n //correlation_id: \"fb3d2015-bc17-4bb9-bb85-30c5cf1aaaa7\", //@@\n details: details\n }\n}\n","import Ajv, { Schema } from 'ajv/dist/jtd.js'\nimport { AnyValidateFunction } from 'ajv/dist/core.js';\n\nimport { JSONObject } from './index'\n\nconst ajv = new Ajv();\n\nconst _Validate = (validator: AnyValidateFunction<unknown>, payload: JSONObject): unknown | null => {\n const valid: boolean = validator(payload) as boolean;\n if (!valid) {\n return validator.errors;\n } else {\n return null;\n }\n /*\n\t\tconsole.error(validator.errors);\n\t\tconsole.trace('Invalid Schema');\n\t\tconsole.log('Payload:-');\n\t\tconsole.log(JSON.stringify(payload));\n\t\tprocess.exit(1);\n\t\t*/\n};\n\nexport function AddSchema(name: string, schema: Schema): void {\n ajv.addSchema(schema, name);\n /*\n\treturn (payload) => {\n\t\tconst validator = ajv.getSchema(name)\n\t\t_Validate(validator, payload)\n\t}*/\n\n}\n\nexport function Validate(name: string, payload: JSONObject): unknown {\n const validator: AnyValidateFunction<unknown> | undefined = ajv.getSchema(name)\n if (validator) {\n return _Validate(validator, payload);\n }\n}\n","import { Validate } from './validate.js'\n\nimport { JSONObject } from './index'\n\nexport class STSOptionsBase\n{\n #options: JSONObject | null;\n\n constructor(options: JSONObject | null = null)\n {\n this.#options = options;\n\n if (options !== null) {\n if (typeof options.validator === 'undefined') {\n //console.log(JSON.stringify(options));\n //console.trace(\"Options Here ------------------------------------------------------------------------------------------\")\n } else {\n Validate(options.validator as string, options);\n }\n }\n }\n\n get options()\n {\n return this.#options;\n }\n}\n","export async function Sleep(milliseconds = 1000): Promise<void> { \n return new Promise(resolve => setTimeout(resolve, milliseconds))\n}\n \n// poolsleep is required to avoid JEST reporting unclosed handles during shutdown of all tests\nexport async function JestSleep(): Promise<void> {\n return Sleep(100);\n}\n","import { errorCode, errorPayload } from './errorhandling'\n\n// Ref: https://datatracker.ietf.org/doc/html/rfc6749#appendix-A\nexport enum OAuth2ParameterType {\n\tAUDIENCE = 'AUDIENCE', // STS Extension\n\tCLIENT_ID = 'client_id',\n\tCLIENT_SECRET = 'client_secret',\n\tRESPONSE_TYPE = 'response_type',\n\tSCOPE = 'scope',\n\tSTATE = 'state',\n\tREDIRECT_URI = 'redirect_uri',\n\tERROR = 'error',\n\tERROR_DESCRIPTION = 'error_description',\n\tERROR_CODES = 'error_codes', // STS Extension\n\tERROR_URI = 'error_uri',\n\tGRANT_TYPE = 'grant_type',\n\tCODE = 'code',\n\tACCESS_TOKEN = 'access_token',\n\tTOKEN_TYPE = 'token_type',\n\tEXPIRES_IN = 'expires_in',\n\tUSERNAME = 'username',\n\tPASSWORD = 'password',\n\tREFRESH_TOKEN = 'refresh_token',\n\tRESPONSE_MODE = 'response_mode', // STS Extension\n\tTIMESTAMP = 'timestamp', // STS Extension\n\tTRACE_ID = 'trace_id', // STS Extension\n\tCORRELATION_ID = 'correlation_id' // STS Extension\n}\n\n// OIDC Standard Claims\n// Ref: https://openid.net/specs/openid-connect-core-1_0.html#Claims\nexport enum OIDCStandardClaim {\n\tSUB = 'sub',\n\tNAME = 'name',\n\tGIVEN_NAME = 'given_name',\n\tFAMILY_NAME = 'family_name',\n\tMIDDLE_NAME = 'middle_name',\n\tNICKNAME = 'nickname',\n\tPREFERRED_USERNAME = 'preferred_username',\n\tPROFILE = 'profile',\n\tPICTURE = 'picture',\n\tWEBSITE = 'website',\n\tEMAIL = 'email',\n\tEMAIL_VERIFIED = 'email_verified',\n\tGENDER = 'gender',\n\tBIRTHDATE = 'birthdate',\n\tZONEINFO = 'zoneinfo',\n\tLOCALE = 'locale',\n\tPHONE_NUMBER = 'phone_number',\n\tPHONE_NUMBER_VERIFIED = 'phone_number_verified',\n\tADDRESS = 'address',\n\tCLIENT_SECRET = 'client_secret',\n\tNONCE = 'nonce' // STS Extension\n}\n\nexport enum OIDCAddressClaim {\n\tFORMATTED = 'formatted',\n\tSTREET_ADDRESS = 'street_address',\n\tLOCALITY = 'locality',\n\tREGION = 'region',\n\tCOUNTRY = 'country'\n}\n\nexport class OAuth2ParameterErrorType {\n static readonly NOT_EQUAL: errorCode = {\n code: 'STS_OAUTH2_ERR_0001',\n description: 'Parameter values not equal.'\n }\n static readonly NOT_PRESENT: errorCode = {\n code: 'STS_OAUTH2_ERR_0002',\n description: 'Parameter not provided.'\n }\n static readonly INVALID_FORMAT: errorCode = {\n code: 'STS_OAUTH2_ERR_0003',\n description: 'Parameter value format invalid.'\n }\n static readonly EXPIRED: errorCode = {\n code: 'STS_OAUTH2_ERR_0004',\n description: 'Parameter value expired.'\n }\n}\n\nexport function compareParameterTypes(source1: string[], source2: string[], authParameterTypes: OAuth2ParameterType[]): errorPayload[] {\n const errors: errorPayload[] = [ ];\n for (let i=0 ; i < authParameterTypes.length; i++) {\n const authParameterType = authParameterTypes[i];\n if (source1[i].localeCompare(source2[i]) !== 0) {\n const error: errorPayload = {\n error: OAuth2ParameterErrorType.NOT_EQUAL.code,\n error_description: OAuth2ParameterErrorType.NOT_EQUAL.description,\n timestamp: Date.now(),\n details: `${OAuth2ParameterErrorType.NOT_EQUAL.description}: Parameter: [${authParameterType}]`\n }\n errors.push(error);\n }\n }\n return errors;\n}\n","/* eslint @typescript-eslint/no-explicit-any: 0 */ // --> OFF\nimport Transport, { TransportStreamOptions } from 'winston-transport'\n\nimport debugModule from 'debug'\n\nexport interface ISTSWinstonTransport extends TransportStreamOptions {\n stsContext: string\n}\n\nexport class STSWinstonTransport extends Transport {\n #debug: debugModule.Debugger;\n\n constructor(opts: ISTSWinstonTransport) {\n super(opts);\n this.#debug = debugModule(`proc:${process.pid}:${opts.stsContext}`);\n }\n \n log(info: any, callback: any) {\n if (info[Symbol.for('level')] == 'debug') {\n this.#debug(info.message);\n }\n this.emit('logged', info);\n callback();\n }\n}\n","/*\nexport interface JSONObject {\n [x: string]: string | number | boolean | string[] | number[] | boolean[] | Array<JSONObject> | JSONObject | ((p: any) => any) | undefined\n}\n// This also works :-\n//interface JSONObject2 extends Record<string, string | number | string[] | Array<JSONObject2> | JSONObject2> {};\n*/\n\nexport interface JSONObject {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [x: string]: any | JSONObject | undefined\n}\n\nexport * from './errorhandling'\nexport * from './stsoptionsbase'\nexport * from './sleep'\nexport * from './validate'\nexport * from './oauth2terms'\nexport * from './winstonTransport'\n\nexport enum ModelDelimeter {\n\tROOT = '_',\n\tSEPERATOR = '|',\n\tCOMPONENT_SEPERATOR = '@',\n\tNID_SEPERATOR = '^' // This seperator splits the static and dynamic part of a context string (nid). Used for creating payload header for size optimisation.\n}\n\nexport const CheckValidChar = (checkParams: string[][]): void => {\n const invalidChars = [ \n ModelDelimeter.ROOT, \n ModelDelimeter.SEPERATOR, \n ModelDelimeter.COMPONENT_SEPERATOR, \n ModelDelimeter.NID_SEPERATOR\n ];\n\n checkParams.forEach(param => {\n invalidChars.forEach(char => {\n if (param[1].includes(char)) {\n throw new Error(`Invalid character inside [${param[0]}:${param[1]}], no [${char}] allowed`);\n }\n });\n });\n}\n\n/* Below is legacy code used as a global record container. No longer required.\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const $stsgd: Record<string, any> = { };\n\nexport function $stsgdf<T>(): Record<string, T> {\n return $stsgd as Record<string, T>;\n}\n*/\n"],"names":["OAuth2ParameterType","OIDCStandardClaim","OIDCAddressClaim","ModelDelimeter"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nsshunt/stsutils",
3
- "version": "1.16.30",
3
+ "version": "1.16.32",
4
4
  "description": "",
5
5
  "main": "./dist/stsutils.umd.js",
6
6
  "module": "./dist/stsutils.mjs",
@@ -40,16 +40,19 @@
40
40
  },
41
41
  "devDependencies": {
42
42
  "@tsconfig/node20": "^20.1.2",
43
- "@types/node": "^20.10.5",
44
- "@typescript-eslint/eslint-plugin": "^6.16.0",
45
- "@typescript-eslint/parser": "^6.16.0",
43
+ "@types/debug": "^4.1.12",
44
+ "@types/node": "^20.11.13",
45
+ "@typescript-eslint/eslint-plugin": "^6.20.0",
46
+ "@typescript-eslint/parser": "^6.20.0",
46
47
  "eslint": "^8.56.0",
47
- "rollup-plugin-visualizer": "^5.11.0",
48
+ "rollup-plugin-visualizer": "^5.12.0",
48
49
  "typescript": "^5.3.3",
49
- "vite": "^5.0.10",
50
- "vitest": "^1.1.0"
50
+ "vite": "^5.0.11",
51
+ "vitest": "^1.2.2"
51
52
  },
52
53
  "dependencies": {
53
- "ajv": "^8.12.0"
54
+ "ajv": "^8.12.0",
55
+ "debug": "^4.3.4",
56
+ "winston": "^3.11.0"
54
57
  }
55
58
  }
package/types/index.d.ts CHANGED
@@ -6,6 +6,7 @@ export * from './stsoptionsbase';
6
6
  export * from './sleep';
7
7
  export * from './validate';
8
8
  export * from './oauth2terms';
9
+ export * from './winstonTransport';
9
10
  export declare enum ModelDelimeter {
10
11
  ROOT = "_",
11
12
  SEPERATOR = "|",
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAQA,MAAM,WAAW,UAAU;IAEvB,CAAC,CAAC,EAAE,MAAM,GAAG,GAAG,GAAG,UAAU,GAAG,SAAS,CAAA;CAC5C;AAED,cAAc,iBAAiB,CAAA;AAC/B,cAAc,kBAAkB,CAAA;AAChC,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,eAAe,CAAA;AAE7B,oBAAY,cAAc;IACzB,IAAI,MAAM;IACV,SAAS,MAAM;IACf,mBAAmB,MAAM;IACzB,aAAa,MAAM;CACnB;AAED,eAAO,MAAM,cAAc,gBAAiB,MAAM,EAAE,EAAE,KAAG,IAexD,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAQA,MAAM,WAAW,UAAU;IAEvB,CAAC,CAAC,EAAE,MAAM,GAAG,GAAG,GAAG,UAAU,GAAG,SAAS,CAAA;CAC5C;AAED,cAAc,iBAAiB,CAAA;AAC/B,cAAc,kBAAkB,CAAA;AAChC,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,eAAe,CAAA;AAC7B,cAAc,oBAAoB,CAAA;AAElC,oBAAY,cAAc;IACzB,IAAI,MAAM;IACV,SAAS,MAAM;IACf,mBAAmB,MAAM;IACzB,aAAa,MAAM;CACnB;AAED,eAAO,MAAM,cAAc,gBAAiB,MAAM,EAAE,EAAE,KAAG,IAexD,CAAA"}
@@ -0,0 +1,10 @@
1
+ import Transport, { TransportStreamOptions } from 'winston-transport';
2
+ export interface ISTSWinstonTransport extends TransportStreamOptions {
3
+ stsContext: string;
4
+ }
5
+ export declare class STSWinstonTransport extends Transport {
6
+ #private;
7
+ constructor(opts: ISTSWinstonTransport);
8
+ log(info: any, callback: any): void;
9
+ }
10
+ //# sourceMappingURL=winstonTransport.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"winstonTransport.d.ts","sourceRoot":"","sources":["../src/winstonTransport.ts"],"names":[],"mappings":"AACA,OAAO,SAAS,EAAE,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAA;AAIrE,MAAM,WAAW,oBAAqB,SAAQ,sBAAsB;IAChE,UAAU,EAAE,MAAM,CAAA;CACrB;AAED,qBAAa,mBAAoB,SAAQ,SAAS;;gBAGlC,IAAI,EAAE,oBAAoB;IAKtC,GAAG,CAAC,IAAI,EAAE,GAAG,EAAE,QAAQ,EAAE,GAAG;CAO/B"}