@cubist-labs/cubesigner-sdk 0.4.239 → 0.4.244
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/package.json +1 -1
- package/dist/src/audit_log.d.ts +4 -4
- package/dist/src/audit_log.js +1 -1
- package/dist/src/client/api_client.d.ts +35 -14
- package/dist/src/client/api_client.d.ts.map +1 -1
- package/dist/src/client/api_client.js +63 -29
- package/dist/src/client/base_client.d.ts +7 -0
- package/dist/src/client/base_client.d.ts.map +1 -1
- package/dist/src/client/base_client.js +15 -7
- package/dist/src/client.d.ts +24 -32
- package/dist/src/client.d.ts.map +1 -1
- package/dist/src/client.js +21 -29
- package/dist/src/fetch.d.ts.map +1 -1
- package/dist/src/fetch.js +2 -3
- package/dist/src/key.d.ts +17 -1
- package/dist/src/key.d.ts.map +1 -1
- package/dist/src/key.js +17 -1
- package/dist/src/response.d.ts +27 -3
- package/dist/src/response.d.ts.map +1 -1
- package/dist/src/response.js +60 -19
- package/dist/src/schema.d.ts +819 -81
- package/dist/src/schema.d.ts.map +1 -1
- package/dist/src/schema.js +1 -1
- package/dist/src/schema_types.d.ts +10 -1
- package/dist/src/schema_types.d.ts.map +1 -1
- package/dist/src/schema_types.js +1 -1
- package/dist/src/scopes.d.ts.map +1 -1
- package/dist/src/scopes.js +20 -3
- package/package.json +1 -1
- package/src/audit_log.ts +3 -5
- package/src/client/api_client.ts +80 -18
- package/src/client/base_client.ts +22 -9
- package/src/client.ts +23 -57
- package/src/fetch.ts +1 -2
- package/src/key.ts +24 -0
- package/src/response.ts +67 -17
- package/src/schema.ts +879 -90
- package/src/schema_types.ts +11 -1
- package/src/scopes.ts +19 -2
|
@@ -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":"AAEA,OAAO,KAAK,EAAE,wBAAwB,EAAE,EAAE,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAGvF,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,KAAK,EAAE,WAAW,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAE9E,OAAO,KAAK,EAAE,kBAAkB,EAAiB,MAAM,iBAAiB,CAAC;AACzE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;
|
|
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 */
|
|
@@ -140,7 +142,7 @@ class BaseClient extends events_1.EventEmitter {
|
|
|
140
142
|
return status >= 500 && status < 600;
|
|
141
143
|
},
|
|
142
144
|
});
|
|
143
|
-
// Once we have a non-5XX response, we will assertOk (either throwing or yielding the
|
|
145
|
+
// Once we have a non-5XX response, we will assertOk (either throwing or yielding the response)
|
|
144
146
|
return (0, fetch_1.assertOk)(resp);
|
|
145
147
|
}
|
|
146
148
|
catch (e) {
|
|
@@ -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
|
-
|
|
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 response)\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"]}
|
package/dist/src/client.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { ApiClient } from "./client/api_client";
|
|
2
|
-
import type { IdentityProof, RatchetConfig
|
|
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 {
|
|
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
|
-
*
|
|
79
|
+
* Create a new OIDC-backed session.
|
|
80
80
|
*
|
|
81
|
-
* @
|
|
82
|
-
*
|
|
83
|
-
* @param
|
|
84
|
-
* @
|
|
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(
|
|
86
|
+
static createOidcSession(...args: Parameters<typeof ApiClient.oidcSessionCreate>): Promise<Awaited<ReturnType<typeof ApiClient.oidcSessionCreate>>>;
|
|
91
87
|
/**
|
|
92
|
-
*
|
|
88
|
+
* Prove an OIDC identity.
|
|
89
|
+
*
|
|
90
|
+
* Same as {@link ApiClient.identityProveOidc}, see its documentation for more details.
|
|
93
91
|
*
|
|
94
|
-
* @param
|
|
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(
|
|
95
|
+
static proveOidcIdentity(...args: Parameters<typeof ApiClient.identityProveOidc>): Promise<IdentityProof>;
|
|
100
96
|
/**
|
|
101
|
-
*
|
|
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
|
-
*
|
|
99
|
+
* Same as {@link ApiClient.initEmailOtpAuth}, see its documentation for more details.
|
|
106
100
|
*
|
|
107
|
-
* @param
|
|
108
|
-
* @
|
|
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(
|
|
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
|
*
|
package/dist/src/client.d.ts.map
CHANGED
|
@@ -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,
|
|
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"}
|
package/dist/src/client.js
CHANGED
|
@@ -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
|
-
*
|
|
108
|
-
*
|
|
109
|
-
* @
|
|
110
|
-
*
|
|
111
|
-
* @param
|
|
112
|
-
* @
|
|
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(
|
|
119
|
-
return await api_client_1.ApiClient.oidcSessionCreate(
|
|
114
|
+
static async createOidcSession(...args) {
|
|
115
|
+
return await api_client_1.ApiClient.oidcSessionCreate(...args);
|
|
120
116
|
}
|
|
121
117
|
/**
|
|
122
|
-
*
|
|
118
|
+
* Prove an OIDC identity.
|
|
119
|
+
*
|
|
120
|
+
* Same as {@link ApiClient.identityProveOidc}, see its documentation for more details.
|
|
123
121
|
*
|
|
124
|
-
* @param
|
|
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(
|
|
130
|
-
return await api_client_1.ApiClient.identityProveOidc(
|
|
125
|
+
static async proveOidcIdentity(...args) {
|
|
126
|
+
return await api_client_1.ApiClient.identityProveOidc(...args);
|
|
131
127
|
}
|
|
132
128
|
/**
|
|
133
|
-
*
|
|
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
|
-
*
|
|
131
|
+
* Same as {@link ApiClient.initEmailOtpAuth}, see its documentation for more details.
|
|
138
132
|
*
|
|
139
|
-
* @param
|
|
140
|
-
* @
|
|
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(
|
|
145
|
-
return await api_client_1.ApiClient.initEmailOtpAuth(
|
|
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/dist/src/fetch.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fetch.d.ts","sourceRoot":"","sources":["../../src/fetch.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,OAAO,EACL,KAAK,YAAY,EACjB,KAAK,aAAa,EAKnB,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,UAAU,EAAE,KAAK,IAAI,SAAS,EAAE,MAAM,UAAU,CAAC;AAI/D,KAAK,UAAU,GAAG,KAAK,GAAG,MAAM,GAAG,QAAQ,GAAG,KAAK,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;AAClF,MAAM,MAAM,SAAS,GAAG,UAAU,CAAC,MAAM,UAAU,CAAC,CAAC;AAGrD,KAAK,KAAK,GAAG;KACV,CAAC,IAAI,MAAM,SAAS,GAAG;SACrB,CAAC,IAAI,UAAU,IAAI,CAAC,SAAS,MAAM,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,SAAS,MAAM,SAAS,CAAC,CAAC,CAAC,GACvF,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,SAAS,GAC/B,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GACf,KAAK,GACP,KAAK;KACV;CACF,CAAC;AAGF,MAAM,MAAM,aAAa,CAAC,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,GAAG;IAAE,OAAO,EAAE,MAAM,CAAA;CAAE,CAAC;AAOrE;;;;;;;;;;GAUG;AACH,wBAAsB,QAAQ,CAAC,CAAC,SAAS,MAAM,KAAK,EAAE,CAAC,SAAS,MAAM,KAAK,CAAC,CAAC,CAAC,EAC5E,IAAI,EAAE,CAAC,EACP,MAAM,EAAE,CAAC,EACT,YAAY,EAAE,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GACvC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CA6FrC;AAED,+FAA+F;AAC/F,MAAM,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;AAEzE;;;;;;;GAOG;AACH,wBAAgB,EAAE,CAAC,CAAC,SAAS,MAAM,KAAK,EAAE,CAAC,SAAS,MAAM,KAAK,CAAC,CAAC,CAAC,EAChE,IAAI,EAAE,CAAC,EACP,MAAM,EAAE,CAAC,GACR,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAEjB;AAED;;;GAGG;AACH,MAAM,MAAM,wBAAwB,CAAC,CAAC,IAAI,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;AAE7E;;;;;GAKG;AACH,wBAAgB,QAAQ,CAAC,CAAC,EAAE,IAAI,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,wBAAwB,CAAC,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"fetch.d.ts","sourceRoot":"","sources":["../../src/fetch.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,OAAO,EACL,KAAK,YAAY,EACjB,KAAK,aAAa,EAKnB,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,UAAU,EAAE,KAAK,IAAI,SAAS,EAAE,MAAM,UAAU,CAAC;AAI/D,KAAK,UAAU,GAAG,KAAK,GAAG,MAAM,GAAG,QAAQ,GAAG,KAAK,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;AAClF,MAAM,MAAM,SAAS,GAAG,UAAU,CAAC,MAAM,UAAU,CAAC,CAAC;AAGrD,KAAK,KAAK,GAAG;KACV,CAAC,IAAI,MAAM,SAAS,GAAG;SACrB,CAAC,IAAI,UAAU,IAAI,CAAC,SAAS,MAAM,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,SAAS,MAAM,SAAS,CAAC,CAAC,CAAC,GACvF,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,SAAS,GAC/B,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GACf,KAAK,GACP,KAAK;KACV;CACF,CAAC;AAGF,MAAM,MAAM,aAAa,CAAC,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,GAAG;IAAE,OAAO,EAAE,MAAM,CAAA;CAAE,CAAC;AAOrE;;;;;;;;;;GAUG;AACH,wBAAsB,QAAQ,CAAC,CAAC,SAAS,MAAM,KAAK,EAAE,CAAC,SAAS,MAAM,KAAK,CAAC,CAAC,CAAC,EAC5E,IAAI,EAAE,CAAC,EACP,MAAM,EAAE,CAAC,EACT,YAAY,EAAE,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GACvC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CA6FrC;AAED,+FAA+F;AAC/F,MAAM,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;AAEzE;;;;;;;GAOG;AACH,wBAAgB,EAAE,CAAC,CAAC,SAAS,MAAM,KAAK,EAAE,CAAC,SAAS,MAAM,KAAK,CAAC,CAAC,CAAC,EAChE,IAAI,EAAE,CAAC,EACP,MAAM,EAAE,CAAC,GACR,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAEjB;AAED;;;GAGG;AACH,MAAM,MAAM,wBAAwB,CAAC,CAAC,IAAI,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;AAE7E;;;;;GAKG;AACH,wBAAgB,QAAQ,CAAC,CAAC,EAAE,IAAI,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,wBAAwB,CAAC,CAAC,CAAC,CAa/E"}
|
package/dist/src/fetch.js
CHANGED
|
@@ -118,7 +118,7 @@ function op(path, method) {
|
|
|
118
118
|
function assertOk(resp) {
|
|
119
119
|
if (!resp.response.ok) {
|
|
120
120
|
const errResp = resp.error;
|
|
121
|
-
|
|
121
|
+
throw new _1.ErrResponse({
|
|
122
122
|
requestId: errResp?.request_id,
|
|
123
123
|
message: errResp?.message,
|
|
124
124
|
statusText: resp.response?.statusText,
|
|
@@ -126,8 +126,7 @@ function assertOk(resp) {
|
|
|
126
126
|
url: resp.response?.url,
|
|
127
127
|
errorCode: errResp?.error_code,
|
|
128
128
|
});
|
|
129
|
-
throw error;
|
|
130
129
|
}
|
|
131
130
|
return resp.data;
|
|
132
131
|
}
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fetch.js","sourceRoot":"","sources":["../../src/fetch.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * This module amounts to an inlining of much of openapi-fetch.\n *\n * Rather than constructing a stateful client that separates out the HTTP methods,\n * this module creates a fetch function called `apiFetch` which can be used to make direct requests\n */\nimport {\n  type FetchOptions,\n  type FetchResponse,\n  createFinalURL,\n  defaultBodySerializer,\n  defaultQuerySerializer,\n  mergeHeaders,\n} from \"openapi-fetch\";\nimport type { operations, paths as gen_paths } from \"./schema\";\nimport type { ErrorResponse } from \".\";\nimport { ErrResponse } from \".\";\n\ntype HttpMethod = \"get\" | \"post\" | \"delete\" | \"put\" | \"head\" | \"option\" | \"patch\";\nexport type Operation = operations[keyof operations];\n\n// We filter all the paths that aren't associated with operations\ntype paths = {\n  [p in keyof gen_paths]: {\n    [m in HttpMethod as m extends keyof gen_paths[p] ? m : never]: m extends keyof gen_paths[p]\n      ? gen_paths[p][m] extends Operation\n        ? gen_paths[p][m]\n        : never\n      : never;\n  };\n};\n\n// Unlike openapi-fetch, we don't have a client to store the baseUrl, so we need to let it be specified on all requests\nexport type SimpleOptions<T> = FetchOptions<T> & { baseUrl: string };\n\n// By default we set the headers on requests to include the Content-Type for JSON\nconst DEFAULT_HEADERS = {\n  \"Content-Type\": \"application/json\",\n};\n\n/**\n * The raw, stateless fetch interface for the cubesigner API. Can be called directly from anywhere to produce a well-typed request.\n *\n * All type assertions in this function are a result of openapi-fetch's weaker\n * typescript config\n *\n * @param path The path of an API endpoint\n * @param method The HTTP method with which to invoke the endpoint\n * @param fetchOptions The options with which to invoke the endpoint\n * @returns A well-typed request\n */\nexport async function apiFetch<P extends keyof paths, M extends keyof paths[P]>(\n  path: P,\n  method: M,\n  fetchOptions: SimpleOptions<paths[P][M]>,\n): Promise<FetchResponse<paths[P][M]>> {\n  // MIT License\n\n  // Copyright (c) 2023 Drew Powers\n\n  // Permission is hereby granted, free of charge, to any person obtaining a copy\n  // of this software and associated documentation files (the \"Software\"), to deal\n  // in the Software without restriction, including without limitation the rights\n  // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n  // copies of the Software, and to permit persons to whom the Software is\n  // furnished to do so, subject to the following conditions:\n\n  // The above copyright notice and this permission notice shall be included in all\n  // copies or substantial portions of the Software.\n\n  // THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n  // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n  // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n  // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n  // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n  // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n  // SOFTWARE.\n\n  const {\n    headers,\n    body: requestBody,\n    params = {},\n    baseUrl = \"\",\n    parseAs = \"json\",\n    querySerializer = defaultQuerySerializer,\n    bodySerializer = defaultBodySerializer,\n    ...init\n  } = fetchOptions || {};\n\n  // URL\n  const finalURL = createFinalURL(path, {\n    baseUrl,\n    params,\n    querySerializer,\n  });\n  const finalHeaders = mergeHeaders(DEFAULT_HEADERS, headers);\n\n  // fetch!\n  const requestInit = {\n    redirect: \"follow\",\n    body: undefined as BodyInit | undefined,\n    ...init,\n    method: (method as string).toUpperCase(),\n    headers: finalHeaders,\n  };\n\n  if (requestBody) {\n    requestInit.body = bodySerializer(requestBody);\n  }\n  // remove `Content-Type` if serialized body is FormData; browser will correctly set Content-Type & boundary expression\n  if (requestInit.body instanceof FormData) {\n    finalHeaders.delete(\"Content-Type\");\n  }\n\n  const response = await fetch(finalURL, requestInit);\n\n  // handle empty content\n  // note: we return `{}` because we want user truthy checks for `.data` or `.error` to succeed\n  if (response.status === 204 || response.headers.get(\"Content-Length\") === \"0\") {\n    return (response.ok ? { data: {}, response } : { error: {}, response }) as FetchResponse<\n      paths[P][M]\n    >;\n  }\n\n  // parse response (falling back to .text() when necessary)\n  if (response.ok) {\n    // if \"stream\", skip parsing entirely\n    if (parseAs === \"stream\") {\n      // fix for bun: bun consumes response.body, therefore clone before accessing\n      // TODO: test this?\n      return { data: response.clone().body, response } as FetchResponse<paths[P][M]>;\n    }\n    const cloned = response.clone();\n    const res = {\n      data: typeof cloned[parseAs] === \"function\" ? await cloned[parseAs]() : await cloned.text(),\n      response,\n    };\n    return res;\n  }\n\n  // handle errors (always parse as .json() or .text())\n  let error = {};\n  try {\n    error = await response.clone().json();\n  } catch {\n    error = await response.clone().text();\n  }\n  return { error, response } as FetchResponse<paths[P][M]>;\n}\n\n/** A functional representation of an operation (can be constructed using the `op` function) */\nexport type Op<T> = (opt: SimpleOptions<T>) => Promise<FetchResponse<T>>;\n\n/**\n * Generates a function from params -> response for a given path and method\n *\n * @param path The path for an API endpoint\n * @param method The method to invoke that path with\n *\n * @returns The op function to invoke the endpoint\n */\nexport function op<P extends keyof paths, M extends keyof paths[P]>(\n  path: P,\n  method: M,\n): Op<paths[P][M]> {\n  return (opt) => apiFetch(path, method, opt);\n}\n\n/**\n * Type alias for the type of the response body (the \"data\" field of\n * {@link FetchResponse<T>}) when that response is successful.\n */\nexport type FetchResponseSuccessData<T> = Required<FetchResponse<T>>[\"data\"];\n\n/**\n * Turns the response from `apiFetch` into its underlying data, throwing if the response was an error\n *\n * @param resp The response from an API endpoint\n * @returns The data from a successful response\n */\nexport function assertOk<T>(resp: FetchResponse<T>): FetchResponseSuccessData<T> {\n  if (!resp.response.ok) {\n    const errResp = resp.error as unknown as ErrorResponse | undefined;\n    const error = new ErrResponse({\n      requestId: errResp?.request_id,\n      message: errResp?.message,\n      statusText: resp.response?.statusText,\n      status: resp.response?.status,\n      url: resp.response?.url,\n      errorCode: errResp?.error_code,\n    });\n    throw error;\n  }\n  return resp.data!;\n}\n"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fetch.js","sourceRoot":"","sources":["../../src/fetch.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * This module amounts to an inlining of much of openapi-fetch.\n *\n * Rather than constructing a stateful client that separates out the HTTP methods,\n * this module creates a fetch function called `apiFetch` which can be used to make direct requests\n */\nimport {\n  type FetchOptions,\n  type FetchResponse,\n  createFinalURL,\n  defaultBodySerializer,\n  defaultQuerySerializer,\n  mergeHeaders,\n} from \"openapi-fetch\";\nimport type { operations, paths as gen_paths } from \"./schema\";\nimport type { ErrorResponse } from \".\";\nimport { ErrResponse } from \".\";\n\ntype HttpMethod = \"get\" | \"post\" | \"delete\" | \"put\" | \"head\" | \"option\" | \"patch\";\nexport type Operation = operations[keyof operations];\n\n// We filter all the paths that aren't associated with operations\ntype paths = {\n  [p in keyof gen_paths]: {\n    [m in HttpMethod as m extends keyof gen_paths[p] ? m : never]: m extends keyof gen_paths[p]\n      ? gen_paths[p][m] extends Operation\n        ? gen_paths[p][m]\n        : never\n      : never;\n  };\n};\n\n// Unlike openapi-fetch, we don't have a client to store the baseUrl, so we need to let it be specified on all requests\nexport type SimpleOptions<T> = FetchOptions<T> & { baseUrl: string };\n\n// By default we set the headers on requests to include the Content-Type for JSON\nconst DEFAULT_HEADERS = {\n  \"Content-Type\": \"application/json\",\n};\n\n/**\n * The raw, stateless fetch interface for the cubesigner API. Can be called directly from anywhere to produce a well-typed request.\n *\n * All type assertions in this function are a result of openapi-fetch's weaker\n * typescript config\n *\n * @param path The path of an API endpoint\n * @param method The HTTP method with which to invoke the endpoint\n * @param fetchOptions The options with which to invoke the endpoint\n * @returns A well-typed request\n */\nexport async function apiFetch<P extends keyof paths, M extends keyof paths[P]>(\n  path: P,\n  method: M,\n  fetchOptions: SimpleOptions<paths[P][M]>,\n): Promise<FetchResponse<paths[P][M]>> {\n  // MIT License\n\n  // Copyright (c) 2023 Drew Powers\n\n  // Permission is hereby granted, free of charge, to any person obtaining a copy\n  // of this software and associated documentation files (the \"Software\"), to deal\n  // in the Software without restriction, including without limitation the rights\n  // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n  // copies of the Software, and to permit persons to whom the Software is\n  // furnished to do so, subject to the following conditions:\n\n  // The above copyright notice and this permission notice shall be included in all\n  // copies or substantial portions of the Software.\n\n  // THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n  // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n  // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n  // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n  // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n  // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n  // SOFTWARE.\n\n  const {\n    headers,\n    body: requestBody,\n    params = {},\n    baseUrl = \"\",\n    parseAs = \"json\",\n    querySerializer = defaultQuerySerializer,\n    bodySerializer = defaultBodySerializer,\n    ...init\n  } = fetchOptions || {};\n\n  // URL\n  const finalURL = createFinalURL(path, {\n    baseUrl,\n    params,\n    querySerializer,\n  });\n  const finalHeaders = mergeHeaders(DEFAULT_HEADERS, headers);\n\n  // fetch!\n  const requestInit = {\n    redirect: \"follow\",\n    body: undefined as BodyInit | undefined,\n    ...init,\n    method: (method as string).toUpperCase(),\n    headers: finalHeaders,\n  };\n\n  if (requestBody) {\n    requestInit.body = bodySerializer(requestBody);\n  }\n  // remove `Content-Type` if serialized body is FormData; browser will correctly set Content-Type & boundary expression\n  if (requestInit.body instanceof FormData) {\n    finalHeaders.delete(\"Content-Type\");\n  }\n\n  const response = await fetch(finalURL, requestInit);\n\n  // handle empty content\n  // note: we return `{}` because we want user truthy checks for `.data` or `.error` to succeed\n  if (response.status === 204 || response.headers.get(\"Content-Length\") === \"0\") {\n    return (response.ok ? { data: {}, response } : { error: {}, response }) as FetchResponse<\n      paths[P][M]\n    >;\n  }\n\n  // parse response (falling back to .text() when necessary)\n  if (response.ok) {\n    // if \"stream\", skip parsing entirely\n    if (parseAs === \"stream\") {\n      // fix for bun: bun consumes response.body, therefore clone before accessing\n      // TODO: test this?\n      return { data: response.clone().body, response } as FetchResponse<paths[P][M]>;\n    }\n    const cloned = response.clone();\n    const res = {\n      data: typeof cloned[parseAs] === \"function\" ? await cloned[parseAs]() : await cloned.text(),\n      response,\n    };\n    return res;\n  }\n\n  // handle errors (always parse as .json() or .text())\n  let error = {};\n  try {\n    error = await response.clone().json();\n  } catch {\n    error = await response.clone().text();\n  }\n  return { error, response } as FetchResponse<paths[P][M]>;\n}\n\n/** A functional representation of an operation (can be constructed using the `op` function) */\nexport type Op<T> = (opt: SimpleOptions<T>) => Promise<FetchResponse<T>>;\n\n/**\n * Generates a function from params -> response for a given path and method\n *\n * @param path The path for an API endpoint\n * @param method The method to invoke that path with\n *\n * @returns The op function to invoke the endpoint\n */\nexport function op<P extends keyof paths, M extends keyof paths[P]>(\n  path: P,\n  method: M,\n): Op<paths[P][M]> {\n  return (opt) => apiFetch(path, method, opt);\n}\n\n/**\n * Type alias for the type of the response body (the \"data\" field of\n * {@link FetchResponse<T>}) when that response is successful.\n */\nexport type FetchResponseSuccessData<T> = Required<FetchResponse<T>>[\"data\"];\n\n/**\n * Turns the response from `apiFetch` into its underlying data, throwing if the response was an error\n *\n * @param resp The response from an API endpoint\n * @returns The data from a successful response\n */\nexport function assertOk<T>(resp: FetchResponse<T>): FetchResponseSuccessData<T> {\n  if (!resp.response.ok) {\n    const errResp = resp.error as unknown as ErrorResponse | undefined;\n    throw new ErrResponse({\n      requestId: errResp?.request_id,\n      message: errResp?.message,\n      statusText: resp.response?.statusText,\n      status: resp.response?.status,\n      url: resp.response?.url,\n      errorCode: errResp?.error_code,\n    });\n  }\n  return resp.data!;\n}\n"]}
|
package/dist/src/key.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { KeyPolicy } from "./role";
|
|
2
2
|
import type { PageOpts } from "./paginator";
|
|
3
|
-
import type { KeyInfo, SchemaKeyType, KeyInRoleInfo, EvmSignRequest, EvmSignResponse, Eip191SignRequest, Eip712SignRequest, Eth2SignRequest, Eth2UnstakeRequest, AvaTx, BlobSignRequest, BtcSignRequest, SolanaSignRequest, SolanaSignResponse, BtcMessageSignResponse, BtcSignResponse, BlobSignResponse, AvaSignResponse, Eth2UnstakeResponse, Eth2SignResponse, Eip191Or712SignResponse, PsbtSignRequest, PsbtSignResponse, DiffieHellmanResponse, KeyInfoJwt, KeyAttestationQuery } from "./schema_types";
|
|
3
|
+
import type { KeyInfo, SchemaKeyType, KeyInRoleInfo, EvmSignRequest, EvmSignResponse, Eip191SignRequest, Eip712SignRequest, Eth2SignRequest, Eth2UnstakeRequest, AvaTx, BlobSignRequest, BtcSignRequest, SolanaSignRequest, SolanaSignResponse, BtcMessageSignResponse, BtcSignResponse, BlobSignResponse, AvaSignResponse, Eth2UnstakeResponse, Eth2SignResponse, Eip191Or712SignResponse, PsbtSignRequest, PsbtSignResponse, DiffieHellmanResponse, KeyInfoJwt, KeyAttestationQuery, BinanceApiProperties } from "./schema_types";
|
|
4
4
|
import type { ApiClient, AvaChain, BabylonRegistrationRequest, BabylonRegistrationResponse, BabylonStakingRequest, BabylonStakingResponse, CubeSignerResponse, EditPolicy, Empty, HistoricalTx, JsonValue, MfaReceipts, SuiSignRequest, SuiSignResponse } from ".";
|
|
5
5
|
import { CubeSignerClient } from ".";
|
|
6
6
|
/** Secp256k1 key type */
|
|
@@ -44,6 +44,7 @@ export declare enum Ed25519 {
|
|
|
44
44
|
Stellar = "Ed25519StellarAddr",
|
|
45
45
|
Substrate = "Ed25519SubstrateAddr",
|
|
46
46
|
Tendermint = "Ed25519TendermintAddr",
|
|
47
|
+
BinanceApi = "Ed25519BinanceApi",
|
|
47
48
|
Ton = "Ed25519TonAddr",
|
|
48
49
|
Xrp = "Ed25519XrpAddr"
|
|
49
50
|
}
|
|
@@ -64,6 +65,10 @@ export declare const BabyJubjub: "BabyJubjub";
|
|
|
64
65
|
export type BabyJubjub = typeof BabyJubjub;
|
|
65
66
|
/** Key type */
|
|
66
67
|
export type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark | P256 | BabyJubjub;
|
|
68
|
+
/** The type representing all different kinds of key properties. */
|
|
69
|
+
export type KeyPropertiesPatch = {
|
|
70
|
+
kind: "BinanceApi";
|
|
71
|
+
} & BinanceApiProperties;
|
|
67
72
|
/**
|
|
68
73
|
* A representation of a signing key.
|
|
69
74
|
*/
|
|
@@ -163,6 +168,17 @@ export declare class Key {
|
|
|
163
168
|
* @returns The updated key info
|
|
164
169
|
*/
|
|
165
170
|
setMetadata(metadata: JsonValue, mfaReceipt?: MfaReceipts): Promise<KeyInfo>;
|
|
171
|
+
/**
|
|
172
|
+
* Set key properties. Each field in the provided patch is independent: missing
|
|
173
|
+
* means leave alone, `null` clears, a value sets. Sending `null` for the whole
|
|
174
|
+
* field clears all properties on the key.
|
|
175
|
+
*
|
|
176
|
+
* @param patch Type-specific properties
|
|
177
|
+
* @param mfaReceipt Optional MFA receipt(s)
|
|
178
|
+
* @throws if MFA is required and no receipts are provided
|
|
179
|
+
* @returns The updated key info
|
|
180
|
+
*/
|
|
181
|
+
setProperties(patch: KeyPropertiesPatch | null, mfaReceipt?: MfaReceipts): Promise<KeyInfo>;
|
|
166
182
|
/**
|
|
167
183
|
* Retrieves the existing metadata, asserts that it is an object (throws if it is not),
|
|
168
184
|
* then sets the value of the {@link name} property in that object to {@link value},
|