@cubist-labs/cubesigner-sdk 0.1.26 → 0.1.77

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.
Files changed (44) hide show
  1. package/README.md +94 -33
  2. package/dist/src/ethers/index.d.ts +25 -5
  3. package/dist/src/ethers/index.js +58 -16
  4. package/dist/src/fido.d.ts +76 -0
  5. package/dist/src/fido.js +148 -0
  6. package/dist/src/index.d.ts +148 -35
  7. package/dist/src/index.js +320 -53
  8. package/dist/src/key.d.ts +64 -8
  9. package/dist/src/key.js +91 -19
  10. package/dist/src/org.d.ts +98 -9
  11. package/dist/src/org.js +144 -29
  12. package/dist/src/paginator.d.ts +76 -0
  13. package/dist/src/paginator.js +99 -0
  14. package/dist/src/role.d.ts +20 -8
  15. package/dist/src/role.js +7 -5
  16. package/dist/src/schema.d.ts +2395 -393
  17. package/dist/src/schema.js +1 -1
  18. package/dist/src/session/cognito_manager.d.ts +59 -0
  19. package/dist/src/session/cognito_manager.js +111 -0
  20. package/dist/src/session/session_manager.d.ts +15 -0
  21. package/dist/src/session/session_manager.js +21 -2
  22. package/dist/src/session/session_storage.js +1 -1
  23. package/dist/src/session/signer_session_manager.d.ts +24 -12
  24. package/dist/src/session/signer_session_manager.js +45 -20
  25. package/dist/src/signer_session.d.ts +136 -38
  26. package/dist/src/signer_session.js +187 -80
  27. package/dist/src/util.d.ts +20 -0
  28. package/dist/src/util.js +31 -2
  29. package/package.json +12 -7
  30. package/src/ethers/index.ts +88 -16
  31. package/src/fido.ts +166 -0
  32. package/src/index.ts +366 -77
  33. package/src/key.ts +112 -16
  34. package/src/org.ts +200 -37
  35. package/src/paginator.ts +122 -0
  36. package/src/role.ts +24 -11
  37. package/src/schema.ts +2458 -449
  38. package/src/session/{management_session_manager.ts → cognito_manager.ts} +13 -15
  39. package/src/session/session_manager.ts +25 -1
  40. package/src/session/session_storage.ts +1 -1
  41. package/src/session/signer_session_manager.ts +57 -27
  42. package/src/signer_session.ts +266 -89
  43. package/src/util.ts +41 -0
  44. package/src/session/oidc_session_manager.ts +0 -193
package/dist/src/key.d.ts CHANGED
@@ -4,10 +4,12 @@ import { components } from "./client";
4
4
  export declare enum Secp256k1 {
5
5
  Evm = "SecpEthAddr",
6
6
  Btc = "SecpBtc",
7
- BtcTest = "SecpBtcTest"
7
+ BtcTest = "SecpBtcTest",
8
+ Ava = "SecpAvaAddr",
9
+ AvaTest = "SecpAvaTestAddr"
8
10
  }
9
11
  /** BLS key type */
