@cubist-labs/cubesigner-sdk 0.4.239 → 0.4.241

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.
@@ -120,5 +120,12 @@ export type OmitAutoParams<O> = DeepOmit<O, {
120
120
  path?: Record<string, unknown>;
121
121
  };
122
122
  };
123
+ /**
124
+ * Creates {@link HeadersInit} containing a single "Authorization" header with a given value.
125
+ *
126
+ * @param token The "Authorization" header value
127
+ * @returns A {@link HeadersInit} object containing a single "Authorization" header with a given value.
128
+ */
129
+ export declare function authHeader(token: string): HeadersInit;
123
130
  export {};
124
131
  //# sourceMappingURL=base_client.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"base_client.d.ts","sourceRoot":"","sources":["../../../src/client/base_client.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"base_client.d.ts","sourceRoot":"","sources":["../../../src/client/base_client.ts"],"names":[],"mappings":"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"}
@@ -17,6 +17,7 @@ var _BaseClient_instances, _BaseClient_targetOrgId, _BaseClient_applyOptions, _B
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  exports.BaseClient = exports.ALL_EVENTS = exports.UserMfaFailedEvent = exports.SessionExpiredEvent = exports.VERSION = exports.NAME = void 0;
19
19
  exports.signerSessionFromSessionInfo = signerSessionFromSessionInfo;
20
+ exports.authHeader = authHeader;
20
21
  // NOTE: add '// @ts-nocheck' at the top of this file to speed up type checking
21
22
  const package_json_1 = __importDefault(require("../../package.json"));
22
23
  const fetch_1 = require("../fetch");
@@ -24,6 +25,7 @@ const retry_1 = require("../retry");
24
25
  const events_1 = require("../events");
25
26
  const error_1 = require("../error");
26
27
  const session_1 = require("./session");
28
+ const openapi_fetch_1 = require("openapi-fetch");
27
29
  /** CubeSigner SDK package name */
28
30
  exports.NAME = package_json_1.default.name;
29
31
  /** CubeSigner SDK version */
@@ -161,14 +163,11 @@ _BaseClient_targetOrgId = new WeakMap(), _BaseClient_instances = new WeakSet(),
161
163
  // If we have an activeSession, let it dictate the baseUrl. Otherwise fall back to the one set at construction
162
164
  baseUrl,
163
165
  ...opts,
