@cubist-labs/cubesigner-sdk 0.1.23

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 (64) hide show
  1. package/LICENSE-APACHE +177 -0
  2. package/LICENSE-MIT +25 -0
  3. package/NOTICE +13 -0
  4. package/README.md +470 -0
  5. package/dist/examples/ethers.d.ts +1 -0
  6. package/dist/examples/ethers.js +142 -0
  7. package/dist/spec/env/beta.json +9 -0
  8. package/dist/spec/env/gamma.json +9 -0
  9. package/dist/spec/env/prod.json +9 -0
  10. package/dist/src/client.d.ts +10 -0
  11. package/dist/src/client.js +21 -0
  12. package/dist/src/env.d.ts +15 -0
  13. package/dist/src/env.js +35 -0
  14. package/dist/src/ethers/index.d.ts +50 -0
  15. package/dist/src/ethers/index.js +122 -0
  16. package/dist/src/index.d.ts +114 -0
  17. package/dist/src/index.js +205 -0
  18. package/dist/src/key.d.ts +114 -0
  19. package/dist/src/key.js +201 -0
  20. package/dist/src/mfa.d.ts +23 -0
  21. package/dist/src/mfa.js +63 -0
  22. package/dist/src/org.d.ts +161 -0
  23. package/dist/src/org.js +264 -0
  24. package/dist/src/role.d.ts +224 -0
  25. package/dist/src/role.js +256 -0
  26. package/dist/src/schema.d.ts +3049 -0
  27. package/dist/src/schema.js +7 -0
  28. package/dist/src/session/generic.d.ts +47 -0
  29. package/dist/src/session/generic.js +3 -0
  30. package/dist/src/session/management_session_manager.d.ts +59 -0
  31. package/dist/src/session/management_session_manager.js +111 -0
  32. package/dist/src/session/oidc_session_manager.d.ts +78 -0
  33. package/dist/src/session/oidc_session_manager.js +142 -0
  34. package/dist/src/session/session_manager.d.ts +74 -0
  35. package/dist/src/session/session_manager.js +79 -0
  36. package/dist/src/session/session_storage.d.ts +47 -0
  37. package/dist/src/session/session_storage.js +76 -0
  38. package/dist/src/session/signer_session_manager.d.ts +88 -0
  39. package/dist/src/session/signer_session_manager.js +159 -0
  40. package/dist/src/sign.d.ts +114 -0
  41. package/dist/src/sign.js +248 -0
  42. package/dist/src/signer_session.d.ts +180 -0
  43. package/dist/src/signer_session.js +369 -0
  44. package/dist/src/util.d.ts +35 -0
  45. package/dist/src/util.js +75 -0
  46. package/dist/test/sessions.d.ts +35 -0
  47. package/dist/test/sessions.js +56 -0
  48. package/package.json +61 -0
  49. package/src/client.ts +12 -0
  50. package/src/env.ts +25 -0
  51. package/src/ethers/index.ts +131 -0
  52. package/src/index.ts +220 -0
  53. package/src/key.ts +249 -0
  54. package/src/org.ts +333 -0
  55. package/src/role.ts +385 -0
  56. package/src/schema.ts +3054 -0
  57. package/src/session/management_session_manager.ts +136 -0
  58. package/src/session/oidc_session_manager.ts +193 -0
  59. package/src/session/session_manager.ts +114 -0
  60. package/src/session/session_storage.ts +73 -0
  61. package/src/session/signer_session_manager.ts +211 -0
  62. package/src/signer_session.ts +464 -0
  63. package/src/util.ts +58 -0
  64. package/tsconfig.json +32 -0
