@cubist-labs/cubesigner-sdk 0.4.53-0 → 0.4.54-0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/package.json +1 -1
- package/dist/src/client/base_client.d.ts +8 -2
- package/dist/src/client/base_client.d.ts.map +1 -1
- package/dist/src/client/base_client.js +18 -10
- package/dist/src/index.d.ts +0 -4
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +2 -10
- package/package.json +1 -1
- package/src/client/base_client.ts +12 -9
- package/src/index.ts +0 -8
package/README.md
CHANGED
|
@@ -157,7 +157,7 @@ which determine what that session can be used for. We'll talk more about this la
|
|
|
157
157
|
let signingClient = await cs.CubeSignerClient.create(
|
|
158
158
|
// declare the "sign:*" scope which allows us to sign using any keys the
|
|
159
159
|
// account has access to
|
|
160
|
-
await cubesigner.org().createSession("readme signing demo", ["sign:*"]));
|
|
160
|
+
await cubesigner.org().createSession("readme signing demo", ["manage:key:get", "sign:*"]));
|
|
161
161
|
const signingKey = new cs.Key(signingClient, secpKey.cached);
|
|
162
162
|
let sig = await signingKey.signEvm(eth1Request);
|
|
163
163
|
console.log(sig.data());
|
package/dist/package.json
CHANGED
|
@@ -1,7 +1,13 @@
|
|
|
1
|
-
import type { EnvInterface, NewSessionResponse, SessionManager, SessionMetadata, SessionData } from "..";
|
|
2
|
-
import { ErrResponse } from "..";
|
|
3
1
|
import type { FetchResponseSuccessData, Op, Operation, SimpleOptions } from "../fetch";
|
|
4
2
|
import { EventEmitter } from "../events";
|
|
3
|
+
import { ErrResponse } from "../error";
|
|
4
|
+
import type { SessionData, SessionManager, SessionMetadata } from "./session";
|
|
5
|
+
import type { NewSessionResponse } from "../schema_types";
|
|
6
|
+
import type { EnvInterface } from "../env";
|
|
7
|
+
/** CubeSigner SDK package name */
|
|
8
|
+
export declare const NAME: string;
|
|
9
|
+
/** CubeSigner SDK version */
|
|
10
|
+
export declare const VERSION: string;
|
|
5
11
|
export type ErrorEvent = ErrResponse;
|
|
6
12
|
/** Event emitted when a request fails because of an expired/invalid session */
|
|
7
13
|
export declare class SessionExpiredEvent {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base_client.d.ts","sourceRoot":"","sources":["../../../src/client/base_client.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"base_client.d.ts","sourceRoot":"","sources":["../../../src/client/base_client.ts"],"names":[],"mappings":"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"}
|
|
@@ -10,20 +10,28 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
10
10
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
11
11
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
12
12
|
};
|
|
13
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
14
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
15
|
+
};
|
|
13
16
|
var _BaseClient_instances, _BaseClient_sessionManager, _BaseClient_applyOptions, _BaseClient_classifyAndEmitError;
|
|
14
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.signerSessionFromSessionInfo = exports.BaseClient = exports.ALL_EVENTS = exports.UserMfaFailedEvent = exports.SessionExpiredEvent = void 0;
|
|
16
|
-
const
|
|
18
|
+
exports.signerSessionFromSessionInfo = exports.BaseClient = exports.ALL_EVENTS = exports.UserMfaFailedEvent = exports.SessionExpiredEvent = exports.VERSION = exports.NAME = void 0;
|
|
19
|
+
const package_json_1 = __importDefault(require("../../package.json"));
|
|
17
20
|
const fetch_1 = require("../fetch");
|
|
18
21
|
const retry_1 = require("../retry");
|
|
19
|
-
const index_1 = require("../index");
|
|
20
22
|
const events_1 = require("../events");
|
|
23
|
+
const error_1 = require("../error");
|
|
24
|
+
const session_1 = require("./session");
|
|
25
|
+
/** CubeSigner SDK package name */
|
|
26
|
+
exports.NAME = package_json_1.default.name;
|
|
27
|
+
/** CubeSigner SDK version */
|
|
28
|
+
exports.VERSION = package_json_1.default.version;
|
|
21
29
|
/** Event emitted when a request fails because of an expired/invalid session */
|
|
22
30
|
class SessionExpiredEvent {
|
|
23
31
|
}
|
|
24
32
|
exports.SessionExpiredEvent = SessionExpiredEvent;
|
|
25
33
|
/** Event emitted when a request fails because user failed to answer an MFA challenge */
|
|
26
|
-
class UserMfaFailedEvent extends
|
|
34
|
+
class UserMfaFailedEvent extends error_1.ErrResponse {
|
|
27
35
|
}
|
|
28
36
|
exports.UserMfaFailedEvent = UserMfaFailedEvent;
|
|
29
37
|
/**
|
|
@@ -46,14 +54,14 @@ class BaseClient extends events_1.EventEmitter {
|
|
|
46
54
|
* @return {T} A Client
|
|
47
55
|
*/
|
|
48
56
|
static async create(session) {
|
|
49
|
-
const sessionObj = typeof session === "string" ? (0,
|
|
57
|
+
const sessionObj = typeof session === "string" ? (0, session_1.parseBase64SessionData)(session) : session;
|
|
50
58
|
if (typeof sessionObj.token === "function") {
|
|
51
59
|
const manager = sessionObj;
|
|
52
60
|
return new this(await manager.metadata(), manager);
|
|
53
61
|
}
|
|
54
62
|
else {
|
|
55
63
|
session = sessionObj;
|
|
56
|
-
return new this((0,
|
|
64
|
+
return new this((0, session_1.metadata)(session), new session_1.MemorySessionManager(session));
|
|
57
65
|
}
|
|
58
66
|
}
|
|
59
67
|
/**
|
|
@@ -91,7 +99,7 @@ class BaseClient extends events_1.EventEmitter {
|
|
|
91
99
|
return (0, retry_1.retryOn5XX)(() => __classPrivateFieldGet(this, _BaseClient_instances, "m", _BaseClient_applyOptions).call(this, opts).then(op))
|
|
92
100
|
.then(fetch_1.assertOk) // Once we have a non-5XX response, we will assertOk (either throwing or yielding the reponse)
|
|
93
101
|
.catch(async (e) => {
|
|
94
|
-
if (e instanceof
|
|
102
|
+
if (e instanceof error_1.ErrResponse) {
|
|
95
103
|
await __classPrivateFieldGet(this, _BaseClient_instances, "m", _BaseClient_classifyAndEmitError).call(this, e); // Emit appropriate events
|
|
96
104
|
}
|
|
97
105
|
throw e; // Rethrow the error
|
|
@@ -115,8 +123,8 @@ async function _BaseClient_applyOptions(opts) {
|
|
|
115
123
|
baseUrl,
|
|
116
124
|
...opts,
|
|
117
125
|
headers: {
|
|
118
|
-
"User-Agent": `${
|
|
119
|
-
"X-Cubist-Ts-Sdk": `${
|
|
126
|
+
"User-Agent": `${exports.NAME}@${exports.VERSION}`,
|
|
127
|
+
"X-Cubist-Ts-Sdk": `${exports.NAME}@${exports.VERSION}`,
|
|
120
128
|
Authorization: await __classPrivateFieldGet(this, _BaseClient_sessionManager, "f").token(),
|
|
121
129
|
...opts.headers,
|
|
122
130
|
},
|
|
@@ -173,4 +181,4 @@ function signerSessionFromSessionInfo(meta, info, ctx) {
|
|
|
173
181
|
};
|
|
174
182
|
}
|
|
175
183
|
exports.signerSessionFromSessionInfo = signerSessionFromSessionInfo;
|
|
176
|
-
//# 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":["import type {\n  EnvInterface,\n  NewSessionResponse,\n  SessionManager,\n  SessionMetadata,\n  SessionData,\n} from \"..\";\nimport { ErrResponse, metadata, MemorySessionManager, parseBase64SessionData } from \"..\";\nimport type { FetchResponseSuccessData, Op, Operation, SimpleOptions } from \"../fetch\";\nimport { assertOk } from \"../fetch\";\nimport { retryOn5XX } from \"../retry\";\nimport { NAME, VERSION } from \"../index\";\nimport { EventEmitter } from \"../events\";\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 * @deprecated\n */\nexport const ALL_EVENTS: EventEmitter<ClientEvents> = new EventEmitter();\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  #sessionManager: SessionManager;\n\n  /** MUTABLE configuration */\n  config: { updateRetryDelaysMs: number[] } = {\n    /** Update retry delays */\n    updateRetryDelaysMs: [100, 200, 400],\n  };\n\n  /** Get 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   * @param {StaticClientSubclass<T>} this Allows this static method to return subtypes when invoked through them\n   * @param {SessionManager | SessionData | string} session  The session (object or base64 string) or manager that will back this client\n   * @return {T} A Client\n   */\n  static async create<T>(\n    this: StaticClientSubclass<T>,\n    session: string | SessionManager | SessionData,\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);\n    } else {\n      session = sessionObj as SessionData;\n      return new this(metadata(session), new MemorySessionManager(session));\n    }\n  }\n\n  /**\n   * @param {SessionMetadata} [sessionMeta] The initial session metadata\n   * @param {SessionManager} [manager] The manager for the current session\n   *\n   * @internal\n   */\n  constructor(sessionMeta: SessionMetadata, manager: SessionManager) {\n    super();\n    this.#sessionManager = manager;\n    this.sessionMeta = sessionMeta;\n  }\n\n  /** The organization ID */\n  get orgId() {\n    return this.sessionMeta.org_id;\n  }\n\n  /**\n   * Apply the session's implicit arguments on top of what was provided\n   *\n   * @param {SimpleOptions} opts The user-supplied opts\n   * @return {SimpleOptions} The union of the user-supplied opts and the default ones\n   */\n  async #applyOptions<T extends Operation>(\n    opts: OmitAutoParams<SimpleOptions<T>>,\n  ): Promise<SimpleOptions<T>> {\n    const pathParams = \"path\" in (opts.params ?? {}) ? opts.params?.path : undefined;\n    const baseUrl = this.env.SignerApiRoot.replace(/\\/$/, \"\");\n\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\": `${NAME}@${VERSION}`,\n        \"X-Cubist-Ts-Sdk\": `${NAME}@${VERSION}`,\n        Authorization: await this.#sessionManager.token(),\n        ...opts.headers,\n      },\n      params: {\n        ...opts.params,\n        path: {\n          org_id: this.sessionMeta.org_id,\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 {ErrorEvent} 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      this.emit(\"user-mfa-failed\", err);\n      ALL_EVENTS.emit(\"user-mfa-failed\", 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      this.emit(\"session-expired\", err);\n      ALL_EVENTS.emit(\"user-mfa-failed\", 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<T>} op The API operation you wish to perform\n   * @param {SimpleOptions<T>} opts The parameters for the operation\n   * @return {FetchResponseSuccessData<T>} A promise for the successful result (errors will be thrown)\n   */\n  exec<T extends Operation>(\n    op: Op<T>,\n    opts: OmitAutoParams<SimpleOptions<T>>,\n  ): Promise<FetchResponseSuccessData<T>> {\n    return retryOn5XX(() => this.#applyOptions(opts).then(op))\n      .then(assertOk) // Once we have a non-5XX response, we will assertOk (either throwing or yielding the reponse)\n      .catch(async (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 * @param {SessionData} meta An existing SessionData\n * @param {NewSessionResponse} info A new session created via the API\n * @param {object} ctx Additional manual overrides\n * @return {SessionData}\n */\nexport function signerSessionFromSessionInfo(\n  meta: SessionMetadata,\n  info: NewSessionResponse,\n  ctx: Partial<{ purpose: string; role_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"]}
|
|
184
|
+
//# 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":["import pkg from \"../../package.json\";\nimport type { FetchResponseSuccessData, Op, Operation, SimpleOptions } from \"../fetch\";\nimport { assertOk } from \"../fetch\";\nimport { retryOn5XX } 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 } 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 * @deprecated\n */\nexport const ALL_EVENTS: EventEmitter<ClientEvents> = new EventEmitter();\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  #sessionManager: SessionManager;\n\n  /** MUTABLE configuration */\n  config: { updateRetryDelaysMs: number[] } = {\n    /** Update retry delays */\n    updateRetryDelaysMs: [100, 200, 400],\n  };\n\n  /** Get 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   * @param {StaticClientSubclass<T>} this Allows this static method to return subtypes when invoked through them\n   * @param {SessionManager | SessionData | string} session  The session (object or base64 string) or manager that will back this client\n   * @return {T} A Client\n   */\n  static async create<T>(\n    this: StaticClientSubclass<T>,\n    session: string | SessionManager | SessionData,\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);\n    } else {\n      session = sessionObj as SessionData;\n      return new this(metadata(session), new MemorySessionManager(session));\n    }\n  }\n\n  /**\n   * @param {SessionMetadata} [sessionMeta] The initial session metadata\n   * @param {SessionManager} [manager] The manager for the current session\n   *\n   * @internal\n   */\n  constructor(sessionMeta: SessionMetadata, manager: SessionManager) {\n    super();\n    this.#sessionManager = manager;\n    this.sessionMeta = sessionMeta;\n  }\n\n  /** The organization ID */\n  get orgId() {\n    return this.sessionMeta.org_id;\n  }\n\n  /**\n   * Apply the session's implicit arguments on top of what was provided\n   *\n   * @param {SimpleOptions} opts The user-supplied opts\n   * @return {SimpleOptions} The union of the user-supplied opts and the default ones\n   */\n  async #applyOptions<T extends Operation>(\n    opts: OmitAutoParams<SimpleOptions<T>>,\n  ): Promise<SimpleOptions<T>> {\n    const pathParams = \"path\" in (opts.params ?? {}) ? opts.params?.path : undefined;\n    const baseUrl = this.env.SignerApiRoot.replace(/\\/$/, \"\");\n\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\": `${NAME}@${VERSION}`,\n        \"X-Cubist-Ts-Sdk\": `${NAME}@${VERSION}`,\n        Authorization: await this.#sessionManager.token(),\n        ...opts.headers,\n      },\n      params: {\n        ...opts.params,\n        path: {\n          org_id: this.sessionMeta.org_id,\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 {ErrorEvent} 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      this.emit(\"user-mfa-failed\", err);\n      ALL_EVENTS.emit(\"user-mfa-failed\", 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      this.emit(\"session-expired\", err);\n      ALL_EVENTS.emit(\"user-mfa-failed\", 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<T>} op The API operation you wish to perform\n   * @param {SimpleOptions<T>} opts The parameters for the operation\n   * @return {FetchResponseSuccessData<T>} A promise for the successful result (errors will be thrown)\n   */\n  exec<T extends Operation>(\n    op: Op<T>,\n    opts: OmitAutoParams<SimpleOptions<T>>,\n  ): Promise<FetchResponseSuccessData<T>> {\n    return retryOn5XX(() => this.#applyOptions(opts).then(op))\n      .then(assertOk) // Once we have a non-5XX response, we will assertOk (either throwing or yielding the reponse)\n      .catch(async (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 * @param {SessionData} meta An existing SessionData\n * @param {NewSessionResponse} info A new session created via the API\n * @param {object} ctx Additional manual overrides\n * @return {SessionData}\n */\nexport function signerSessionFromSessionInfo(\n  meta: SessionMetadata,\n  info: NewSessionResponse,\n  ctx: Partial<{ purpose: string; role_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"]}
|
package/dist/src/index.d.ts
CHANGED
|
@@ -34,8 +34,4 @@ export * from "./util";
|
|
|
34
34
|
export { userExportDecrypt, userExportKeygen } from "./user_export";
|
|
35
35
|
/** Ethers.js helpers */
|
|
36
36
|
export * from "./evm";
|
|
37
|
-
/** CubeSigner SDK package name */
|
|
38
|
-
export declare const NAME: string;
|
|
39
|
-
/** CubeSigner SDK version */
|
|
40
|
-
export declare const VERSION: string;
|
|
41
37
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/src/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,aAAa;AACb,cAAc,SAAS,CAAC;AACxB,UAAU;AACV,cAAc,qBAAqB,CAAC;AACpC,aAAa;AACb,cAAc,UAAU,CAAC;AACzB,gBAAgB;AAChB,OAAO,EAAE,UAAU,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AACvE,oBAAoB;AACpB,cAAc,OAAO,CAAC;AACtB,WAAW;AACX,cAAc,OAAO,CAAC;AACtB,aAAa;AACb,cAAc,UAAU,CAAC;AACzB,YAAY;AACZ,cAAc,QAAQ,CAAC;AACvB,UAAU;AACV,cAAc,OAAO,CAAC;AACtB,WAAW;AACX,cAAc,OAAO,CAAC;AACtB,iBAAiB;AACjB,cAAc,aAAa,CAAC;AAC5B,eAAe;AACf,cAAc,YAAY,CAAC;AAC3B,YAAY;AACZ,cAAc,gBAAgB,CAAC;AAC/B,eAAe;AACf,cAAc,kBAAkB,CAAC;AACjC,sBAAsB;AACtB,cAAc,kBAAkB,CAAC;AACjC,YAAY;AACZ,cAAc,QAAQ,CAAC;AACvB,oCAAoC;AACpC,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACpE,wBAAwB;AACxB,cAAc,OAAO,CAAC"}
|
package/dist/src/index.js
CHANGED
|
@@ -13,12 +13,8 @@ var __createBinding = (this && this.__createBinding) || (Object.create ? (functi
|
|
|
13
13
|
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
17
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
18
|
-
};
|
|
19
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
20
|
-
exports.
|
|
21
|
-
const package_json_1 = __importDefault(require("./../package.json"));
|
|
17
|
+
exports.userExportKeygen = exports.userExportDecrypt = exports.SessionExpiredEvent = void 0;
|
|
22
18
|
/** Errors */
|
|
23
19
|
__exportStar(require("./error"), exports);
|
|
24
20
|
/** API */
|
|
@@ -58,8 +54,4 @@ Object.defineProperty(exports, "userExportDecrypt", { enumerable: true, get: fun
|
|
|
58
54
|
Object.defineProperty(exports, "userExportKeygen", { enumerable: true, get: function () { return user_export_1.userExportKeygen; } });
|
|
59
55
|
/** Ethers.js helpers */
|
|
60
56
|
__exportStar(require("./evm"), exports);
|
|
61
|
-
|
|
62
|
-
exports.NAME = package_json_1.default.name;
|
|
63
|
-
/** CubeSigner SDK version */
|
|
64
|
-
exports.VERSION = package_json_1.default.version;
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxxRUFBb0M7QUFFcEMsYUFBYTtBQUNiLDBDQUF3QjtBQUN4QixVQUFVO0FBQ1Ysc0RBQW9DO0FBQ3BDLGFBQWE7QUFDYiwyQ0FBeUI7QUFDekIsZ0JBQWdCO0FBQ2hCLG9EQUF1RTtBQUFsRCxrSEFBQSxtQkFBbUIsT0FBQTtBQUN4QyxvQkFBb0I7QUFDcEIsd0NBQXNCO0FBQ3RCLFdBQVc7QUFDWCx3Q0FBc0I7QUFDdEIsYUFBYTtBQUNiLDJDQUF5QjtBQUN6QixZQUFZO0FBQ1oseUNBQXVCO0FBQ3ZCLFVBQVU7QUFDVix3Q0FBc0I7QUFDdEIsV0FBVztBQUNYLHdDQUFzQjtBQUN0QixpQkFBaUI7QUFDakIsOENBQTRCO0FBQzVCLGVBQWU7QUFDZiw2Q0FBMkI7QUFDM0IsWUFBWTtBQUNaLGlEQUErQjtBQUMvQixlQUFlO0FBQ2YsbURBQWlDO0FBQ2pDLHNCQUFzQjtBQUN0QixtREFBaUM7QUFDakMsWUFBWTtBQUNaLHlDQUF1QjtBQUN2QixvQ0FBb0M7QUFDcEMsNkNBQW9FO0FBQTNELGdIQUFBLGlCQUFpQixPQUFBO0FBQUUsK0dBQUEsZ0JBQWdCLE9BQUE7QUFDNUMsd0JBQXdCO0FBQ3hCLHdDQUFzQjtBQUV0QixrQ0FBa0M7QUFDckIsUUFBQSxJQUFJLEdBQVcsc0JBQUcsQ0FBQyxJQUFJLENBQUM7QUFFckMsNkJBQTZCO0FBQ2hCLFFBQUEsT0FBTyxHQUFXLHNCQUFHLENBQUMsT0FBTyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHBrZyBmcm9tIFwiLi8uLi9wYWNrYWdlLmpzb25cIjtcblxuLyoqIEVycm9ycyAqL1xuZXhwb3J0ICogZnJvbSBcIi4vZXJyb3JcIjtcbi8qKiBBUEkgKi9cbmV4cG9ydCAqIGZyb20gXCIuL2NsaWVudC9hcGlfY2xpZW50XCI7XG4vKiogQ2xpZW50ICovXG5leHBvcnQgKiBmcm9tIFwiLi9jbGllbnRcIjtcbi8qKiBDYWxsYmFja3MgKi9cbmV4cG9ydCB7IEVycm9yRXZlbnQsIFNlc3Npb25FeHBpcmVkRXZlbnQgfSBmcm9tIFwiLi9jbGllbnQvYmFzZV9jbGllbnRcIjtcbi8qKiBPcmdhbml6YXRpb25zICovXG5leHBvcnQgKiBmcm9tIFwiLi9vcmdcIjtcbi8qKiBLZXlzICovXG5leHBvcnQgKiBmcm9tIFwiLi9rZXlcIjtcbi8qKiBFdmVudHMgKi9cbmV4cG9ydCAqIGZyb20gXCIuL2V2ZW50c1wiO1xuLyoqIFJvbGVzICovXG5leHBvcnQgKiBmcm9tIFwiLi9yb2xlXCI7XG4vKiogRW52ICovXG5leHBvcnQgKiBmcm9tIFwiLi9lbnZcIjtcbi8qKiBGaWRvICovXG5leHBvcnQgKiBmcm9tIFwiLi9tZmFcIjtcbi8qKiBQYWdpbmF0aW9uICovXG5leHBvcnQgKiBmcm9tIFwiLi9wYWdpbmF0b3JcIjtcbi8qKiBSZXNwb25zZSAqL1xuZXhwb3J0ICogZnJvbSBcIi4vcmVzcG9uc2VcIjtcbi8qKiBUeXBlcyAqL1xuZXhwb3J0ICogZnJvbSBcIi4vc2NoZW1hX3R5cGVzXCI7XG4vKiogU2Vzc2lvbnMgKi9cbmV4cG9ydCAqIGZyb20gXCIuL3NpZ25lcl9zZXNzaW9uXCI7XG4vKiogU2Vzc2lvbiBzdG9yYWdlICovXG5leHBvcnQgKiBmcm9tIFwiLi9jbGllbnQvc2Vzc2lvblwiO1xuLyoqIFV0aWxzICovXG5leHBvcnQgKiBmcm9tIFwiLi91dGlsXCI7XG4vKiogVXNlci1leHBvcnQgZGVjcnlwdGlvbiBoZWxwZXIgKi9cbmV4cG9ydCB7IHVzZXJFeHBvcnREZWNyeXB0LCB1c2VyRXhwb3J0S2V5Z2VuIH0gZnJvbSBcIi4vdXNlcl9leHBvcnRcIjtcbi8qKiBFdGhlcnMuanMgaGVscGVycyAqL1xuZXhwb3J0ICogZnJvbSBcIi4vZXZtXCI7XG5cbi8qKiBDdWJlU2lnbmVyIFNESyBwYWNrYWdlIG5hbWUgKi9cbmV4cG9ydCBjb25zdCBOQU1FOiBzdHJpbmcgPSBwa2cubmFtZTtcblxuLyoqIEN1YmVTaWduZXIgU0RLIHZlcnNpb24gKi9cbmV4cG9ydCBjb25zdCBWRVJTSU9OOiBzdHJpbmcgPSBwa2cudmVyc2lvbjtcbiJdfQ==
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxhQUFhO0FBQ2IsMENBQXdCO0FBQ3hCLFVBQVU7QUFDVixzREFBb0M7QUFDcEMsYUFBYTtBQUNiLDJDQUF5QjtBQUN6QixnQkFBZ0I7QUFDaEIsb0RBQXVFO0FBQWxELGtIQUFBLG1CQUFtQixPQUFBO0FBQ3hDLG9CQUFvQjtBQUNwQix3Q0FBc0I7QUFDdEIsV0FBVztBQUNYLHdDQUFzQjtBQUN0QixhQUFhO0FBQ2IsMkNBQXlCO0FBQ3pCLFlBQVk7QUFDWix5Q0FBdUI7QUFDdkIsVUFBVTtBQUNWLHdDQUFzQjtBQUN0QixXQUFXO0FBQ1gsd0NBQXNCO0FBQ3RCLGlCQUFpQjtBQUNqQiw4Q0FBNEI7QUFDNUIsZUFBZTtBQUNmLDZDQUEyQjtBQUMzQixZQUFZO0FBQ1osaURBQStCO0FBQy9CLGVBQWU7QUFDZixtREFBaUM7QUFDakMsc0JBQXNCO0FBQ3RCLG1EQUFpQztBQUNqQyxZQUFZO0FBQ1oseUNBQXVCO0FBQ3ZCLG9DQUFvQztBQUNwQyw2Q0FBb0U7QUFBM0QsZ0hBQUEsaUJBQWlCLE9BQUE7QUFBRSwrR0FBQSxnQkFBZ0IsT0FBQTtBQUM1Qyx3QkFBd0I7QUFDeEIsd0NBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqIEVycm9ycyAqL1xuZXhwb3J0ICogZnJvbSBcIi4vZXJyb3JcIjtcbi8qKiBBUEkgKi9cbmV4cG9ydCAqIGZyb20gXCIuL2NsaWVudC9hcGlfY2xpZW50XCI7XG4vKiogQ2xpZW50ICovXG5leHBvcnQgKiBmcm9tIFwiLi9jbGllbnRcIjtcbi8qKiBDYWxsYmFja3MgKi9cbmV4cG9ydCB7IEVycm9yRXZlbnQsIFNlc3Npb25FeHBpcmVkRXZlbnQgfSBmcm9tIFwiLi9jbGllbnQvYmFzZV9jbGllbnRcIjtcbi8qKiBPcmdhbml6YXRpb25zICovXG5leHBvcnQgKiBmcm9tIFwiLi9vcmdcIjtcbi8qKiBLZXlzICovXG5leHBvcnQgKiBmcm9tIFwiLi9rZXlcIjtcbi8qKiBFdmVudHMgKi9cbmV4cG9ydCAqIGZyb20gXCIuL2V2ZW50c1wiO1xuLyoqIFJvbGVzICovXG5leHBvcnQgKiBmcm9tIFwiLi9yb2xlXCI7XG4vKiogRW52ICovXG5leHBvcnQgKiBmcm9tIFwiLi9lbnZcIjtcbi8qKiBGaWRvICovXG5leHBvcnQgKiBmcm9tIFwiLi9tZmFcIjtcbi8qKiBQYWdpbmF0aW9uICovXG5leHBvcnQgKiBmcm9tIFwiLi9wYWdpbmF0b3JcIjtcbi8qKiBSZXNwb25zZSAqL1xuZXhwb3J0ICogZnJvbSBcIi4vcmVzcG9uc2VcIjtcbi8qKiBUeXBlcyAqL1xuZXhwb3J0ICogZnJvbSBcIi4vc2NoZW1hX3R5cGVzXCI7XG4vKiogU2Vzc2lvbnMgKi9cbmV4cG9ydCAqIGZyb20gXCIuL3NpZ25lcl9zZXNzaW9uXCI7XG4vKiogU2Vzc2lvbiBzdG9yYWdlICovXG5leHBvcnQgKiBmcm9tIFwiLi9jbGllbnQvc2Vzc2lvblwiO1xuLyoqIFV0aWxzICovXG5leHBvcnQgKiBmcm9tIFwiLi91dGlsXCI7XG4vKiogVXNlci1leHBvcnQgZGVjcnlwdGlvbiBoZWxwZXIgKi9cbmV4cG9ydCB7IHVzZXJFeHBvcnREZWNyeXB0LCB1c2VyRXhwb3J0S2V5Z2VuIH0gZnJvbSBcIi4vdXNlcl9leHBvcnRcIjtcbi8qKiBFdGhlcnMuanMgaGVscGVycyAqL1xuZXhwb3J0ICogZnJvbSBcIi4vZXZtXCI7XG4iXX0=
|
package/package.json
CHANGED
|
@@ -1,16 +1,19 @@
|
|
|
1
|
-
import
|
|
2
|
-
EnvInterface,
|
|
3
|
-
NewSessionResponse,
|
|
4
|
-
SessionManager,
|
|
5
|
-
SessionMetadata,
|
|
6
|
-
SessionData,
|
|
7
|
-
} from "..";
|
|
8
|
-
import { ErrResponse, metadata, MemorySessionManager, parseBase64SessionData } from "..";
|
|
1
|
+
import pkg from "../../package.json";
|
|
9
2
|
import type { FetchResponseSuccessData, Op, Operation, SimpleOptions } from "../fetch";
|
|
10
3
|
import { assertOk } from "../fetch";
|
|
11
4
|
import { retryOn5XX } from "../retry";
|
|
12
|
-
import { NAME, VERSION } from "../index";
|
|
13
5
|
import { EventEmitter } from "../events";
|
|
6
|
+
import { ErrResponse } from "../error";
|
|
7
|
+
import type { SessionData, SessionManager, SessionMetadata } from "./session";
|
|
8
|
+
import { MemorySessionManager, metadata, parseBase64SessionData } from "./session";
|
|
9
|
+
import type { NewSessionResponse } from "../schema_types";
|
|
10
|
+
import type { EnvInterface } from "../env";
|
|
11
|
+
|
|
12
|
+
/** CubeSigner SDK package name */
|
|
13
|
+
export const NAME: string = pkg.name;
|
|
14
|
+
|
|
15
|
+
/** CubeSigner SDK version */
|
|
16
|
+
export const VERSION: string = pkg.version;
|
|
14
17
|
|
|
15
18
|
export type ErrorEvent = ErrResponse;
|
|
16
19
|
|
package/src/index.ts
CHANGED
|
@@ -1,5 +1,3 @@
|
|
|
1
|
-
import pkg from "./../package.json";
|
|
2
|
-
|
|
3
1
|
/** Errors */
|
|
4
2
|
export * from "./error";
|
|
5
3
|
/** API */
|
|
@@ -36,9 +34,3 @@ export * from "./util";
|
|
|
36
34
|
export { userExportDecrypt, userExportKeygen } from "./user_export";
|
|
37
35
|
/** Ethers.js helpers */
|
|
38
36
|
export * from "./evm";
|
|
39
|
-
|
|
40
|
-
/** CubeSigner SDK package name */
|
|
41
|
-
export const NAME: string = pkg.name;
|
|
42
|
-
|
|
43
|
-
/** CubeSigner SDK version */
|
|
44
|
-
export const VERSION: string = pkg.version;
|