164
- headers: {
166
+ headers: (0, openapi_fetch_1.mergeHeaders)({
165
167
  "User-Agent": browserUserAgent ?? `${exports.NAME}@${exports.VERSION}`,
166
168
  "X-Cubist-Ts-Sdk": `${exports.NAME}@${exports.VERSION}`,
167
169
  Origin: this.config.origin,
168
- Authorization: token,
169
- ...(this.config.headers ?? {}),
170
- ...opts.headers,
171
- },
170
+ }, authHeader(token), this.config.headers, opts.headers),
172
171
  params: {
173
172
  ...opts.params,
174
173
  path: {
@@ -224,4 +223,13 @@ function signerSessionFromSessionInfo(meta, info, ctx) {
224
223
  ...ctx,
225
224
  };
226
225
  }
227
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base_client.js","sourceRoot":"","sources":["../../../src/client/base_client.ts"],"names":[],"mappings":"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","sourcesContent":["// NOTE: add '// @ts-nocheck' at the top of this file to speed up type checking\nimport pkg from \"../../package.json\";\nimport type { FetchResponseSuccessData, Op, Operation, SimpleOptions } from \"../fetch\";\nimport { assertOk } from \"../fetch\";\nimport { retry } from \"../retry\";\nimport { EventEmitter } from \"../events\";\nimport { ErrResponse } from \"../error\";\nimport type { SessionData, SessionManager, SessionMetadata } from \"./session\";\nimport { MemorySessionManager, metadata, parseBase64SessionData } from \"./session\";\nimport type { NewSessionResponse, ErrorResponse } from \"../schema_types\";\nimport type { EnvInterface } from \"../env\";\n\n/** CubeSigner SDK package name */\nexport const NAME: string = pkg.name;\n\n/** CubeSigner SDK version */\nexport const VERSION: string = pkg.version;\n\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\ntype ClientEvents = {\n  \"user-mfa-failed\": (ev: UserMfaFailedEvent) => void;\n  \"session-expired\": (ev: SessionExpiredEvent) => void;\n  error: (ev: ErrorEvent) => void;\n};\n\ntype StaticClientSubclass<T> = {\n  new (...args: ConstructorParameters<typeof BaseClient>): T;\n} & typeof BaseClient;\n\n/**\n * An event emitter for all clients\n *\n * @deprecated\n */\nexport const ALL_EVENTS: EventEmitter<ClientEvents> = new EventEmitter();\n\n/**\n * Client configuration options.\n */\nexport interface ClientConfig {\n  /** Update retry delays (in milliseconds) */\n  updateRetryDelaysMs: number[];\n\n  /** Custom origin to set (NOTE that if running in a browser, the browser will overwrite this) */\n  origin?: string;\n\n  /** Additional headers to set (default to empty) */\n  headers: HeadersInit;\n}\n\n/**\n * Implements a retry strategy and session refreshes\n */\nexport class BaseClient extends EventEmitter<ClientEvents> {\n  /** Information about the session contained within the client */\n  sessionMeta: SessionMetadata;\n\n  /** Session persistence */\n  protected sessionManager: SessionManager;\n\n  /**\n   * Target org id, i.e., the organization this client should operate on.\n   *\n   * The only scenario in which it makes sense to use a target organization\n   * different from the session organization is if the target organization is\n   * a child of the session organization.\n   */\n  #targetOrgId: string | undefined;\n\n  /** MUTABLE configuration. */\n  readonly config: ClientConfig;\n\n  /** @returns The env */\n  get env(): EnvInterface {\n    return this.sessionMeta.env[\"Dev-CubeSignerStack\"];\n  }\n\n  /**\n   * Construct a client with a session or session manager\n   *\n   * @param this Allows this static method to return subtypes when invoked through them\n   * @param session The session (object or base64 string) or manager that will back this client\n   * @param targetOrgId The ID of the organization this client should operate on. Defaults to\n   *   the org id from the supplied session. The only scenario in which it makes sense to use\n   *   a {@link targetOrgId} different from the session org id is if {@link targetOrgId} is a\n   *   child organization of the session organization.\n   * @returns A Client\n   */\n  static async create<T>(\n    this: StaticClientSubclass<T>,\n    session: string | SessionManager | SessionData,\n    targetOrgId?: string,\n  ): Promise<T> {\n    const sessionObj: SessionManager | SessionData =\n      typeof session === \"string\" ? parseBase64SessionData(session) : session;\n\n    if (typeof sessionObj.token === \"function\") {\n      const manager = sessionObj as SessionManager;\n      return new this(await manager.metadata(), manager, targetOrgId);\n    } else {\n      session = sessionObj as SessionData;\n      return new this(metadata(session), new MemorySessionManager(session), targetOrgId);\n    }\n  }\n\n  /**\n   * @param sessionMeta The initial session metadata\n   * @param manager The manager for the current session\n   * @param targetOrgId The ID of the organization this client should operate on. Defaults to\n   *   the org id from the supplied session. The only scenario in which it makes sense to use\n   *   a {@link targetOrgId} different from the session org id is if {@link targetOrgId} is a\n   *   child organization of the session organization.\n   * @param config Client configuration\n   *\n   * @internal\n   */\n  constructor(\n    sessionMeta: SessionMetadata,\n    manager: SessionManager,\n    targetOrgId?: string,\n    config?: ClientConfig,\n  ) {\n    super();\n    this.#targetOrgId = targetOrgId;\n    this.sessionManager = manager;\n    this.sessionMeta = sessionMeta;\n    this.config = {\n      updateRetryDelaysMs: [100, 200, 400],\n      headers: {},\n      origin: undefined,\n      ...(config ?? {}),\n    };\n  }\n\n  /** @returns The organization ID. If the org ID was set explicitly, it returns that ID; otherwise it returns the session's organization ID. */\n  get orgId() {\n    return this.#targetOrgId ?? this.sessionMeta.org_id;\n  }\n\n  /**\n   * Apply the session's implicit arguments on top of what was provided\n   *\n   * @param token The authorization token to use for the request\n   * @param opts The user-supplied opts\n   * @returns The union of the user-supplied opts and the default ones\n   */\n  #applyOptions<T extends Operation>(\n    token: string,\n    opts: OmitAutoParams<SimpleOptions<T>>,\n  ): SimpleOptions<T> {\n    const pathParams = \"path\" in (opts.params ?? {}) ? opts.params?.path : undefined;\n    const baseUrl = this.env.SignerApiRoot.replace(/\\/$/, \"\");\n    const browserUserAgent = typeof window !== \"undefined\" ? navigator?.userAgent : undefined;\n    return {\n      cache: \"no-store\",\n      // If we have an activeSession, let it dictate the baseUrl. Otherwise fall back to the one set at construction\n      baseUrl,\n      ...opts,\n      headers: {\n        \"User-Agent\": browserUserAgent ?? `${NAME}@${VERSION}`,\n        \"X-Cubist-Ts-Sdk\": `${NAME}@${VERSION}`,\n        Origin: this.config.origin,\n        Authorization: token,\n        ...(this.config.headers ?? {}),\n        ...opts.headers,\n      },\n      params: {\n        ...opts.params,\n        path: {\n          org_id: this.orgId,\n          ...pathParams,\n        },\n      },\n    } as unknown as SimpleOptions<T>;\n  }\n\n  /**\n   * Emits specific error events when a request failed\n   *\n   * @param err The error to classify\n   */\n  async #classifyAndEmitError(err: ErrorEvent) {\n    this.emit(\"error\", err);\n    ALL_EVENTS.emit(\"error\", err);\n\n    if (err.isUserMfaError()) {\n      const ev = \"user-mfa-failed\";\n      this.emit(ev, err);\n      ALL_EVENTS.emit(ev, 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      const ev = \"session-expired\";\n      this.emit(ev, err);\n      ALL_EVENTS.emit(ev, err);\n    }\n  }\n\n  /**\n   * Executes an op using the state of the client (auth headers & org_id) with retries\n   *\n   * @internal\n   * @param op The API operation you wish to perform\n   * @param opts The parameters for the operation\n   * @returns A promise for the successful result (errors will be thrown)\n   */\n  async exec<T extends Operation>(\n    op: Op<T>,\n    opts: OmitAutoParams<SimpleOptions<T>>,\n  ): Promise<FetchResponseSuccessData<T>> {\n    try {\n      let token = await this.sessionManager.token();\n      const resp = await retry(() => op(this.#applyOptions(token, opts)), {\n        pred: async (resp) => {\n          const status = resp.response.status;\n          const error = resp.error as ErrorResponse | undefined;\n          const requestId = error?.request_id;\n\n          // If we get a \"Forbidden\" error, erase the cached token\n          //\n          // TODO: Check error codes once our API returns error codes for\n          // authorization failures\n          if (\n            status === 403 &&\n            requestId === undefined &&\n            this.sessionManager.onInvalidToken !== undefined\n          ) {\n            this.sessionManager.onInvalidToken();\n            const oldToken = token;\n            token = await this.sessionManager.token();\n            return token !== oldToken;\n          }\n\n          // Also retry server-side errors\n          return status >= 500 && status < 600;\n        },\n      });\n      // Once we have a non-5XX response, we will assertOk (either throwing or yielding the reponse)\n      return assertOk(resp);\n    } catch (e) {\n      if (e instanceof ErrResponse) {\n        await this.#classifyAndEmitError(e); // Emit appropriate events\n      }\n      throw e; // Rethrow the error\n    }\n  }\n}\n\n/**\n * Upgrade a session response into a full SessionData by incorporating\n * elements of an existing SessionData\n *\n * @param meta An existing SessionData\n * @param info A new session created via the API\n * @param ctx Additional manual overrides\n * @returns SessionData with new information from info and ctx\n */\nexport function signerSessionFromSessionInfo(\n  meta: SessionMetadata,\n  info: NewSessionResponse,\n  ctx: Partial<{ purpose: string; role_id: string; org_id: string }>,\n): SessionData {\n  return {\n    env: meta.env,\n    org_id: meta.org_id,\n    session_exp: info.expiration,\n    session_info: info.session_info,\n    token: info.token,\n    refresh_token: info.refresh_token,\n    purpose: meta.purpose,\n    role_id: meta.role_id,\n    ...ctx,\n  };\n}\n\ntype DeepOmit<A, B> = [A, B] extends [object, object]\n  ? {\n      [K in keyof A as K extends keyof B // If the key is in both A and B\n        ? A[K] extends B[K]\n          ? K //\n          : never\n        : never]?: K extends keyof B ? DeepOmit<A[K], B[K]> : never;\n    } & {\n      [K in keyof A as K extends keyof B ? (B[K] extends A[K] ? never : K) : K]: K extends keyof B\n        ? DeepOmit<A[K], B[K]>\n        : A[K];\n    }\n  : A;\n\nexport type OmitAutoParams<O> = DeepOmit<\n  O,\n  {\n    baseUrl: string;\n    params: { path: { org_id: string } };\n  }\n> & { params?: { path?: Record<string, unknown> } };\n"]}
226
+ /**
227
+ * Creates {@link HeadersInit} containing a single "Authorization" header with a given value.
228
+ *
229
+ * @param token The "Authorization" header value
230
+ * @returns A {@link HeadersInit} object containing a single "Authorization" header with a given value.
231
+ */
232
+ function authHeader(token) {
233
+ return { Authorization: token };
234
+ }
235
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base_client.js","sourceRoot":"","sources":["../../../src/client/base_client.ts"],"names":[],"mappings":"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","sourcesContent":["// NOTE: add '// @ts-nocheck' at the top of this file to speed up type checking\nimport pkg from \"../../package.json\";\nimport type { FetchResponseSuccessData, Op, Operation, SimpleOptions } from \"../fetch\";\nimport { assertOk } from \"../fetch\";\nimport { retry } from \"../retry\";\nimport { EventEmitter } from \"../events\";\nimport { ErrResponse } from \"../error\";\nimport type { SessionData, SessionManager, SessionMetadata } from \"./session\";\nimport { MemorySessionManager, metadata, parseBase64SessionData } from \"./session\";\nimport type { NewSessionResponse, ErrorResponse } from \"../schema_types\";\nimport type { EnvInterface } from \"../env\";\nimport { mergeHeaders } from \"openapi-fetch\";\n\n/** CubeSigner SDK package name */\nexport const NAME: string = pkg.name;\n\n/** CubeSigner SDK version */\nexport const VERSION: string = pkg.version;\n\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\ntype ClientEvents = {\n  \"user-mfa-failed\": (ev: UserMfaFailedEvent) => void;\n  \"session-expired\": (ev: SessionExpiredEvent) => void;\n  error: (ev: ErrorEvent) => void;\n};\n\ntype StaticClientSubclass<T> = {\n  new (...args: ConstructorParameters<typeof BaseClient>): T;\n} & typeof BaseClient;\n\n/**\n * An event emitter for all clients\n *\n * @deprecated\n */\nexport const ALL_EVENTS: EventEmitter<ClientEvents> = new EventEmitter();\n\n/**\n * Client configuration options.\n */\nexport interface ClientConfig {\n  /** Update retry delays (in milliseconds) */\n  updateRetryDelaysMs: number[];\n\n  /** Custom origin to set (NOTE that if running in a browser, the browser will overwrite this) */\n  origin?: string;\n\n  /** Additional headers to set (default to empty) */\n  headers: HeadersInit;\n}\n\n/**\n * Implements a retry strategy and session refreshes\n */\nexport class BaseClient extends EventEmitter<ClientEvents> {\n  /** Information about the session contained within the client */\n  sessionMeta: SessionMetadata;\n\n  /** Session persistence */\n  protected sessionManager: SessionManager;\n\n  /**\n   * Target org id, i.e., the organization this client should operate on.\n   *\n   * The only scenario in which it makes sense to use a target organization\n   * different from the session organization is if the target organization is\n   * a child of the session organization.\n   */\n  #targetOrgId: string | undefined;\n\n  /** MUTABLE configuration. */\n  readonly config: ClientConfig;\n\n  /** @returns The env */\n  get env(): EnvInterface {\n    return this.sessionMeta.env[\"Dev-CubeSignerStack\"];\n  }\n\n  /**\n   * Construct a client with a session or session manager\n   *\n   * @param this Allows this static method to return subtypes when invoked through them\n   * @param session The session (object or base64 string) or manager that will back this client\n   * @param targetOrgId The ID of the organization this client should operate on. Defaults to\n   *   the org id from the supplied session. The only scenario in which it makes sense to use\n   *   a {@link targetOrgId} different from the session org id is if {@link targetOrgId} is a\n   *   child organization of the session organization.\n   * @returns A Client\n   */\n  static async create<T>(\n    this: StaticClientSubclass<T>,\n    session: string | SessionManager | SessionData,\n    targetOrgId?: string,\n  ): Promise<T> {\n    const sessionObj: SessionManager | SessionData =\n      typeof session === \"string\" ? parseBase64SessionData(session) : session;\n\n    if (typeof sessionObj.token === \"function\") {\n      const manager = sessionObj as SessionManager;\n      return new this(await manager.metadata(), manager, targetOrgId);\n    } else {\n      session = sessionObj as SessionData;\n      return new this(metadata(session), new MemorySessionManager(session), targetOrgId);\n    }\n  }\n\n  /**\n   * @param sessionMeta The initial session metadata\n   * @param manager The manager for the current session\n   * @param targetOrgId The ID of the organization this client should operate on. Defaults to\n   *   the org id from the supplied session. The only scenario in which it makes sense to use\n   *   a {@link targetOrgId} different from the session org id is if {@link targetOrgId} is a\n   *   child organization of the session organization.\n   * @param config Client configuration\n   *\n   * @internal\n   */\n  constructor(\n    sessionMeta: SessionMetadata,\n    manager: SessionManager,\n    targetOrgId?: string,\n    config?: ClientConfig,\n  ) {\n    super();\n    this.#targetOrgId = targetOrgId;\n    this.sessionManager = manager;\n    this.sessionMeta = sessionMeta;\n    this.config = {\n      updateRetryDelaysMs: [100, 200, 400],\n      headers: {},\n      origin: undefined,\n      ...(config ?? {}),\n    };\n  }\n\n  /** @returns The organization ID. If the org ID was set explicitly, it returns that ID; otherwise it returns the session's organization ID. */\n  get orgId() {\n    return this.#targetOrgId ?? this.sessionMeta.org_id;\n  }\n\n  /**\n   * Apply the session's implicit arguments on top of what was provided\n   *\n   * @param token The authorization token to use for the request\n   * @param opts The user-supplied opts\n   * @returns The union of the user-supplied opts and the default ones\n   */\n  #applyOptions<T extends Operation>(\n    token: string,\n    opts: OmitAutoParams<SimpleOptions<T>>,\n  ): SimpleOptions<T> {\n    const pathParams = \"path\" in (opts.params ?? {}) ? opts.params?.path : undefined;\n    const baseUrl = this.env.SignerApiRoot.replace(/\\/$/, \"\");\n    const browserUserAgent = typeof window !== \"undefined\" ? navigator?.userAgent : undefined;\n    return {\n      cache: \"no-store\",\n      // If we have an activeSession, let it dictate the baseUrl. Otherwise fall back to the one set at construction\n      baseUrl,\n      ...opts,\n      headers: mergeHeaders(\n        {\n          \"User-Agent\": browserUserAgent ?? `${NAME}@${VERSION}`,\n          \"X-Cubist-Ts-Sdk\": `${NAME}@${VERSION}`,\n          Origin: this.config.origin,\n        },\n        authHeader(token),\n        this.config.headers,\n        opts.headers,\n      ),\n      params: {\n        ...opts.params,\n        path: {\n          org_id: this.orgId,\n          ...pathParams,\n        },\n      },\n    } as unknown as SimpleOptions<T>;\n  }\n\n  /**\n   * Emits specific error events when a request failed\n   *\n   * @param err The error to classify\n   */\n  async #classifyAndEmitError(err: ErrorEvent) {\n    this.emit(\"error\", err);\n    ALL_EVENTS.emit(\"error\", err);\n\n    if (err.isUserMfaError()) {\n      const ev = \"user-mfa-failed\";\n      this.emit(ev, err);\n      ALL_EVENTS.emit(ev, 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      const ev = \"session-expired\";\n      this.emit(ev, err);\n      ALL_EVENTS.emit(ev, err);\n    }\n  }\n\n  /**\n   * Executes an op using the state of the client (auth headers & org_id) with retries\n   *\n   * @internal\n   * @param op The API operation you wish to perform\n   * @param opts The parameters for the operation\n   * @returns A promise for the successful result (errors will be thrown)\n   */\n  async exec<T extends Operation>(\n    op: Op<T>,\n    opts: OmitAutoParams<SimpleOptions<T>>,\n  ): Promise<FetchResponseSuccessData<T>> {\n    try {\n      let token = await this.sessionManager.token();\n      const resp = await retry(() => op(this.#applyOptions(token, opts)), {\n        pred: async (resp) => {\n          const status = resp.response.status;\n          const error = resp.error as ErrorResponse | undefined;\n          const requestId = error?.request_id;\n\n          // If we get a \"Forbidden\" error, erase the cached token\n          //\n          // TODO: Check error codes once our API returns error codes for\n          // authorization failures\n          if (\n            status === 403 &&\n            requestId === undefined &&\n            this.sessionManager.onInvalidToken !== undefined\n          ) {\n            this.sessionManager.onInvalidToken();\n            const oldToken = token;\n            token = await this.sessionManager.token();\n            return token !== oldToken;\n          }\n\n          // Also retry server-side errors\n          return status >= 500 && status < 600;\n        },\n      });\n      // Once we have a non-5XX response, we will assertOk (either throwing or yielding the reponse)\n      return assertOk(resp);\n    } catch (e) {\n      if (e instanceof ErrResponse) {\n        await this.#classifyAndEmitError(e); // Emit appropriate events\n      }\n      throw e; // Rethrow the error\n    }\n  }\n}\n\n/**\n * Upgrade a session response into a full SessionData by incorporating\n * elements of an existing SessionData\n *\n * @param meta An existing SessionData\n * @param info A new session created via the API\n * @param ctx Additional manual overrides\n * @returns SessionData with new information from info and ctx\n */\nexport function signerSessionFromSessionInfo(\n  meta: SessionMetadata,\n  info: NewSessionResponse,\n  ctx: Partial<{ purpose: string; role_id: string; org_id: string }>,\n): SessionData {\n  return {\n    env: meta.env,\n    org_id: meta.org_id,\n    session_exp: info.expiration,\n    session_info: info.session_info,\n    token: info.token,\n    refresh_token: info.refresh_token,\n    purpose: meta.purpose,\n    role_id: meta.role_id,\n    ...ctx,\n  };\n}\n\ntype DeepOmit<A, B> = [A, B] extends [object, object]\n  ? {\n      [K in keyof A as K extends keyof B // If the key is in both A and B\n        ? A[K] extends B[K]\n          ? K //\n          : never\n        : never]?: K extends keyof B ? DeepOmit<A[K], B[K]> : never;\n    } & {\n      [K in keyof A as K extends keyof B ? (B[K] extends A[K] ? never : K) : K]: K extends keyof B\n        ? DeepOmit<A[K], B[K]>\n        : A[K];\n    }\n  : A;\n\nexport type OmitAutoParams<O> = DeepOmit<\n  O,\n  {\n    baseUrl: string;\n    params: { path: { org_id: string } };\n  }\n> & { params?: { path?: Record<string, unknown> } };\n\n/**\n * Creates {@link HeadersInit} containing a single \"Authorization\" header with a given value.\n *\n * @param token The \"Authorization\" header value\n * @returns A {@link HeadersInit} object containing a single \"Authorization\" header with a given value.\n */\nexport function authHeader(token: string): HeadersInit {\n  return { Authorization: token };\n}\n"]}
@@ -1,8 +1,8 @@
1
1
  import { ApiClient } from "./client/api_client";
2
- import type { IdentityProof, RatchetConfig, EmailOtpResponse } from "./schema_types";
2
+ import type { EmailOtpResponse, IdentityProof, RatchetConfig } from "./schema_types";
3
3
  import { AddFidoChallenge, TotpChallenge } from "./mfa";
4
4
  import { Org } from "./org";
5
- import type { CubeSignerResponse, EnvInterface, MfaReceipts, Scope, SessionData, SessionInfo, SessionManager } from ".";
5
+ import type { MfaReceipts, SessionData, SessionInfo, SessionManager } from ".";
6
6
  import { Key } from ".";
7
7
  /** Options for logging in with OIDC token */
8
8
  export interface OidcAuthOptions {
@@ -24,7 +24,7 @@ export declare class CubeSignerClient {
24
24
  /**
25
25
  * @returns The environment.
26
26
  */
27
- get env(): EnvInterface;
27
+ get env(): import("./env").EnvInterface;
28
28
  /**
29
29
  * @returns The org ID of the client.
30
30
  */
@@ -76,40 +76,32 @@ export declare class CubeSignerClient {
76
76
  */
77
77
  sessionKeys(): Promise<Key[]>;
78
78
  /**
79
- * Exchange an OIDC token for a CubeSigner session token.
79
+ * Create a new OIDC-backed session.
80
80
  *
81
- * @param env The environment to log into
82
- * @param orgId The org to log into.
83
- * @param token The OIDC token to exchange
84
- * @param scopes The scopes for the new session
85
- * @param lifetimes Lifetimes of the new session.
86
- * @param mfaReceipt Optional MFA receipt(s)
87
- * @param purpose Optional session description.
88
- * @returns The session data.
81
+ * Same as {@link ApiClient.oidcSessionCreate}, see its documentation for more details.
82
+ *
83
+ * @param args Request arguments
84
+ * @returns The new session data
89
85
  */
90
- static createOidcSession(env: EnvInterface, orgId: string, token: string, scopes: Array<Scope>, lifetimes?: RatchetConfig, mfaReceipt?: MfaReceipts, purpose?: string): Promise<CubeSignerResponse<SessionData>>;
86
+ static createOidcSession(...args: Parameters<typeof ApiClient.oidcSessionCreate>): Promise<Awaited<ReturnType<typeof ApiClient.oidcSessionCreate>>>;
91
87
  /**
92
- * Exchange an OIDC token for a proof of authentication.
88
+ * Prove an OIDC identity.
89
+ *
90
+ * Same as {@link ApiClient.identityProveOidc}, see its documentation for more details.
93
91
  *
94
- * @param env The environment to log into
95
- * @param orgId The org id in which to generate proof
96
- * @param token The oidc token
92
+ * @param args Request arguments
97
93
  * @returns Proof of authentication
98
94
  */
99
- static proveOidcIdentity(env: EnvInterface, orgId: string, token: string): Promise<IdentityProof>;
95
+ static proveOidcIdentity(...args: Parameters<typeof ApiClient.identityProveOidc>): Promise<IdentityProof>;
100
96
  /**
101
- * Initiates login via Email OTP.
102
- * Returns an unsigned OIDC token and sends an email to the user containing the signature of that token.
103
- * The OIDC token can be reconstructed by appending the signature to the partial token like so:
97
+ * Initialize email OTP authentication.
104
98
  *
105
- * token = partial_token + signature
99
+ * Same as {@link ApiClient.initEmailOtpAuth}, see its documentation for more details.
106
100
  *
107
- * @param env The environment to use
108
- * @param orgId The org to login to
109
- * @param email The email to send the signature to
110
- * @returns The partial OIDC token that must be combined with the signature in the email
101
+ * @param args Request arguments
102
+ * @returns The partial OIDC token that must be combined with the signature in the email
111
103
  */
112
- static initEmailOtpAuth(env: EnvInterface, orgId: string, email: string): Promise<EmailOtpResponse>;
104
+ static initEmailOtpAuth(...args: Parameters<typeof ApiClient.initEmailOtpAuth>): Promise<EmailOtpResponse>;
113
105
  /**
114
106
  * Creates a request to add a new FIDO device.
115
107
  *
@@ -121,7 +113,7 @@ export declare class CubeSignerClient {
121
113
  *
122
114
  * @returns A function that resolves to an AddFidoChallenge
123
115
  */
124
- get addFido(): (name: string | import("./schema_types").schemas["FidoCreateRequest"], mfaReceipt?: MfaReceipts) => Promise<CubeSignerResponse<AddFidoChallenge>>;
116
+ get addFido(): (name: string | import("./schema_types").schemas["FidoCreateRequest"], mfaReceipt?: MfaReceipts) => Promise<import("./response").CubeSignerResponse<AddFidoChallenge>>;
125
117
  /**
126
118
  * Delete a FIDO key from the user's account.
127
119
  * Allowed only if TOTP is also defined.
@@ -131,7 +123,7 @@ export declare class CubeSignerClient {
131
123
  *
132
124
  * @returns A function that deletes a FIDO key
133
125
  */
134
- get deleteFido(): (fidoId: string, mfaReceipt?: MfaReceipts) => Promise<CubeSignerResponse<import("./schema_types").Empty>>;
126
+ get deleteFido(): (fidoId: string, mfaReceipt?: MfaReceipts) => Promise<import("./response").CubeSignerResponse<import("./schema_types").Empty>>;
135
127
  /**
136
128
  * Create a reference to an existing TOTP challenge.
137
129
  *
@@ -147,7 +139,7 @@ export declare class CubeSignerClient {
147
139
  *
148
140
  * @returns A promise that resolves to a TOTP challenge
149
141
  */
150
- get resetTotp(): (issuer?: string, mfaReceipt?: MfaReceipts) => Promise<CubeSignerResponse<TotpChallenge>>;
142
+ get resetTotp(): (issuer?: string, mfaReceipt?: MfaReceipts) => Promise<import("./response").CubeSignerResponse<TotpChallenge>>;
151
143
  /**
152
144
  * Creates a request to change this user's verified email.
153
145
  *
@@ -155,7 +147,7 @@ export declare class CubeSignerClient {
155
147
  *
156
148
  * @returns A promise that resolves to an email challenge
157
149
  */
158
- get resetEmail(): (req: string | import("./schema_types").schemas["EmailResetRequest"], mfaReceipt?: MfaReceipts) => Promise<CubeSignerResponse<import("./mfa").ResetEmailChallenge>>;
150
+ get resetEmail(): (req: string | import("./schema_types").schemas["EmailResetRequest"], mfaReceipt?: MfaReceipts) => Promise<import("./response").CubeSignerResponse<import("./mfa").ResetEmailChallenge>>;
159
151
  /**
160
152
  * Verifies a given TOTP code against the current user's TOTP configuration.
161
153
  * Throws an error if the verification fails.
@@ -174,7 +166,7 @@ export declare class CubeSignerClient {
174
166
  *
175
167
  * @returns A function that deletes TOTP from the user
176
168
  */
177
- get deleteTotp(): (mfaReceipt?: MfaReceipts) => Promise<CubeSignerResponse<import("./schema_types").Empty>>;
169
+ get deleteTotp(): (mfaReceipt?: MfaReceipts) => Promise<import("./response").CubeSignerResponse<import("./schema_types").Empty>>;
178
170
  /**
179
171
  * Add a listener for an event
180
172
  *
@@ -1 +1 @@
1
- {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAIrF,OAAO,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AACxD,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAC5B,OAAO,KAAK,EACV,kBAAkB,EAClB,YAAY,EACZ,WAAW,EACX,KAAK,EACL,WAAW,EACX,WAAW,EACX,cAAc,EACf,MAAM,GAAG,CAAC;AACX,OAAO,EAAE,GAAG,EAAE,MAAM,GAAG,CAAC;AAExB,6CAA6C;AAC7C,MAAM,WAAW,eAAe;IAC9B,+BAA+B;IAC/B,SAAS,CAAC,EAAE,aAAa,CAAC;IAC1B,8BAA8B;IAC9B,UAAU,CAAC,EAAE,WAAW,CAAC;CAC1B;AAED;;;GAGG;AACH,qBAAa,gBAAgB;;IAG3B;;OAEG;IACH,IAAI,SAAS,cAEZ;IAED;;OAEG;IACH,IAAI,GAAG,iBAEN;IAED;;OAEG;IACH,IAAI,KAAK,WAER;IAED;;;;OAIG;gBACS,SAAS,EAAE,SAAS;IAIhC;;;;;;;;;OASG;WACU,MAAM,CACjB,OAAO,EAAE,MAAM,GAAG,cAAc,GAAG,WAAW,EAC9C,WAAW,CAAC,EAAE,MAAM,GACnB,OAAO,CAAC,gBAAgB,CAAC;IAI5B;;;;OAIG;IACH,GAAG,IAAI,GAAG;IAIV;;;;;OAKG;IACH,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,GAAG;IAI1B;;;;;;OAMG;IACH,IAAI,IAAI,qDAEP;IAED;;;;;;OAMG;IACG,WAAW,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;IAMnC;;;;;;;;;;;OAWG;WACU,iBAAiB,CAC5B,GAAG,EAAE,YAAY,EACjB,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,EACpB,SAAS,CAAC,EAAE,aAAa,EACzB,UAAU,CAAC,EAAE,WAAW,EACxB,OAAO,CAAC,EAAE,MAAM,GACf,OAAO,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC;IAY3C;;;;;;;OAOG;WACU,iBAAiB,CAC5B,GAAG,EAAE,YAAY,EACjB,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,aAAa,CAAC;IAIzB;;;;;;;;;;;OAWG;WACU,gBAAgB,CAC3B,GAAG,EAAE,YAAY,EACjB,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,gBAAgB,CAAC;IAI5B;;;;;;;;;;OAUG;IACH,IAAI,OAAO,sJAEV;IAED;;;;;;;;OAQG;IACH,IAAI,UAAU,8GAEb;IAED;;;;;OAKG;IACH,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,aAAa;IAI/C;;;;;;;OAOG;IACH,IAAI,SAAS,8FAEZ;IAED;;;;;;OAMG;IACH,IAAI,UAAU,wKAEb;IAED;;;;;;;OAOG;IACH,IAAI,UAAU,oCAEb;IAED;;;;;;;;OAQG;IACH,IAAI,UAAU,8FAEb;IAED;;;;;;OAMG;IACH,IAAI,gBAAgB;;;;uBAEnB;IAED;;;;;;OAMG;IACH,IAAI,mBAAmB;;;;uBAEtB;IAED;;;;OAIG;IACG,UAAU,IAAI,OAAO,CAAC,WAAW,CAAC;IAIxC;;OAEG;IACG,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;CAGrC"}
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,KAAK,EAAE,gBAAgB,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAIrF,OAAO,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AACxD,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAC5B,OAAO,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,GAAG,CAAC;AAC/E,OAAO,EAAE,GAAG,EAAE,MAAM,GAAG,CAAC;AAExB,6CAA6C;AAC7C,MAAM,WAAW,eAAe;IAC9B,+BAA+B;IAC/B,SAAS,CAAC,EAAE,aAAa,CAAC;IAC1B,8BAA8B;IAC9B,UAAU,CAAC,EAAE,WAAW,CAAC;CAC1B;AAED;;;GAGG;AACH,qBAAa,gBAAgB;;IAG3B;;OAEG;IACH,IAAI,SAAS,cAEZ;IAED;;OAEG;IACH,IAAI,GAAG,iCAEN;IAED;;OAEG;IACH,IAAI,KAAK,WAER;IAED;;;;OAIG;gBACS,SAAS,EAAE,SAAS;IAIhC;;;;;;;;;OASG;WACU,MAAM,CACjB,OAAO,EAAE,MAAM,GAAG,cAAc,GAAG,WAAW,EAC9C,WAAW,CAAC,EAAE,MAAM,GACnB,OAAO,CAAC,gBAAgB,CAAC;IAI5B;;;;OAIG;IACH,GAAG,IAAI,GAAG;IAIV;;;;;OAKG;IACH,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,GAAG;IAI1B;;;;;;OAMG;IACH,IAAI,IAAI,qDAEP;IAED;;;;;;OAMG;IACG,WAAW,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;IAMnC;;;;;;;OAOG;WACU,iBAAiB,CAC5B,GAAG,IAAI,EAAE,UAAU,CAAC,OAAO,SAAS,CAAC,iBAAiB,CAAC,GACtD,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC,OAAO,SAAS,CAAC,iBAAiB,CAAC,CAAC,CAAC;IAInE;;;;;;;OAOG;WACU,iBAAiB,CAC5B,GAAG,IAAI,EAAE,UAAU,CAAC,OAAO,SAAS,CAAC,iBAAiB,CAAC,GACtD,OAAO,CAAC,aAAa,CAAC;IAIzB;;;;;;;OAOG;WACU,gBAAgB,CAC3B,GAAG,IAAI,EAAE,UAAU,CAAC,OAAO,SAAS,CAAC,gBAAgB,CAAC,GACrD,OAAO,CAAC,gBAAgB,CAAC;IAI5B;;;;;;;;;;OAUG;IACH,IAAI,OAAO,2KAEV;IAED;;;;;;;;OAQG;IACH,IAAI,UAAU,mIAEb;IAED;;;;;OAKG;IACH,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,aAAa;IAI/C;;;;;;;OAOG;IACH,IAAI,SAAS,mHAEZ;IAED;;;;;;OAMG;IACH,IAAI,UAAU,6LAEb;IAED;;;;;;;OAOG;IACH,IAAI,UAAU,oCAEb;IAED;;;;;;;;OAQG;IACH,IAAI,UAAU,mHAEb;IAED;;;;;;OAMG;IACH,IAAI,gBAAgB;;;;uBAEnB;IAED;;;;;;OAMG;IACH,IAAI,mBAAmB;;;;uBAEtB;IAED;;;;OAIG;IACG,UAAU,IAAI,OAAO,CAAC,WAAW,CAAC;IAIxC;;OAEG;IACG,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;CAGrC"}
@@ -104,45 +104,37 @@ class CubeSignerClient {
104
104
  .then((keyInfos) => keyInfos.map((keyInfo) => new _1.Key(__classPrivateFieldGet(this, _CubeSignerClient_apiClient, "f"), keyInfo)));
105
105
  }
106
106
  /**
107
- * Exchange an OIDC token for a CubeSigner session token.
108
- *
109
- * @param env The environment to log into
110
- * @param orgId The org to log into.
111
- * @param token The OIDC token to exchange
112
- * @param scopes The scopes for the new session
113
- * @param lifetimes Lifetimes of the new session.
114
- * @param mfaReceipt Optional MFA receipt(s)
115
- * @param purpose Optional session description.
116
- * @returns The session data.
107
+ * Create a new OIDC-backed session.
108
+ *
109
+ * Same as {@link ApiClient.oidcSessionCreate}, see its documentation for more details.
110
+ *
111
+ * @param args Request arguments
112
+ * @returns The new session data
117
113
  */
118
- static async createOidcSession(env, orgId, token, scopes, lifetimes, mfaReceipt, purpose) {
119
- return await api_client_1.ApiClient.oidcSessionCreate(env, orgId, token, scopes, lifetimes, mfaReceipt, purpose);
114
+ static async createOidcSession(...args) {
115
+ return await api_client_1.ApiClient.oidcSessionCreate(...args);
120
116
  }
121
117
  /**
122
- * Exchange an OIDC token for a proof of authentication.
118
+ * Prove an OIDC identity.
119
+ *
120
+ * Same as {@link ApiClient.identityProveOidc}, see its documentation for more details.
123
121
  *
124
- * @param env The environment to log into
125
- * @param orgId The org id in which to generate proof
126
- * @param token The oidc token
122
+ * @param args Request arguments
127
123
  * @returns Proof of authentication
128
124
  */
129
- static async proveOidcIdentity(env, orgId, token) {
130
- return await api_client_1.ApiClient.identityProveOidc(env, orgId, token);
125
+ static async proveOidcIdentity(...args) {
126
+ return await api_client_1.ApiClient.identityProveOidc(...args);
131
127
  }
132
128
  /**
133
- * Initiates login via Email OTP.
134
- * Returns an unsigned OIDC token and sends an email to the user containing the signature of that token.
135
- * The OIDC token can be reconstructed by appending the signature to the partial token like so:
129
+ * Initialize email OTP authentication.
136
130
  *
137
- * token = partial_token + signature
131
+ * Same as {@link ApiClient.initEmailOtpAuth}, see its documentation for more details.
138
132
  *
139
- * @param env The environment to use
140
- * @param orgId The org to login to
141
- * @param email The email to send the signature to
142
- * @returns The partial OIDC token that must be combined with the signature in the email
133
+ * @param args Request arguments
134
+ * @returns The partial OIDC token that must be combined with the signature in the email
143
135
  */
144
- static async initEmailOtpAuth(env, orgId, email) {
145
- return await api_client_1.ApiClient.initEmailOtpAuth(env, orgId, email);
136
+ static async initEmailOtpAuth(...args) {
137
+ return await api_client_1.ApiClient.initEmailOtpAuth(...args);
146
138
  }
147
139
  /**
148
140
  * Creates a request to add a new FIDO device.
@@ -260,4 +252,4 @@ class CubeSignerClient {
260
252
  }
261
253
  exports.CubeSignerClient = CubeSignerClient;
262
254
  _CubeSignerClient_apiClient = new WeakMap();
263
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/client.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApiClient } from \"./client/api_client\";\nimport type { IdentityProof, RatchetConfig, EmailOtpResponse } from \"./schema_types\";\n\n// used in doc comments\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nimport { AddFidoChallenge, TotpChallenge } from \"./mfa\";\nimport { Org } from \"./org\";\nimport type {\n  CubeSignerResponse,\n  EnvInterface,\n  MfaReceipts,\n  Scope,\n  SessionData,\n  SessionInfo,\n  SessionManager,\n} from \".\";\nimport { Key } from \".\";\n\n/** Options for logging in with OIDC token */\nexport interface OidcAuthOptions {\n  /** Optional token lifetimes */\n  lifetimes?: RatchetConfig;\n  /** Optional MFA receipt(s) */\n  mfaReceipt?: MfaReceipts;\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 {\n  readonly #apiClient: ApiClient;\n\n  /**\n   * @returns The underlying API client. This client provides direct API access without convenience wrappers.\n   */\n  get apiClient() {\n    return this.#apiClient;\n  }\n\n  /**\n   * @returns The environment.\n   */\n  get env() {\n    return this.#apiClient.env;\n  }\n\n  /**\n   * @returns The org ID of the client.\n   */\n  get orgId() {\n    return this.#apiClient.orgId;\n  }\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   */\n  constructor(apiClient: ApiClient) {\n    this.#apiClient = apiClient;\n  }\n\n  /**\n   * Construct a client with a session or session manager\n   *\n   * @param session The session (object or base64 string) or manager that will back this client\n   * @param targetOrgId The ID of the organization this client should operate on. Defaults to\n   *   the org id from the supplied session. The only scenario in which it makes sense to use\n   *   a {@link targetOrgId} different from the session org id is if {@link targetOrgId} is a\n   *   child organization of the session organization.\n   * @returns A client\n   */\n  static async create(\n    session: string | SessionManager | SessionData,\n    targetOrgId?: string,\n  ): Promise<CubeSignerClient> {\n    return new CubeSignerClient(await ApiClient.create(session, targetOrgId));\n  }\n\n  /**\n   * Get the org associated with this session.\n   *\n   * @returns The org\n   */\n  org(): Org {\n    return new Org(this.#apiClient, this.orgId);\n  }\n\n  /**\n   * Get information about an org.\n   *\n   * @param orgId The ID or name of the org\n   * @returns CubeSigner client for the requested org.\n   */\n  getOrg(orgId: string): Org {\n    return new Org(this.#apiClient, orgId);\n  }\n\n  /**\n   * Obtain information about the current user.\n   *\n   * Same as {@link ApiClient.userGet}, see its documentation for more details.\n   *\n   * @returns A function that resolves to the current user's information\n   */\n  get user() {\n    return this.#apiClient.userGet.bind(this.#apiClient);\n  }\n\n  /**\n   * Get all keys accessible to the current session\n   *\n   * NOTE: this may be a subset from the keys in the current org.\n   *\n   * @returns The keys that a client can access\n   */\n  async sessionKeys(): Promise<Key[]> {\n    return await this.#apiClient\n      .sessionKeysList()\n      .then((keyInfos) => keyInfos.map((keyInfo) => new Key(this.#apiClient, keyInfo)));\n  }\n\n  /**\n   * Exchange an OIDC token for a CubeSigner session token.\n   *\n   * @param env The environment to log into\n   * @param orgId The org to log into.\n   * @param token The OIDC token to exchange\n   * @param scopes The scopes for the new session\n   * @param lifetimes Lifetimes of the new session.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @param purpose Optional session description.\n   * @returns The session data.\n   */\n  static async createOidcSession(\n    env: EnvInterface,\n    orgId: string,\n    token: string,\n    scopes: Array<Scope>,\n    lifetimes?: RatchetConfig,\n    mfaReceipt?: MfaReceipts,\n    purpose?: string,\n  ): Promise<CubeSignerResponse<SessionData>> {\n    return await ApiClient.oidcSessionCreate(\n      env,\n      orgId,\n      token,\n      scopes,\n      lifetimes,\n      mfaReceipt,\n      purpose,\n    );\n  }\n\n  /**\n   * Exchange an OIDC token for a proof of authentication.\n   *\n   * @param env The environment to log into\n   * @param orgId The org id in which to generate proof\n   * @param token The oidc token\n   * @returns Proof of authentication\n   */\n  static async proveOidcIdentity(\n    env: EnvInterface,\n    orgId: string,\n    token: string,\n  ): Promise<IdentityProof> {\n    return await ApiClient.identityProveOidc(env, orgId, token);\n  }\n\n  /**\n   * Initiates login via Email OTP.\n   * Returns an unsigned OIDC token and sends an email to the user containing the signature of that token.\n   * The OIDC token can be reconstructed by appending the signature to the partial token like so:\n   *\n   * token = partial_token + signature\n   *\n   * @param env The environment to use\n   * @param orgId The org to login to\n   * @param email The email to send the signature to\n   * @returns The partial OIDC token that must be combined with the signature in the email\n   */\n  static async initEmailOtpAuth(\n    env: EnvInterface,\n    orgId: string,\n    email: string,\n  ): Promise<EmailOtpResponse> {\n    return await ApiClient.initEmailOtpAuth(env, orgId, email);\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 ApiClient.userFidoRegisterInit}, see its documentation for more details.\n   *\n   * @returns A function that resolves to an AddFidoChallenge\n   */\n  get addFido() {\n    return this.#apiClient.userFidoRegisterInit.bind(this.#apiClient);\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 ApiClient.userFidoDelete}, see its documentation for more details.\n   *\n   * @returns A function that deletes a FIDO key\n   */\n  get deleteFido() {\n    return this.#apiClient.userFidoDelete.bind(this.#apiClient);\n  }\n\n  /**\n   * Create a reference to an existing TOTP challenge.\n   *\n   * @param totpId The ID of the challenge\n   * @returns The TOTP challenge\n   */\n  getTotpChallenge(totpId: string): TotpChallenge {\n    return new TotpChallenge(this.#apiClient, totpId);\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}.\n   *\n   * Same as {@link ApiClient.userTotpResetInit}, see its documentation for more details.\n   *\n   * @returns A promise that resolves to a TOTP challenge\n   */\n  get resetTotp() {\n    return this.#apiClient.userTotpResetInit.bind(this.#apiClient);\n  }\n\n  /**\n   * Creates a request to change this user's verified email.\n   *\n   * Same as {@link ApiClient.userEmailResetInit}, see its documentation for more details.\n   *\n   * @returns A promise that resolves to an email challenge\n   */\n  get resetEmail() {\n    return this.#apiClient.userEmailResetInit.bind(this.#apiClient);\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 ApiClient.userTotpVerify}, see its documentation for more details.\n   *\n   * @returns A function that verifies the TOTP code, throwing if not valid\n   */\n  get verifyTotp() {\n    return this.#apiClient.userTotpVerify.bind(this.#apiClient);\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 ApiClient.userTotpDelete}, see its documentation for more details.\n   *\n   * @returns A function that deletes TOTP from the user\n   */\n  get deleteTotp() {\n    return this.#apiClient.userTotpDelete.bind(this.#apiClient);\n  }\n\n  /**\n   * Add a listener for an event\n   *\n   * Same as {@link ApiClient.addEventListener}, see its documentation for more details.\n   *\n   * @returns A function that resolves to the ApiClient with the new listener\n   */\n  get addEventListener() {\n    return this.#apiClient.addEventListener.bind(this.#apiClient);\n  }\n\n  /**\n   * Remove a listener for an event\n   *\n   * Same as {@link ApiClient.removeEventListener}, see its documentation for more details.\n   *\n   * @returns A function that resolves to the ApiClient with a removed listener\n   */\n  get removeEventListener() {\n    return this.#apiClient.removeEventListener.bind(this.#apiClient);\n  }\n\n  /**\n   * Get this session metadata.\n   *\n   * @returns Current session metadata.\n   */\n  async getSession(): Promise<SessionInfo> {\n    return await this.#apiClient.sessionGet();\n  }\n\n  /**\n   * Revoke this session.\n   */\n  async revokeSession(): Promise<void> {\n    await this.#apiClient.sessionRevoke();\n  }\n}\n"]}
255
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/client.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApiClient } from \"./client/api_client\";\nimport type { EmailOtpResponse, IdentityProof, RatchetConfig } from \"./schema_types\";\n\n// used in doc comments\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nimport { AddFidoChallenge, TotpChallenge } from \"./mfa\";\nimport { Org } from \"./org\";\nimport type { MfaReceipts, SessionData, SessionInfo, SessionManager } from \".\";\nimport { Key } from \".\";\n\n/** Options for logging in with OIDC token */\nexport interface OidcAuthOptions {\n  /** Optional token lifetimes */\n  lifetimes?: RatchetConfig;\n  /** Optional MFA receipt(s) */\n  mfaReceipt?: MfaReceipts;\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 {\n  readonly #apiClient: ApiClient;\n\n  /**\n   * @returns The underlying API client. This client provides direct API access without convenience wrappers.\n   */\n  get apiClient() {\n    return this.#apiClient;\n  }\n\n  /**\n   * @returns The environment.\n   */\n  get env() {\n    return this.#apiClient.env;\n  }\n\n  /**\n   * @returns The org ID of the client.\n   */\n  get orgId() {\n    return this.#apiClient.orgId;\n  }\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   */\n  constructor(apiClient: ApiClient) {\n    this.#apiClient = apiClient;\n  }\n\n  /**\n   * Construct a client with a session or session manager\n   *\n   * @param session The session (object or base64 string) or manager that will back this client\n   * @param targetOrgId The ID of the organization this client should operate on. Defaults to\n   *   the org id from the supplied session. The only scenario in which it makes sense to use\n   *   a {@link targetOrgId} different from the session org id is if {@link targetOrgId} is a\n   *   child organization of the session organization.\n   * @returns A client\n   */\n  static async create(\n    session: string | SessionManager | SessionData,\n    targetOrgId?: string,\n  ): Promise<CubeSignerClient> {\n    return new CubeSignerClient(await ApiClient.create(session, targetOrgId));\n  }\n\n  /**\n   * Get the org associated with this session.\n   *\n   * @returns The org\n   */\n  org(): Org {\n    return new Org(this.#apiClient, this.orgId);\n  }\n\n  /**\n   * Get information about an org.\n   *\n   * @param orgId The ID or name of the org\n   * @returns CubeSigner client for the requested org.\n   */\n  getOrg(orgId: string): Org {\n    return new Org(this.#apiClient, orgId);\n  }\n\n  /**\n   * Obtain information about the current user.\n   *\n   * Same as {@link ApiClient.userGet}, see its documentation for more details.\n   *\n   * @returns A function that resolves to the current user's information\n   */\n  get user() {\n    return this.#apiClient.userGet.bind(this.#apiClient);\n  }\n\n  /**\n   * Get all keys accessible to the current session\n   *\n   * NOTE: this may be a subset from the keys in the current org.\n   *\n   * @returns The keys that a client can access\n   */\n  async sessionKeys(): Promise<Key[]> {\n    return await this.#apiClient\n      .sessionKeysList()\n      .then((keyInfos) => keyInfos.map((keyInfo) => new Key(this.#apiClient, keyInfo)));\n  }\n\n  /**\n   * Create a new OIDC-backed session.\n   *\n   * Same as {@link ApiClient.oidcSessionCreate}, see its documentation for more details.\n   *\n   * @param args Request arguments\n   * @returns The new session data\n   */\n  static async createOidcSession(\n    ...args: Parameters<typeof ApiClient.oidcSessionCreate>\n  ): Promise<Awaited<ReturnType<typeof ApiClient.oidcSessionCreate>>> {\n    return await ApiClient.oidcSessionCreate(...args);\n  }\n\n  /**\n   * Prove an OIDC identity.\n   *\n   * Same as {@link ApiClient.identityProveOidc}, see its documentation for more details.\n   *\n   * @param args Request arguments\n   * @returns Proof of authentication\n   */\n  static async proveOidcIdentity(\n    ...args: Parameters<typeof ApiClient.identityProveOidc>\n  ): Promise<IdentityProof> {\n    return await ApiClient.identityProveOidc(...args);\n  }\n\n  /**\n   * Initialize email OTP authentication.\n   *\n   * Same as {@link ApiClient.initEmailOtpAuth}, see its documentation for more details.\n   *\n   * @param args Request arguments\n   * @returns — The partial OIDC token that must be combined with the signature in the email\n   */\n  static async initEmailOtpAuth(\n    ...args: Parameters<typeof ApiClient.initEmailOtpAuth>\n  ): Promise<EmailOtpResponse> {\n    return await ApiClient.initEmailOtpAuth(...args);\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 ApiClient.userFidoRegisterInit}, see its documentation for more details.\n   *\n   * @returns A function that resolves to an AddFidoChallenge\n   */\n  get addFido() {\n    return this.#apiClient.userFidoRegisterInit.bind(this.#apiClient);\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 ApiClient.userFidoDelete}, see its documentation for more details.\n   *\n   * @returns A function that deletes a FIDO key\n   */\n  get deleteFido() {\n    return this.#apiClient.userFidoDelete.bind(this.#apiClient);\n  }\n\n  /**\n   * Create a reference to an existing TOTP challenge.\n   *\n   * @param totpId The ID of the challenge\n   * @returns The TOTP challenge\n   */\n  getTotpChallenge(totpId: string): TotpChallenge {\n    return new TotpChallenge(this.#apiClient, totpId);\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}.\n   *\n   * Same as {@link ApiClient.userTotpResetInit}, see its documentation for more details.\n   *\n   * @returns A promise that resolves to a TOTP challenge\n   */\n  get resetTotp() {\n    return this.#apiClient.userTotpResetInit.bind(this.#apiClient);\n  }\n\n  /**\n   * Creates a request to change this user's verified email.\n   *\n   * Same as {@link ApiClient.userEmailResetInit}, see its documentation for more details.\n   *\n   * @returns A promise that resolves to an email challenge\n   */\n  get resetEmail() {\n    return this.#apiClient.userEmailResetInit.bind(this.#apiClient);\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 ApiClient.userTotpVerify}, see its documentation for more details.\n   *\n   * @returns A function that verifies the TOTP code, throwing if not valid\n   */\n  get verifyTotp() {\n    return this.#apiClient.userTotpVerify.bind(this.#apiClient);\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 ApiClient.userTotpDelete}, see its documentation for more details.\n   *\n   * @returns A function that deletes TOTP from the user\n   */\n  get deleteTotp() {\n    return this.#apiClient.userTotpDelete.bind(this.#apiClient);\n  }\n\n  /**\n   * Add a listener for an event\n   *\n   * Same as {@link ApiClient.addEventListener}, see its documentation for more details.\n   *\n   * @returns A function that resolves to the ApiClient with the new listener\n   */\n  get addEventListener() {\n    return this.#apiClient.addEventListener.bind(this.#apiClient);\n  }\n\n  /**\n   * Remove a listener for an event\n   *\n   * Same as {@link ApiClient.removeEventListener}, see its documentation for more details.\n   *\n   * @returns A function that resolves to the ApiClient with a removed listener\n   */\n  get removeEventListener() {\n    return this.#apiClient.removeEventListener.bind(this.#apiClient);\n  }\n\n  /**\n   * Get this session metadata.\n   *\n   * @returns Current session metadata.\n   */\n  async getSession(): Promise<SessionInfo> {\n    return await this.#apiClient.sessionGet();\n  }\n\n  /**\n   * Revoke this session.\n   */\n  async revokeSession(): Promise<void> {\n    await this.#apiClient.sessionRevoke();\n  }\n}\n"]}
package/package.json CHANGED
@@ -5,7 +5,7 @@
5
5
  "url": "git+https://github.com/cubist-labs/CubeSigner-TypeScript-SDK.git",
6
6
  "directory": "packages/sdk"
7
7
  },
8
- "version": "0.4.239",
8
+ "version": "0.4.241",
9
9
  "description": "CubeSigner TypeScript SDK",
10
10
  "license": "MIT OR Apache-2.0",
11
11
  "author": "Cubist, Inc.",