@cubist-labs/cubesigner-sdk 0.1.77 → 0.2.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/package.json +68 -0
- package/dist/src/api.d.ts +493 -0
- package/dist/src/api.js +1166 -0
- package/dist/src/client.d.ts +534 -10
- package/dist/src/client.js +355 -19
- package/dist/src/ethers/index.d.ts +34 -9
- package/dist/src/ethers/index.js +63 -19
- package/dist/src/index.d.ts +51 -70
- package/dist/src/index.js +83 -237
- package/dist/src/key.d.ts +35 -64
- package/dist/src/key.js +32 -96
- package/dist/src/mfa.d.ts +85 -14
- package/dist/src/mfa.js +146 -40
- package/dist/src/org.d.ts +42 -194
- package/dist/src/org.js +52 -336
- package/dist/src/paginator.js +1 -1
- package/dist/src/response.d.ts +101 -0
- package/dist/src/response.js +164 -0
- package/dist/src/role.d.ts +87 -83
- package/dist/src/role.js +79 -136
- package/dist/src/schema.d.ts +936 -28
- package/dist/src/schema.js +1 -1
- package/dist/src/schema_types.d.ts +109 -0
- package/dist/src/schema_types.js +3 -0
- package/dist/src/session/cognito_manager.d.ts +15 -3
- package/dist/src/session/cognito_manager.js +23 -5
- package/dist/src/session/session_manager.d.ts +1 -1
- package/dist/src/session/session_manager.js +3 -11
- package/dist/src/session/session_storage.js +1 -1
- package/dist/src/session/signer_session_manager.d.ts +10 -29
- package/dist/src/session/signer_session_manager.js +21 -80
- package/dist/src/signer_session.d.ts +15 -252
- package/dist/src/signer_session.js +25 -424
- package/dist/src/user_export.d.ts +52 -0
- package/dist/src/user_export.js +129 -0
- package/dist/src/util.d.ts +15 -0
- package/dist/src/util.js +33 -11
- package/package.json +13 -11
- package/src/api.ts +1395 -0
- package/src/client.ts +413 -12
- package/src/ethers/index.ts +74 -28
- package/src/index.ts +96 -273
- package/src/key.ts +36 -131
- package/src/{fido.ts → mfa.ts} +62 -38
- package/src/org.ts +54 -405
- package/src/response.ts +196 -0
- package/src/role.ts +113 -184
- package/src/schema.ts +936 -28
- package/src/schema_types.ts +110 -0
- package/src/session/cognito_manager.ts +33 -6
- package/src/session/session_manager.ts +2 -8
- package/src/session/signer_session_manager.ts +29 -110
- package/src/signer_session.ts +22 -597
- package/src/user_export.ts +116 -0
- package/src/util.ts +29 -10
package/dist/src/role.js
CHANGED
|
@@ -10,11 +10,10 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (
|
|
|
10
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
11
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
12
12
|
};
|
|
13
|
-
var
|
|
13
|
+
var _KeyWithPolicies_csc, _Role_csc;
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
15
|
exports.Role = exports.KeyWithPolicies = exports.AllowRawBlobSigning = exports.OperationKind = exports.DepositContract = void 0;
|
|
16
16
|
const _1 = require(".");
|
|
17
|
-
const util_1 = require("./util");
|
|
18
17
|
/** The kind of deposit contracts. */
|
|
19
18
|
var DepositContract;
|
|
20
19
|
(function (DepositContract) {
|
|
@@ -39,30 +38,29 @@ exports.AllowRawBlobSigning = "AllowRawBlobSigning";
|
|
|
39
38
|
class KeyWithPolicies {
|
|
40
39
|
/** @return {Promise<Key>} The key */
|
|
41
40
|
async getKey() {
|
|
42
|
-
|
|
41
|
+
const keyInfo = await __classPrivateFieldGet(this, _KeyWithPolicies_csc, "f").keyGet(this.keyId);
|
|
42
|
+
return new _1.Key(__classPrivateFieldGet(this, _KeyWithPolicies_csc, "f"), keyInfo);
|
|
43
43
|
}
|
|
44
|
-
/**
|
|
45
|
-
*
|
|
46
|
-
* @param {
|
|
44
|
+
/**
|
|
45
|
+
* Constructor.
|
|
46
|
+
* @param {CubeSignerClient} csc The CubeSigner instance to use for signing.
|
|
47
47
|
* @param {KeyWithPoliciesInfo} keyWithPolicies The key and its policies
|
|
48
48
|
* @internal
|
|
49
|
-
|
|
50
|
-
constructor(
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
__classPrivateFieldSet(this, _KeyWithPolicies_cs, cs, "f");
|
|
54
|
-
__classPrivateFieldSet(this, _KeyWithPolicies_orgId, orgId, "f");
|
|
49
|
+
*/
|
|
50
|
+
constructor(csc, keyWithPolicies) {
|
|
51
|
+
_KeyWithPolicies_csc.set(this, void 0);
|
|
52
|
+
__classPrivateFieldSet(this, _KeyWithPolicies_csc, csc, "f");
|
|
55
53
|
this.keyId = keyWithPolicies.key_id;
|
|
56
54
|
this.policy = keyWithPolicies.policy;
|
|
57
55
|
}
|
|
58
56
|
}
|
|
59
57
|
exports.KeyWithPolicies = KeyWithPolicies;
|
|
60
|
-
|
|
58
|
+
_KeyWithPolicies_csc = new WeakMap();
|
|
61
59
|
/** Roles. */
|
|
62
60
|
class Role {
|
|
63
61
|
/** Delete the role. */
|
|
64
62
|
async delete() {
|
|
65
|
-
await
|
|
63
|
+
await __classPrivateFieldGet(this, _Role_csc, "f").roleDelete(this.id);
|
|
66
64
|
}
|
|
67
65
|
/** Is the role enabled? */
|
|
68
66
|
async enabled() {
|
|
@@ -77,182 +75,127 @@ class Role {
|
|
|
77
75
|
async disable() {
|
|
78
76
|
await this.update({ enabled: false });
|
|
79
77
|
}
|
|
80
|
-
/**
|
|
78
|
+
/**
|
|
79
|
+
* The list of all users with access to the role.
|
|
81
80
|
* @example [
|
|
82
81
|
* "User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f",
|
|
83
82
|
* "User#5593c25b-52e2-4fb5-b39b-96d41d681d82"
|
|
84
83
|
* ]
|
|
85
|
-
*
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
84
|
+
*
|
|
85
|
+
* @param {PageOpts} page Optional pagination options; by default, retrieves all users.
|
|
86
|
+
*/
|
|
87
|
+
async users(page) {
|
|
88
|
+
const users = await __classPrivateFieldGet(this, _Role_csc, "f").roleUsersList(this.id, page).fetch();
|
|
89
|
+
return (users || []).map((u) => u.user_id);
|
|
89
90
|
}
|
|
90
|
-
/**
|
|
91
|
-
*
|
|
91
|
+
/**
|
|
92
|
+
* Add an existing user to an existing role.
|
|
93
|
+
*
|
|
92
94
|
* @param {string} userId The user-id of the user to add to the role.
|
|
93
|
-
|
|
95
|
+
*/
|
|
94
96
|
async addUser(userId) {
|
|
95
|
-
|
|
96
|
-
params: { path: { org_id: __classPrivateFieldGet(this, _Role_orgId, "f"), role_id: this.id, user_id: userId } },
|
|
97
|
-
parseAs: "json",
|
|
98
|
-
});
|
|
99
|
-
(0, util_1.assertOk)(resp, "Failed to add user to role");
|
|
97
|
+
await __classPrivateFieldGet(this, _Role_csc, "f").roleUserAdd(this.id, userId);
|
|
100
98
|
}
|
|
101
|
-
/**
|
|
99
|
+
/**
|
|
100
|
+
* The list of keys in the role.
|
|
102
101
|
* @example [
|
|
103
102
|
* {
|
|
104
103
|
* id: "Key#bfe3eccb-731e-430d-b1e5-ac1363e6b06b",
|
|
105
104
|
* policy: { TxReceiver: "0x8c594691c0e592ffa21f153a16ae41db5befcaaa" }
|
|
106
105
|
* },
|
|
107
106
|
* ]
|
|
108
|
-
*
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
107
|
+
*
|
|
108
|
+
* @param {PageOpts} page Optional pagination options; by default, retrieves all keys in this role.
|
|
109
|
+
*/
|
|
110
|
+
async keys(page) {
|
|
111
|
+
const keysInRole = await __classPrivateFieldGet(this, _Role_csc, "f").roleKeysList(this.id, page).fetch();
|
|
112
|
+
return keysInRole.map((k) => new KeyWithPolicies(__classPrivateFieldGet(this, _Role_csc, "f"), k));
|
|
112
113
|
}
|
|
113
|
-
/**
|
|
114
|
-
*
|
|
114
|
+
/**
|
|
115
|
+
* Add a list of existing keys to an existing role.
|
|
116
|
+
*
|
|
115
117
|
* @param {Key[]} keys The list of keys to add to the role.
|
|
116
118
|
* @param {KeyPolicy?} policy The optional policy to apply to each key.
|
|
117
|
-
|
|
119
|
+
*/
|
|
118
120
|
async addKeys(keys, policy) {
|
|
119
|
-
|
|
120
|
-
params: { path: { org_id: __classPrivateFieldGet(this, _Role_orgId, "f"), role_id: this.id } },
|
|
121
|
-
body: {
|
|
122
|
-
key_ids: keys.map((k) => k.id),
|
|
123
|
-
policy: (policy ?? null),
|
|
124
|
-
},
|
|
125
|
-
parseAs: "json",
|
|
126
|
-
});
|
|
127
|
-
(0, util_1.assertOk)(resp, "Failed to add keys to role");
|
|
121
|
+
await __classPrivateFieldGet(this, _Role_csc, "f").roleKeysAdd(this.id, keys.map((k) => k.id), policy);
|
|
128
122
|
}
|
|
129
|
-
/**
|
|
130
|
-
*
|
|
123
|
+
/**
|
|
124
|
+
* Add an existing key to an existing role.
|
|
125
|
+
*
|
|
131
126
|
* @param {Key} key The key to add to the role.
|
|
132
127
|
* @param {KeyPolicy?} policy The optional policy to apply to the key.
|
|
133
|
-
|
|
128
|
+
*/
|
|
134
129
|
async addKey(key, policy) {
|
|
135
|
-
|
|
130
|
+
await this.addKeys([key], policy);
|
|
136
131
|
}
|
|
137
|
-
/**
|
|
138
|
-
*
|
|
132
|
+
/**
|
|
133
|
+
* Remove an existing key from an existing role.
|
|
134
|
+
*
|
|
139
135
|
* @param {Key} key The key to remove from the role.
|
|
140
|
-
|
|
136
|
+
*/
|
|
141
137
|
async removeKey(key) {
|
|
142
|
-
|
|
143
|
-
params: { path: { org_id: __classPrivateFieldGet(this, _Role_orgId, "f"), role_id: this.id, key_id: key.id } },
|
|
144
|
-
parseAs: "json",
|
|
145
|
-
});
|
|
146
|
-
(0, util_1.assertOk)(resp, "Failed to remove key from role");
|
|
138
|
+
await __classPrivateFieldGet(this, _Role_csc, "f").roleKeysRemove(this.id, key.id);
|
|
147
139
|
}
|
|
148
140
|
/**
|
|
149
141
|
* Create a new session for this role.
|
|
150
142
|
* @param {SignerSessionStorage} storage The session storage to use
|
|
151
143
|
* @param {string} purpose Descriptive purpose.
|
|
152
|
-
* @param {SignerSessionLifetime}
|
|
144
|
+
* @param {SignerSessionLifetime} lifetimes Optional session lifetimes.
|
|
145
|
+
* @param {string[]} scopes Session scopes. Only `sign:*` scopes are allowed.
|
|
153
146
|
* @return {Promise<SignerSession>} New signer session.
|
|
154
147
|
*/
|
|
155
|
-
async createSession(storage, purpose,
|
|
156
|
-
const
|
|
148
|
+
async createSession(storage, purpose, lifetimes, scopes) {
|
|
149
|
+
const sessionData = await __classPrivateFieldGet(this, _Role_csc, "f").sessionCreateForRole(this.id, purpose, scopes, lifetimes);
|
|
150
|
+
await storage.save(sessionData);
|
|
151
|
+
const manager = await _1.SignerSessionManager.loadFromStorage(storage);
|
|
157
152
|
return new _1.SignerSession(manager);
|
|
158
153
|
}
|
|
159
154
|
/**
|
|
160
155
|
* List all signer sessions for this role. Returned objects can be used to
|
|
161
156
|
* revoke individual sessions, but they cannot be used for authentication.
|
|
157
|
+
*
|
|
158
|
+
* @param {PageOpts} page Optional pagination options; by default, retrieves all sessions.
|
|
162
159
|
* @return {Promise<SignerSessionInfo[]>} Signer sessions for this role.
|
|
163
160
|
*/
|
|
164
|
-
async sessions() {
|
|
165
|
-
const
|
|
166
|
-
|
|
167
|
-
});
|
|
168
|
-
const data = (0, util_1.assertOk)(resp);
|
|
169
|
-
return data.tokens.map((t) => new _1.SignerSessionInfo(__classPrivateFieldGet(this, _Role_cs, "f"), __classPrivateFieldGet(this, _Role_orgId, "f"), this.id, t.hash, t.purpose));
|
|
161
|
+
async sessions(page) {
|
|
162
|
+
const sessions = await __classPrivateFieldGet(this, _Role_csc, "f").sessionsList(this.id, page).fetch();
|
|
163
|
+
return sessions.map((t) => new _1.SignerSessionInfo(__classPrivateFieldGet(this, _Role_csc, "f"), t.session_id, t.purpose));
|
|
170
164
|
}
|
|
171
165
|
// --------------------------------------------------------------------------
|
|
172
166
|
// -- INTERNAL --------------------------------------------------------------
|
|
173
167
|
// --------------------------------------------------------------------------
|
|
174
|
-
/**
|
|
175
|
-
*
|
|
176
|
-
* @param {
|
|
168
|
+
/**
|
|
169
|
+
* Constructor.
|
|
170
|
+
* @param {CubeSignerClient} csc The CubeSigner instance to use for signing.
|
|
177
171
|
* @param {RoleInfo} data The JSON response from the API server.
|
|
178
172
|
* @internal
|
|
179
|
-
|
|
180
|
-
constructor(
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
__classPrivateFieldSet(this, _Role_cs, cs, "f");
|
|
184
|
-
__classPrivateFieldSet(this, _Role_orgId, orgId, "f");
|
|
173
|
+
*/
|
|
174
|
+
constructor(csc, data) {
|
|
175
|
+
_Role_csc.set(this, void 0);
|
|
176
|
+
__classPrivateFieldSet(this, _Role_csc, csc, "f");
|
|
185
177
|
this.id = data.role_id;
|
|
186
178
|
this.name = data.name ?? undefined;
|
|
187
179
|
}
|
|
188
|
-
/**
|
|
180
|
+
/**
|
|
181
|
+
* Update the role.
|
|
182
|
+
*
|
|
189
183
|
* @param {UpdateRoleRequest} request The JSON request to send to the API server.
|
|
190
|
-
*
|
|
184
|
+
* @return {Promise<RoleInfo>} The updated role information.
|
|
185
|
+
*/
|
|
191
186
|
async update(request) {
|
|
192
|
-
|
|
193
|
-
params: { path: { org_id: __classPrivateFieldGet(this, _Role_orgId, "f"), role_id: this.id } },
|
|
194
|
-
body: request,
|
|
195
|
-
parseAs: "json",
|
|
196
|
-
});
|
|
197
|
-
(0, util_1.assertOk)(resp);
|
|
198
|
-
}
|
|
199
|
-
/** Create new role.
|
|
200
|
-
* @param {CubeSigner} cs The CubeSigner instance to use for signing.
|
|
201
|
-
* @param {string} orgId The id of the organization to which the role belongs.
|
|
202
|
-
* @param {string?} name The optional name of the role.
|
|
203
|
-
* @return {Role} The new role.
|
|
204
|
-
* @internal
|
|
205
|
-
* */
|
|
206
|
-
static async createRole(cs, orgId, name) {
|
|
207
|
-
const resp = await (await cs.management()).post("/v0/org/{org_id}/roles", {
|
|
208
|
-
params: { path: { org_id: orgId } },
|
|
209
|
-
body: name ? { name } : undefined,
|
|
210
|
-
parseAs: "json",
|
|
211
|
-
});
|
|
212
|
-
const data = (0, util_1.assertOk)(resp);
|
|
213
|
-
return await Role.getRole(cs, orgId, data.role_id);
|
|
214
|
-
}
|
|
215
|
-
/** Get a role by id.
|
|
216
|
-
* @param {CubeSigner} cs The CubeSigner instance to use for signing.
|
|
217
|
-
* @param {string} orgId The id of the organization to which the role belongs.
|
|
218
|
-
* @param {string} roleId The id of the role to get.
|
|
219
|
-
* @return {Role} The role.
|
|
220
|
-
* @internal
|
|
221
|
-
* */
|
|
222
|
-
static async getRole(cs, orgId, roleId) {
|
|
223
|
-
const resp = await (await cs.management()).get("/v0/org/{org_id}/roles/{role_id}", {
|
|
224
|
-
params: { path: { org_id: orgId, role_id: roleId } },
|
|
225
|
-
parseAs: "json",
|
|
226
|
-
});
|
|
227
|
-
const data = (0, util_1.assertOk)(resp);
|
|
228
|
-
return new Role(cs, orgId, data);
|
|
187
|
+
return await __classPrivateFieldGet(this, _Role_csc, "f").roleUpdate(this.id, request);
|
|
229
188
|
}
|
|
230
|
-
/**
|
|
189
|
+
/**
|
|
190
|
+
* Fetches the role information.
|
|
191
|
+
*
|
|
231
192
|
* @return {RoleInfo} The role information.
|
|
232
193
|
* @internal
|
|
233
|
-
|
|
194
|
+
*/
|
|
234
195
|
async fetch() {
|
|
235
|
-
|
|
236
|
-
params: { path: { org_id: __classPrivateFieldGet(this, _Role_orgId, "f"), role_id: this.id } },
|
|
237
|
-
parseAs: "json",
|
|
238
|
-
});
|
|
239
|
-
const data = (0, util_1.assertOk)(resp);
|
|
240
|
-
return data;
|
|
241
|
-
}
|
|
242
|
-
/** Delete role.
|
|
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
|
-
* @param {string} roleId The id of the role to delete.
|
|
246
|
-
* @internal
|
|
247
|
-
* */
|
|
248
|
-
static async deleteRole(cs, orgId, roleId) {
|
|
249
|
-
const resp = await (await cs.management()).del("/v0/org/{org_id}/roles/{role_id}", {
|
|
250
|
-
params: { path: { org_id: orgId, role_id: roleId } },
|
|
251
|
-
parseAs: "json",
|
|
252
|
-
});
|
|
253
|
-
(0, util_1.assertOk)(resp);
|
|
196
|
+
return await __classPrivateFieldGet(this, _Role_csc, "f").roleGet(this.id);
|
|
254
197
|
}
|
|
255
198
|
}
|
|
256
199
|
exports.Role = Role;
|
|
257
|
-
|
|
258
|
-
//# 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\"][\"KeyInRoleInfo\"];\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/** MFA policy\n * @example {\n * {\n *   count: 1,\n *   num_auth_factors: 1,\n *   allowed_mfa_types: [ \"Totp\" ],\n *   allowed_approvers: [ \"User#123\" ],\n * }\n * */\nexport type MfaPolicy = {\n  count?: number;\n  num_auth_factors?: number;\n  allowed_approvers?: string[];\n  allowed_mfa_types?: MfaType[];\n  restricted_operations?: OperationKind[];\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: MfaPolicy;\n};\n\n/** Allow raw blob signing */\nexport const AllowRawBlobSigning = \"AllowRawBlobSigning\" as const;\nexport type AllowRawBlobSigning = typeof 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(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"]}
|
|
200
|
+
_Role_csc = new WeakMap();
|
|
201
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role.js","sourceRoot":"","sources":["../../src/role.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Key,\n  KeyWithPoliciesInfo,\n  MfaType,\n  PageOpts,\n  RoleInfo,\n  SignerSession,\n  SignerSessionInfo,\n  SignerSessionLifetime,\n  SignerSessionManager,\n  SignerSessionStorage,\n  UpdateRoleRequest,\n} from \".\";\nimport { CubeSignerClient } from \"./client\";\n\n/**\n * Restrict transaction receiver.\n *\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/**\n * Restrict transactions to calls to deposit contract with fixed validator (pubkey):\n *\n * @example { TxDeposit: { kind: DespositContract.Canonical, validator: { pubkey: \"8879...8\"} }}\n */\nexport type TxDepositPubkey = { TxDeposit: { kind: DepositContract; pubkey: string } };\n\n/**\n * Restrict transactions to calls to deposit contract with any validator key in a role:\n *\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/**\n * MFA policy\n *\n * @example {\n * {\n *   count: 1,\n *   num_auth_factors: 1,\n *   allowed_mfa_types: [ \"Totp\" ],\n *   allowed_approvers: [ \"User#123\" ],\n * }\n */\nexport type MfaPolicy = {\n  count?: number;\n  num_auth_factors?: number;\n  allowed_approvers?: string[];\n  allowed_mfa_types?: MfaType[];\n  restricted_operations?: OperationKind[];\n};\n\n/**\n * Require MFA for transactions.\n *\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: MfaPolicy;\n};\n\n/** Allow raw blob signing */\nexport const AllowRawBlobSigning = \"AllowRawBlobSigning\" as const;\nexport type AllowRawBlobSigning = typeof AllowRawBlobSigning;\n\n/**\n * Key policy\n *\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 #csc: CubeSignerClient;\n  readonly keyId: string;\n  readonly policy?: KeyPolicy;\n\n  /** @return {Promise<Key>} The key */\n  async getKey(): Promise<Key> {\n    const keyInfo = await this.#csc.keyGet(this.keyId);\n    return new Key(this.#csc, keyInfo);\n  }\n\n  /**\n   * Constructor.\n   * @param {CubeSignerClient} csc The CubeSigner instance to use for signing.\n   * @param {KeyWithPoliciesInfo} keyWithPolicies The key and its policies\n   * @internal\n   */\n  constructor(csc: CubeSignerClient, keyWithPolicies: KeyWithPoliciesInfo) {\n    this.#csc = csc;\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 #csc: CubeSignerClient;\n\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 this.#csc.roleDelete(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  /**\n   * The list of all 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   * @param {PageOpts} page Optional pagination options; by default, retrieves all users.\n   */\n  async users(page?: PageOpts): Promise<string[]> {\n    const users = await this.#csc.roleUsersList(this.id, page).fetch();\n    return (users || []).map((u) => u.user_id);\n  }\n\n  /**\n   * Add an existing user to an existing role.\n   *\n   * @param {string} userId The user-id of the user to add to the role.\n   */\n  async addUser(userId: string) {\n    await this.#csc.roleUserAdd(this.id, userId);\n  }\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   * @param {PageOpts} page Optional pagination options; by default, retrieves all keys in this role.\n   */\n  async keys(page?: PageOpts): Promise<KeyWithPolicies[]> {\n    const keysInRole = await this.#csc.roleKeysList(this.id, page).fetch();\n    return keysInRole.map((k) => new KeyWithPolicies(this.#csc, k));\n  }\n\n  /**\n   * Add a list of existing keys to an existing role.\n   *\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    await this.#csc.roleKeysAdd(\n      this.id,\n      keys.map((k) => k.id),\n      policy,\n    );\n  }\n\n  /**\n   * Add an existing key to an existing role.\n   *\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    await this.addKeys([key], policy);\n  }\n\n  /**\n   * Remove an existing key from an existing role.\n   *\n   * @param {Key} key The key to remove from the role.\n   */\n  async removeKey(key: Key) {\n    await this.#csc.roleKeysRemove(this.id, key.id);\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} lifetimes Optional session lifetimes.\n   * @param {string[]} scopes Session scopes. Only `sign:*` scopes are allowed.\n   * @return {Promise<SignerSession>} New signer session.\n   */\n  async createSession(\n    storage: SignerSessionStorage,\n    purpose: string,\n    lifetimes?: SignerSessionLifetime,\n    scopes?: string[],\n  ): Promise<SignerSession> {\n    const sessionData = await this.#csc.sessionCreateForRole(this.id, purpose, scopes, lifetimes);\n    await storage.save(sessionData);\n    const manager = await SignerSessionManager.loadFromStorage(storage);\n    return new SignerSession(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   *\n   * @param {PageOpts} page Optional pagination options; by default, retrieves all sessions.\n   * @return {Promise<SignerSessionInfo[]>} Signer sessions for this role.\n   */\n  async sessions(page?: PageOpts): Promise<SignerSessionInfo[]> {\n    const sessions = await this.#csc.sessionsList(this.id, page).fetch();\n    return sessions.map((t) => new SignerSessionInfo(this.#csc, t.session_id, t.purpose));\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   * @param {CubeSignerClient} csc The CubeSigner instance to use for signing.\n   * @param {RoleInfo} data The JSON response from the API server.\n   * @internal\n   */\n  constructor(csc: CubeSignerClient, data: RoleInfo) {\n    this.#csc = csc;\n    this.id = data.role_id;\n    this.name = data.name ?? undefined;\n  }\n\n  /**\n   * Update the role.\n   *\n   * @param {UpdateRoleRequest} request The JSON request to send to the API server.\n   * @return {Promise<RoleInfo>} The updated role information.\n   */\n  private async update(request: UpdateRoleRequest): Promise<RoleInfo> {\n    return await this.#csc.roleUpdate(this.id, request);\n  }\n\n  /**\n   * Fetches the role information.\n   *\n   * @return {RoleInfo} The role information.\n   * @internal\n   */\n  private async fetch(): Promise<RoleInfo> {\n    return await this.#csc.roleGet(this.id);\n  }\n}\n"]}
|