10
- export declare enum BLS {
12
+ export declare enum Bls {
11
13
  Eth2Deposited = "BlsPub",
12
14
  Eth2Inactive = "BlsInactive"
13
15
  }
@@ -15,11 +17,41 @@ export declare enum BLS {
15
17
  export declare enum Ed25519 {
16
18
  Solana = "Ed25519SolanaAddr",
17
19
  Sui = "Ed25519SuiAddr",
18
- Aptos = "Ed25519AptosAddr"
20
+ Aptos = "Ed25519AptosAddr",
21
+ Cardano = "Ed25519CardanoAddrVk",
22
+ Stellar = "Ed25519StellarAddr"
19
23
  }
24
+ /** Mnemonic key type */
25
+ export declare const Mnemonic: "Mnemonic";
26
+ export type Mnemonic = typeof Mnemonic;
27
+ /** Stark key type */
28
+ export declare const Stark: "Stark";
29
+ export type Stark = typeof Stark;
20
30
  /** Key type */
21
- export type KeyType = Secp256k1 | BLS | Ed25519;
22
- type KeyInfo = components["schemas"]["KeyInfo"];
31
+ export type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark;
32
+ /** Schema key type (i.e., key type at the API level) */
33
+ type SchemaKeyType = components["schemas"]["KeyType"];
34
+ type KeyInfoApi = components["schemas"]["KeyInfo"];
35
+ type KeyTypeApi = components["schemas"]["KeyType"];
36
+ /** Additional properties (for backward compatibility) */
37
+ export interface KeyInfo extends KeyInfoApi {
38
+ /** Alias for key_id */
39
+ id: string;
40
+ /** Alias for key_type */
41
+ type: KeyTypeApi;
42
+ /** Alias for material_id */
43
+ materialId: string;
44
+ /** Alias for public_key */
45
+ publicKey: string;
46
+ }
47
+ /**
48
+ * Define some additional (backward compatibility) properties
49
+ * on a `KeyInfoApi` object returned from the remote end.
50
+ *
51
+ * @param {KeyInfoApi} key Key information returned from the remote end
52
+ * @return {KeyInfo} The same `key` object extended with some derived properties.
53
+ */
54
+ export declare function toKeyInfo(key: KeyInfoApi): KeyInfo;
23
55
  /** Signing keys. */
24
56
  export declare class Key {
25
57
  #private;
@@ -31,8 +63,6 @@ export declare class Key {
31
63
  * @example Key#0x8e3484687e66cdd26cf04c3647633ab4f3570148
32
64
  * */
33
65
  readonly id: string;
34
- /** The type of key. */
35
- readonly type: KeyType;
36
66
  /**
37
67
  * A unique identifier specific to the type of key, such as a public key or an ethereum address
38
68
  * @example 0x8e3484687e66cdd26cf04c3647633ab4f3570148
@@ -45,6 +75,8 @@ export declare class Key {
45
75
  * @example 0x04d2688b6bc2ce7f9879b9e745f3c4dc177908c5cef0c1b64cff19ae7ff27dee623c64fe9d9c325c7fbbc748bbd5f607ce14dd83e28ebbbb7d3e7f2ffb70a79431
46
76
  * */
47
77
  readonly publicKey: string;
78
+ /** The type of key. */
79
+ type(): Promise<KeyType>;
48
80
  /** Is the key enabled? */
49
81
  enabled(): Promise<boolean>;
50
82
  /** Enable the key. */
@@ -75,13 +107,17 @@ export declare class Key {
75
107
  * @param {string} owner The user-id of the new owner of the key.
76
108
  * */
77
109
  setOwner(owner: string): Promise<void>;
110
+ /**
111
+ * Delete this key.
112
+ */
113
+ delete(): Promise<void>;
78
114
  /** Create a new key.
79
115
  * @param {CubeSigner} cs The CubeSigner instance to use for signing.
80
116
  * @param {string} orgId The id of the organization to which the key belongs.
81
117
  * @param {KeyInfo} data The JSON response from the API server.
82
118
  * @internal
83
119
  * */
84
- constructor(cs: CubeSigner, orgId: string, data: KeyInfo);
120
+ constructor(cs: CubeSigner, orgId: string, data: KeyInfoApi);
85
121
  /** Update the key.
86
122
  * @param {UpdateKeyRequest} request The JSON request to send to the API server.
87
123
  * @return {KeyInfo} The JSON response from the API server.
@@ -97,6 +133,20 @@ export declare class Key {
97
133
  * @internal
98
134
  * */
99
135
  static createKeys(cs: CubeSigner, orgId: string, keyType: KeyType, count: number, ownerId?: string): Promise<Key[]>;
136
+ /**
137
+ * Derives a key of a specified type using a supplied derivation path and an existing long-lived mnemonic.
138
+ *
139
+ * The owner of the derived key will be the owner of the mnemonic.
140
+ *
141
+ * @param {CubeSigner} cs The CubeSigner instance to use for key creation.
142
+ * @param {string} orgId The id of the organization to which the key belongs.
143
+ * @param {KeyType} keyType The type of key to create.
144
+ * @param {string[]} derivationPaths Derivation paths from which to derive new keys.
145
+ * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.
146
+ *
147
+ * @return {Key[]} The newly derived keys.
148
+ */
149
+ static deriveKeys(cs: CubeSigner, orgId: string, keyType: KeyType, derivationPaths: string[], mnemonicId: string): Promise<Key[]>;
100
150
  /** Get a key by id.
101
151
  * @param {CubeSigner} cs The CubeSigner instance to use for signing.
102
152
  * @param {string} orgId The id of the organization to which the key belongs.
@@ -111,4 +161,10 @@ export declare class Key {
111
161
  * */
112
162
  private fetch;
113
163
  }
164
+ /** Convert a schema key type to a key type.
165
+ * @param {SchemaKeyType} ty The schema key type.
166
+ * @return {KeyType} The key type.
167
+ * @internal
168
+ * */
169
+ export declare function fromSchemaKeyType(ty: SchemaKeyType): KeyType;
114
170
  export {};
package/dist/src/key.js CHANGED
@@ -1,18 +1,18 @@
1
1
  "use strict";
2
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
3
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
4
+ 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");
5
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
6
+ };
2
7
  var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
3
8
  if (kind === "m") throw new TypeError("Private method is not writable");
4
9
  if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
5
10
  if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
6
11
  return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
7
12
  };
8
- var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
9
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
10
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
11
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
12
- };
13
13
  var _Key_cs;
14
14
  Object.defineProperty(exports, "__esModule", { value: true });
15
- exports.Key = exports.Ed25519 = exports.BLS = exports.Secp256k1 = void 0;
15
+ exports.fromSchemaKeyType = exports.Key = exports.toKeyInfo = exports.Stark = exports.Mnemonic = exports.Ed25519 = exports.Bls = exports.Secp256k1 = void 0;
16
16
  const util_1 = require("./util");
17
17
  /** Secp256k1 key type */
18
18
  var Secp256k1;
@@ -20,22 +20,52 @@ var Secp256k1;
20
20
  Secp256k1["Evm"] = "SecpEthAddr";
21
21
  Secp256k1["Btc"] = "SecpBtc";
22
22
  Secp256k1["BtcTest"] = "SecpBtcTest";
23
+ Secp256k1["Ava"] = "SecpAvaAddr";
24
+ Secp256k1["AvaTest"] = "SecpAvaTestAddr";
23
25
  })(Secp256k1 || (exports.Secp256k1 = Secp256k1 = {}));
24
26
  /** BLS key type */
25
- var BLS;
26
- (function (BLS) {
27
- BLS["Eth2Deposited"] = "BlsPub";
28
- BLS["Eth2Inactive"] = "BlsInactive";
29
- })(BLS || (exports.BLS = BLS = {}));
27
+ var Bls;
28
+ (function (Bls) {
29
+ Bls["Eth2Deposited"] = "BlsPub";
30
+ Bls["Eth2Inactive"] = "BlsInactive";
31
+ })(Bls || (exports.Bls = Bls = {}));
30
32
  /** Ed25519 key type */
31
33
  var Ed25519;
32
34
  (function (Ed25519) {
33
35
  Ed25519["Solana"] = "Ed25519SolanaAddr";
34
36
  Ed25519["Sui"] = "Ed25519SuiAddr";
35
37
  Ed25519["Aptos"] = "Ed25519AptosAddr";
38
+ Ed25519["Cardano"] = "Ed25519CardanoAddrVk";
39
+ Ed25519["Stellar"] = "Ed25519StellarAddr";
36
40
  })(Ed25519 || (exports.Ed25519 = Ed25519 = {}));