@@ -0,0 +1,224 @@
1
+ import { CubeSigner, Key, MfaType, SignerSession, SignerSessionInfo, SignerSessionLifetime, SignerSessionStorage } from ".";
2
+ import { components } from "./client";
3
+ type KeyWithPoliciesInfo = components["schemas"]["KeyWithPolicies"];
4
+ export type RoleInfo = components["schemas"]["RoleInfo"];
5
+ /** Restrict transaction receiver.
6
+ * @example { TxReceiver: "0x8c594691c0e592ffa21f153a16ae41db5befcaaa" }
7
+ * */
8
+ export type TxReceiver = {
9
+ TxReceiver: string;
10
+ };
11
+ /** The kind of deposit contracts. */
12
+ export declare enum DepositContract {
13
+ /** Canonical deposit contract */
14
+ Canonical = 0,
15
+ /** Wrapper deposit contract */
16
+ Wrapper = 1
17
+ }
18
+ /** Restrict transactions to calls to deposit contract. */
19
+ export type TxDeposit = TxDepositBase | TxDepositPubkey | TxDepositRole;
20
+ /** Restrict transactions to calls to deposit contract*/
21
+ export type TxDepositBase = {
22
+ TxDeposit: {
23
+ kind: DepositContract;
24
+ };
25
+ };
26
+ /** Restrict transactions to calls to deposit contract with fixed validator (pubkey):
27
+ * @example { TxDeposit: { kind: DespositContract.Canonical, validator: { pubkey: "8879...8"} }}
28
+ * */
29
+ export type TxDepositPubkey = {
30
+ TxDeposit: {
31
+ kind: DepositContract;
32
+ pubkey: string;
33
+ };
34
+ };
35
+ /** Restrict transactions to calls to deposit contract with any validator key in a role:
36
+ * @example { TxDeposit: { kind: DespositContract.Canonical, validator: { role_id: "Role#c63...af"} }}
37
+ * */
38
+ export type TxDepositRole = {
39
+ TxDeposit: {
40
+ kind: DepositContract;
41
+ role_id: string;
42
+ };
43
+ };
44
+ /** All different kinds of sensitive operations. */
45
+ export declare enum OperationKind {
46
+ BlobSign = "BlobSign",
47
+ EvmSign = "Eth1Sign",
48
+ Eth2Sign = "Eth2Sign",
49
+ Eth2Stake = "Eth2Stake",
50
+ Eth2Unstake = "Eth2Unstake",
51
+ SolanaSign = "SolanaSign"
52
+ }
53
+ /** Require MFA for transactions.
54
+ * @example {
55
+ * RequireMfa: {
56
+ * count: 1,
57
+ * allowed_mfa_types: [ "Totp" ],
58
+ * allowed_approvers: [ "User#123" ],
59
+ * restricted_operations: [
60
+ * "Eth1Sign",
61
+ * "BlobSign"
62
+ * ]
63
+ * }
64
+ * }
65
+ * */
66
+ export type RequireMfa = {
67
+ RequireMfa: {
68
+ count?: number;
69
+ restricted_operations?: OperationKind[];
70
+ allowed_approvers?: string[];
71
+ allowed_mfa_types?: MfaType[];
72
+ };
73
+ };
74
+ /** Allow raw blob signing */
75
+ export type AllowRawBlobSigning = "AllowRawBlobSigning";
76
+ /** Key policy
77
+ * @example [
78
+ * {
79
+ * "TxReceiver": "0x8c594691c0e592ffa21f153a16ae41db5befcaaa"
80
+ * },
81
+ * {
82
+ * "TxDeposit": {
83
+ * "kind": "Canonical"
84
+ * }
85
+ * },
86
+ * {
87
+ * "RequireMfa": {
88
+ * "count": 1,
89
+ * "allowed_mfa_types": ["CubeSigner"],
90
+ * "restricted_operations": [
91
+ * "Eth1Sign",
92
+ * "BlobSign"
93
+ * ]
94
+ * }
95
+ * }
96
+ * ]
97
+ * */
98
+ export type KeyPolicy = (TxReceiver | TxDeposit | RequireMfa | AllowRawBlobSigning)[];
99
+ /** A key guarded by a policy. */
100
+ export declare class KeyWithPolicies {
101
+ #private;
102
+ readonly keyId: string;
103
+ readonly policy?: KeyPolicy;
104
+ /** @return {Promise<Key>} The key */
105
+ getKey(): Promise<Key>;
106
+ /** Constructor.
107
+ * @param {CubeSigner} cs The CubeSigner instance to use for signing.
108
+ * @param {string} orgId The id of the organization to which the key belongs.
109
+ * @param {KeyWithPoliciesInfo} keyWithPolicies The key and its policies
110
+ * @internal
111
+ * */
112
+ constructor(cs: CubeSigner, orgId: string, keyWithPolicies: KeyWithPoliciesInfo);
113
+ }
114
+ /** Roles. */
115
+ export declare class Role {
116
+ #private;
117
+ /** Human-readable name for the role */
118
+ readonly name?: string;
119
+ /**
120
+ * The ID of the role.
121
+ * @example Role#bfe3eccb-731e-430d-b1e5-ac1363e6b06b
122
+ * */
123
+ readonly id: string;
124
+ /** Delete the role. */
125
+ delete(): Promise<void>;
126
+ /** Is the role enabled? */
127
+ enabled(): Promise<boolean>;
128
+ /** Enable the role. */
129
+ enable(): Promise<void>;
130
+ /** Disable the role. */
131
+ disable(): Promise<void>;
132
+ /** The list of users with access to the role.
133
+ * @example [
134
+ * "User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f",
135
+ * "User#5593c25b-52e2-4fb5-b39b-96d41d681d82"
136
+ * ]
137
+ * */
138
+ users(): Promise<string[]>;
139
+ /** Add a user to the role.
140
+ * Adds an existing user to an existing role.
141
+ * @param {string} userId The user-id of the user to add to the role.
142
+ * */
143
+ addUser(userId: string): Promise<void>;
144
+ /** The list of keys in the role.
145
+ * @example [
146
+ * {
147
+ * id: "Key#bfe3eccb-731e-430d-b1e5-ac1363e6b06b",
148
+ * policy: { TxReceiver: "0x8c594691c0e592ffa21f153a16ae41db5befcaaa" }
149
+ * },
150
+ * ]
151
+ * */
152
+ keys(): Promise<KeyWithPolicies[]>;
153
+ /** Add keys to the role.
154
+ * Adds a list of existing keys to an existing role.
155
+ * @param {Key[]} keys The list of keys to add to the role.
156
+ * @param {KeyPolicy?} policy The optional policy to apply to each key.
157
+ * */
158
+ addKeys(keys: Key[], policy?: KeyPolicy): Promise<void>;
159
+ /** Add a key to the role.
160
+ * Adds an existing key to an existing role.
161
+ * @param {Key} key The key to add to the role.
162
+ * @param {KeyPolicy?} policy The optional policy to apply to the key.
163
+ * */
164
+ addKey(key: Key, policy?: KeyPolicy): Promise<void>;
165
+ /** Remove key from the role.
166
+ * Removes an existing key from an existing role.
167
+ * @param {Key} key The key to remove from the role.
168
+ * */
169
+ removeKey(key: Key): Promise<void>;
170
+ /**
171
+ * Create a new session for this role.
172
+ * @param {SignerSessionStorage} storage The session storage to use
173
+ * @param {string} purpose Descriptive purpose.
174
+ * @param {SignerSessionLifetime} ttl Optional session lifetimes.
175
+ * @return {Promise<SignerSession>} New signer session.
176
+ */
177
+ createSession(storage: SignerSessionStorage, purpose: string, ttl?: SignerSessionLifetime): Promise<SignerSession>;
178
+ /**
179
+ * List all signer sessions for this role. Returned objects can be used to
180
+ * revoke individual sessions, but they cannot be used for authentication.
181
+ * @return {Promise<SignerSessionInfo[]>} Signer sessions for this role.
182
+ */
183
+ sessions(): Promise<SignerSessionInfo[]>;
184
+ /** Create a new role.
185
+ * @param {CubeSigner} cs The CubeSigner instance to use for signing.
186
+ * @param {string} orgId The id of the organization to which the role belongs.
187
+ * @param {RoleInfo} data The JSON response from the API server.
188
+ * @internal
189
+ * */
190
+ constructor(cs: CubeSigner, orgId: string, data: RoleInfo);
191
+ /** Update the role.
192
+ * @param {UpdateRoleRequest} request The JSON request to send to the API server.
193
+ * */
194
+ private update;
195
+ /** Create new role.
196
+ * @param {CubeSigner} cs The CubeSigner instance to use for signing.
197
+ * @param {string} orgId The id of the organization to which the role belongs.
198
+ * @param {string?} name The optional name of the role.
199
+ * @return {Role} The new role.
200
+ * @internal
201
+ * */
202
+ static createRole(cs: CubeSigner, orgId: string, name?: string): Promise<Role>;
203
+ /** Get a role by id.
204
+ * @param {CubeSigner} cs The CubeSigner instance to use for signing.
205
+ * @param {string} orgId The id of the organization to which the role belongs.
206
+ * @param {string} roleId The id of the role to get.
207
+ * @return {Role} The role.
208
+ * @internal
209
+ * */
210
+ static getRole(cs: CubeSigner, orgId: string, roleId: string): Promise<Role>;
211
+ /** Fetches the role information.
212
+ * @return {RoleInfo} The role information.
213
+ * @internal
214
+ * */
215
+ private fetch;
216
+ /** Delete role.
217
+ * @param {CubeSigner} cs The CubeSigner instance to use for signing.
218
+ * @param {string} orgId The id of the organization to which the role belongs.
219
+ * @param {string} roleId The id of the role to delete.
220
+ * @internal
221
+ * */
222
+ private static deleteRole;
223
+ }
224
+ export {};
@@ -0,0 +1,256 @@
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
+ };
7
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
8
+ if (kind === "m") throw new TypeError("Private method is not writable");
9
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
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");
11
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
12
+ };
13
+ var _KeyWithPolicies_cs, _KeyWithPolicies_orgId, _Role_cs, _Role_orgId;
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.Role = exports.KeyWithPolicies = exports.OperationKind = exports.DepositContract = void 0;
16
+ const _1 = require(".");
17
+ const util_1 = require("./util");
18
+ /** The kind of deposit contracts. */
19
+ var DepositContract;
20
+ (function (DepositContract) {
21
+ /** Canonical deposit contract */
22
+ DepositContract[DepositContract["Canonical"] = 0] = "Canonical";
23
+ /** Wrapper deposit contract */
24
+ DepositContract[DepositContract["Wrapper"] = 1] = "Wrapper";
25
+ })(DepositContract || (exports.DepositContract = DepositContract = {}));
26
+ /** All different kinds of sensitive operations. */
27
+ var OperationKind;
28
+ (function (OperationKind) {
29
+ OperationKind["BlobSign"] = "BlobSign";
30
+ OperationKind["EvmSign"] = "Eth1Sign";
31
+ OperationKind["Eth2Sign"] = "Eth2Sign";
32
+ OperationKind["Eth2Stake"] = "Eth2Stake";
33
+ OperationKind["Eth2Unstake"] = "Eth2Unstake";
34
+ OperationKind["SolanaSign"] = "SolanaSign";
35
+ })(OperationKind || (exports.OperationKind = OperationKind = {}));
36
+ /** A key guarded by a policy. */
37
+ class KeyWithPolicies {
38
+ /** @return {Promise<Key>} The key */
39
+ async getKey() {
40
+ return await _1.Key.getKey(__classPrivateFieldGet(this, _KeyWithPolicies_cs, "f"), __classPrivateFieldGet(this, _KeyWithPolicies_orgId, "f"), this.keyId);
41
+ }
42
+ /** Constructor.
43
+ * @param {CubeSigner} cs The CubeSigner instance to use for signing.
44
+ * @param {string} orgId The id of the organization to which the key belongs.
45
+ * @param {KeyWithPoliciesInfo} keyWithPolicies The key and its policies
46
+ * @internal
47
+ * */
48
+ constructor(cs, orgId, keyWithPolicies) {
49
+ _KeyWithPolicies_cs.set(this, void 0);
50
+ _KeyWithPolicies_orgId.set(this, void 0);
51
+ __classPrivateFieldSet(this, _KeyWithPolicies_cs, cs, "f");
52
+ __classPrivateFieldSet(this, _KeyWithPolicies_orgId, orgId, "f");
53
+ this.keyId = keyWithPolicies.key_id;
54
+ this.policy = keyWithPolicies.policy;
55
+ }
56
+ }
57
+ exports.KeyWithPolicies = KeyWithPolicies;
58
+ _KeyWithPolicies_cs = new WeakMap(), _KeyWithPolicies_orgId = new WeakMap();
59
+ /** Roles. */
60
+ class Role {
61
+ /** Delete the role. */
62
+ async delete() {
63
+ await Role.deleteRole(__classPrivateFieldGet(this, _Role_cs, "f"), __classPrivateFieldGet(this, _Role_orgId, "f"), this.id);
64
+ }
65
+ /** Is the role enabled? */
66
+ async enabled() {
67
+ const data = await this.fetch();
68
+ return data.enabled;
69
+ }
70
+ /** Enable the role. */
71
+ async enable() {
72
+ await this.update({ enabled: true });
73
+ }
74
+ /** Disable the role. */
75
+ async disable() {
76
+ await this.update({ enabled: false });
77
+ }
78
+ /** The list of users with access to the role.
79
+ * @example [
80
+ * "User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f",
81
+ * "User#5593c25b-52e2-4fb5-b39b-96d41d681d82"
82
+ * ]
83
+ * */
84
+ async users() {
85
+ const data = await this.fetch();
86
+ return data.users;
87
+ }
88
+ /** Add a user to the role.
89
+ * Adds an existing user to an existing role.
90
+ * @param {string} userId The user-id of the user to add to the role.
91
+ * */
92
+ async addUser(userId) {
93
+ const resp = await (await __classPrivateFieldGet(this, _Role_cs, "f").management()).put("/v0/org/{org_id}/roles/{role_id}/add_user/{user_id}", {
94
+ params: { path: { org_id: __classPrivateFieldGet(this, _Role_orgId, "f"), role_id: this.id, user_id: userId } },
95
+ parseAs: "json",
96
+ });
97
+ (0, util_1.assertOk)(resp, "Failed to add user to role");
98
+ }
99
+ /** The list of keys in the role.
100
+ * @example [
101
+ * {
102
+ * id: "Key#bfe3eccb-731e-430d-b1e5-ac1363e6b06b",
103
+ * policy: { TxReceiver: "0x8c594691c0e592ffa21f153a16ae41db5befcaaa" }
104
+ * },
105
+ * ]
106
+ * */
107
+ async keys() {
108
+ const data = await this.fetch();
109
+ return data.keys.map((k) => new KeyWithPolicies(__classPrivateFieldGet(this, _Role_cs, "f"), __classPrivateFieldGet(this, _Role_orgId, "f"), k));
110
+ }
111
+ /** Add keys to the role.
112
+ * Adds a list of existing keys to an existing role.
113
+ * @param {Key[]} keys The list of keys to add to the role.
114
+ * @param {KeyPolicy?} policy The optional policy to apply to each key.
115
+ * */
116
+ async addKeys(keys, policy) {
117
+ const resp = await (await __classPrivateFieldGet(this, _Role_cs, "f").management()).put("/v0/org/{org_id}/roles/{role_id}/add_keys", {
118
+ params: { path: { org_id: __classPrivateFieldGet(this, _Role_orgId, "f"), role_id: this.id } },
119
+ body: {
120
+ key_ids: keys.map((k) => k.id),
121
+ policy: (policy ?? null),
122
+ },
123
+ parseAs: "json",
124
+ });
125
+ (0, util_1.assertOk)(resp, "Failed to add keys to role");
126
+ }
127
+ /** Add a key to the role.
128
+ * Adds an existing key to an existing role.
129
+ * @param {Key} key The key to add to the role.
130
+ * @param {KeyPolicy?} policy The optional policy to apply to the key.
131
+ * */
132
+ async addKey(key, policy) {
133
+ return await this.addKeys([key], policy);
134
+ }
135
+ /** Remove key from the role.
136
+ * Removes an existing key from an existing role.
137
+ * @param {Key} key The key to remove from the role.
138
+ * */
139
+ async removeKey(key) {
140
+ const resp = await (await __classPrivateFieldGet(this, _Role_cs, "f").management()).del("/v0/org/{org_id}/roles/{role_id}/keys/{key_id}", {
141
+ params: { path: { org_id: __classPrivateFieldGet(this, _Role_orgId, "f"), role_id: this.id, key_id: key.id } },
142
+ parseAs: "json",
143
+ });
144
+ (0, util_1.assertOk)(resp, "Failed to remove key from role");
145
+ }
146
+ /**
147
+ * Create a new session for this role.
148
+ * @param {SignerSessionStorage} storage The session storage to use
149
+ * @param {string} purpose Descriptive purpose.
150
+ * @param {SignerSessionLifetime} ttl Optional session lifetimes.
151
+ * @return {Promise<SignerSession>} New signer session.
152
+ */
153
+ async createSession(storage, purpose, ttl) {
154
+ const manager = await _1.SignerSessionManager.create(__classPrivateFieldGet(this, _Role_cs, "f"), storage, __classPrivateFieldGet(this, _Role_orgId, "f"), this.id, purpose, ttl);
155
+ return new _1.SignerSession(__classPrivateFieldGet(this, _Role_cs, "f"), manager);
156
+ }
157
+ /**
158
+ * List all signer sessions for this role. Returned objects can be used to
159
+ * revoke individual sessions, but they cannot be used for authentication.
160
+ * @return {Promise<SignerSessionInfo[]>} Signer sessions for this role.
161
+ */
162
+ async sessions() {
163
+ const resp = await (await __classPrivateFieldGet(this, _Role_cs, "f").management()).get("/v0/org/{org_id}/roles/{role_id}/tokens", {
164
+ params: { path: { org_id: __classPrivateFieldGet(this, _Role_orgId, "f"), role_id: this.id } },
165
+ });
166
+ const data = (0, util_1.assertOk)(resp);
167
+ return data.tokens.map((t) => new _1.SignerSessionInfo(__classPrivateFieldGet(this, _Role_cs, "f"), __classPrivateFieldGet(this, _Role_orgId, "f"), this.id, t.hash, t.purpose));
168
+ }
169
+ // --------------------------------------------------------------------------
170
+ // -- INTERNAL --------------------------------------------------------------
171
+ // --------------------------------------------------------------------------
172
+ /** Create a new role.
173
+ * @param {CubeSigner} cs The CubeSigner instance to use for signing.
174
+ * @param {string} orgId The id of the organization to which the role belongs.
175
+ * @param {RoleInfo} data The JSON response from the API server.
176
+ * @internal
177
+ * */
178
+ constructor(cs, orgId, data) {
179
+ _Role_cs.set(this, void 0);
180
+ _Role_orgId.set(this, void 0);
181
+ __classPrivateFieldSet(this, _Role_cs, cs, "f");
182
+ __classPrivateFieldSet(this, _Role_orgId, orgId, "f");
183
+ this.id = data.role_id;
184
+ this.name = data.name ?? undefined;
185
+ }
186
+ /** Update the role.
187
+ * @param {UpdateRoleRequest} request The JSON request to send to the API server.
188
+ * */
189
+ async update(request) {
190
+ const resp = await (await __classPrivateFieldGet(this, _Role_cs, "f").management()).patch("/v0/org/{org_id}/roles/{role_id}", {
191
+ params: { path: { org_id: __classPrivateFieldGet(this, _Role_orgId, "f"), role_id: this.id } },
192
+ body: request,
193
+ parseAs: "json",
194
+ });
195
+ (0, util_1.assertOk)(resp);
196
+ }
197
+ /** Create new role.
198
+ * @param {CubeSigner} cs The CubeSigner instance to use for signing.
199
+ * @param {string} orgId The id of the organization to which the role belongs.
200
+ * @param {string?} name The optional name of the role.
201
+ * @return {Role} The new role.
202
+ * @internal
203
+ * */
204
+ static async createRole(cs, orgId, name) {
205
+ const resp = await (await cs.management()).post("/v0/org/{org_id}/roles", {
206
+ params: { path: { org_id: orgId } },
207
+ body: name ? { name } : undefined,
208
+ parseAs: "json",
209
+ });
210
+ const data = (0, util_1.assertOk)(resp);
211
+ return await Role.getRole(cs, orgId, data.role_id);
212
+ }
213
+ /** Get a role by id.
214
+ * @param {CubeSigner} cs The CubeSigner instance to use for signing.
215
+ * @param {string} orgId The id of the organization to which the role belongs.
216
+ * @param {string} roleId The id of the role to get.
217
+ * @return {Role} The role.
218
+ * @internal
219
+ * */
220
+ static async getRole(cs, orgId, roleId) {
221
+ const resp = await (await cs.management()).get("/v0/org/{org_id}/roles/{role_id}", {
222
+ params: { path: { org_id: orgId, role_id: roleId } },
223
+ parseAs: "json",
224
+ });
225
+ const data = (0, util_1.assertOk)(resp);
226
+ return new Role(cs, orgId, data);
227
+ }
228
+ /** Fetches the role information.
229
+ * @return {RoleInfo} The role information.
230
+ * @internal
231
+ * */
232
+ async fetch() {
233
+ const resp = await (await __classPrivateFieldGet(this, _Role_cs, "f").management()).get("/v0/org/{org_id}/roles/{role_id}", {
234
+ params: { path: { org_id: __classPrivateFieldGet(this, _Role_orgId, "f"), role_id: this.id } },
235
+ parseAs: "json",
236
+ });
237
+ const data = (0, util_1.assertOk)(resp);
238
+ return data;
239
+ }
240
+ /** Delete role.
241
+ * @param {CubeSigner} cs The CubeSigner instance to use for signing.
242
+ * @param {string} orgId The id of the organization to which the role belongs.
243
+ * @param {string} roleId The id of the role to delete.
244
+ * @internal
245
+ * */
246
+ static async deleteRole(cs, orgId, roleId) {
247
+ const resp = await (await cs.management()).del("/v0/org/{org_id}/roles/{role_id}", {
248
+ params: { path: { org_id: orgId, role_id: roleId } },
249
+ parseAs: "json",
250
+ });
251
+ (0, util_1.assertOk)(resp);
252
+ }
253
+ }
254
+ exports.Role = Role;
255
+ _Role_cs = new WeakMap(), _Role_orgId = new WeakMap();
256
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role.js","sourceRoot":"","sources":["../../src/role.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  CubeSigner,\n  Key,\n  MfaType,\n  SignerSession,\n  SignerSessionInfo,\n  SignerSessionLifetime,\n  SignerSessionManager,\n  SignerSessionStorage,\n} from \".\";\nimport { components, paths } from \"./client\";\nimport { assertOk } from \"./util\";\n\ntype UpdateRoleRequest =\n  paths[\"/v0/org/{org_id}/keys/{key_id}\"][\"patch\"][\"requestBody\"][\"content\"][\"application/json\"];\ntype KeyWithPoliciesInfo = components[\"schemas\"][\"KeyWithPolicies\"];\nexport type RoleInfo = components[\"schemas\"][\"RoleInfo\"];\n\n/** Restrict transaction receiver.\n * @example { TxReceiver: \"0x8c594691c0e592ffa21f153a16ae41db5befcaaa\" }\n * */\nexport type TxReceiver = { TxReceiver: string };\n\n/** The kind of deposit contracts. */\nexport enum DepositContract {\n  /** Canonical deposit contract */\n  Canonical, // eslint-disable-line no-unused-vars\n  /** Wrapper deposit contract */\n  Wrapper, // eslint-disable-line no-unused-vars\n}\n\n/** Restrict transactions to calls to deposit contract. */\nexport type TxDeposit = TxDepositBase | TxDepositPubkey | TxDepositRole;\n\n/** Restrict transactions to calls to deposit contract*/\nexport type TxDepositBase = { TxDeposit: { kind: DepositContract } };\n\n/** Restrict transactions to calls to deposit contract with fixed validator (pubkey):\n *  @example { TxDeposit: { kind: DespositContract.Canonical, validator: { pubkey: \"8879...8\"} }}\n * */\nexport type TxDepositPubkey = { TxDeposit: { kind: DepositContract; pubkey: string } };\n\n/** Restrict transactions to calls to deposit contract with any validator key in a role:\n * @example { TxDeposit: { kind: DespositContract.Canonical, validator: { role_id: \"Role#c63...af\"} }}\n * */\nexport type TxDepositRole = { TxDeposit: { kind: DepositContract; role_id: string } };\n\n/** All different kinds of sensitive operations. */\nexport enum OperationKind {\n  BlobSign = \"BlobSign\", // eslint-disable-line no-unused-vars\n  EvmSign = \"Eth1Sign\", // eslint-disable-line no-unused-vars\n  Eth2Sign = \"Eth2Sign\", // eslint-disable-line no-unused-vars\n  Eth2Stake = \"Eth2Stake\", // eslint-disable-line no-unused-vars\n  Eth2Unstake = \"Eth2Unstake\", // eslint-disable-line no-unused-vars\n  SolanaSign = \"SolanaSign\", // eslint-disable-line no-unused-vars\n}\n\n/** Require MFA for transactions.\n * @example {\n *     RequireMfa: {\n *       count: 1,\n *       allowed_mfa_types: [ \"Totp\" ],\n *       allowed_approvers: [ \"User#123\" ],\n *       restricted_operations: [\n *         \"Eth1Sign\",\n *         \"BlobSign\"\n *       ]\n *     }\n *   }\n * */\nexport type RequireMfa = {\n  RequireMfa: {\n    count?: number;\n    restricted_operations?: OperationKind[];\n    allowed_approvers?: string[];\n    allowed_mfa_types?: MfaType[];\n  };\n};\n\n/** Allow raw blob signing */\nexport type AllowRawBlobSigning = \"AllowRawBlobSigning\";\n\n/** Key policy\n * @example [\n *   {\n *     \"TxReceiver\": \"0x8c594691c0e592ffa21f153a16ae41db5befcaaa\"\n *   },\n *   {\n *     \"TxDeposit\": {\n *       \"kind\": \"Canonical\"\n *     }\n *   },\n *   {\n *     \"RequireMfa\": {\n *       \"count\": 1,\n *       \"allowed_mfa_types\": [\"CubeSigner\"],\n *       \"restricted_operations\": [\n *         \"Eth1Sign\",\n *         \"BlobSign\"\n *       ]\n *     }\n *   }\n * ]\n * */\nexport type KeyPolicy = (TxReceiver | TxDeposit | RequireMfa | AllowRawBlobSigning)[];\n\n/** A key guarded by a policy. */\nexport class KeyWithPolicies {\n  readonly #cs: CubeSigner;\n  readonly #orgId: string;\n  readonly keyId: string;\n  readonly policy?: KeyPolicy;\n\n  /** @return {Promise<Key>} The key */\n  async getKey(): Promise<Key> {\n    return await Key.getKey(this.#cs, this.#orgId, this.keyId);\n  }\n\n  /** Constructor.\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 {KeyWithPoliciesInfo} keyWithPolicies The key and its policies\n   * @internal\n   * */\n  constructor(cs: CubeSigner, orgId: string, keyWithPolicies: KeyWithPoliciesInfo) {\n    this.#cs = cs;\n    this.#orgId = orgId;\n    this.keyId = keyWithPolicies.key_id;\n    this.policy = keyWithPolicies.policy as unknown as KeyPolicy;\n  }\n}\n\n/** Roles. */\nexport class Role {\n  readonly #cs: CubeSigner;\n  readonly #orgId: string;\n  /** Human-readable name for the role */\n  public readonly name?: string;\n\n  /**\n   * The ID of the role.\n   * @example Role#bfe3eccb-731e-430d-b1e5-ac1363e6b06b\n   * */\n  readonly id: string;\n\n  /** Delete the role. */\n  async delete(): Promise<void> {\n    await Role.deleteRole(this.#cs, this.#orgId, this.id);\n  }\n\n  /** Is the role enabled? */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /** Enable the role. */\n  async enable() {\n    await this.update({ enabled: true });\n  }\n\n  /** Disable the role. */\n  async disable() {\n    await this.update({ enabled: false });\n  }\n\n  /** The list of users with access to the role.\n   * @example [\n   *   \"User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\",\n   *   \"User#5593c25b-52e2-4fb5-b39b-96d41d681d82\"\n   * ]\n   * */\n  async users(): Promise<string[]> {\n    const data = await this.fetch();\n    return data.users;\n  }\n\n  /** Add a user to the role.\n   * Adds an existing user to an existing role.\n   * @param {string} userId The user-id of the user to add to the role.\n   * */\n  async addUser(userId: string) {\n    const resp = await (\n      await this.#cs.management()\n    ).put(\"/v0/org/{org_id}/roles/{role_id}/add_user/{user_id}\", {\n      params: { path: { org_id: this.#orgId, role_id: this.id, user_id: userId } },\n      parseAs: \"json\",\n    });\n    assertOk(resp, \"Failed to add user to role\");\n  }\n\n  /** The list of keys in the role.\n   * @example [\n   *    {\n   *     id: \"Key#bfe3eccb-731e-430d-b1e5-ac1363e6b06b\",\n   *     policy: { TxReceiver: \"0x8c594691c0e592ffa21f153a16ae41db5befcaaa\" }\n   *    },\n   *  ]\n   * */\n  async keys(): Promise<KeyWithPolicies[]> {\n    const data = await this.fetch();\n    return data.keys.map((k) => new KeyWithPolicies(this.#cs, this.#orgId, k));\n  }\n\n  /** Add keys to the role.\n   * Adds a list of existing keys to an existing role.\n   * @param {Key[]} keys The list of keys to add to the role.\n   * @param {KeyPolicy?} policy The optional policy to apply to each key.\n   * */\n  async addKeys(keys: Key[], policy?: KeyPolicy) {\n    const resp = await (\n      await this.#cs.management()\n    ).put(\"/v0/org/{org_id}/roles/{role_id}/add_keys\", {\n      params: { path: { org_id: this.#orgId, role_id: this.id } },\n      body: {\n        key_ids: keys.map((k) => k.id),\n        policy: (policy ?? null) as Record<string, never>[] | null,\n      },\n      parseAs: \"json\",\n    });\n    assertOk(resp, \"Failed to add keys to role\");\n  }\n\n  /** Add a key to the role.\n   * Adds an existing key to an existing role.\n   * @param {Key} key The key to add to the role.\n   * @param {KeyPolicy?} policy The optional policy to apply to the key.\n   * */\n  async addKey(key: Key, policy?: KeyPolicy) {\n    return await this.addKeys([key], policy);\n  }\n\n  /** Remove key from the role.\n   * Removes an existing key from an existing role.\n   * @param {Key} key The key to remove from the role.\n   * */\n  async removeKey(key: Key) {\n    const resp = await (\n      await this.#cs.management()\n    ).del(\"/v0/org/{org_id}/roles/{role_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.#orgId, role_id: this.id, key_id: key.id } },\n      parseAs: \"json\",\n    });\n    assertOk(resp, \"Failed to remove key from role\");\n  }\n\n  /**\n   * Create a new session for this role.\n   * @param {SignerSessionStorage} storage The session storage to use\n   * @param {string} purpose Descriptive purpose.\n   * @param {SignerSessionLifetime} ttl Optional session lifetimes.\n   * @return {Promise<SignerSession>} New signer session.\n   */\n  async createSession(\n    storage: SignerSessionStorage,\n    purpose: string,\n    ttl?: SignerSessionLifetime,\n  ): Promise<SignerSession> {\n    const manager = await SignerSessionManager.create(\n      this.#cs,\n      storage,\n      this.#orgId,\n      this.id,\n      purpose,\n      ttl,\n    );\n    return new SignerSession(this.#cs, manager);\n  }\n\n  /**\n   * List all signer sessions for this role. Returned objects can be used to\n   * revoke individual sessions, but they cannot be used for authentication.\n   * @return {Promise<SignerSessionInfo[]>} Signer sessions for this role.\n   */\n  async sessions(): Promise<SignerSessionInfo[]> {\n    const resp = await (\n      await this.#cs.management()\n    ).get(\"/v0/org/{org_id}/roles/{role_id}/tokens\", {\n      params: { path: { org_id: this.#orgId, role_id: this.id } },\n    });\n    const data = assertOk(resp);\n    return data.tokens.map(\n      (t) => new SignerSessionInfo(this.#cs, this.#orgId, this.id, t.hash, t.purpose),\n    );\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /** Create a new role.\n   * @param {CubeSigner} cs The CubeSigner instance to use for signing.\n   * @param {string} orgId The id of the organization to which the role belongs.\n   * @param {RoleInfo} data The JSON response from the API server.\n   * @internal\n   * */\n  constructor(cs: CubeSigner, orgId: string, data: RoleInfo) {\n    this.#cs = cs;\n    this.#orgId = orgId;\n    this.id = data.role_id;\n    this.name = data.name ?? undefined;\n  }\n\n  /** Update the role.\n   * @param {UpdateRoleRequest} request The JSON request to send to the API server.\n   * */\n  private async update(request: UpdateRoleRequest): Promise<void> {\n    const resp = await (\n      await this.#cs.management()\n    ).patch(\"/v0/org/{org_id}/roles/{role_id}\", {\n      params: { path: { org_id: this.#orgId, role_id: this.id } },\n      body: request,\n      parseAs: \"json\",\n    });\n    assertOk(resp);\n  }\n\n  /** Create new role.\n   * @param {CubeSigner} cs The CubeSigner instance to use for signing.\n   * @param {string} orgId The id of the organization to which the role belongs.\n   * @param {string?} name The optional name of the role.\n   * @return {Role} The new role.\n   * @internal\n   * */\n  static async createRole(cs: CubeSigner, orgId: string, name?: string): Promise<Role> {\n    const resp = await (\n      await cs.management()\n    ).post(\"/v0/org/{org_id}/roles\", {\n      params: { path: { org_id: orgId } },\n      body: name ? { name } : undefined,\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return await Role.getRole(cs, orgId, data.role_id);\n  }\n\n  /** Get a role 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 role belongs.\n   * @param {string} roleId The id of the role to get.\n   * @return {Role} The role.\n   * @internal\n   * */\n  static async getRole(cs: CubeSigner, orgId: string, roleId: string): Promise<Role> {\n    const resp = await (\n      await cs.management()\n    ).get(\"/v0/org/{org_id}/roles/{role_id}\", {\n      params: { path: { org_id: orgId, role_id: roleId } },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return new Role(cs, orgId, data);\n  }\n\n  /** Fetches the role information.\n   * @return {RoleInfo} The role information.\n   * @internal\n   * */\n  private async fetch(): Promise<RoleInfo> {\n    const resp = await (\n      await this.#cs.management()\n    ).get(\"/v0/org/{org_id}/roles/{role_id}\", {\n      params: { path: { org_id: this.#orgId, role_id: this.id } },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return data;\n  }\n\n  /** Delete role.\n   * @param {CubeSigner} cs The CubeSigner instance to use for signing.\n   * @param {string} orgId The id of the organization to which the role belongs.\n   * @param {string} roleId The id of the role to delete.\n   * @internal\n   * */\n  private static async deleteRole(cs: CubeSigner, orgId: string, roleId: string): Promise<void> {\n    const resp = await (\n      await cs.management()\n    ).del(\"/v0/org/{org_id}/roles/{role_id}\", {\n      params: { path: { org_id: orgId, role_id: roleId } },\n      parseAs: \"json\",\n    });\n    assertOk(resp);\n  }\n}\n"]}