@cubist-labs/cubesigner-sdk 0.3.8 → 0.3.13

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/README.md CHANGED
@@ -210,6 +210,7 @@ assert((await ethersSigner.getAddress()) === secpKey.materialId);
210
210
  console.log(
211
211
  "ethers.js signature:",
212
212
  await ethersSigner.signTransaction({
213
+ chainId: 1,
213
214
  to: "0xff50ed3d0ec03ac01d4c79aad74928bff48a7b2b",
214
215
  value: ethers.parseEther("0.0000001"),
215
216
  }),
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cubist-labs/cubesigner-sdk",
3
- "version": "0.3.8",
3
+ "version": "0.3.13",
4
4
  "description": "CubeSigner TypeScript SDK",
5
5
  "license": "MIT OR Apache-2.0",
6
6
  "author": "Cubist, Inc.",
@@ -489,12 +489,13 @@ export declare class CubeSignerClient extends CubeSignerApi {
489
489
  */
490
490
  get proveIdentity(): () => Promise<{
491
491
  aud?: string | null | undefined;
492
- email: string;
492
+ email?: string | null | undefined;
493
493
  exp_epoch: number;
494
494
  identity?: {
495
495
  iss: string;
496
496
  sub: string;
497
497
  } | null | undefined;
498
+ preferred_username?: string | null | undefined;
498
499
  user_info?: {
499
500
  configured_mfa: ({
500
501
  type: "totp";
@@ -517,12 +518,13 @@ export declare class CubeSignerClient extends CubeSignerApi {
517
518
  */
518
519
  get verifyIdentity(): (proof: {
519
520
  aud?: string | null | undefined;
520
- email: string;
521
+ email?: string | null | undefined;
521
522
  exp_epoch: number;
522
523
  identity?: {
523
524
  iss: string;
524
525
  sub: string;
525
526
  } | null | undefined;
527
+ preferred_username?: string | null | undefined;
526
528
  user_info?: {
527
529
  configured_mfa: ({
528
530
  type: "totp";
@@ -18,6 +18,29 @@ export declare class ErrResponse extends Error {
18
18
  * @param {Partial<ErrResponse>} init Initializer
19
19
  */
20
20
  constructor(init: Partial<ErrResponse>);
21
+ /**
22
+ * Checks whether the root cause of an {@link ErrResponse} is an invalid session.
23
+ *
24
+ * Examples include:
25
+ * - the session has expired
26
+ * - the session has been revoked
27
+ * - provided auth token is invalid/malformed/expired
28
+ *
29
+ * @return {boolean} Whether the response matches one of several different "invalid session" responses.
30
+ */
31
+ isSessionExpiredError(): boolean;
32
+ /**
33
+ * Checks whether the root cause of an {@link ErrResponse} is the user failing to answer an MFA challenge.
34
+ *
35
+ * Examples include:
36
+ * - user provides a bad TOTP code
37
+ * - user is TOTP-rate-limited (because of too many failed attempts)
38
+ * - MFA challenge expired
39
+ * - FIDO challenge verification failed
40
+ *
41
+ * @return {boolean} Whether the error was caused by the user failing to authenticate with MFA
42
+ */
43
+ isUserMfaError(): boolean;
21
44
  }
22
45
  /**
23
46
  * An error that is thrown when a session has expired
@@ -1,6 +1,25 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.SessionExpiredError = exports.ErrResponse = void 0;
4
+ /**
5
+ * Error codes corresponding to all different "MFA failed" error responses
6
+ */
7
+ const mfaErrorCodes = [
8
+ "MfaChallengeExpired",
9
+ "MfaDisallowedApprover",
10
+ "MfaDisallowedIdentity",
11
+ "MfaTypeNotAllowed",
12
+ "MfaTotpBadCode",
13
+ "MfaTotpRateLimit",
14
+ "MfaTotpBadConfiguration",
15
+ "TotpNotConfigured",
16
+ "FidoVerificationFailed",
17
+ "UserRoleUnprivileged",
18
+ ];
19
+ /**
20
+ * Opcodes corresponding to all different MFA approve/reject requests
21
+ */
22
+ const mfaOpCodes = ["mfaVoteCs", "mfaVoteTotp", "mfaVoteFidoComplete"];
4
23
  /**
5
24
  * Error response type, thrown on non-successful responses.
6
25
  */
@@ -12,6 +31,35 @@ class ErrResponse extends Error {
12
31
  super(init.message);
13
32
  Object.assign(this, init);
14
33
  }
34
+ /**
35
+ * Checks whether the root cause of an {@link ErrResponse} is an invalid session.
36
+ *
37
+ * Examples include:
38
+ * - the session has expired
39
+ * - the session has been revoked
40
+ * - provided auth token is invalid/malformed/expired
41
+ *
42
+ * @return {boolean} Whether the response matches one of several different "invalid session" responses.
43
+ */
44
+ isSessionExpiredError() {
45
+ return this.errorCode !== undefined && invalidSessionErrorCodes.includes(this.errorCode);
46
+ }
47
+ /**
48
+ * Checks whether the root cause of an {@link ErrResponse} is the user failing to answer an MFA challenge.
49
+ *
50
+ * Examples include:
51
+ * - user provides a bad TOTP code
52
+ * - user is TOTP-rate-limited (because of too many failed attempts)
53
+ * - MFA challenge expired
54
+ * - FIDO challenge verification failed
55
+ *
56
+ * @return {boolean} Whether the error was caused by the user failing to authenticate with MFA
57
+ */
58
+ isUserMfaError() {
59
+ return (this.status === 403 &&
60
+ (this.operation === undefined || mfaOpCodes.includes(this.operation)) &&
61
+ (this.errorCode === undefined || mfaErrorCodes.includes(this.errorCode)));
62
+ }
15
63
  }
16
64
  exports.ErrResponse = ErrResponse;
17
65
  /**
@@ -34,4 +82,18 @@ class SessionExpiredError extends ErrResponse {
34
82
  }
35
83
  }
36
84
  exports.SessionExpiredError = SessionExpiredError;
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZXJyb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBR0E7O0dBRUc7QUFDSCxNQUFhLFdBQVksU0FBUSxLQUFLO0lBWXBDOztPQUVHO0lBQ0gsWUFBWSxJQUEwQjtRQUNwQyxLQUFLLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3BCLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzVCLENBQUM7Q0FDRjtBQW5CRCxrQ0FtQkM7QUFFRDs7R0FFRztBQUNILE1BQWEsbUJBQW9CLFNBQVEsV0FBVztJQUNsRDs7OztPQUlHO0lBQ0gsWUFBWSxTQUE0QjtRQUN0QyxLQUFLLENBQUM7WUFDSixPQUFPLEVBQUUscUJBQXFCO1lBQzlCLE1BQU0sRUFBRSxHQUFHO1lBQ1gsVUFBVSxFQUFFLFdBQVc7WUFDdkIsU0FBUztZQUNULFNBQVMsRUFBRSxnQkFBZ0I7U0FDNUIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBZkQsa0RBZUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDc0VyckNvZGUgfSBmcm9tIFwiLi9zY2hlbWFfdHlwZXNcIjtcbmltcG9ydCB7IG9wZXJhdGlvbnMgfSBmcm9tIFwiLi9zY2hlbWFcIjtcblxuLyoqXG4gKiBFcnJvciByZXNwb25zZSB0eXBlLCB0aHJvd24gb24gbm9uLXN1Y2Nlc3NmdWwgcmVzcG9uc2VzLlxuICovXG5leHBvcnQgY2xhc3MgRXJyUmVzcG9uc2UgZXh0ZW5kcyBFcnJvciB7XG4gIC8qKiBPcGVyYXRpb24gdGhhdCBwcm9kdWNlZCB0aGlzIGVycm9yICovXG4gIHJlYWRvbmx5IG9wZXJhdGlvbj86IGtleW9mIG9wZXJhdGlvbnM7XG4gIC8qKiBIVFRQIHN0YXR1cyBjb2RlIHRleHQgKGRlcml2ZWQgZnJvbSBgdGhpcy5zdGF0dXNgKSAqL1xuICByZWFkb25seSBzdGF0dXNUZXh0Pzogc3RyaW5nO1xuICAvKiogSFRUUCBzdGF0dXMgY29kZSAqL1xuICByZWFkb25seSBzdGF0dXM/OiBudW1iZXI7XG4gIC8qKiBIVFRQIHJlc3BvbnNlIHVybCAqL1xuICByZWFkb25seSB1cmw/OiBzdHJpbmc7XG4gIC8qKiBDdWJlU2lnbmVyIGVycm9yIGNvZGUgKi9cbiAgcmVhZG9ubHkgZXJyb3JDb2RlPzogQ3NFcnJDb2RlO1xuXG4gIC8qKlxuICAgKiBAcGFyYW0ge1BhcnRpYWw8RXJyUmVzcG9uc2U+fSBpbml0IEluaXRpYWxpemVyXG4gICAqL1xuICBjb25zdHJ1Y3Rvcihpbml0OiBQYXJ0aWFsPEVyclJlc3BvbnNlPikge1xuICAgIHN1cGVyKGluaXQubWVzc2FnZSk7XG4gICAgT2JqZWN0LmFzc2lnbih0aGlzLCBpbml0KTtcbiAgfVxufVxuXG4vKipcbiAqIEFuIGVycm9yIHRoYXQgaXMgdGhyb3duIHdoZW4gYSBzZXNzaW9uIGhhcyBleHBpcmVkXG4gKi9cbmV4cG9ydCBjbGFzcyBTZXNzaW9uRXhwaXJlZEVycm9yIGV4dGVuZHMgRXJyUmVzcG9uc2Uge1xuICAvKipcbiAgICogQ29uc3RydWN0b3IuXG4gICAqXG4gICAqIEBwYXJhbSB7b3BlcmF0aW9uc30gb3BlcmF0aW9uIFRoZSBvcGVyYXRpb24gdGhhdCB3YXMgYXR0ZW1wdGVkXG4gICAqL1xuICBjb25zdHJ1Y3RvcihvcGVyYXRpb24/OiBrZXlvZiBvcGVyYXRpb25zKSB7XG4gICAgc3VwZXIoe1xuICAgICAgbWVzc2FnZTogXCJTZXNzaW9uIGhhcyBleHBpcmVkXCIsXG4gICAgICBzdGF0dXM6IDQwMyxcbiAgICAgIHN0YXR1c1RleHQ6IFwiRm9yYmlkZGVuXCIsXG4gICAgICBvcGVyYXRpb24sXG4gICAgICBlcnJvckNvZGU6IFwiU2Vzc2lvbkV4cGlyZWRcIixcbiAgICB9KTtcbiAgfVxufVxuIl19
85
+ /**
86
+ * Error codes corresponding to all different "invalid session" error responses
87
+ */
88
+ const invalidSessionErrorCodes = [
89
+ "SessionExpired",
90
+ "SessionRevoked",
91
+ "SessionNotFound",
92
+ "SessionInvalidAuthToken",
93
+ "SessionInvalidEpochToken",
94
+ "SessionInvalidRefreshToken",
95
+ "SessionAuthTokenExpired",
96
+ "SessionRefreshTokenExpired",
97
+ "SessionPossiblyStolenToken",
98
+ ];
99
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZXJyb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBR0E7O0dBRUc7QUFDSCxNQUFNLGFBQWEsR0FBZ0I7SUFDakMscUJBQXFCO0lBQ3JCLHVCQUF1QjtJQUN2Qix1QkFBdUI7SUFDdkIsbUJBQW1CO0lBQ25CLGdCQUFnQjtJQUNoQixrQkFBa0I7SUFDbEIseUJBQXlCO0lBQ3pCLG1CQUFtQjtJQUNuQix3QkFBd0I7SUFDeEIsc0JBQXNCO0NBQ3ZCLENBQUM7QUFFRjs7R0FFRztBQUNILE1BQU0sVUFBVSxHQUF5QixDQUFDLFdBQVcsRUFBRSxhQUFhLEVBQUUscUJBQXFCLENBQUMsQ0FBQztBQUU3Rjs7R0FFRztBQUNILE1BQWEsV0FBWSxTQUFRLEtBQUs7SUFZcEM7O09BRUc7SUFDSCxZQUFZLElBQTBCO1FBQ3BDLEtBQUssQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDcEIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDNUIsQ0FBQztJQUVEOzs7Ozs7Ozs7T0FTRztJQUNILHFCQUFxQjtRQUNuQixPQUFPLElBQUksQ0FBQyxTQUFTLEtBQUssU0FBUyxJQUFJLHdCQUF3QixDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDM0YsQ0FBQztJQUVEOzs7Ozs7Ozs7O09BVUc7SUFDSCxjQUFjO1FBQ1osT0FBTyxDQUNMLElBQUksQ0FBQyxNQUFNLEtBQUssR0FBRztZQUNuQixDQUFDLElBQUksQ0FBQyxTQUFTLEtBQUssU0FBUyxJQUFJLFVBQVUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ3JFLENBQUMsSUFBSSxDQUFDLFNBQVMsS0FBSyxTQUFTLElBQUksYUFBYSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FDekUsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQXBERCxrQ0FvREM7QUFFRDs7R0FFRztBQUNILE1BQWEsbUJBQW9CLFNBQVEsV0FBVztJQUNsRDs7OztPQUlHO0lBQ0gsWUFBWSxTQUE0QjtRQUN0QyxLQUFLLENBQUM7WUFDSixPQUFPLEVBQUUscUJBQXFCO1lBQzlCLE1BQU0sRUFBRSxHQUFHO1lBQ1gsVUFBVSxFQUFFLFdBQVc7WUFDdkIsU0FBUztZQUNULFNBQVMsRUFBRSxnQkFBZ0I7U0FDNUIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBZkQsa0RBZUM7QUFFRDs7R0FFRztBQUNILE1BQU0sd0JBQXdCLEdBQWdCO0lBQzVDLGdCQUFnQjtJQUNoQixnQkFBZ0I7SUFDaEIsaUJBQWlCO0lBQ2pCLHlCQUF5QjtJQUN6QiwwQkFBMEI7SUFDMUIsNEJBQTRCO0lBQzVCLHlCQUF5QjtJQUN6Qiw0QkFBNEI7SUFDNUIsNEJBQTRCO0NBQzdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDc0VyckNvZGUgfSBmcm9tIFwiLi9zY2hlbWFfdHlwZXNcIjtcbmltcG9ydCB7IG9wZXJhdGlvbnMgfSBmcm9tIFwiLi9zY2hlbWFcIjtcblxuLyoqXG4gKiBFcnJvciBjb2RlcyBjb3JyZXNwb25kaW5nIHRvIGFsbCBkaWZmZXJlbnQgXCJNRkEgZmFpbGVkXCIgZXJyb3IgcmVzcG9uc2VzXG4gKi9cbmNvbnN0IG1mYUVycm9yQ29kZXM6IENzRXJyQ29kZVtdID0gW1xuICBcIk1mYUNoYWxsZW5nZUV4cGlyZWRcIixcbiAgXCJNZmFEaXNhbGxvd2VkQXBwcm92ZXJcIixcbiAgXCJNZmFEaXNhbGxvd2VkSWRlbnRpdHlcIixcbiAgXCJNZmFUeXBlTm90QWxsb3dlZFwiLFxuICBcIk1mYVRvdHBCYWRDb2RlXCIsXG4gIFwiTWZhVG90cFJhdGVMaW1pdFwiLFxuICBcIk1mYVRvdHBCYWRDb25maWd1cmF0aW9uXCIsXG4gIFwiVG90cE5vdENvbmZpZ3VyZWRcIixcbiAgXCJGaWRvVmVyaWZpY2F0aW9uRmFpbGVkXCIsXG4gIFwiVXNlclJvbGVVbnByaXZpbGVnZWRcIixcbl07XG5cbi8qKlxuICogT3Bjb2RlcyBjb3JyZXNwb25kaW5nIHRvIGFsbCBkaWZmZXJlbnQgTUZBIGFwcHJvdmUvcmVqZWN0IHJlcXVlc3RzXG4gKi9cbmNvbnN0IG1mYU9wQ29kZXM6IChrZXlvZiBvcGVyYXRpb25zKVtdID0gW1wibWZhVm90ZUNzXCIsIFwibWZhVm90ZVRvdHBcIiwgXCJtZmFWb3RlRmlkb0NvbXBsZXRlXCJdO1xuXG4vKipcbiAqIEVycm9yIHJlc3BvbnNlIHR5cGUsIHRocm93biBvbiBub24tc3VjY2Vzc2Z1bCByZXNwb25zZXMuXG4gKi9cbmV4cG9ydCBjbGFzcyBFcnJSZXNwb25zZSBleHRlbmRzIEVycm9yIHtcbiAgLyoqIE9wZXJhdGlvbiB0aGF0IHByb2R1Y2VkIHRoaXMgZXJyb3IgKi9cbiAgcmVhZG9ubHkgb3BlcmF0aW9uPzoga2V5b2Ygb3BlcmF0aW9ucztcbiAgLyoqIEhUVFAgc3RhdHVzIGNvZGUgdGV4dCAoZGVyaXZlZCBmcm9tIGB0aGlzLnN0YXR1c2ApICovXG4gIHJlYWRvbmx5IHN0YXR1c1RleHQ/OiBzdHJpbmc7XG4gIC8qKiBIVFRQIHN0YXR1cyBjb2RlICovXG4gIHJlYWRvbmx5IHN0YXR1cz86IG51bWJlcjtcbiAgLyoqIEhUVFAgcmVzcG9uc2UgdXJsICovXG4gIHJlYWRvbmx5IHVybD86IHN0cmluZztcbiAgLyoqIEN1YmVTaWduZXIgZXJyb3IgY29kZSAqL1xuICByZWFkb25seSBlcnJvckNvZGU/OiBDc0VyckNvZGU7XG5cbiAgLyoqXG4gICAqIEBwYXJhbSB7UGFydGlhbDxFcnJSZXNwb25zZT59IGluaXQgSW5pdGlhbGl6ZXJcbiAgICovXG4gIGNvbnN0cnVjdG9yKGluaXQ6IFBhcnRpYWw8RXJyUmVzcG9uc2U+KSB7XG4gICAgc3VwZXIoaW5pdC5tZXNzYWdlKTtcbiAgICBPYmplY3QuYXNzaWduKHRoaXMsIGluaXQpO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrcyB3aGV0aGVyIHRoZSByb290IGNhdXNlIG9mIGFuIHtAbGluayBFcnJSZXNwb25zZX0gaXMgYW4gaW52YWxpZCBzZXNzaW9uLlxuICAgKlxuICAgKiBFeGFtcGxlcyBpbmNsdWRlOlxuICAgKiAtIHRoZSBzZXNzaW9uIGhhcyBleHBpcmVkXG4gICAqIC0gdGhlIHNlc3Npb24gaGFzIGJlZW4gcmV2b2tlZFxuICAgKiAtIHByb3ZpZGVkIGF1dGggdG9rZW4gaXMgaW52YWxpZC9tYWxmb3JtZWQvZXhwaXJlZFxuICAgKlxuICAgKiBAcmV0dXJuIHtib29sZWFufSBXaGV0aGVyIHRoZSByZXNwb25zZSBtYXRjaGVzIG9uZSBvZiBzZXZlcmFsIGRpZmZlcmVudCBcImludmFsaWQgc2Vzc2lvblwiIHJlc3BvbnNlcy5cbiAgICovXG4gIGlzU2Vzc2lvbkV4cGlyZWRFcnJvcigpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5lcnJvckNvZGUgIT09IHVuZGVmaW5lZCAmJiBpbnZhbGlkU2Vzc2lvbkVycm9yQ29kZXMuaW5jbHVkZXModGhpcy5lcnJvckNvZGUpO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrcyB3aGV0aGVyIHRoZSByb290IGNhdXNlIG9mIGFuIHtAbGluayBFcnJSZXNwb25zZX0gaXMgdGhlIHVzZXIgZmFpbGluZyB0byBhbnN3ZXIgYW4gTUZBIGNoYWxsZW5nZS5cbiAgICpcbiAgICogRXhhbXBsZXMgaW5jbHVkZTpcbiAgICogLSB1c2VyIHByb3ZpZGVzIGEgYmFkIFRPVFAgY29kZVxuICAgKiAtIHVzZXIgaXMgVE9UUC1yYXRlLWxpbWl0ZWQgKGJlY2F1c2Ugb2YgdG9vIG1hbnkgZmFpbGVkIGF0dGVtcHRzKVxuICAgKiAtIE1GQSBjaGFsbGVuZ2UgZXhwaXJlZFxuICAgKiAtIEZJRE8gY2hhbGxlbmdlIHZlcmlmaWNhdGlvbiBmYWlsZWRcbiAgICpcbiAgICogQHJldHVybiB7Ym9vbGVhbn0gV2hldGhlciB0aGUgZXJyb3Igd2FzIGNhdXNlZCBieSB0aGUgdXNlciBmYWlsaW5nIHRvIGF1dGhlbnRpY2F0ZSB3aXRoIE1GQVxuICAgKi9cbiAgaXNVc2VyTWZhRXJyb3IoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIChcbiAgICAgIHRoaXMuc3RhdHVzID09PSA0MDMgJiZcbiAgICAgICh0aGlzLm9wZXJhdGlvbiA9PT0gdW5kZWZpbmVkIHx8IG1mYU9wQ29kZXMuaW5jbHVkZXModGhpcy5vcGVyYXRpb24pKSAmJlxuICAgICAgKHRoaXMuZXJyb3JDb2RlID09PSB1bmRlZmluZWQgfHwgbWZhRXJyb3JDb2Rlcy5pbmNsdWRlcyh0aGlzLmVycm9yQ29kZSkpXG4gICAgKTtcbiAgfVxufVxuXG4vKipcbiAqIEFuIGVycm9yIHRoYXQgaXMgdGhyb3duIHdoZW4gYSBzZXNzaW9uIGhhcyBleHBpcmVkXG4gKi9cbmV4cG9ydCBjbGFzcyBTZXNzaW9uRXhwaXJlZEVycm9yIGV4dGVuZHMgRXJyUmVzcG9uc2Uge1xuICAvKipcbiAgICogQ29uc3RydWN0b3IuXG4gICAqXG4gICAqIEBwYXJhbSB7b3BlcmF0aW9uc30gb3BlcmF0aW9uIFRoZSBvcGVyYXRpb24gdGhhdCB3YXMgYXR0ZW1wdGVkXG4gICAqL1xuICBjb25zdHJ1Y3RvcihvcGVyYXRpb24/OiBrZXlvZiBvcGVyYXRpb25zKSB7XG4gICAgc3VwZXIoe1xuICAgICAgbWVzc2FnZTogXCJTZXNzaW9uIGhhcyBleHBpcmVkXCIsXG4gICAgICBzdGF0dXM6IDQwMyxcbiAgICAgIHN0YXR1c1RleHQ6IFwiRm9yYmlkZGVuXCIsXG4gICAgICBvcGVyYXRpb24sXG4gICAgICBlcnJvckNvZGU6IFwiU2Vzc2lvbkV4cGlyZWRcIixcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIEVycm9yIGNvZGVzIGNvcnJlc3BvbmRpbmcgdG8gYWxsIGRpZmZlcmVudCBcImludmFsaWQgc2Vzc2lvblwiIGVycm9yIHJlc3BvbnNlc1xuICovXG5jb25zdCBpbnZhbGlkU2Vzc2lvbkVycm9yQ29kZXM6IENzRXJyQ29kZVtdID0gW1xuICBcIlNlc3Npb25FeHBpcmVkXCIsXG4gIFwiU2Vzc2lvblJldm9rZWRcIixcbiAgXCJTZXNzaW9uTm90Rm91bmRcIixcbiAgXCJTZXNzaW9uSW52YWxpZEF1dGhUb2tlblwiLFxuICBcIlNlc3Npb25JbnZhbGlkRXBvY2hUb2tlblwiLFxuICBcIlNlc3Npb25JbnZhbGlkUmVmcmVzaFRva2VuXCIsXG4gIFwiU2Vzc2lvbkF1dGhUb2tlbkV4cGlyZWRcIixcbiAgXCJTZXNzaW9uUmVmcmVzaFRva2VuRXhwaXJlZFwiLFxuICBcIlNlc3Npb25Qb3NzaWJseVN0b2xlblRva2VuXCIsXG5dO1xuIl19
@@ -1,16 +1,12 @@
1
1
  import { ErrResponse } from "./error";
2
2
  export type EventHandler<T> = (event: T) => Promise<void>;
3
3
  export type ErrorEvent = ErrResponse;
4
- export interface SessionExpiredEvent {
4
+ /** Event emitted when a request fails because of an expired/invalid session */
5
+ export declare class SessionExpiredEvent {
6
+ }
7
+ /** Event emitted when a request fails because user failed to answer an MFA challenge */
8
+ export declare class UserMfaFailedEvent extends ErrResponse {
5
9
  }
6
- /**
7
- * Whether an error message matches one of several different "session expired" responses.
8
- *
9
- * @param {string} msg The string to test.
10
- * @return {boolean} Whether the string matches.
11
- * @internal Exported only so that it can be called from a unit test
12
- */
13
- export declare function messageMatchesSessionExpired(msg: string): boolean;
14
10
  /**
15
11
  * Class for registering and unregistering event handlers.
16
12
  */
@@ -30,6 +26,14 @@ export declare class Events {
30
26
  * @param {EventHandler<SessionExpiredEvent>} handler The handler to register.
31
27
  */
32
28
  onSessionExpired(handler: EventHandler<SessionExpiredEvent>): void;
29
+ /**
30
+ * Register a handler for {@link UserMfaFailedEvent}: triggered every time a
31
+ * request to a CubeSigner API endpoint fails because the user failed to
32
+ * answer an MFA challenge.
33
+ *
34
+ * @param {EventHandler<UserMfaFailedEvent>} handler The handler to register.
35
+ */
36
+ onUserMfaFailed(handler: EventHandler<UserMfaFailedEvent>): void;
33
37
  /**
34
38
  * Unregister a handler for {@link ErrorEvent}.
35
39
  *
@@ -44,8 +48,20 @@ export declare class Events {
44
48
  * @return {boolean} Whether the handler was found (and unregistered).
45
49
  */
46
50
  unregisterOnSessionExpired(handler: EventHandler<SessionExpiredEvent>): boolean;
51
+ /**
52
+ * Unregister a handler for {@link UserMfaFailedEvent}.
53
+ *
54
+ * @param {EventHandler<UserMfaFailedEvent>} handler The handler to unregister.
55
+ * @return {boolean} Whether the handler was found (and unregistered).
56
+ */
57
+ unregisterOnUserMfaFailed(handler: EventHandler<UserMfaFailedEvent>): boolean;
47
58
  /** @internal */
48
59
  triggerSessionExpired(): Promise<void>;
60
+ /**
61
+ * @param {UserMfaFailedEvent} ev The event to emit
62
+ * @internal
63
+ */
64
+ triggerUserMfaFailed(ev: UserMfaFailedEvent): Promise<void>;
49
65
  /**
50
66
  * @param {ErrorEvent} event Event to trigger
51
67
  * @internal
@@ -77,6 +93,12 @@ export declare class EventEmitter {
77
93
  * @internal
78
94
  */
79
95
  emitSessionExpired(): Promise<void>;
96
+ /**
97
+ * Emits {@link UserMfaFailedEvent} to all subscribers
98
+ *
99
+ * @param {UserMfaFailedEvent} ev The event to emit.
100
+ */
101
+ private emitUserMfaFailed;
80
102
  }
81
103
  /**
82
104
  * Global events.
@@ -10,9 +10,18 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
10
10
  if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
11
11
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
12
12
  };
13
- var _EventDispatcher_handlers, _Events_onError, _Events_onSessionExpired, _EventEmitter_events;
13
+ var _EventDispatcher_handlers, _Events_onError, _Events_onSessionExpired, _Events_onUserMfaFailed, _EventEmitter_events;
14
14
  Object.defineProperty(exports, "__esModule", { value: true });
15
- exports.GlobalEvents = exports.EventEmitter = exports.Events = exports.messageMatchesSessionExpired = void 0;
15
+ exports.GlobalEvents = exports.EventEmitter = exports.Events = exports.UserMfaFailedEvent = exports.SessionExpiredEvent = void 0;
16
+ const error_1 = require("./error");
17
+ /** Event emitted when a request fails because of an expired/invalid session */
18
+ class SessionExpiredEvent {
19
+ }
20
+ exports.SessionExpiredEvent = SessionExpiredEvent;
21
+ /** Event emitted when a request fails because user failed to answer an MFA challenge */
22
+ class UserMfaFailedEvent extends error_1.ErrResponse {
23
+ }
24
+ exports.UserMfaFailedEvent = UserMfaFailedEvent;
16
25
  /**
17
26
  * Dispatcher for a single event type.
18
27
  *
@@ -62,24 +71,6 @@ class EventDispatcher {
62
71
  }
63
72
  }
64
73
  _EventDispatcher_handlers = new WeakMap();
65
- const SessionExpiredRegexes = [
66
- /^Session '(?<purpose>[^']*)' for '(?<identity>[^']*)' has expired$/,
67
- /^Session '(?<purpose>[^']*)' for '(?<identity>[^']*)' has been revoked$/,
68
- /^Auth token for epoch (?<epoch>\d+) has expired$/,
69
- /^Refresh token for epoch (?<epoch_num>\d+) has expired$/,
70
- /^Outdated session$/,
71
- ];
72
- /**
73
- * Whether an error message matches one of several different "session expired" responses.
74
- *
75
- * @param {string} msg The string to test.
76
- * @return {boolean} Whether the string matches.
77
- * @internal Exported only so that it can be called from a unit test
78
- */
79
- function messageMatchesSessionExpired(msg) {
80
- return SessionExpiredRegexes.some((re) => re.test(msg));
81
- }
82
- exports.messageMatchesSessionExpired = messageMatchesSessionExpired;
83
74
  /**
84
75
  * Class for registering and unregistering event handlers.
85
76
  */
@@ -87,6 +78,7 @@ class Events {
87
78
  constructor() {
88
79
  _Events_onError.set(this, new EventDispatcher());
89
80
  _Events_onSessionExpired.set(this, new EventDispatcher());
81
+ _Events_onUserMfaFailed.set(this, new EventDispatcher());
90
82
  }
91
83
  /**
92
84
  * Register a handler for {@link ErrorEvent}: triggered every time a request to
@@ -106,6 +98,16 @@ class Events {
106
98
  onSessionExpired(handler) {
107
99
  __classPrivateFieldGet(this, _Events_onSessionExpired, "f").register(handler);
108
100
  }
101
+ /**
102
+ * Register a handler for {@link UserMfaFailedEvent}: triggered every time a
103
+ * request to a CubeSigner API endpoint fails because the user failed to
104
+ * answer an MFA challenge.
105
+ *
106
+ * @param {EventHandler<UserMfaFailedEvent>} handler The handler to register.
107
+ */
108
+ onUserMfaFailed(handler) {
109
+ __classPrivateFieldGet(this, _Events_onUserMfaFailed, "f").register(handler);
110
+ }
109
111
  /**
110
112
  * Unregister a handler for {@link ErrorEvent}.
111
113
  *
@@ -124,9 +126,25 @@ class Events {
124
126
  unregisterOnSessionExpired(handler) {
125
127
  return __classPrivateFieldGet(this, _Events_onSessionExpired, "f").unregister(handler);
126
128
  }
129
+ /**
130
+ * Unregister a handler for {@link UserMfaFailedEvent}.
131
+ *
132
+ * @param {EventHandler<UserMfaFailedEvent>} handler The handler to unregister.
133
+ * @return {boolean} Whether the handler was found (and unregistered).
134
+ */
135
+ unregisterOnUserMfaFailed(handler) {
136
+ return __classPrivateFieldGet(this, _Events_onUserMfaFailed, "f").unregister(handler);
137
+ }
127
138
  /** @internal */
128
139
  async triggerSessionExpired() {
129
- await __classPrivateFieldGet(this, _Events_onSessionExpired, "f").dispatch({});
140
+ await __classPrivateFieldGet(this, _Events_onSessionExpired, "f").dispatch(new SessionExpiredEvent());
141
+ }
142
+ /**
143
+ * @param {UserMfaFailedEvent} ev The event to emit
144
+ * @internal
145
+ */
146
+ async triggerUserMfaFailed(ev) {
147
+ await __classPrivateFieldGet(this, _Events_onUserMfaFailed, "f").dispatch(ev);
130
148
  }
131
149
  /**
132
150
  * @param {ErrorEvent} event Event to trigger
@@ -137,7 +155,7 @@ class Events {
137
155
  }
138
156
  }
139
157
  exports.Events = Events;
140
- _Events_onError = new WeakMap(), _Events_onSessionExpired = new WeakMap();
158
+ _Events_onError = new WeakMap(), _Events_onSessionExpired = new WeakMap(), _Events_onUserMfaFailed = new WeakMap();
141
159
  /**
142
160
  * Used to classify and emit events to one or more {@link Events} instances.
143
161
  */
@@ -165,12 +183,15 @@ class EventEmitter {
165
183
  for (const ev of __classPrivateFieldGet(this, _EventEmitter_events, "f")) {
166
184
  await ev.triggerErrorEvent(err);
167
185
  }
168
- // if status is 403 and error matches one of the SessionExpiredRegexes trigger onSessionExpired
186
+ if (err.isUserMfaError()) {
187
+ await this.emitUserMfaFailed(err);
188
+ }
189
+ // if status is 403 and error matches one of the "invalid session" error codes trigger onSessionExpired
169
190
  //
170
191
  // TODO: because errors returned by the authorizer lambda are not forwarded to the client
171
192
  // we also trigger onSessionExpired when "signerSessionRefresh" fails
172
193
  if (err.status === 403 &&
173
- (messageMatchesSessionExpired(err.message) || err.operation == "signerSessionRefresh")) {
194
+ (err.isSessionExpiredError() || err.operation == "signerSessionRefresh")) {
174
195
  await this.emitSessionExpired();
175
196
  }
176
197
  }
@@ -185,6 +206,16 @@ class EventEmitter {
185
206
  await e.triggerSessionExpired();
186
207
  }
187
208
  }
209
+ /**
210
+ * Emits {@link UserMfaFailedEvent} to all subscribers
211
+ *
212
+ * @param {UserMfaFailedEvent} ev The event to emit.
213
+ */
214
+ async emitUserMfaFailed(ev) {
215
+ for (const e of __classPrivateFieldGet(this, _EventEmitter_events, "f")) {
216
+ await e.triggerUserMfaFailed(ev);
217
+ }
218
+ }
188
219
  }
189
220
  exports.EventEmitter = EventEmitter;
190
221
  _EventEmitter_events = new WeakMap();
@@ -192,4 +223,4 @@ _EventEmitter_events = new WeakMap();
192
223
  * Global events.
193
224
  */
194
225
  exports.GlobalEvents = new Events();
195
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"events.js","sourceRoot":"","sources":["../../../src/events.ts"],"names":[],"mappings":"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","sourcesContent":["import { ErrResponse } from \"./error\";\n\nexport type EventHandler<T> = (event: T) => Promise<void>;\nexport type ErrorEvent = ErrResponse;\n\n/* eslint-disable-next-line @typescript-eslint/no-empty-interface */\nexport interface SessionExpiredEvent {}\n\n/**\n * Dispatcher for a single event type.\n *\n * Provides methods for registering and unregistering handlers,\n * as well as dispatching events to all registered handlers.\n */\nclass EventDispatcher<T> {\n  readonly #handlers: EventHandler<T>[];\n\n  /**\n   * Constructor.\n   */\n  constructor() {\n    this.#handlers = [];\n  }\n\n  /**\n   * Register a new handler.\n   *\n   * @param {EventHandler<T>} handler Event handler to register\n   * @return {EventDispatcher<T>} This instance to allow for chaining.\n   */\n  register(handler: EventHandler<T>): EventDispatcher<T> {\n    this.#handlers.push(handler);\n    return this;\n  }\n\n  /**\n   * Unregister a handler. If {@link handler} is not already registered, it's a no-op.\n   *\n   * @param {EventHandler<T>} handler Event handler to unregister\n   * @return {boolean} Whether the handler was found (and unregistered).\n   */\n  unregister(handler: EventHandler<T>): boolean {\n    const idx = this.#handlers.indexOf(handler);\n    if (idx >= 0) {\n      this.#handlers.splice(idx, 1);\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  /**\n   * Dispatch an event to all registered handlers.\n   * @param {T} event Event to dispatch.\n   */\n  async dispatch(event: T): Promise<void> {\n    await Promise.all(this.#handlers.map((h) => h(event)));\n  }\n}\n\nconst SessionExpiredRegexes = [\n  /^Session '(?<purpose>[^']*)' for '(?<identity>[^']*)' has expired$/,\n  /^Session '(?<purpose>[^']*)' for '(?<identity>[^']*)' has been revoked$/,\n  /^Auth token for epoch (?<epoch>\\d+) has expired$/,\n  /^Refresh token for epoch (?<epoch_num>\\d+) has expired$/,\n  /^Outdated session$/,\n];\n\n/**\n * Whether an error message matches one of several different \"session expired\" responses.\n *\n * @param {string} msg The string to test.\n * @return {boolean} Whether the string matches.\n * @internal Exported only so that it can be called from a unit test\n */\nexport function messageMatchesSessionExpired(msg: string): boolean {\n  return SessionExpiredRegexes.some((re) => re.test(msg));\n}\n\n/**\n * Class for registering and unregistering event handlers.\n */\nexport class Events {\n  readonly #onError = new EventDispatcher<ErrorEvent>();\n  readonly #onSessionExpired = new EventDispatcher<SessionExpiredEvent>();\n\n  /**\n   * Register a handler for {@link ErrorEvent}: triggered every time a request to\n   * a CubeSigner API endpoint returns a non-success response.\n   *\n   * @param {EventHandler<ErrorEvent>} handler The handler to register.\n   */\n  onError(handler: EventHandler<ErrorEvent>) {\n    this.#onError.register(handler);\n  }\n\n  /**\n   * Register a handler for {@link SessionExpiredEvent}: triggered every time a\n   * request to a CubeSigner API endpoint fails because of an expired session.\n   *\n   * @param {EventHandler<SessionExpiredEvent>} handler The handler to register.\n   */\n  onSessionExpired(handler: EventHandler<SessionExpiredEvent>) {\n    this.#onSessionExpired.register(handler);\n  }\n\n  /**\n   * Unregister a handler for {@link ErrorEvent}.\n   *\n   * @param {EventHandler<ErrorEvent>} handler The handler to unregister.\n   * @return {boolean} Whether the handler was found (and unregistered).\n   */\n  unregisterOnError(handler: EventHandler<ErrorEvent>): boolean {\n    return this.#onError.unregister(handler);\n  }\n\n  /**\n   * Unregister a handler for {@link SessionExpiredEvent}.\n   *\n   * @param {EventHandler<SessionExpiredEvent>} handler The handler to unregister.\n   * @return {boolean} Whether the handler was found (and unregistered).\n   */\n  unregisterOnSessionExpired(handler: EventHandler<SessionExpiredEvent>): boolean {\n    return this.#onSessionExpired.unregister(handler);\n  }\n\n  /** @internal */\n  async triggerSessionExpired() {\n    await this.#onSessionExpired.dispatch(<SessionExpiredEvent>{});\n  }\n\n  /**\n   * @param {ErrorEvent} event Event to trigger\n   * @internal\n   */\n  async triggerErrorEvent(event: ErrorEvent) {\n    await this.#onError.dispatch(event);\n  }\n}\n\n/**\n * Used to classify and emit events to one or more {@link Events} instances.\n */\nexport class EventEmitter {\n  readonly #events: Events[];\n\n  /**\n   *\n   * @param {Events[]} events Instances to which to emit events\n   * @param {boolean} skipGlobal Whether to include the global events instance {@link GlobalEvents}\n   */\n  constructor(events: Events[], skipGlobal?: boolean) {\n    skipGlobal ??= false;\n    this.#events = events;\n    if (!skipGlobal) {\n      this.#events.push(GlobalEvents);\n    }\n  }\n\n  /**\n   * Called by {@link CubeSignerApi} when an API response indicates an error.\n   *\n   * @param {ErrorEvent} err The error to dispatch.\n   * @internal\n   */\n  async classifyAndEmitError(err: ErrorEvent) {\n    for (const ev of this.#events) {\n      await ev.triggerErrorEvent(err);\n    }\n\n    // if status is 403 and error matches one of the SessionExpiredRegexes trigger onSessionExpired\n    //\n    // TODO: because errors returned by the authorizer lambda are not forwarded to the client\n    //       we also trigger onSessionExpired when \"signerSessionRefresh\" fails\n    if (\n      err.status === 403 &&\n      (messageMatchesSessionExpired(err.message) || err.operation == \"signerSessionRefresh\")\n    ) {\n      await this.emitSessionExpired();\n    }\n  }\n\n  /**\n   * Called by {@link SignerSessionManager} to notify that the session is expired\n   * beyond the possibility of refreshing, meaning that full re-login is required.\n   *\n   * @internal\n   */\n  async emitSessionExpired() {\n    for (const e of this.#events) {\n      await e.triggerSessionExpired();\n    }\n  }\n}\n\n/**\n * Global events.\n */\nexport const GlobalEvents = new Events();\n"]}
226
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"events.js","sourceRoot":"","sources":["../../../src/events.ts"],"names":[],"mappings":"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","sourcesContent":["import { ErrResponse } from \"./error\";\n\nexport type EventHandler<T> = (event: T) => Promise<void>;\nexport type ErrorEvent = ErrResponse;\n\n/** Event emitted when a request fails because of an expired/invalid session */\nexport class SessionExpiredEvent {}\n\n/** Event emitted when a request fails because user failed to answer an MFA challenge */\nexport class UserMfaFailedEvent extends ErrResponse {}\n\n/**\n * Dispatcher for a single event type.\n *\n * Provides methods for registering and unregistering handlers,\n * as well as dispatching events to all registered handlers.\n */\nclass EventDispatcher<T> {\n  readonly #handlers: EventHandler<T>[];\n\n  /**\n   * Constructor.\n   */\n  constructor() {\n    this.#handlers = [];\n  }\n\n  /**\n   * Register a new handler.\n   *\n   * @param {EventHandler<T>} handler Event handler to register\n   * @return {EventDispatcher<T>} This instance to allow for chaining.\n   */\n  register(handler: EventHandler<T>): EventDispatcher<T> {\n    this.#handlers.push(handler);\n    return this;\n  }\n\n  /**\n   * Unregister a handler. If {@link handler} is not already registered, it's a no-op.\n   *\n   * @param {EventHandler<T>} handler Event handler to unregister\n   * @return {boolean} Whether the handler was found (and unregistered).\n   */\n  unregister(handler: EventHandler<T>): boolean {\n    const idx = this.#handlers.indexOf(handler);\n    if (idx >= 0) {\n      this.#handlers.splice(idx, 1);\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  /**\n   * Dispatch an event to all registered handlers.\n   * @param {T} event Event to dispatch.\n   */\n  async dispatch(event: T): Promise<void> {\n    await Promise.all(this.#handlers.map((h) => h(event)));\n  }\n}\n\n/**\n * Class for registering and unregistering event handlers.\n */\nexport class Events {\n  readonly #onError = new EventDispatcher<ErrorEvent>();\n  readonly #onSessionExpired = new EventDispatcher<SessionExpiredEvent>();\n  readonly #onUserMfaFailed = new EventDispatcher<UserMfaFailedEvent>();\n\n  /**\n   * Register a handler for {@link ErrorEvent}: triggered every time a request to\n   * a CubeSigner API endpoint returns a non-success response.\n   *\n   * @param {EventHandler<ErrorEvent>} handler The handler to register.\n   */\n  onError(handler: EventHandler<ErrorEvent>) {\n    this.#onError.register(handler);\n  }\n\n  /**\n   * Register a handler for {@link SessionExpiredEvent}: triggered every time a\n   * request to a CubeSigner API endpoint fails because of an expired session.\n   *\n   * @param {EventHandler<SessionExpiredEvent>} handler The handler to register.\n   */\n  onSessionExpired(handler: EventHandler<SessionExpiredEvent>) {\n    this.#onSessionExpired.register(handler);\n  }\n\n  /**\n   * Register a handler for {@link UserMfaFailedEvent}: triggered every time a\n   * request to a CubeSigner API endpoint fails because the user failed to\n   * answer an MFA challenge.\n   *\n   * @param {EventHandler<UserMfaFailedEvent>} handler The handler to register.\n   */\n  onUserMfaFailed(handler: EventHandler<UserMfaFailedEvent>) {\n    this.#onUserMfaFailed.register(handler);\n  }\n\n  /**\n   * Unregister a handler for {@link ErrorEvent}.\n   *\n   * @param {EventHandler<ErrorEvent>} handler The handler to unregister.\n   * @return {boolean} Whether the handler was found (and unregistered).\n   */\n  unregisterOnError(handler: EventHandler<ErrorEvent>): boolean {\n    return this.#onError.unregister(handler);\n  }\n\n  /**\n   * Unregister a handler for {@link SessionExpiredEvent}.\n   *\n   * @param {EventHandler<SessionExpiredEvent>} handler The handler to unregister.\n   * @return {boolean} Whether the handler was found (and unregistered).\n   */\n  unregisterOnSessionExpired(handler: EventHandler<SessionExpiredEvent>): boolean {\n    return this.#onSessionExpired.unregister(handler);\n  }\n\n  /**\n   * Unregister a handler for {@link UserMfaFailedEvent}.\n   *\n   * @param {EventHandler<UserMfaFailedEvent>} handler The handler to unregister.\n   * @return {boolean} Whether the handler was found (and unregistered).\n   */\n  unregisterOnUserMfaFailed(handler: EventHandler<UserMfaFailedEvent>): boolean {\n    return this.#onUserMfaFailed.unregister(handler);\n  }\n\n  /** @internal */\n  async triggerSessionExpired() {\n    await this.#onSessionExpired.dispatch(new SessionExpiredEvent());\n  }\n\n  /**\n   * @param {UserMfaFailedEvent} ev The event to emit\n   * @internal\n   */\n  async triggerUserMfaFailed(ev: UserMfaFailedEvent) {\n    await this.#onUserMfaFailed.dispatch(ev);\n  }\n\n  /**\n   * @param {ErrorEvent} event Event to trigger\n   * @internal\n   */\n  async triggerErrorEvent(event: ErrorEvent) {\n    await this.#onError.dispatch(event);\n  }\n}\n\n/**\n * Used to classify and emit events to one or more {@link Events} instances.\n */\nexport class EventEmitter {\n  readonly #events: Events[];\n\n  /**\n   *\n   * @param {Events[]} events Instances to which to emit events\n   * @param {boolean} skipGlobal Whether to include the global events instance {@link GlobalEvents}\n   */\n  constructor(events: Events[], skipGlobal?: boolean) {\n    skipGlobal ??= false;\n    this.#events = events;\n    if (!skipGlobal) {\n      this.#events.push(GlobalEvents);\n    }\n  }\n\n  /**\n   * Called by {@link CubeSignerApi} when an API response indicates an error.\n   *\n   * @param {ErrorEvent} err The error to dispatch.\n   * @internal\n   */\n  async classifyAndEmitError(err: ErrorEvent) {\n    for (const ev of this.#events) {\n      await ev.triggerErrorEvent(err);\n    }\n\n    if (err.isUserMfaError()) {\n      await this.emitUserMfaFailed(err);\n    }\n\n    // if status is 403 and error matches one of the \"invalid session\" error codes trigger onSessionExpired\n    //\n    // TODO: because errors returned by the authorizer lambda are not forwarded to the client\n    //       we also trigger onSessionExpired when \"signerSessionRefresh\" fails\n    if (\n      err.status === 403 &&\n      (err.isSessionExpiredError() || err.operation == \"signerSessionRefresh\")\n    ) {\n      await this.emitSessionExpired();\n    }\n  }\n\n  /**\n   * Called by {@link SignerSessionManager} to notify that the session is expired\n   * beyond the possibility of refreshing, meaning that full re-login is required.\n   *\n   * @internal\n   */\n  async emitSessionExpired() {\n    for (const e of this.#events) {\n      await e.triggerSessionExpired();\n    }\n  }\n\n  /**\n   * Emits {@link UserMfaFailedEvent} to all subscribers\n   *\n   * @param {UserMfaFailedEvent} ev The event to emit.\n   */\n  private async emitUserMfaFailed(ev: UserMfaFailedEvent) {\n    for (const e of this.#events) {\n      await e.triggerUserMfaFailed(ev);\n    }\n  }\n}\n\n/**\n * Global events.\n */\nexport const GlobalEvents = new Events();\n"]}
@@ -26,7 +26,7 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (
26
26
  };
27
27
  var _CubeSigner_env, _CubeSigner_csc;
28
28
  Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.VERSION = exports.NAME = exports.userExportKeygen = exports.userExportDecrypt = exports.GlobalEvents = exports.Events = exports.CubeSigner = void 0;
29
+ exports.VERSION = exports.NAME = exports.userExportKeygen = exports.userExportDecrypt = exports.SessionExpiredEvent = exports.GlobalEvents = exports.Events = exports.CubeSigner = void 0;
30
30
  const env_1 = require("./env");
31
31
  const api_1 = require("./api");
32
32
  const client_1 = require("./client");
@@ -263,6 +263,7 @@ __exportStar(require("./client"), exports);
263
263
  var events_1 = require("./events");
264
264
  Object.defineProperty(exports, "Events", { enumerable: true, get: function () { return events_1.Events; } });
265
265
  Object.defineProperty(exports, "GlobalEvents", { enumerable: true, get: function () { return events_1.GlobalEvents; } });
266
+ Object.defineProperty(exports, "SessionExpiredEvent", { enumerable: true, get: function () { return events_1.SessionExpiredEvent; } });
266
267
  /** Organizations */
267
268
  __exportStar(require("./org"), exports);
268
269
  /** Keys */
@@ -295,4 +296,4 @@ Object.defineProperty(exports, "userExportKeygen", { enumerable: true, get: func
295
296
  exports.NAME = package_json_1.name;
296
297
  /** CubeSigner SDK version */
297
298
  exports.VERSION = package_json_1.version;
298
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { envs, EnvInterface } from \"./env\";\nimport { Client, OidcClient } from \"./api\";\nimport { CubeSignerClient } from \"./client\";\nimport { Org } from \"./org\";\n\nimport {\n  SignerSessionStorage,\n  SignerSessionManager,\n  SignerSessionData,\n} from \"./session/signer_session_manager\";\nimport { CubeSignerResponse } from \"./response\";\nimport { SignerSession } from \"./signer_session\";\nimport { MfaReceipt } from \"./mfa\";\nimport { name, version } from \"./../package.json\";\nimport { IdentityProof, MfaRequestInfo, RatchetConfig, UserInfo } from \"./schema_types\";\n\n/** CubeSigner constructor options */\nexport interface CubeSignerOptions {\n  /** The environment to use */\n  env?: EnvInterface;\n  /** The management authorization token */\n  sessionMgr?: SignerSessionManager;\n  /** Optional organization id */\n  orgId?: string;\n}\n\n/**\n * CubeSigner client\n *\n * @deprecated Use {@link Org} or {@link CubeSignerClient} instead.\n */\nexport class CubeSigner {\n  readonly #env: EnvInterface;\n  readonly sessionMgr?: SignerSessionManager;\n  #csc?: CubeSignerClient;\n\n  /**\n   * Underlying {@link CubeSignerClient} instance, if set; otherwise throws.\n   * @internal\n   */\n  get csc(): CubeSignerClient {\n    if (!this.#csc) {\n      throw new Error(\"CubeSignerClient is not set\");\n    }\n    return this.#csc;\n  }\n\n  /** @return {EnvInterface} The CubeSigner environment of this client */\n  get env(): EnvInterface {\n    return this.#env;\n  }\n\n  /** Organization ID */\n  get orgId() {\n    return this.csc.orgId;\n  }\n\n  /**\n   * Set the organization ID\n   * @param {string} orgId The new organization id.\n   */\n  setOrgId(orgId: string) {\n    this.#csc = this.csc.withOrg(orgId);\n  }\n\n  /**\n   * Loads an existing management session and creates a CubeSigner instance.\n   *\n   * @param {SignerSessionStorage} storage Session storage to load the session from.\n   * @return {Promise<CubeSigner>} New CubeSigner instance\n   */\n  static async loadManagementSession(storage: SignerSessionStorage): Promise<CubeSigner> {\n    return new CubeSigner(<CubeSignerOptions>{\n      sessionMgr: await SignerSessionManager.loadFromStorage(storage),\n    });\n  }\n\n  /**\n   * Loads a signer session from a session storage (e.g., session file).\n   * @param {SignerSessionStorage} storage Session storage to load the session from.\n   * @return {Promise<SignerSession>} New signer session\n   */\n  static async loadSignerSession(storage: SignerSessionStorage): Promise<SignerSession> {\n    return await SignerSession.loadSignerSession(storage);\n  }\n\n  /**\n   * Create a new CubeSigner instance.\n   * @param {CubeSignerOptions} options The optional configuration options for the CubeSigner instance.\n   */\n  constructor(options?: CubeSignerOptions) {\n    let env = options?.env;\n    if (options?.sessionMgr) {\n      this.sessionMgr = options.sessionMgr;\n      env = env ?? this.sessionMgr.env;\n    }\n    this.#env = env ?? envs[\"gamma\"];\n    this.#csc = new CubeSignerClient(\n      // HACK: ignore that sessionMgr may be a CognitoSessionManager and pretend that it\n      //       is a SignerSessionManager; that's fine because the CubeSignerClient will\n      //       almost always just call `await token()` on it, which works in both cases.\n      //\n      // This is done here for backward compatibility reasons only; in the future,\n      // we should deprecate this class and people should start using `CubeSingerClient` directly.\n      options?.sessionMgr as unknown as SignerSessionManager,\n      options?.orgId,\n    );\n  }\n\n  /**\n   * Authenticate an OIDC user and create a new session manager for them.\n   *\n   * @param {string} oidcToken The OIDC token\n   * @param {string} orgId The id of the organization that the user is in\n   * @param {List<string>} scopes The scopes of the resulting session\n   * @param {RatchetConfig} lifetimes Lifetimes of the new session.\n   * @param {SignerSessionStorage?} storage Optional signer session storage (defaults to in-memory storage)\n   * @return {Promise<SignerSessionManager>} The signer session manager\n   */\n  async oidcAuth(\n    oidcToken: string,\n    orgId: string,\n    scopes: Array<string>,\n    lifetimes?: RatchetConfig,\n    storage?: SignerSessionStorage,\n  ): Promise<SignerSessionManager> {\n    const resp = await this.oidcLogin(oidcToken, orgId, scopes, lifetimes);\n    return await SignerSessionManager.createFromSessionInfo(this.env, orgId, resp.data(), storage);\n  }\n\n  /**\n   * Retrieves information about the current user.\n   *\n   * @return {Promise<UserInfo>} User information.\n   */\n  async aboutMe(): Promise<UserInfo> {\n    return await this.csc.userGet();\n  }\n\n  /**\n   * Retrieves existing MFA request.\n   *\n   * @param {string} orgId Organization ID\n   * @param {string} mfaId MFA request ID\n   * @return {Promise<MfaRequestInfo>} MFA request information\n   */\n  async mfaGet(orgId: string, mfaId: string): Promise<MfaRequestInfo> {\n    return await this.csc.withOrg(orgId).mfaGet(mfaId);\n  }\n\n  /**\n   * List pending MFA requests accessible to the current user.\n   * @param {string} orgId Organization ID\n   * @return {Promise<MfaRequestInfo[]>} The MFA requests.\n   */\n  async mfaList(orgId: string): Promise<MfaRequestInfo[]> {\n    return await this.csc.withOrg(orgId).mfaList();\n  }\n\n  /**\n   * Approve a pending MFA request.\n   *\n   * @param {string} orgId The org id of the MFA request\n   * @param {string} mfaId The id of the MFA request\n   * @return {Promise<MfaRequestInfo>} The result of the MFA request\n   */\n  async mfaApprove(orgId: string, mfaId: string): Promise<MfaRequestInfo> {\n    return await this.csc.withOrg(orgId).mfaApprove(mfaId);\n  }\n\n  /** Initiate adding a new FIDO device. MFA may be required. */\n  get addFidoStart() {\n    return this.csc.userFidoRegisterInit.bind(this.csc);\n  }\n\n  /**\n   * Creates a request to change user's TOTP. This request returns a new TOTP challenge\n   * that must be answered by calling `resetTotpComplete`\n   */\n  get resetTotpStart() {\n    return this.csc.userTotpResetInit.bind(this.#csc);\n  }\n\n  /**\n   * Answer the TOTP challenge issued by `resetTotpStart`. If successful, user's\n   * TOTP configuration will be updated to that of the TOTP challenge.he TOTP configuration from the challenge.\n   */\n  get resetTotpComplete() {\n    return this.csc.userTotpResetComplete.bind(this.#csc);\n  }\n\n  /**\n   * Verifies a given TOTP code against the current user's TOTP configuration.\n   * Throws an error if the verification fails.\n   */\n  get verifyTotp() {\n    return this.csc.userTotpVerify.bind(this.#csc);\n  }\n\n  /**\n   * Retrieve information about an organization.\n   * @param {string} orgId The ID or name of the organization.\n   * @return {Org} The organization.\n   */\n  async getOrg(orgId?: string): Promise<Org> {\n    return new Org(this.csc.sessionMgr, orgId ?? this.csc.orgId);\n  }\n\n  /**\n   * Deletes a given key.\n   * @param {string} orgId - Organization id\n   * @param {string} keyId - Key id\n   */\n  async deleteKey(orgId: string, keyId: string) {\n    await this.csc.withOrg(orgId).keyDelete(keyId);\n  }\n\n  /**\n   * Get the management client.\n   * @return {Client} The client.\n   * @internal\n   */\n  async management(): Promise<Client> {\n    if (!this.sessionMgr) {\n      throw new Error(\"No management session loaded\");\n    }\n    return await this.sessionMgr.client();\n  }\n\n  /**\n   * Obtain a proof of authentication.\n   *\n   * @param {string} orgId The id of the organization that the user is in\n   * @return {Promise<IdentityProof>} Proof of authentication\n   */\n  async proveIdentity(orgId: string): Promise<IdentityProof> {\n    return await this.csc.withOrg(orgId).identityProve();\n  }\n\n  /**\n   * Exchange an OIDC token for a proof of authentication.\n   *\n   * @param {string} oidcToken The OIDC token\n   * @param {string} orgId The id of the organization that the user is in\n   * @return {Promise<IdentityProof>} Proof of authentication\n   */\n  async oidcProveIdentity(oidcToken: string, orgId: string): Promise<IdentityProof> {\n    const oidcClient = new OidcClient(this.#env, orgId, oidcToken);\n    return await oidcClient.identityProve();\n  }\n\n  /**\n   * Checks if a given identity proof is valid.\n   *\n   * @param {string} orgId The id of the organization that the user is in.\n   * @param {IdentityProof} identityProof The proof of authentication.\n   */\n  async verifyIdentity(orgId: string, identityProof: IdentityProof) {\n    await this.csc.withOrg(orgId).identityVerify(identityProof);\n  }\n\n  /**\n   * Exchange an OIDC token for a CubeSigner session token.\n   * @param {string} oidcToken The OIDC token\n   * @param {string} orgId The id of the organization that the user is in\n   * @param {List<string>} scopes The scopes of the resulting session\n   * @param {RatchetConfig} lifetimes Lifetimes of the new session.\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt (id + confirmation code)\n   * @return {Promise<CubeSignerResponse<SignerSessionData>>} The session data.\n   */\n  async oidcLogin(\n    oidcToken: string,\n    orgId: string,\n    scopes: Array<string>,\n    lifetimes?: RatchetConfig,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<SignerSessionData>> {\n    const oidcClient = new OidcClient(this.#env, orgId, oidcToken);\n    return await oidcClient.sessionCreate(scopes, lifetimes, mfaReceipt);\n  }\n}\n\n/** Errors */\nexport * from \"./error\";\n/** API */\nexport * from \"./api\";\n/** Client */\nexport * from \"./client\";\n/** Callbacks */\nexport { Events, EventHandler, ErrorEvent, GlobalEvents, SessionExpiredEvent } from \"./events\";\n/** Organizations */\nexport * from \"./org\";\n/** Keys */\nexport * from \"./key\";\n/** Roles */\nexport * from \"./role\";\n/** Env */\nexport * from \"./env\";\n/** Fido */\nexport * from \"./mfa\";\n/** Pagination */\nexport * from \"./paginator\";\n/** Response */\nexport * from \"./response\";\n/** Types */\nexport * from \"./schema_types\";\n/** Sessions */\nexport * from \"./signer_session\";\n/** Session storage */\nexport * from \"./session/session_storage\";\n/** Signer session manager */\nexport * from \"./session/signer_session_manager\";\n/** Utils */\nexport * from \"./util\";\n/** User-export decryption helper */\nexport { userExportDecrypt, userExportKeygen } from \"./user_export\";\n\n/** CubeSigner SDK package name */\nexport const NAME: string = name;\n\n/** CubeSigner SDK version */\nexport const VERSION: string = version;\n"]}
299
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { envs, EnvInterface } from \"./env\";\nimport { Client, OidcClient } from \"./api\";\nimport { CubeSignerClient } from \"./client\";\nimport { Org } from \"./org\";\n\nimport {\n  SignerSessionStorage,\n  SignerSessionManager,\n  SignerSessionData,\n} from \"./session/signer_session_manager\";\nimport { CubeSignerResponse } from \"./response\";\nimport { SignerSession } from \"./signer_session\";\nimport { MfaReceipt } from \"./mfa\";\nimport { name, version } from \"./../package.json\";\nimport { IdentityProof, MfaRequestInfo, RatchetConfig, UserInfo } from \"./schema_types\";\n\n/** CubeSigner constructor options */\nexport interface CubeSignerOptions {\n  /** The environment to use */\n  env?: EnvInterface;\n  /** The management authorization token */\n  sessionMgr?: SignerSessionManager;\n  /** Optional organization id */\n  orgId?: string;\n}\n\n/**\n * CubeSigner client\n *\n * @deprecated Use {@link Org} or {@link CubeSignerClient} instead.\n */\nexport class CubeSigner {\n  readonly #env: EnvInterface;\n  readonly sessionMgr?: SignerSessionManager;\n  #csc?: CubeSignerClient;\n\n  /**\n   * Underlying {@link CubeSignerClient} instance, if set; otherwise throws.\n   * @internal\n   */\n  get csc(): CubeSignerClient {\n    if (!this.#csc) {\n      throw new Error(\"CubeSignerClient is not set\");\n    }\n    return this.#csc;\n  }\n\n  /** @return {EnvInterface} The CubeSigner environment of this client */\n  get env(): EnvInterface {\n    return this.#env;\n  }\n\n  /** Organization ID */\n  get orgId() {\n    return this.csc.orgId;\n  }\n\n  /**\n   * Set the organization ID\n   * @param {string} orgId The new organization id.\n   */\n  setOrgId(orgId: string) {\n    this.#csc = this.csc.withOrg(orgId);\n  }\n\n  /**\n   * Loads an existing management session and creates a CubeSigner instance.\n   *\n   * @param {SignerSessionStorage} storage Session storage to load the session from.\n   * @return {Promise<CubeSigner>} New CubeSigner instance\n   */\n  static async loadManagementSession(storage: SignerSessionStorage): Promise<CubeSigner> {\n    return new CubeSigner(<CubeSignerOptions>{\n      sessionMgr: await SignerSessionManager.loadFromStorage(storage),\n    });\n  }\n\n  /**\n   * Loads a signer session from a session storage (e.g., session file).\n   * @param {SignerSessionStorage} storage Session storage to load the session from.\n   * @return {Promise<SignerSession>} New signer session\n   */\n  static async loadSignerSession(storage: SignerSessionStorage): Promise<SignerSession> {\n    return await SignerSession.loadSignerSession(storage);\n  }\n\n  /**\n   * Create a new CubeSigner instance.\n   * @param {CubeSignerOptions} options The optional configuration options for the CubeSigner instance.\n   */\n  constructor(options?: CubeSignerOptions) {\n    let env = options?.env;\n    if (options?.sessionMgr) {\n      this.sessionMgr = options.sessionMgr;\n      env = env ?? this.sessionMgr.env;\n    }\n    this.#env = env ?? envs[\"gamma\"];\n    this.#csc = new CubeSignerClient(\n      // HACK: ignore that sessionMgr may be a CognitoSessionManager and pretend that it\n      //       is a SignerSessionManager; that's fine because the CubeSignerClient will\n      //       almost always just call `await token()` on it, which works in both cases.\n      //\n      // This is done here for backward compatibility reasons only; in the future,\n      // we should deprecate this class and people should start using `CubeSingerClient` directly.\n      options?.sessionMgr as unknown as SignerSessionManager,\n      options?.orgId,\n    );\n  }\n\n  /**\n   * Authenticate an OIDC user and create a new session manager for them.\n   *\n   * @param {string} oidcToken The OIDC token\n   * @param {string} orgId The id of the organization that the user is in\n   * @param {List<string>} scopes The scopes of the resulting session\n   * @param {RatchetConfig} lifetimes Lifetimes of the new session.\n   * @param {SignerSessionStorage?} storage Optional signer session storage (defaults to in-memory storage)\n   * @return {Promise<SignerSessionManager>} The signer session manager\n   */\n  async oidcAuth(\n    oidcToken: string,\n    orgId: string,\n    scopes: Array<string>,\n    lifetimes?: RatchetConfig,\n    storage?: SignerSessionStorage,\n  ): Promise<SignerSessionManager> {\n    const resp = await this.oidcLogin(oidcToken, orgId, scopes, lifetimes);\n    return await SignerSessionManager.createFromSessionInfo(this.env, orgId, resp.data(), storage);\n  }\n\n  /**\n   * Retrieves information about the current user.\n   *\n   * @return {Promise<UserInfo>} User information.\n   */\n  async aboutMe(): Promise<UserInfo> {\n    return await this.csc.userGet();\n  }\n\n  /**\n   * Retrieves existing MFA request.\n   *\n   * @param {string} orgId Organization ID\n   * @param {string} mfaId MFA request ID\n   * @return {Promise<MfaRequestInfo>} MFA request information\n   */\n  async mfaGet(orgId: string, mfaId: string): Promise<MfaRequestInfo> {\n    return await this.csc.withOrg(orgId).mfaGet(mfaId);\n  }\n\n  /**\n   * List pending MFA requests accessible to the current user.\n   * @param {string} orgId Organization ID\n   * @return {Promise<MfaRequestInfo[]>} The MFA requests.\n   */\n  async mfaList(orgId: string): Promise<MfaRequestInfo[]> {\n    return await this.csc.withOrg(orgId).mfaList();\n  }\n\n  /**\n   * Approve a pending MFA request.\n   *\n   * @param {string} orgId The org id of the MFA request\n   * @param {string} mfaId The id of the MFA request\n   * @return {Promise<MfaRequestInfo>} The result of the MFA request\n   */\n  async mfaApprove(orgId: string, mfaId: string): Promise<MfaRequestInfo> {\n    return await this.csc.withOrg(orgId).mfaApprove(mfaId);\n  }\n\n  /** Initiate adding a new FIDO device. MFA may be required. */\n  get addFidoStart() {\n    return this.csc.userFidoRegisterInit.bind(this.csc);\n  }\n\n  /**\n   * Creates a request to change user's TOTP. This request returns a new TOTP challenge\n   * that must be answered by calling `resetTotpComplete`\n   */\n  get resetTotpStart() {\n    return this.csc.userTotpResetInit.bind(this.#csc);\n  }\n\n  /**\n   * Answer the TOTP challenge issued by `resetTotpStart`. If successful, user's\n   * TOTP configuration will be updated to that of the TOTP challenge.he TOTP configuration from the challenge.\n   */\n  get resetTotpComplete() {\n    return this.csc.userTotpResetComplete.bind(this.#csc);\n  }\n\n  /**\n   * Verifies a given TOTP code against the current user's TOTP configuration.\n   * Throws an error if the verification fails.\n   */\n  get verifyTotp() {\n    return this.csc.userTotpVerify.bind(this.#csc);\n  }\n\n  /**\n   * Retrieve information about an organization.\n   * @param {string} orgId The ID or name of the organization.\n   * @return {Org} The organization.\n   */\n  async getOrg(orgId?: string): Promise<Org> {\n    return new Org(this.csc.sessionMgr, orgId ?? this.csc.orgId);\n  }\n\n  /**\n   * Deletes a given key.\n   * @param {string} orgId - Organization id\n   * @param {string} keyId - Key id\n   */\n  async deleteKey(orgId: string, keyId: string) {\n    await this.csc.withOrg(orgId).keyDelete(keyId);\n  }\n\n  /**\n   * Get the management client.\n   * @return {Client} The client.\n   * @internal\n   */\n  async management(): Promise<Client> {\n    if (!this.sessionMgr) {\n      throw new Error(\"No management session loaded\");\n    }\n    return await this.sessionMgr.client();\n  }\n\n  /**\n   * Obtain a proof of authentication.\n   *\n   * @param {string} orgId The id of the organization that the user is in\n   * @return {Promise<IdentityProof>} Proof of authentication\n   */\n  async proveIdentity(orgId: string): Promise<IdentityProof> {\n    return await this.csc.withOrg(orgId).identityProve();\n  }\n\n  /**\n   * Exchange an OIDC token for a proof of authentication.\n   *\n   * @param {string} oidcToken The OIDC token\n   * @param {string} orgId The id of the organization that the user is in\n   * @return {Promise<IdentityProof>} Proof of authentication\n   */\n  async oidcProveIdentity(oidcToken: string, orgId: string): Promise<IdentityProof> {\n    const oidcClient = new OidcClient(this.#env, orgId, oidcToken);\n    return await oidcClient.identityProve();\n  }\n\n  /**\n   * Checks if a given identity proof is valid.\n   *\n   * @param {string} orgId The id of the organization that the user is in.\n   * @param {IdentityProof} identityProof The proof of authentication.\n   */\n  async verifyIdentity(orgId: string, identityProof: IdentityProof) {\n    await this.csc.withOrg(orgId).identityVerify(identityProof);\n  }\n\n  /**\n   * Exchange an OIDC token for a CubeSigner session token.\n   * @param {string} oidcToken The OIDC token\n   * @param {string} orgId The id of the organization that the user is in\n   * @param {List<string>} scopes The scopes of the resulting session\n   * @param {RatchetConfig} lifetimes Lifetimes of the new session.\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt (id + confirmation code)\n   * @return {Promise<CubeSignerResponse<SignerSessionData>>} The session data.\n   */\n  async oidcLogin(\n    oidcToken: string,\n    orgId: string,\n    scopes: Array<string>,\n    lifetimes?: RatchetConfig,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<SignerSessionData>> {\n    const oidcClient = new OidcClient(this.#env, orgId, oidcToken);\n    return await oidcClient.sessionCreate(scopes, lifetimes, mfaReceipt);\n  }\n}\n\n/** Errors */\nexport * from \"./error\";\n/** API */\nexport * from \"./api\";\n/** Client */\nexport * from \"./client\";\n/** Callbacks */\nexport { Events, EventHandler, ErrorEvent, GlobalEvents, SessionExpiredEvent } from \"./events\";\n/** Organizations */\nexport * from \"./org\";\n/** Keys */\nexport * from \"./key\";\n/** Roles */\nexport * from \"./role\";\n/** Env */\nexport * from \"./env\";\n/** Fido */\nexport * from \"./mfa\";\n/** Pagination */\nexport * from \"./paginator\";\n/** Response */\nexport * from \"./response\";\n/** Types */\nexport * from \"./schema_types\";\n/** Sessions */\nexport * from \"./signer_session\";\n/** Session storage */\nexport * from \"./session/session_storage\";\n/** Signer session manager */\nexport * from \"./session/signer_session_manager\";\n/** Utils */\nexport * from \"./util\";\n/** User-export decryption helper */\nexport { userExportDecrypt, userExportKeygen } from \"./user_export\";\n\n/** CubeSigner SDK package name */\nexport const NAME: string = name;\n\n/** CubeSigner SDK version */\nexport const VERSION: string = version;\n"]}