41
+ /** Mnemonic key type */
42
+ exports.Mnemonic = "Mnemonic";
43
+ /** Stark key type */
44
+ exports.Stark = "Stark";
45
+ /**
46
+ * Define some additional (backward compatibility) properties
47
+ * on a `KeyInfoApi` object returned from the remote end.
48
+ *
49
+ * @param {KeyInfoApi} key Key information returned from the remote end
50
+ * @return {KeyInfo} The same `key` object extended with some derived properties.
51
+ */
52
+ function toKeyInfo(key) {
53
+ return {
54
+ ...key,
55
+ id: key.key_id,
56
+ type: key.key_type,
57
+ publicKey: key.public_key,
58
+ materialId: key.material_id,
59
+ };
60
+ }
61
+ exports.toKeyInfo = toKeyInfo;
37
62
  /** Signing keys. */
38
63
  class Key {
64
+ /** The type of key. */
65
+ async type() {
66
+ const data = await this.fetch();
67
+ return fromSchemaKeyType(data.key_type);
68
+ }
39
69
  /** Is the key enabled? */
40
70
  async enabled() {
41
71
  const data = await this.fetch();
@@ -86,6 +116,12 @@ class Key {
86
116
  async setOwner(owner) {
87
117
  await this.update({ owner });
88
118
  }
119
+ /**
120
+ * Delete this key.
121
+ */
122
+ async delete() {
123
+ await __classPrivateFieldGet(this, _Key_cs, "f").deleteKey(this.orgId, this.id);
124
+ }
89
125
  // --------------------------------------------------------------------------
90
126
  // -- INTERNAL --------------------------------------------------------------
91
127
  // --------------------------------------------------------------------------
@@ -101,7 +137,6 @@ class Key {
101
137
  __classPrivateFieldSet(this, _Key_cs, cs, "f");
102
138
  this.orgId = orgId;
103
139
  this.id = data.key_id;
104
- this.type = fromSchemaKeyType(data.key_type);
105
140
  this.materialId = data.material_id;
106
141
  this.publicKey = data.public_key;
107
142
  }
@@ -115,7 +150,7 @@ class Key {
115
150
  body: request,
116
151
  parseAs: "json",
117
152
  });
118
- return (0, util_1.assertOk)(resp);
153
+ return toKeyInfo((0, util_1.assertOk)(resp));
119
154
  }
120
155
  /** Create new signing keys.
121
156
  * @param {CubeSigner} cs The CubeSigner instance to use for signing.
@@ -141,6 +176,32 @@ class Key {
141
176
  const data = (0, util_1.assertOk)(resp);
142
177
  return data.keys.map((k) => new Key(cs, orgId, k));
143
178
  }
179
+ /**
180
+ * Derives a key of a specified type using a supplied derivation path and an existing long-lived mnemonic.
181
+ *
182
+ * The owner of the derived key will be the owner of the mnemonic.
183
+ *
184
+ * @param {CubeSigner} cs The CubeSigner instance to use for key creation.
185
+ * @param {string} orgId The id of the organization to which the key belongs.
186
+ * @param {KeyType} keyType The type of key to create.
187
+ * @param {string[]} derivationPaths Derivation paths from which to derive new keys.
188
+ * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.
189
+ *
190
+ * @return {Key[]} The newly derived keys.
191
+ */
192
+ static async deriveKeys(cs, orgId, keyType, derivationPaths, mnemonicId) {
193
+ const resp = await (await cs.management()).put("/v0/org/{org_id}/derive_key", {
194
+ params: { path: { org_id: orgId } },
195
+ body: {
196
+ derivation_path: derivationPaths,
197
+ mnemonic_id: mnemonicId,
198
+ key_type: keyType,
199
+ },
200
+ parseAs: "json",
201
+ });
202
+ const data = (0, util_1.assertOk)(resp);
203
+ return data.keys.map((k) => new Key(cs, orgId, k));
204
+ }
144
205
  /** Get a key by id.
145
206
  * @param {CubeSigner} cs The CubeSigner instance to use for signing.
146
207
  * @param {string} orgId The id of the organization to which the key belongs.
@@ -166,7 +227,7 @@ class Key {
166
227
  parseAs: "json",
167
228
  });
168
229
  const data = (0, util_1.assertOk)(resp);
169
- return data;
230
+ return toKeyInfo(data);
170
231
  }
171
232
  }
172
233
  exports.Key = Key;
@@ -184,18 +245,29 @@ function fromSchemaKeyType(ty) {
184
245
  return Secp256k1.Btc;
185
246
  case "SecpBtcTest":
186
247
  return Secp256k1.BtcTest;
248
+ case "SecpAvaAddr":
249
+ return Secp256k1.Ava;
250
+ case "SecpAvaTestAddr":
251
+ return Secp256k1.AvaTest;
187
252
  case "BlsPub":
188
- return BLS.Eth2Deposited;
253
+ return Bls.Eth2Deposited;
189
254
  case "BlsInactive":
190
- return BLS.Eth2Inactive;
255
+ return Bls.Eth2Inactive;
191
256
  case "Ed25519SolanaAddr":
192
257
  return Ed25519.Solana;
193
258
  case "Ed25519SuiAddr":
194
259
  return Ed25519.Sui;
195
260
  case "Ed25519AptosAddr":
196
261
  return Ed25519.Aptos;
197
- default:
198
- throw new Error(`Unknown key type: ${ty}`);
262
+ case "Ed25519CardanoAddrVk":
263
+ return Ed25519.Cardano;
264
+ case "Ed25519StellarAddr":
265
+ return Ed25519.Stellar;
266
+ case "Stark":
267
+ return exports.Stark;
268
+ case "Mnemonic":
269
+ return exports.Mnemonic;
199
270
  }
200
271
  }
201
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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","sourcesContent":["import { CubeSigner, KeyPolicy } from \".\";\nimport { components } from \"./client\";\nimport { assertOk } from \"./util\";\n\n/** Secp256k1 key type */\nexport enum Secp256k1 {\n  Evm = \"SecpEthAddr\", // eslint-disable-line no-unused-vars\n  Btc = \"SecpBtc\", // eslint-disable-line no-unused-vars\n  BtcTest = \"SecpBtcTest\", // eslint-disable-line no-unused-vars\n}\n\n/** BLS key type */\nexport enum BLS {\n  Eth2Deposited = \"BlsPub\", // eslint-disable-line no-unused-vars\n  Eth2Inactive = \"BlsInactive\", // eslint-disable-line no-unused-vars\n}\n\n/** Ed25519 key type */\nexport enum Ed25519 {\n  Solana = \"Ed25519SolanaAddr\", // eslint-disable-line no-unused-vars\n  Sui = \"Ed25519SuiAddr\", // eslint-disable-line no-unused-vars\n  Aptos = \"Ed25519AptosAddr\", // eslint-disable-line no-unused-vars\n}\n\n/** Key type */\nexport type KeyType = Secp256k1 | BLS | Ed25519;\n\n/** Schema key type (i.e., key type at the API level) */\ntype SchemaKeyType = components[\"schemas\"][\"KeyType\"];\n\ntype UpdateKeyRequest = components[\"schemas\"][\"UpdateKeyRequest\"];\ntype KeyInfo = components[\"schemas\"][\"KeyInfo\"];\n\n/** Signing keys. */\nexport class Key {\n  /** The CubeSigner instance that this key is associated with */\n  readonly #cs: CubeSigner;\n  /** The organization that this key is in */\n  readonly orgId: string;\n  /**\n   * The id of the key: \"Key#\" followed by a unique identifier specific to\n   * the type of key (such as a public key for BLS or an ethereum address for Secp)\n   * @example Key#0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   * */\n  readonly id: string;\n\n  /** The type of key. */\n  readonly type: KeyType;\n\n  /**\n   * A unique identifier specific to the type of key, such as a public key or an ethereum address\n   * @example 0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   * */\n  readonly materialId: string;\n\n  /**\n   * @description Hex-encoded, serialized public key. The format used depends on the key type:\n   * - secp256k1 keys use 65-byte uncompressed SECG format\n   * - BLS keys use 48-byte compressed BLS12-381 (ZCash) format\n   * @example 0x04d2688b6bc2ce7f9879b9e745f3c4dc177908c5cef0c1b64cff19ae7ff27dee623c64fe9d9c325c7fbbc748bbd5f607ce14dd83e28ebbbb7d3e7f2ffb70a79431\n   * */\n  readonly publicKey: string;\n\n  /** Is the key enabled? */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /** Enable the key. */\n  async enable() {\n    await this.update({ enabled: true });\n  }\n\n  /** Disable the key. */\n  async disable() {\n    await this.update({ enabled: false });\n  }\n\n  /**\n   * Set new policy (overwriting any policies previously set for this key)\n   * @param {KeyPolicy} policy The new policy to set\n   */\n  async setPolicy(policy: KeyPolicy) {\n    await this.update({ policy: policy as unknown as Record<string, never>[] });\n  }\n\n  /**\n   * Append to existing key policy. This append is not atomic -- it uses {@link policy} to fetch the current policy and then {@link setPolicy} to set the policy -- and should not be used in across concurrent sessions.\n   * @param {KeyPolicy} policy The policy to append to the existing one.\n   */\n  async appendPolicy(policy: KeyPolicy) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy]);\n  }\n\n  /**\n   * Get the policy for the org.\n   * @return {Promise<KeyPolicy>} The policy for the org.\n   */\n  async policy(): Promise<KeyPolicy> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as KeyPolicy;\n  }\n\n  /**\n   * @description Owner of the key\n   * @example User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\n   * */\n  async owner(): Promise<string> {\n    const data = await this.fetch();\n    return data.owner;\n  }\n\n  /** Set the owner of the key. Only the key (or org) owner can change the owner of the key.\n   * @param {string} owner The user-id of the new owner of the key.\n   * */\n  async setOwner(owner: string) {\n    await this.update({ owner });\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /** Create a new key.\n   * @param {CubeSigner} cs The CubeSigner instance to use for signing.\n   * @param {string} orgId The id of the organization to which the key belongs.\n   * @param {KeyInfo} data The JSON response from the API server.\n   * @internal\n   * */\n  constructor(cs: CubeSigner, orgId: string, data: KeyInfo) {\n    this.#cs = cs;\n    this.orgId = orgId;\n    this.id = data.key_id;\n    this.type = fromSchemaKeyType(data.key_type);\n    this.materialId = data.material_id;\n    this.publicKey = data.public_key;\n  }\n\n  /** Update the key.\n   * @param {UpdateKeyRequest} request The JSON request to send to the API server.\n   * @return {KeyInfo} The JSON response from the API server.\n   * */\n  private async update(request: UpdateKeyRequest): Promise<KeyInfo> {\n    const resp = await (\n      await this.#cs.management()\n    ).patch(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.orgId, key_id: this.id } },\n      body: request,\n      parseAs: \"json\",\n    });\n    return assertOk(resp);\n  }\n\n  /** Create new signing keys.\n   * @param {CubeSigner} cs The CubeSigner instance to use for signing.\n   * @param {string} orgId The id of the organization to which the key belongs.\n   * @param {KeyType} keyType The type of key to create.\n   * @param {number} count The number of keys to create.\n   * @param {string?} ownerId The owner of the keys. Defaults to the session's user.\n   * @return {Key[]} The new keys.\n   * @internal\n   * */\n  static async createKeys(\n    cs: CubeSigner,\n    orgId: string,\n    keyType: KeyType,\n    count: number,\n    ownerId?: string,\n  ): Promise<Key[]> {\n    const chain_id = 0; // not used anymore\n    const resp = await (\n      await cs.management()\n    ).post(\"/v0/org/{org_id}/keys\", {\n      params: { path: { org_id: orgId } },\n      body: {\n        count,\n        chain_id,\n        key_type: keyType,\n        owner: ownerId || null,\n      },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return data.keys.map((k: KeyInfo) => new Key(cs, orgId, k));\n  }\n\n  /** Get a key by id.\n   * @param {CubeSigner} cs The CubeSigner instance to use for signing.\n   * @param {string} orgId The id of the organization to which the key belongs.\n   * @param {string} keyId The id of the key to get.\n   * @return {Key} The key.\n   * @internal\n   * */\n  static async getKey(cs: CubeSigner, orgId: string, keyId: string): Promise<Key> {\n    const resp = await (\n      await cs.management()\n    ).get(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: orgId, key_id: keyId } },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return new Key(cs, orgId, data);\n  }\n\n  /** Fetches the key information.\n   * @return {KeyInfo} The key information.\n   * @internal\n   * */\n  private async fetch(): Promise<KeyInfo> {\n    const resp = await (\n      await this.#cs.management()\n    ).get(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.orgId, key_id: this.id } },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return data;\n  }\n}\n\n/** Convert a schema key type to a key type.\n * @param {SchemaKeyType} ty The schema key type.\n * @return {KeyType} The key type.\n * @internal\n * */\nfunction fromSchemaKeyType(ty: SchemaKeyType): KeyType {\n  switch (ty) {\n    case \"SecpEthAddr\":\n      return Secp256k1.Evm;\n    case \"SecpBtc\":\n      return Secp256k1.Btc;\n    case \"SecpBtcTest\":\n      return Secp256k1.BtcTest;\n    case \"BlsPub\":\n      return BLS.Eth2Deposited;\n    case \"BlsInactive\":\n      return BLS.Eth2Inactive;\n    case \"Ed25519SolanaAddr\":\n      return Ed25519.Solana;\n    case \"Ed25519SuiAddr\":\n      return Ed25519.Sui;\n    case \"Ed25519AptosAddr\":\n      return Ed25519.Aptos;\n    default:\n      throw new Error(`Unknown key type: ${ty}`);\n  }\n}\n"]}
272
+ exports.fromSchemaKeyType = fromSchemaKeyType;
273
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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","sourcesContent":["import { CubeSigner, KeyPolicy } from \".\";\nimport { components } from \"./client\";\nimport { assertOk } from \"./util\";\n\n/** Secp256k1 key type */\nexport enum Secp256k1 {\n  Evm = \"SecpEthAddr\", // eslint-disable-line no-unused-vars\n  Btc = \"SecpBtc\", // eslint-disable-line no-unused-vars\n  BtcTest = \"SecpBtcTest\", // eslint-disable-line no-unused-vars\n  Ava = \"SecpAvaAddr\", // eslint-disable-line no-unused-vars\n  AvaTest = \"SecpAvaTestAddr\", // eslint-disable-line no-unused-vars\n}\n\n/** BLS key type */\nexport enum Bls {\n  Eth2Deposited = \"BlsPub\", // eslint-disable-line no-unused-vars\n  Eth2Inactive = \"BlsInactive\", // eslint-disable-line no-unused-vars\n}\n\n/** Ed25519 key type */\nexport enum Ed25519 {\n  Solana = \"Ed25519SolanaAddr\", // eslint-disable-line no-unused-vars\n  Sui = \"Ed25519SuiAddr\", // eslint-disable-line no-unused-vars\n  Aptos = \"Ed25519AptosAddr\", // eslint-disable-line no-unused-vars\n  Cardano = \"Ed25519CardanoAddrVk\", // eslint-disable-line no-unused-vars\n  Stellar = \"Ed25519StellarAddr\", // eslint-disable-line no-unused-vars\n}\n\n/** Mnemonic key type */\nexport const Mnemonic = \"Mnemonic\" as const;\nexport type Mnemonic = typeof Mnemonic;\n\n/** Stark key type */\nexport const Stark = \"Stark\" as const;\nexport type Stark = typeof Stark;\n\n/** Key type */\nexport type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark;\n\n/** Schema key type (i.e., key type at the API level) */\ntype SchemaKeyType = components[\"schemas\"][\"KeyType\"];\n\ntype UpdateKeyRequest = components[\"schemas\"][\"UpdateKeyRequest\"];\ntype KeyInfoApi = components[\"schemas\"][\"KeyInfo\"];\ntype KeyTypeApi = components[\"schemas\"][\"KeyType\"];\n\n/** Additional properties (for backward compatibility) */\nexport interface KeyInfo extends KeyInfoApi {\n  /** Alias for key_id */\n  id: string;\n  /** Alias for key_type */\n  type: KeyTypeApi;\n  /** Alias for material_id */\n  materialId: string;\n  /** Alias for public_key */\n  publicKey: string;\n}\n\n/**\n * Define some additional (backward compatibility) properties\n * on a `KeyInfoApi` object returned from the remote end.\n *\n * @param {KeyInfoApi} key Key information returned from the remote end\n * @return {KeyInfo} The same `key` object extended with some derived properties.\n */\nexport function toKeyInfo(key: KeyInfoApi): KeyInfo {\n  return {\n    ...key,\n    id: key.key_id,\n    type: key.key_type,\n    publicKey: key.public_key,\n    materialId: key.material_id,\n  };\n}\n\n/** Signing keys. */\nexport class Key {\n  /** The CubeSigner instance that this key is associated with */\n  readonly #cs: CubeSigner;\n  /** The organization that this key is in */\n  readonly orgId: string;\n  /**\n   * The id of the key: \"Key#\" followed by a unique identifier specific to\n   * the type of key (such as a public key for BLS or an ethereum address for Secp)\n   * @example Key#0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   * */\n  readonly id: string;\n\n  /**\n   * A unique identifier specific to the type of key, such as a public key or an ethereum address\n   * @example 0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   * */\n  readonly materialId: string;\n\n  /**\n   * @description Hex-encoded, serialized public key. The format used depends on the key type:\n   * - secp256k1 keys use 65-byte uncompressed SECG format\n   * - BLS keys use 48-byte compressed BLS12-381 (ZCash) format\n   * @example 0x04d2688b6bc2ce7f9879b9e745f3c4dc177908c5cef0c1b64cff19ae7ff27dee623c64fe9d9c325c7fbbc748bbd5f607ce14dd83e28ebbbb7d3e7f2ffb70a79431\n   * */\n  readonly publicKey: string;\n\n  /** The type of key. */\n  async type(): Promise<KeyType> {\n    const data = await this.fetch();\n    return fromSchemaKeyType(data.key_type);\n  }\n\n  /** Is the key enabled? */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /** Enable the key. */\n  async enable() {\n    await this.update({ enabled: true });\n  }\n\n  /** Disable the key. */\n  async disable() {\n    await this.update({ enabled: false });\n  }\n\n  /**\n   * Set new policy (overwriting any policies previously set for this key)\n   * @param {KeyPolicy} policy The new policy to set\n   */\n  async setPolicy(policy: KeyPolicy) {\n    await this.update({ policy: policy as unknown as Record<string, never>[] });\n  }\n\n  /**\n   * Append to existing key policy. This append is not atomic -- it uses {@link policy} to fetch the current policy and then {@link setPolicy} to set the policy -- and should not be used in across concurrent sessions.\n   * @param {KeyPolicy} policy The policy to append to the existing one.\n   */\n  async appendPolicy(policy: KeyPolicy) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy]);\n  }\n\n  /**\n   * Get the policy for the org.\n   * @return {Promise<KeyPolicy>} The policy for the org.\n   */\n  async policy(): Promise<KeyPolicy> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as KeyPolicy;\n  }\n\n  /**\n   * @description Owner of the key\n   * @example User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\n   * */\n  async owner(): Promise<string> {\n    const data = await this.fetch();\n    return data.owner;\n  }\n\n  /** Set the owner of the key. Only the key (or org) owner can change the owner of the key.\n   * @param {string} owner The user-id of the new owner of the key.\n   * */\n  async setOwner(owner: string) {\n    await this.update({ owner });\n  }\n\n  /**\n   * Delete this key.\n   */\n  async delete() {\n    await this.#cs.deleteKey(this.orgId, this.id);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /** Create a new key.\n   * @param {CubeSigner} cs The CubeSigner instance to use for signing.\n   * @param {string} orgId The id of the organization to which the key belongs.\n   * @param {KeyInfo} data The JSON response from the API server.\n   * @internal\n   * */\n  constructor(cs: CubeSigner, orgId: string, data: KeyInfoApi) {\n    this.#cs = cs;\n    this.orgId = orgId;\n    this.id = data.key_id;\n    this.materialId = data.material_id;\n    this.publicKey = data.public_key;\n  }\n\n  /** Update the key.\n   * @param {UpdateKeyRequest} request The JSON request to send to the API server.\n   * @return {KeyInfo} The JSON response from the API server.\n   * */\n  private async update(request: UpdateKeyRequest): Promise<KeyInfo> {\n    const resp = await (\n      await this.#cs.management()\n    ).patch(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.orgId, key_id: this.id } },\n      body: request,\n      parseAs: \"json\",\n    });\n    return toKeyInfo(assertOk(resp));\n  }\n\n  /** Create new signing keys.\n   * @param {CubeSigner} cs The CubeSigner instance to use for signing.\n   * @param {string} orgId The id of the organization to which the key belongs.\n   * @param {KeyType} keyType The type of key to create.\n   * @param {number} count The number of keys to create.\n   * @param {string?} ownerId The owner of the keys. Defaults to the session's user.\n   * @return {Key[]} The new keys.\n   * @internal\n   * */\n  static async createKeys(\n    cs: CubeSigner,\n    orgId: string,\n    keyType: KeyType,\n    count: number,\n    ownerId?: string,\n  ): Promise<Key[]> {\n    const chain_id = 0; // not used anymore\n    const resp = await (\n      await cs.management()\n    ).post(\"/v0/org/{org_id}/keys\", {\n      params: { path: { org_id: orgId } },\n      body: {\n        count,\n        chain_id,\n        key_type: keyType,\n        owner: ownerId || null,\n      },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return data.keys.map((k) => new Key(cs, orgId, k));\n  }\n\n  /**\n   * Derives a key of a specified type using a supplied derivation path and an existing long-lived mnemonic.\n   *\n   * The owner of the derived key will be the owner of the mnemonic.\n   *\n   * @param {CubeSigner} cs The CubeSigner instance to use for key creation.\n   * @param {string} orgId The id of the organization to which the key belongs.\n   * @param {KeyType} keyType The type of key to create.\n   * @param {string[]} derivationPaths Derivation paths from which to derive new keys.\n   * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.\n   *\n   * @return {Key[]} The newly derived keys.\n   */\n  static async deriveKeys(\n    cs: CubeSigner,\n    orgId: string,\n    keyType: KeyType,\n    derivationPaths: string[],\n    mnemonicId: string,\n  ): Promise<Key[]> {\n    const resp = await (\n      await cs.management()\n    ).put(\"/v0/org/{org_id}/derive_key\", {\n      params: { path: { org_id: orgId } },\n      body: {\n        derivation_path: derivationPaths,\n        mnemonic_id: mnemonicId,\n        key_type: keyType,\n      },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return data.keys.map((k) => new Key(cs, orgId, k));\n  }\n\n  /** Get a key by id.\n   * @param {CubeSigner} cs The CubeSigner instance to use for signing.\n   * @param {string} orgId The id of the organization to which the key belongs.\n   * @param {string} keyId The id of the key to get.\n   * @return {Key} The key.\n   * @internal\n   * */\n  static async getKey(cs: CubeSigner, orgId: string, keyId: string): Promise<Key> {\n    const resp = await (\n      await cs.management()\n    ).get(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: orgId, key_id: keyId } },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return new Key(cs, orgId, data);\n  }\n\n  /** Fetches the key information.\n   * @return {KeyInfo} The key information.\n   * @internal\n   * */\n  private async fetch(): Promise<KeyInfo> {\n    const resp = await (\n      await this.#cs.management()\n    ).get(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.orgId, key_id: this.id } },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return toKeyInfo(data);\n  }\n}\n\n/** Convert a schema key type to a key type.\n * @param {SchemaKeyType} ty The schema key type.\n * @return {KeyType} The key type.\n * @internal\n * */\nexport function fromSchemaKeyType(ty: SchemaKeyType): KeyType {\n  switch (ty) {\n    case \"SecpEthAddr\":\n      return Secp256k1.Evm;\n    case \"SecpBtc\":\n      return Secp256k1.Btc;\n    case \"SecpBtcTest\":\n      return Secp256k1.BtcTest;\n    case \"SecpAvaAddr\":\n      return Secp256k1.Ava;\n    case \"SecpAvaTestAddr\":\n      return Secp256k1.AvaTest;\n    case \"BlsPub\":\n      return Bls.Eth2Deposited;\n    case \"BlsInactive\":\n      return Bls.Eth2Inactive;\n    case \"Ed25519SolanaAddr\":\n      return Ed25519.Solana;\n    case \"Ed25519SuiAddr\":\n      return Ed25519.Sui;\n    case \"Ed25519AptosAddr\":\n      return Ed25519.Aptos;\n    case \"Ed25519CardanoAddrVk\":\n      return Ed25519.Cardano;\n    case \"Ed25519StellarAddr\":\n      return Ed25519.Stellar;\n    case \"Stark\":\n      return Stark;\n    case \"Mnemonic\":\n      return Mnemonic;\n  }\n}\n"]}
package/dist/src/org.d.ts CHANGED
@@ -1,11 +1,18 @@
1
- import { CubeSigner, MfaRequestInfo } from ".";
1
+ import { CubeSigner, MfaRequestInfo, IdentityProof, PageOpts } from ".";
2
2
  import { components } from "./client";
