@cubist-labs/cubesigner-sdk 0.2.17 → 0.2.21

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.
@@ -335,7 +335,7 @@ export declare class CubeSignerClient extends CubeSignerApi {
335
335
  /**
336
336
  * Get a pending MFA request by its id.
337
337
  *
338
- * Same as {@link CubeSignerClient.getMfaInfo}
338
+ * Same as {@link mfaGet}
339
339
  */
340
340
  get getMfaInfo(): (mfaId: string) => Promise<{
341
341
  expires_at: number;
@@ -367,7 +367,7 @@ export declare class CubeSignerClient extends CubeSignerApi {
367
367
  /**
368
368
  * List pending MFA requests accessible to the current user.
369
369
  *
370
- * Same as {@link CubeSignerClient.mfaList}
370
+ * Same as {@link mfaList}
371
371
  */
372
372
  get listMfaInfos(): () => Promise<{
373
373
  expires_at: number;
@@ -399,7 +399,7 @@ export declare class CubeSignerClient extends CubeSignerApi {
399
399
  /**
400
400
  * Obtain a proof of authentication.
401
401
  *
402
- * Same as {@link CubeSignerClient.identityProve}
402
+ * Same as {@link identityProve}
403
403
  */
404
404
  get proveIdentity(): () => Promise<{
405
405
  aud?: string | null | undefined;
@@ -426,7 +426,7 @@ export declare class CubeSignerClient extends CubeSignerApi {
426
426
  /**
427
427
  * Check if a given proof of OIDC authentication is valid.
428
428
  *
429
- * Same as {@link CubeSignerClient.identityVerify}
429
+ * Same as {@link identityVerify}
430
430
  */
431
431
  get verifyIdentity(): (proof: {
432
432
  aud?: string | null | undefined;
@@ -457,31 +457,51 @@ export declare class CubeSignerClient extends CubeSignerApi {
457
457
  *
458
458
  * MFA may be required.
459
459
  *
460
- * Same as {@link CubeSignerClient.userRegisterFidoInit}
460
+ * Same as {@link userFidoRegisterInit}
461
461
  */
462
462
  get addFidoStart(): (name: string, mfaReceipt?: MfaReceipt | undefined) => Promise<import("./response").CubeSignerResponse<AddFidoChallenge>>;
463
+ /**
464
+ * Delete a FIDO key from the user's account.
465
+ * Allowed only if TOTP is also defined.
466
+ * MFA via TOTP is always required.
467
+ *
468
+ * Same as {@link userFidoDelete}
469
+ */
470
+ get deleteFido(): (fidoId: string, mfaReceipt?: MfaReceipt | undefined) => Promise<import("./response").CubeSignerResponse<{
471
+ status: string;
472
+ }>>;
463
473
  /**
464
474
  * Creates a request to change user's TOTP. Returns a {@link TotpChallenge}
465
475
  * that must be answered by calling {@link TotpChallenge.answer} or
466
476
  * {@link resetTotpComplete}.
467
477
  *
468
- * Same as {@link userResetTotpInit}
478
+ * Same as {@link userTotpResetInit}
469
479
  */
470
480
  get resetTotpStart(): (issuer?: string | undefined, mfaReceipt?: MfaReceipt | undefined) => Promise<import("./response").CubeSignerResponse<TotpChallenge>>;
471
481
  /**
472
482
  * Answer the TOTP challenge issued by {@link resetTotpStart}. If successful,
473
483
  * user's TOTP configuration will be updated to that of the TOTP challenge.
474
484
  *
475
- * Same as {@link userResetTotpComplete}
485
+ * Same as {@link userTotpResetComplete}
476
486
  */
477
487
  get resetTotpComplete(): (totpId: string, code: string) => Promise<void>;
478
488
  /**
479
489
  * Verifies a given TOTP code against the current user's TOTP configuration.
480
490
  * Throws an error if the verification fails.
481
491
  *
482
- * Same as {@link userVerifyTotp}
492
+ * Same as {@link userTotpVerify}
483
493
  */
484
494
  get verifyTotp(): (code: string) => Promise<void>;
495
+ /**
496
+ * Delete TOTP from the user's account.
497
+ * Allowed only if at least one FIDO key is registered with the user's account.
498
+ * MFA via FIDO is always required.
499
+ *
500
+ * Same as {@link userTotpDelete}.
501
+ */
502
+ get deleteTotp(): (mfaReceipt?: MfaReceipt | undefined) => Promise<import("./response").CubeSignerResponse<{
503
+ status: string;
504
+ }>>;
485
505
  /**
486
506
  * Sign a stake request.
487
507
  *
@@ -267,7 +267,7 @@ class CubeSignerClient extends api_1.CubeSignerApi {
267
267
  /**
268
268
  * Get a pending MFA request by its id.
269
269
  *
270
- * Same as {@link CubeSignerClient.getMfaInfo}
270
+ * Same as {@link mfaGet}
271
271
  */
272
272
  get getMfaInfo() {
273
273
  return this.mfaGet.bind(this);
@@ -275,7 +275,7 @@ class CubeSignerClient extends api_1.CubeSignerApi {
275
275
  /**
276
276
  * List pending MFA requests accessible to the current user.
277
277
  *
278
- * Same as {@link CubeSignerClient.mfaList}
278
+ * Same as {@link mfaList}
279
279
  */
280
280
  get listMfaInfos() {
281
281
  return this.mfaList.bind(this);
@@ -283,7 +283,7 @@ class CubeSignerClient extends api_1.CubeSignerApi {
283
283
  /**
284
284
  * Obtain a proof of authentication.
285
285
  *
286
- * Same as {@link CubeSignerClient.identityProve}
286
+ * Same as {@link identityProve}
287
287
  */
288
288
  get proveIdentity() {
289
289
  return this.identityProve.bind(this);
@@ -291,7 +291,7 @@ class CubeSignerClient extends api_1.CubeSignerApi {
291
291
  /**
292
292
  * Check if a given proof of OIDC authentication is valid.
293
293
  *
294
- * Same as {@link CubeSignerClient.identityVerify}
294
+ * Same as {@link identityVerify}
295
295
  */
296
296
  get verifyIdentity() {
297
297
  return this.identityVerify.bind(this);
@@ -303,38 +303,58 @@ class CubeSignerClient extends api_1.CubeSignerApi {
303
303
  *
304
304
  * MFA may be required.
305
305
  *
306
- * Same as {@link CubeSignerClient.userRegisterFidoInit}
306
+ * Same as {@link userFidoRegisterInit}
307
307
  */
308
308
  get addFidoStart() {
309
- return this.userRegisterFidoInit.bind(this);
309
+ return this.userFidoRegisterInit.bind(this);
310
+ }
311
+ /**
312
+ * Delete a FIDO key from the user's account.
313
+ * Allowed only if TOTP is also defined.
314
+ * MFA via TOTP is always required.
315
+ *
316
+ * Same as {@link userFidoDelete}
317
+ */
318
+ get deleteFido() {
319
+ return this.userFidoDelete.bind(this);
310
320
  }
311
321
  /**
312
322
  * Creates a request to change user's TOTP. Returns a {@link TotpChallenge}
313
323
  * that must be answered by calling {@link TotpChallenge.answer} or
314
324
  * {@link resetTotpComplete}.
315
325
  *
316
- * Same as {@link userResetTotpInit}
326
+ * Same as {@link userTotpResetInit}
317
327
  */
318
328
  get resetTotpStart() {
319
- return this.userResetTotpInit.bind(this);
329
+ return this.userTotpResetInit.bind(this);
320
330
  }
321
331
  /**
322
332
  * Answer the TOTP challenge issued by {@link resetTotpStart}. If successful,
323
333
  * user's TOTP configuration will be updated to that of the TOTP challenge.
324
334
  *
325
- * Same as {@link userResetTotpComplete}
335
+ * Same as {@link userTotpResetComplete}
326
336
  */
327
337
  get resetTotpComplete() {
328
- return this.userResetTotpComplete.bind(this);
338
+ return this.userTotpResetComplete.bind(this);
329
339
  }
330
340
  /**
331
341
  * Verifies a given TOTP code against the current user's TOTP configuration.
332
342
  * Throws an error if the verification fails.
333
343
  *
334
- * Same as {@link userVerifyTotp}
344
+ * Same as {@link userTotpVerify}
335
345
  */
336
346
  get verifyTotp() {
337
- return this.userVerifyTotp.bind(this);
347
+ return this.userTotpVerify.bind(this);
348
+ }
349
+ /**
350
+ * Delete TOTP from the user's account.
351
+ * Allowed only if at least one FIDO key is registered with the user's account.
352
+ * MFA via FIDO is always required.
353
+ *
354
+ * Same as {@link userTotpDelete}.
355
+ */
356
+ get deleteTotp() {
357
+ return this.userTotpDelete.bind(this);
338
358
  }
339
359
  /**
340
360
  * Sign a stake request.
@@ -354,4 +374,4 @@ class CubeSignerClient extends api_1.CubeSignerApi {
354
374
  }
355
375
  }
356
376
  exports.CubeSignerClient = CubeSignerClient;
357
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/client.ts"],"names":[],"mappings":"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","sourcesContent":["import { SignerSessionManager, SignerSessionStorage } from \"./session/signer_session_manager\";\nimport { CognitoSessionManager } from \"./session/cognito_manager\";\nimport { CubeSignerApi, OidcClient } from \"./api\";\nimport { KeyType, Key } from \"./key\";\nimport { OrgInfo, RatchetConfig } from \"./schema_types\";\nimport { MfaReceipt } from \"./mfa\";\nimport { PageOpts } from \"./paginator\";\nimport { Role } from \"./role\";\n\n// used in doc comments\n// eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\nimport { AddFidoChallenge, MfaFidoChallenge, TotpChallenge } from \"./mfa\";\nimport { MemorySessionStorage } from \"./session/session_storage\";\n\n/** Options for logging in with OIDC token */\nexport interface OidcAuthOptions {\n  /** Optional token lifetimes */\n  lifetimes?: RatchetConfig;\n  /** Optional MFA receipt */\n  mfaReceipt?: MfaReceipt;\n  /** Optional storage to use for the returned session (defaults to {@link MemorySessionStorage}) */\n  storage?: SignerSessionStorage;\n}\n\n/**\n * Client to use to send requests to CubeSigner services\n * when authenticating using a CubeSigner session token.\n */\nexport class CubeSignerClient extends CubeSignerApi {\n  /**\n   * Constructor.\n   * @param {SignerSessionManager} sessionMgr The session manager to use\n   * @param {string?} orgId Optional organization ID; if omitted, uses the org ID from the session manager.\n   */\n  constructor(sessionMgr: SignerSessionManager, orgId?: string) {\n    super(sessionMgr, orgId);\n  }\n\n  /**\n   * Returns a new instance of this class using the same session manager but targeting a different organization.\n   *\n   * @param {string} orgId The organization ID.\n   * @return {CubeSignerClient} A new instance of this class using the same session manager but targeting different organization.\n   */\n  withOrg(orgId?: string): CubeSignerClient {\n    return orgId ? new CubeSignerClient(this.sessionMgr, orgId) : this;\n  }\n\n  /**\n   * Loads an existing management session and creates a {@link CubeSignerClient} instance.\n   *\n   * @return {Promise<CubeSignerClient>} New CubeSigner instance\n   */\n  static async loadManagementSession(): Promise<CubeSignerClient> {\n    const mgr = await CognitoSessionManager.loadManagementSession();\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    // NOTE: This will go away once `cs login` starts producing signer sessions.\n    return new CubeSignerClient(mgr as unknown as SignerSessionManager);\n  }\n\n  /**\n   * Create a new signing key.\n   * @param {KeyType} type The type of key to create.\n   * @param {string?} ownerId The owner of the key. Defaults to the session's user.\n   * @return {Key[]} The new keys.\n   */\n  async createKey(type: KeyType, ownerId?: string): Promise<Key> {\n    return (await this.createKeys(type, 1, ownerId))[0];\n  }\n\n  /**\n   * Create new signing keys.\n   * @param {KeyType} type The type of key to create.\n   * @param {number} count The number of keys to create.\n   * @param {string?} ownerId The owner of the keys. Defaults to the session's user.\n   * @return {Key[]} The new keys.\n   */\n  async createKeys(type: KeyType, count: number, ownerId?: string): Promise<Key[]> {\n    const keys = await this.keysCreate(type, count, ownerId);\n    return keys.map((k) => new Key(this, k));\n  }\n\n  /**\n   * Derive a key of the given type using the given derivation path and mnemonic.\n   * The owner of the derived key will be the owner of the mnemonic.\n   *\n   * @param {KeyType} type Type of key to derive from the mnemonic.\n   * @param {string} derivationPath Mnemonic derivation path used to generate new key.\n   * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.\n   *\n   * @return {Key} newly derived key or undefined if it already exists.\n   */\n  async deriveKey(\n    type: KeyType,\n    derivationPath: string,\n    mnemonicId: string,\n  ): Promise<Key | undefined> {\n    return (await this.deriveKeys(type, [derivationPath], mnemonicId))[0];\n  }\n\n  /**\n   * Derive a set of keys of the given type using the given derivation paths and mnemonic.\n   *\n   * The owner of the derived keys will be the owner of the mnemonic.\n   *\n   * @param {KeyType} type Type of key to derive from the mnemonic.\n   * @param {string[]} derivationPaths Mnemonic derivation paths used to generate new key.\n   * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.\n   *\n   * @return {Key[]} newly derived keys.\n   */\n  async deriveKeys(type: KeyType, derivationPaths: string[], mnemonicId: string): Promise<Key[]> {\n    const keys = await this.keysDerive(type, derivationPaths, mnemonicId);\n    return keys.map((k) => new Key(this, k));\n  }\n\n  /**\n   * Create a new {@link OidcClient} that will use a given OIDC token for auth.\n   * @param {string} oidcToken The authentication token to use\n   * @return {OidcClient} New OIDC client.\n   */\n  newOidcClient(oidcToken: string): OidcClient {\n    return new OidcClient(this.sessionMgr.env, this.orgId, oidcToken);\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 {List<string>} scopes The scopes of the resulting session\n   * @param {OidcAuthOptions} options Options.\n   * @return {Promise<SignerSessionManager>} The signer session manager\n   */\n  async oidcAuth(\n    oidcToken: string,\n    scopes: Array<string>,\n    options?: OidcAuthOptions,\n  ): Promise<SignerSessionManager> {\n    const oidcClient = this.newOidcClient(oidcToken);\n    const resp = await oidcClient.sessionCreate(scopes, options?.lifetimes, options?.mfaReceipt);\n    return await SignerSessionManager.loadFromStorage(new MemorySessionStorage(resp.data()));\n  }\n\n  /**\n   * Create a new user in the organization and sends an invitation to that user.\n   *\n   * Same as {@link orgUserInvite}.\n   */\n  get createUser() {\n    return this.orgUserInvite.bind(this);\n  }\n\n  /**\n   * Create a new OIDC user.\n   *\n   * Same as {@link orgUserCreateOidc}.\n   */\n  get createOidcUser() {\n    return this.orgUserCreateOidc.bind(this);\n  }\n\n  /**\n   * Delete an existing OIDC user.\n   *\n   * Same as {@link orgUserDeleteOidc}.\n   */\n  get deleteOidcUser() {\n    return this.orgUserDeleteOidc.bind(this);\n  }\n\n  /**\n   * List users in the organization.\n   *\n   * Same as {@link orgUsersList}\n   */\n  get users() {\n    return this.orgUsersList.bind(this);\n  }\n\n  /**\n   * Obtain information about the current user.\n   *\n   * Same as {@link userGet}\n   */\n  get user() {\n    return this.userGet.bind(this);\n  }\n\n  /**\n   * Get information about a specific org.\n   *\n   * @param {string?} orgId The ID or name of the org\n   * @return {Promise<OrgInfo>} CubeSigner client for the requested org.\n   */\n  async org(orgId?: string): Promise<OrgInfo> {\n    return await this.withOrg(orgId).orgGet();\n  }\n\n  /**\n   * Obtain information about the current user.\n   *\n   * Same as {@link userGet}\n   */\n  get aboutMe() {\n    return this.userGet.bind(this);\n  }\n\n  /**\n   * Get a key by id.\n   *\n   * @param {string} keyId The id of the key to get.\n   * @return {Key} The key.\n   */\n  async getKey(keyId: string): Promise<Key> {\n    const keyInfo = await this.keyGet(keyId);\n    return new Key(this, keyInfo);\n  }\n\n  /**\n   * Get all keys in the org.\n   *\n   * @param {KeyType?} type Optional key type to filter list for.\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Promise<Key[]>} The keys.\n   */\n  async orgKeys(type?: KeyType, page?: PageOpts): Promise<Key[]> {\n    const paginator = this.keysList(type, page);\n    const keys = await paginator.fetch();\n    return keys.map((k) => new Key(this, k));\n  }\n\n  /**\n   * Create a new role.\n   *\n   * @param {string?} name The name of the role.\n   * @return {Role} The new role.\n   */\n  async createRole(name?: string): Promise<Role> {\n    const roleId = await this.roleCreate(name);\n    const roleInfo = await this.roleGet(roleId);\n    return new Role(this, roleInfo);\n  }\n\n  /**\n   * Get a role by id or name.\n   *\n   * @param {string} roleId The id or name of the role to get.\n   * @return {Role} The role.\n   */\n  async getRole(roleId: string): Promise<Role> {\n    const roleInfo = await this.roleGet(roleId);\n    return new Role(this, roleInfo);\n  }\n\n  /**\n   * List all roles in the org.\n   *\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Role[]} The roles.\n   */\n  async listRoles(page?: PageOpts): Promise<Role[]> {\n    const roles = await this.rolesList(page).fetch();\n    return roles.map((r) => new Role(this, r));\n  }\n\n  /**\n   * List all users in the org.\n   *\n   * Same as {@link orgUsersList}\n   */\n  get listUsers() {\n    return this.orgUsersList.bind(this);\n  }\n\n  /**\n   * Approve a pending MFA request.\n   *\n   * Same as {@link mfaApprove}\n   */\n  get approveMfaRequest() {\n    return this.mfaApprove.bind(this);\n  }\n\n  /**\n   * Approve a pending MFA request using TOTP.\n   *\n   * Same as {@link mfaApproveTotp}\n   */\n  get totpApprove() {\n    return this.mfaApproveTotp.bind(this);\n  }\n\n  /**\n   * Initiate approval of an existing MFA request using FIDO.\n   *\n   * Returns a {@link MfaFidoChallenge} that must be answered by calling\n   * {@link MfaFidoChallenge.answer} or {@link fidoApproveComplete}.\n   *\n   * Same as {@link mfaApproveFidoInit}\n   */\n  get fidoApproveStart() {\n    return this.mfaApproveFidoInit.bind(this);\n  }\n\n  /**\n   * Answer the MFA approval with FIDO challenge issued by {@link fidoApproveStart}.\n   *\n   * Same as {@link mfaApproveFidoComplete}\n   */\n  get fidoApproveComplete() {\n    return this.mfaApproveFidoComplete.bind(this);\n  }\n\n  /**\n   * Get a pending MFA request by its id.\n   *\n   * Same as {@link CubeSignerClient.getMfaInfo}\n   */\n  get getMfaInfo() {\n    return this.mfaGet.bind(this);\n  }\n\n  /**\n   * List pending MFA requests accessible to the current user.\n   *\n   * Same as {@link CubeSignerClient.mfaList}\n   */\n  get listMfaInfos() {\n    return this.mfaList.bind(this);\n  }\n\n  /**\n   * Obtain a proof of authentication.\n   *\n   * Same as {@link CubeSignerClient.identityProve}\n   */\n  get proveIdentity() {\n    return this.identityProve.bind(this);\n  }\n\n  /**\n   * Check if a given proof of OIDC authentication is valid.\n   *\n   * Same as {@link CubeSignerClient.identityVerify}\n   */\n  get verifyIdentity() {\n    return this.identityVerify.bind(this);\n  }\n\n  /**\n   * Creates a request to add a new FIDO device.\n   *\n   * Returns a {@link AddFidoChallenge} that must be answered by calling {@link AddFidoChallenge.answer}.\n   *\n   * MFA may be required.\n   *\n   * Same as {@link CubeSignerClient.userRegisterFidoInit}\n   */\n  get addFidoStart() {\n    return this.userRegisterFidoInit.bind(this);\n  }\n\n  /**\n   * Creates a request to change user's TOTP. Returns a {@link TotpChallenge}\n   * that must be answered by calling {@link TotpChallenge.answer} or\n   * {@link resetTotpComplete}.\n   *\n   * Same as {@link userResetTotpInit}\n   */\n  get resetTotpStart() {\n    return this.userResetTotpInit.bind(this);\n  }\n\n  /**\n   * Answer the TOTP challenge issued by {@link resetTotpStart}. If successful,\n   * user's TOTP configuration will be updated to that of the TOTP challenge.\n   *\n   * Same as {@link userResetTotpComplete}\n   */\n  get resetTotpComplete() {\n    return this.userResetTotpComplete.bind(this);\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   * Same as {@link userVerifyTotp}\n   */\n  get verifyTotp() {\n    return this.userVerifyTotp.bind(this);\n  }\n\n  /**\n   * Sign a stake request.\n   *\n   * Same as {@link signStake}\n   */\n  get stake() {\n    return this.signStake.bind(this);\n  }\n\n  /**\n   * Sign an unstake request.\n   *\n   * Same as {@link signUnstake}\n   */\n  get unstake() {\n    return this.signUnstake.bind(this);\n  }\n}\n"]}
377
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/client.ts"],"names":[],"mappings":"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","sourcesContent":["import { SignerSessionManager, SignerSessionStorage } from \"./session/signer_session_manager\";\nimport { CognitoSessionManager } from \"./session/cognito_manager\";\nimport { CubeSignerApi, OidcClient } from \"./api\";\nimport { KeyType, Key } from \"./key\";\nimport { OrgInfo, RatchetConfig } from \"./schema_types\";\nimport { MfaReceipt } from \"./mfa\";\nimport { PageOpts } from \"./paginator\";\nimport { Role } from \"./role\";\n\n// used in doc comments\n// eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\nimport { AddFidoChallenge, MfaFidoChallenge, TotpChallenge } from \"./mfa\";\nimport { MemorySessionStorage } from \"./session/session_storage\";\n\n/** Options for logging in with OIDC token */\nexport interface OidcAuthOptions {\n  /** Optional token lifetimes */\n  lifetimes?: RatchetConfig;\n  /** Optional MFA receipt */\n  mfaReceipt?: MfaReceipt;\n  /** Optional storage to use for the returned session (defaults to {@link MemorySessionStorage}) */\n  storage?: SignerSessionStorage;\n}\n\n/**\n * Client to use to send requests to CubeSigner services\n * when authenticating using a CubeSigner session token.\n */\nexport class CubeSignerClient extends CubeSignerApi {\n  /**\n   * Constructor.\n   * @param {SignerSessionManager} sessionMgr The session manager to use\n   * @param {string?} orgId Optional organization ID; if omitted, uses the org ID from the session manager.\n   */\n  constructor(sessionMgr: SignerSessionManager, orgId?: string) {\n    super(sessionMgr, orgId);\n  }\n\n  /**\n   * Returns a new instance of this class using the same session manager but targeting a different organization.\n   *\n   * @param {string} orgId The organization ID.\n   * @return {CubeSignerClient} A new instance of this class using the same session manager but targeting different organization.\n   */\n  withOrg(orgId?: string): CubeSignerClient {\n    return orgId ? new CubeSignerClient(this.sessionMgr, orgId) : this;\n  }\n\n  /**\n   * Loads an existing management session and creates a {@link CubeSignerClient} instance.\n   *\n   * @return {Promise<CubeSignerClient>} New CubeSigner instance\n   */\n  static async loadManagementSession(): Promise<CubeSignerClient> {\n    const mgr = await CognitoSessionManager.loadManagementSession();\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    // NOTE: This will go away once `cs login` starts producing signer sessions.\n    return new CubeSignerClient(mgr as unknown as SignerSessionManager);\n  }\n\n  /**\n   * Create a new signing key.\n   * @param {KeyType} type The type of key to create.\n   * @param {string?} ownerId The owner of the key. Defaults to the session's user.\n   * @return {Key[]} The new keys.\n   */\n  async createKey(type: KeyType, ownerId?: string): Promise<Key> {\n    return (await this.createKeys(type, 1, ownerId))[0];\n  }\n\n  /**\n   * Create new signing keys.\n   * @param {KeyType} type The type of key to create.\n   * @param {number} count The number of keys to create.\n   * @param {string?} ownerId The owner of the keys. Defaults to the session's user.\n   * @return {Key[]} The new keys.\n   */\n  async createKeys(type: KeyType, count: number, ownerId?: string): Promise<Key[]> {\n    const keys = await this.keysCreate(type, count, ownerId);\n    return keys.map((k) => new Key(this, k));\n  }\n\n  /**\n   * Derive a key of the given type using the given derivation path and mnemonic.\n   * The owner of the derived key will be the owner of the mnemonic.\n   *\n   * @param {KeyType} type Type of key to derive from the mnemonic.\n   * @param {string} derivationPath Mnemonic derivation path used to generate new key.\n   * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.\n   *\n   * @return {Key} newly derived key or undefined if it already exists.\n   */\n  async deriveKey(\n    type: KeyType,\n    derivationPath: string,\n    mnemonicId: string,\n  ): Promise<Key | undefined> {\n    return (await this.deriveKeys(type, [derivationPath], mnemonicId))[0];\n  }\n\n  /**\n   * Derive a set of keys of the given type using the given derivation paths and mnemonic.\n   *\n   * The owner of the derived keys will be the owner of the mnemonic.\n   *\n   * @param {KeyType} type Type of key to derive from the mnemonic.\n   * @param {string[]} derivationPaths Mnemonic derivation paths used to generate new key.\n   * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.\n   *\n   * @return {Key[]} newly derived keys.\n   */\n  async deriveKeys(type: KeyType, derivationPaths: string[], mnemonicId: string): Promise<Key[]> {\n    const keys = await this.keysDerive(type, derivationPaths, mnemonicId);\n    return keys.map((k) => new Key(this, k));\n  }\n\n  /**\n   * Create a new {@link OidcClient} that will use a given OIDC token for auth.\n   * @param {string} oidcToken The authentication token to use\n   * @return {OidcClient} New OIDC client.\n   */\n  newOidcClient(oidcToken: string): OidcClient {\n    return new OidcClient(this.sessionMgr.env, this.orgId, oidcToken);\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 {List<string>} scopes The scopes of the resulting session\n   * @param {OidcAuthOptions} options Options.\n   * @return {Promise<SignerSessionManager>} The signer session manager\n   */\n  async oidcAuth(\n    oidcToken: string,\n    scopes: Array<string>,\n    options?: OidcAuthOptions,\n  ): Promise<SignerSessionManager> {\n    const oidcClient = this.newOidcClient(oidcToken);\n    const resp = await oidcClient.sessionCreate(scopes, options?.lifetimes, options?.mfaReceipt);\n    return await SignerSessionManager.loadFromStorage(new MemorySessionStorage(resp.data()));\n  }\n\n  /**\n   * Create a new user in the organization and sends an invitation to that user.\n   *\n   * Same as {@link orgUserInvite}.\n   */\n  get createUser() {\n    return this.orgUserInvite.bind(this);\n  }\n\n  /**\n   * Create a new OIDC user.\n   *\n   * Same as {@link orgUserCreateOidc}.\n   */\n  get createOidcUser() {\n    return this.orgUserCreateOidc.bind(this);\n  }\n\n  /**\n   * Delete an existing OIDC user.\n   *\n   * Same as {@link orgUserDeleteOidc}.\n   */\n  get deleteOidcUser() {\n    return this.orgUserDeleteOidc.bind(this);\n  }\n\n  /**\n   * List users in the organization.\n   *\n   * Same as {@link orgUsersList}\n   */\n  get users() {\n    return this.orgUsersList.bind(this);\n  }\n\n  /**\n   * Obtain information about the current user.\n   *\n   * Same as {@link userGet}\n   */\n  get user() {\n    return this.userGet.bind(this);\n  }\n\n  /**\n   * Get information about a specific org.\n   *\n   * @param {string?} orgId The ID or name of the org\n   * @return {Promise<OrgInfo>} CubeSigner client for the requested org.\n   */\n  async org(orgId?: string): Promise<OrgInfo> {\n    return await this.withOrg(orgId).orgGet();\n  }\n\n  /**\n   * Obtain information about the current user.\n   *\n   * Same as {@link userGet}\n   */\n  get aboutMe() {\n    return this.userGet.bind(this);\n  }\n\n  /**\n   * Get a key by id.\n   *\n   * @param {string} keyId The id of the key to get.\n   * @return {Key} The key.\n   */\n  async getKey(keyId: string): Promise<Key> {\n    const keyInfo = await this.keyGet(keyId);\n    return new Key(this, keyInfo);\n  }\n\n  /**\n   * Get all keys in the org.\n   *\n   * @param {KeyType?} type Optional key type to filter list for.\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Promise<Key[]>} The keys.\n   */\n  async orgKeys(type?: KeyType, page?: PageOpts): Promise<Key[]> {\n    const paginator = this.keysList(type, page);\n    const keys = await paginator.fetch();\n    return keys.map((k) => new Key(this, k));\n  }\n\n  /**\n   * Create a new role.\n   *\n   * @param {string?} name The name of the role.\n   * @return {Role} The new role.\n   */\n  async createRole(name?: string): Promise<Role> {\n    const roleId = await this.roleCreate(name);\n    const roleInfo = await this.roleGet(roleId);\n    return new Role(this, roleInfo);\n  }\n\n  /**\n   * Get a role by id or name.\n   *\n   * @param {string} roleId The id or name of the role to get.\n   * @return {Role} The role.\n   */\n  async getRole(roleId: string): Promise<Role> {\n    const roleInfo = await this.roleGet(roleId);\n    return new Role(this, roleInfo);\n  }\n\n  /**\n   * List all roles in the org.\n   *\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Role[]} The roles.\n   */\n  async listRoles(page?: PageOpts): Promise<Role[]> {\n    const roles = await this.rolesList(page).fetch();\n    return roles.map((r) => new Role(this, r));\n  }\n\n  /**\n   * List all users in the org.\n   *\n   * Same as {@link orgUsersList}\n   */\n  get listUsers() {\n    return this.orgUsersList.bind(this);\n  }\n\n  /**\n   * Approve a pending MFA request.\n   *\n   * Same as {@link mfaApprove}\n   */\n  get approveMfaRequest() {\n    return this.mfaApprove.bind(this);\n  }\n\n  /**\n   * Approve a pending MFA request using TOTP.\n   *\n   * Same as {@link mfaApproveTotp}\n   */\n  get totpApprove() {\n    return this.mfaApproveTotp.bind(this);\n  }\n\n  /**\n   * Initiate approval of an existing MFA request using FIDO.\n   *\n   * Returns a {@link MfaFidoChallenge} that must be answered by calling\n   * {@link MfaFidoChallenge.answer} or {@link fidoApproveComplete}.\n   *\n   * Same as {@link mfaApproveFidoInit}\n   */\n  get fidoApproveStart() {\n    return this.mfaApproveFidoInit.bind(this);\n  }\n\n  /**\n   * Answer the MFA approval with FIDO challenge issued by {@link fidoApproveStart}.\n   *\n   * Same as {@link mfaApproveFidoComplete}\n   */\n  get fidoApproveComplete() {\n    return this.mfaApproveFidoComplete.bind(this);\n  }\n\n  /**\n   * Get a pending MFA request by its id.\n   *\n   * Same as {@link mfaGet}\n   */\n  get getMfaInfo() {\n    return this.mfaGet.bind(this);\n  }\n\n  /**\n   * List pending MFA requests accessible to the current user.\n   *\n   * Same as {@link mfaList}\n   */\n  get listMfaInfos() {\n    return this.mfaList.bind(this);\n  }\n\n  /**\n   * Obtain a proof of authentication.\n   *\n   * Same as {@link identityProve}\n   */\n  get proveIdentity() {\n    return this.identityProve.bind(this);\n  }\n\n  /**\n   * Check if a given proof of OIDC authentication is valid.\n   *\n   * Same as {@link identityVerify}\n   */\n  get verifyIdentity() {\n    return this.identityVerify.bind(this);\n  }\n\n  /**\n   * Creates a request to add a new FIDO device.\n   *\n   * Returns a {@link AddFidoChallenge} that must be answered by calling {@link AddFidoChallenge.answer}.\n   *\n   * MFA may be required.\n   *\n   * Same as {@link userFidoRegisterInit}\n   */\n  get addFidoStart() {\n    return this.userFidoRegisterInit.bind(this);\n  }\n\n  /**\n   * Delete a FIDO key from the user's account.\n   * Allowed only if TOTP is also defined.\n   * MFA via TOTP is always required.\n   *\n   * Same as {@link userFidoDelete}\n   */\n  get deleteFido() {\n    return this.userFidoDelete.bind(this);\n  }\n\n  /**\n   * Creates a request to change user's TOTP. Returns a {@link TotpChallenge}\n   * that must be answered by calling {@link TotpChallenge.answer} or\n   * {@link resetTotpComplete}.\n   *\n   * Same as {@link userTotpResetInit}\n   */\n  get resetTotpStart() {\n    return this.userTotpResetInit.bind(this);\n  }\n\n  /**\n   * Answer the TOTP challenge issued by {@link resetTotpStart}. If successful,\n   * user's TOTP configuration will be updated to that of the TOTP challenge.\n   *\n   * Same as {@link userTotpResetComplete}\n   */\n  get resetTotpComplete() {\n    return this.userTotpResetComplete.bind(this);\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   * Same as {@link userTotpVerify}\n   */\n  get verifyTotp() {\n    return this.userTotpVerify.bind(this);\n  }\n\n  /**\n   * Delete TOTP from the user's account.\n   * Allowed only if at least one FIDO key is registered with the user's account.\n   * MFA via FIDO is always required.\n   *\n   * Same as {@link userTotpDelete}.\n   */\n  get deleteTotp() {\n    return this.userTotpDelete.bind(this);\n  }\n\n  /**\n   * Sign a stake request.\n   *\n   * Same as {@link signStake}\n   */\n  get stake() {\n    return this.signStake.bind(this);\n  }\n\n  /**\n   * Sign an unstake request.\n   *\n   * Same as {@link signUnstake}\n   */\n  get unstake() {\n    return this.signUnstake.bind(this);\n  }\n}\n"]}
@@ -0,0 +1,84 @@
1
+ import { ErrResponse } from "./api";
2
+ export type EventHandler<T> = (event: T) => Promise<void>;
3
+ export type ErrorEvent = ErrResponse;
4
+ export interface SessionExpiredEvent {
5
+ }
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
+ /**
15
+ * Class for registering and unregistering event handlers.
16
+ */
17
+ export declare class Events {
18
+ #private;
19
+ /**
20
+ * Register a handler for {@link ErrorEvent}: triggered every time a request to
21
+ * a CubeSigner API endpoint returns a non-success response.
22
+ *
23
+ * @param {EventHandler<ErrorEvent>} handler The handler to register.
24
+ */
25
+ onError(handler: EventHandler<ErrorEvent>): void;
26
+ /**
27
+ * Register a handler for {@link SessionExpiredEvent}: triggered every time a
28
+ * request to a CubeSigner API endpoint fails because of an expired session.
29
+ *
30
+ * @param {EventHandler<SessionExpiredEvent>} handler The handler to register.
31
+ */
32
+ onSessionExpired(handler: EventHandler<SessionExpiredEvent>): void;
33
+ /**
34
+ * Unregister a handler for {@link ErrorEvent}.
35
+ *
36
+ * @param {EventHandler<ErrorEvent>} handler The handler to unregister.
37
+ * @return {boolean} Whether the handler was found (and unregistered).
38
+ */
39
+ unregisterOnError(handler: EventHandler<ErrorEvent>): boolean;
40
+ /**
41
+ * Unregister a handler for {@link SessionExpiredEvent}.
42
+ *
43
+ * @param {EventHandler<SessionExpiredEvent>} handler The handler to unregister.
44
+ * @return {boolean} Whether the handler was found (and unregistered).
45
+ */
46
+ unregisterOnSessionExpired(handler: EventHandler<SessionExpiredEvent>): boolean;
47
+ /** @internal */
48
+ triggerSessionExpired(): Promise<void>;
49
+ /**
50
+ * @param {ErrorEvent} event Event to trigger
51
+ * @internal
52
+ */
53
+ triggerErrorEvent(event: ErrorEvent): Promise<void>;
54
+ }
55
+ /**
56
+ * Used to classify and emit events to one or more {@link Events} instances.
57
+ */
58
+ export declare class EventEmitter {
59
+ #private;
60
+ /**
61
+ *
62
+ * @param {Events[]} events Instances to which to emit events
63
+ * @param {boolean} skipGlobal Whether to include the global events instance {@link GlobalEvents}
64
+ */
65
+ constructor(events: Events[], skipGlobal?: boolean);
66
+ /**
67
+ * Called by {@link CubeSignerApi} when an API response indicates an error.
68
+ *
69
+ * @param {ErrorEvent} err The error to dispatch.
70
+ * @internal
71
+ */
72
+ classifyAndEmitError(err: ErrorEvent): Promise<void>;
73
+ /**
74
+ * Called by {@link SignerSessionManager} to notify that the session is expired
75
+ * beyond the possibility of refreshing, meaning that full re-login is required.
76
+ *
77
+ * @internal
78
+ */
79
+ emitSessionExpired(): Promise<void>;
80
+ }
81
+ /**
82
+ * Global events.
83
+ */
84
+ export declare const GlobalEvents: Events;
@@ -0,0 +1,195 @@
1
+ "use strict";
2
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
3
+ if (kind === "m") throw new TypeError("Private method is not writable");
4
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
5
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
6
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
7
+ };
8
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
9
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
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
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
12
+ };
13
+ var _EventDispatcher_handlers, _Events_onError, _Events_onSessionExpired, _EventEmitter_events;
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.GlobalEvents = exports.EventEmitter = exports.Events = exports.messageMatchesSessionExpired = void 0;
16
+ /**
17
+ * Dispatcher for a single event type.
18
+ *
19
+ * Provides methods for registering and unregistering handlers,
20
+ * as well as dispatching events to all registered handlers.
21
+ */
22
+ class EventDispatcher {
23
+ /**
24
+ * Constructor.
25
+ */
26
+ constructor() {
27
+ _EventDispatcher_handlers.set(this, void 0);
28
+ __classPrivateFieldSet(this, _EventDispatcher_handlers, [], "f");
29
+ }
30
+ /**
31
+ * Register a new handler.
32
+ *
33
+ * @param {EventHandler<T>} handler Event handler to register
34
+ * @return {EventDispatcher<T>} This instance to allow for chaining.
35
+ */
36
+ register(handler) {
37
+ __classPrivateFieldGet(this, _EventDispatcher_handlers, "f").push(handler);
38
+ return this;
39
+ }
40
+ /**
41
+ * Unregister a handler. If {@link handler} is not already registered, it's a no-op.
42
+ *
43
+ * @param {EventHandler<T>} handler Event handler to unregister
44
+ * @return {boolean} Whether the handler was found (and unregistered).
45
+ */
46
+ unregister(handler) {
47
+ const idx = __classPrivateFieldGet(this, _EventDispatcher_handlers, "f").indexOf(handler);
48
+ if (idx >= 0) {
49
+ __classPrivateFieldGet(this, _EventDispatcher_handlers, "f").splice(idx, 1);
50
+ return true;
51
+ }
52
+ else {
53
+ return false;
54
+ }
55
+ }
56
+ /**
57
+ * Dispatch an event to all registered handlers.
58
+ * @param {T} event Event to dispatch.
59
+ */
60
+ async dispatch(event) {
61
+ await Promise.all(__classPrivateFieldGet(this, _EventDispatcher_handlers, "f").map((h) => h(event)));
62
+ }
63
+ }
64
+ _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
+ /**
84
+ * Class for registering and unregistering event handlers.
85
+ */
86
+ class Events {
87
+ constructor() {
88
+ _Events_onError.set(this, new EventDispatcher());
89
+ _Events_onSessionExpired.set(this, new EventDispatcher());
90
+ }
91
+ /**
92
+ * Register a handler for {@link ErrorEvent}: triggered every time a request to
93
+ * a CubeSigner API endpoint returns a non-success response.
94
+ *
95
+ * @param {EventHandler<ErrorEvent>} handler The handler to register.
96
+ */
97
+ onError(handler) {
98
+ __classPrivateFieldGet(this, _Events_onError, "f").register(handler);
99
+ }
100
+ /**
101
+ * Register a handler for {@link SessionExpiredEvent}: triggered every time a
102
+ * request to a CubeSigner API endpoint fails because of an expired session.
103
+ *
104
+ * @param {EventHandler<SessionExpiredEvent>} handler The handler to register.
105
+ */
106
+ onSessionExpired(handler) {
107
+ __classPrivateFieldGet(this, _Events_onSessionExpired, "f").register(handler);
108
+ }
109
+ /**
110
+ * Unregister a handler for {@link ErrorEvent}.
111
+ *
112
+ * @param {EventHandler<ErrorEvent>} handler The handler to unregister.
113
+ * @return {boolean} Whether the handler was found (and unregistered).
114
+ */
115
+ unregisterOnError(handler) {
116
+ return __classPrivateFieldGet(this, _Events_onError, "f").unregister(handler);
117
+ }
118
+ /**
119
+ * Unregister a handler for {@link SessionExpiredEvent}.
120
+ *
121
+ * @param {EventHandler<SessionExpiredEvent>} handler The handler to unregister.
122
+ * @return {boolean} Whether the handler was found (and unregistered).
123
+ */
124
+ unregisterOnSessionExpired(handler) {
125
+ return __classPrivateFieldGet(this, _Events_onSessionExpired, "f").unregister(handler);
126
+ }
127
+ /** @internal */
128
+ async triggerSessionExpired() {
129
+ await __classPrivateFieldGet(this, _Events_onSessionExpired, "f").dispatch({});
130
+ }
131
+ /**
132
+ * @param {ErrorEvent} event Event to trigger
133
+ * @internal
134
+ */
135
+ async triggerErrorEvent(event) {
136
+ await __classPrivateFieldGet(this, _Events_onError, "f").dispatch(event);
137
+ }
138
+ }
139
+ exports.Events = Events;
140
+ _Events_onError = new WeakMap(), _Events_onSessionExpired = new WeakMap();
141
+ /**
142
+ * Used to classify and emit events to one or more {@link Events} instances.
143
+ */
144
+ class EventEmitter {
145
+ /**
146
+ *
147
+ * @param {Events[]} events Instances to which to emit events
148
+ * @param {boolean} skipGlobal Whether to include the global events instance {@link GlobalEvents}
149
+ */
150
+ constructor(events, skipGlobal) {
151
+ _EventEmitter_events.set(this, void 0);
152
+ skipGlobal ??= false;
153
+ __classPrivateFieldSet(this, _EventEmitter_events, events, "f");
154
+ if (!skipGlobal) {
155
+ __classPrivateFieldGet(this, _EventEmitter_events, "f").push(exports.GlobalEvents);
156
+ }
157
+ }
158
+ /**
159
+ * Called by {@link CubeSignerApi} when an API response indicates an error.
160
+ *
161
+ * @param {ErrorEvent} err The error to dispatch.
162
+ * @internal
163
+ */
164
+ async classifyAndEmitError(err) {
165
+ for (const ev of __classPrivateFieldGet(this, _EventEmitter_events, "f")) {
166
+ await ev.triggerErrorEvent(err);
167
+ }
168
+ // if status is 403 and error matches one of the SessionExpiredRegexes trigger onSessionExpired
169
+ //
170
+ // TODO: because errors returned by the authorizer lambda are not forwarded to the client
171
+ // we also trigger onSessionExpired when "signerSessionRefresh" fails
172
+ if (err.status === 403 &&
173
+ (messageMatchesSessionExpired(err.message) || err.operation == "signerSessionRefresh")) {
174
+ await this.emitSessionExpired();
175
+ }
176
+ }
177
+ /**
178
+ * Called by {@link SignerSessionManager} to notify that the session is expired
179
+ * beyond the possibility of refreshing, meaning that full re-login is required.
180
+ *
181
+ * @internal
182
+ */
183
+ async emitSessionExpired() {
184
+ for (const e of __classPrivateFieldGet(this, _EventEmitter_events, "f")) {
185
+ await e.triggerSessionExpired();
186
+ }
187
+ }
188
+ }
189
+ exports.EventEmitter = EventEmitter;
190
+ _EventEmitter_events = new WeakMap();
191
+ /**
192
+ * Global events.
193
+ */
194
+ 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 \"./api\";\n\nexport type EventHandler<T> = (event: T) => Promise<void>;\nexport type ErrorEvent = ErrResponse;\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"]}
@@ -172,6 +172,8 @@ export declare class CubeSigner {
172
172
  export * from "./api";
173
173
  /** Client */
174
174
  export * from "./client";
175
+ /** Callbacks */
176
+ export { Events, EventHandler, ErrorEvent, GlobalEvents, SessionExpiredEvent } from "./events";
175
177
  /** Organizations */
176
178
  export * from "./org";
177
179
  /** Keys */