3
3
  import { KeyType, Key } from "./key";
4
- import { Role } from "./role";
4
+ import { MfaPolicy, Role } from "./role";
5
5
  /** Organization id */
6
6
  export type OrgId = string;
7
7
  /** Org-wide policy */
8
- export type OrgPolicy = SourceIpAllowlistPolicy | OriginAllowlistPolicy | MaxDailyUnstakePolicy;
8
+ export type OrgPolicy = SourceIpAllowlistPolicy | OidcAuthSourcesPolicy | OriginAllowlistPolicy | MaxDailyUnstakePolicy;
9
+ /**
10
+ * Provides an allowlist of OIDC Issuers and audiences that are allowed to authenticate into this org.
11
+ * @example {"OidcAuthSources": { "https://accounts.google.com": [ "1234.apps.googleusercontent.com" ]}}
12
+ */
13
+ export interface OidcAuthSourcesPolicy {
14
+ OidcAuthSources: Record<string, string[]>;
15
+ }
9
16
  /**
10
17
  * Only allow requests from the specified origins.
11
18
  * @example {"OriginAllowlist": "*"}
@@ -31,6 +38,13 @@ type OrgInfo = components["schemas"]["OrgInfo"];
31
38
  type UserIdInfo = components["schemas"]["UserIdInfo"];
32
39
  export type OidcIdentity = components["schemas"]["OIDCIdentity"];
33
40
  export type MemberRole = components["schemas"]["MemberRole"];
41
+ /** Options for a new OIDC user */
42
+ export interface CreateOidcUserOptions {
43
+ /** The role of an OIDC user, default is "Alien" */
44
+ memberRole?: MemberRole;
45
+ /** Optional MFA policy to associate with the user account */
46
+ mfaPolicy?: MfaPolicy;
47
+ }
34
48
  /** An organization. */
35
49
  export declare class Org {
36
50
  #private;
@@ -71,6 +85,29 @@ export declare class Org {
71
85
  * @return {Key[]} The new keys.
72
86
  * */
73
87
  createKeys(type: KeyType, count: number, ownerId?: string): Promise<Key[]>;
88
+ /**
89
+ * Derives a key of the given type using the given derivation path and mnemonic.
90
+ * The owner of the derived key will be the owner of the mnemonic.
91
+ *
92
+ * @param {KeyType} type Type of key to derive from the mnemonic.
93
+ * @param {string} derivationPath Mnemonic derivation path used to generate new key.
94
+ * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.
95
+ *
96
+ * @return {Key} newly derived key.
97
+ */
98
+ deriveKey(type: KeyType, derivationPath: string, mnemonicId: string): Promise<Key>;
99
+ /**
100
+ * Derives a set of keys of the given type using the given derivation paths and mnemonic.
101
+ *
102
+ * The owner of the derived keys will be the owner of the mnemonic.
103
+ *
104
+ * @param {KeyType} type Type of key to derive from the mnemonic.
105
+ * @param {string[]} derivationPaths Mnemonic derivation paths used to generate new key.
106
+ * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.
107
+ *
108
+ * @return {Key[]} newly derived keys.
109
+ */
110
+ deriveKeys(type: KeyType, derivationPaths: string[], mnemonicId: string): Promise<Key[]>;
74
111
  /**
75
112
  * Create a new user in the organization and sends an invitation to that user
76
113
  * @param {string} email Email of the user
@@ -80,10 +117,24 @@ export declare class Org {
80
117
  /**
81
118
  * Create a new OIDC user
82
119
  * @param {OidcIdentity} identity The identity of the OIDC user
83
- * @param {MemberRole} memberRole The type of membership of the new user
120
+ * @param {string} email Email of the OIDC user
121
+ * @param {CreateOidcUserOptions} opts Additional options for new OIDC users
84
122
  * @return {string} User id of the new user
85
123
  */
86
- createOidcUser(identity: OidcIdentity, memberRole: MemberRole): Promise<string>;
124
+ createOidcUser(identity: OidcIdentity, email: string, opts?: CreateOidcUserOptions): Promise<string>;
125
+ /**
126
+ * Delete an existing OIDC user
127
+ * @param {OidcIdentity} identity The identity of the OIDC user
128
+ */
129
+ deleteOidcUser(identity: OidcIdentity): Promise<{
130
+ status: string;
131
+ }>;
132
+ /**
133
+ * Checks if a given proof of OIDC authentication is valid.
134
+ *
135
+ * @param {IdentityProof} proof The proof of authentication.
136
+ */
137
+ verifyIdentity(proof: IdentityProof): Promise<void>;
87
138
  /**
88
139
  * List users in the organization
89
140
  * @return {UserIdInfo[]} List of users
@@ -96,9 +147,10 @@ export declare class Org {
96
147
  getKey(keyId: string): Promise<Key>;
97
148
  /** Get all keys in the org.
98
149
  * @param {KeyType?} type Optional key type to filter list for.
150
+ * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.
99
151
  * @return {Key} The key.
100
152
  * */
101
- keys(type?: KeyType): Promise<Key[]>;
153
+ keys(type?: KeyType, page?: PageOpts): Promise<Key[]>;
102
154
  /** Create a new role.
103
155
  * @param {string?} name The name of the role.
104
156
  * @return {Role} The new role.
@@ -109,14 +161,23 @@ export declare class Org {
109
161
  * @return {Role} The role.
110
162
  * */
111
163
  getRole(roleId: string): Promise<Role>;
112
- /** List all roles in the org..
164
+ /**
165
+ * List all roles in the org.
166
+ *
167
+ * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.
113
168
  * @return {Role[]} The roles.
114
169
  * */
115
- list(): Promise<Role[]>;
170
+ listRoles(page?: PageOpts): Promise<Role[]>;
171
+ /** List all users in the org.
172
+ * @return {User[]} The users.
173
+ * */
174
+ listUsers(): Promise<UserIdInfo[]>;
116
175
  /**
117
176
  * Get a pending MFA request by its id.
118
177
  * @param {string} mfaId The id of the MFA request.
119
178
  * @return {Promise<MfaRequestInfo>} The MFA request.
179
+ *
180
+ * @deprecated Use {@link getMfaInfo()} instead.
120
181
  */
121
182
  mfaGet(mfaId: string): Promise<MfaRequestInfo>;
122
183
  /**
@@ -124,8 +185,28 @@ export declare class Org {
124
185
  *
125
186
  * @param {string} mfaId The id of the MFA request.
126
187
  * @return {Promise<MfaRequestInfo>} The MFA request.
188
+ *
189
+ * @deprecated Use {@link approveMfaRequest()} instead.
127
190
  */
128
191
  mfaApprove(mfaId: string): Promise<MfaRequestInfo>;
192
+ /**
193
+ * Get a pending MFA request by its id.
194
+ * @param {string} mfaId The id of the MFA request.
195
+ * @return {Promise<MfaRequestInfo>} The MFA request.
196
+ */
197
+ getMfaInfo(mfaId: string): Promise<MfaRequestInfo>;
198
+ /**
199
+ * List pending MFA requests accessible to the current user.
200
+ * @return {Promise<MfaRequestInfo[]>} The MFA requests.
201
+ */
202
+ listMfaInfos(): Promise<MfaRequestInfo[]>;
203
+ /**
204
+ * Approve a pending MFA request.
205
+ *
206
+ * @param {string} mfaId The id of the MFA request.
207
+ * @return {Promise<MfaRequestInfo>} The MFA request.
208
+ */
209
+ approveMfaRequest(mfaId: string): Promise<MfaRequestInfo>;
129
210
  /** Create a new org.
130
211
  * @param {CubeSigner} cs The CubeSigner instance.
131
212
  * @param {OrgInfo} data The JSON response from the API server.
@@ -153,9 +234,17 @@ export declare class Org {
153
234
  /** List roles.
154
235
  * @param {CubeSigner} cs The CubeSigner instance to use for signing.
155
236
  * @param {string} orgId The id of the organization to which the role belongs.
156
- * @return {Role} The role.
237
+ * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.
238
+ * @return {Role[]} Org roles.
157
239
  * @internal
158
240
  * */
159
241
  private static roles;
242
+ /** List users.
243
+ * @param {CubeSigner} cs The CubeSigner instance to use for signing.
244
+ * @param {string} orgId The id of the organization to which the role belongs.
245
+ * @return {User[]} Org users.
246
+ * @internal
247
+ * */
248
+ private static users;
160
249
  }
161
250
  export {};