@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.
Files changed (55) hide show
  1. package/dist/package.json +68 -0
  2. package/dist/src/api.d.ts +493 -0
  3. package/dist/src/api.js +1166 -0
  4. package/dist/src/client.d.ts +534 -10
  5. package/dist/src/client.js +355 -19
  6. package/dist/src/ethers/index.d.ts +34 -9
  7. package/dist/src/ethers/index.js +63 -19
  8. package/dist/src/index.d.ts +51 -70
  9. package/dist/src/index.js +83 -237
  10. package/dist/src/key.d.ts +35 -64
  11. package/dist/src/key.js +32 -96
  12. package/dist/src/mfa.d.ts +85 -14
  13. package/dist/src/mfa.js +146 -40
  14. package/dist/src/org.d.ts +42 -194
  15. package/dist/src/org.js +52 -336
  16. package/dist/src/paginator.js +1 -1
  17. package/dist/src/response.d.ts +101 -0
  18. package/dist/src/response.js +164 -0
  19. package/dist/src/role.d.ts +87 -83
  20. package/dist/src/role.js +79 -136
  21. package/dist/src/schema.d.ts +936 -28
  22. package/dist/src/schema.js +1 -1
  23. package/dist/src/schema_types.d.ts +109 -0
  24. package/dist/src/schema_types.js +3 -0
  25. package/dist/src/session/cognito_manager.d.ts +15 -3
  26. package/dist/src/session/cognito_manager.js +23 -5
  27. package/dist/src/session/session_manager.d.ts +1 -1
  28. package/dist/src/session/session_manager.js +3 -11
  29. package/dist/src/session/session_storage.js +1 -1
  30. package/dist/src/session/signer_session_manager.d.ts +10 -29
  31. package/dist/src/session/signer_session_manager.js +21 -80
  32. package/dist/src/signer_session.d.ts +15 -252
  33. package/dist/src/signer_session.js +25 -424
  34. package/dist/src/user_export.d.ts +52 -0
  35. package/dist/src/user_export.js +129 -0
  36. package/dist/src/util.d.ts +15 -0
  37. package/dist/src/util.js +33 -11
  38. package/package.json +13 -11
  39. package/src/api.ts +1395 -0
  40. package/src/client.ts +413 -12
  41. package/src/ethers/index.ts +74 -28
  42. package/src/index.ts +96 -273
  43. package/src/key.ts +36 -131
  44. package/src/{fido.ts → mfa.ts} +62 -38
  45. package/src/org.ts +54 -405
  46. package/src/response.ts +196 -0
  47. package/src/role.ts +113 -184
  48. package/src/schema.ts +936 -28
  49. package/src/schema_types.ts +110 -0
  50. package/src/session/cognito_manager.ts +33 -6
  51. package/src/session/session_manager.ts +2 -8
  52. package/src/session/signer_session_manager.ts +29 -110
  53. package/src/signer_session.ts +22 -597
  54. package/src/user_export.ts +116 -0
  55. package/src/util.ts +29 -10
package/dist/src/org.js CHANGED
@@ -1,379 +1,95 @@
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
- };
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 _Org_cs, _Org_id;
14
2
  Object.defineProperty(exports, "__esModule", { value: true });
15
3
  exports.Org = void 0;
4
+ const client_1 = require("./client");
16
5
  const _1 = require(".");
17
- const util_1 = require("./util");
18
- const key_1 = require("./key");
19
- const role_1 = require("./role");
20
- /** An organization. */
21
- class Org {
6
+ /**
7
+ * An organization.
8
+ *
9
+ * Extends {@link CubeSignerClient} and provides a few org-specific methods on top.
10
+ */
11
+ class Org extends client_1.CubeSignerClient {
22
12
  /**
23
13
  * @description The org id
24
14
  * @example Org#c3b9379c-4e8c-4216-bd0a-65ace53cf98f
25
- * */
15
+ */
26
16
  get id() {
27
- return __classPrivateFieldGet(this, _Org_id, "f");
17
+ return this.orgId;
18
+ }
19
+ /**
20
+ * Obtain information about the current organization.
21
+ *
22
+ * Same as {@link orgGet}.
23
+ */
24
+ get info() {
25
+ return this.orgGet.bind(this);
28
26
  }
29
27
  /** Human-readable name for the org */
30
28
  async name() {
31
- const data = await this.fetch();
32
- return data.name ?? undefined;
29
+ const org = await this.orgGet();
30
+ return org.name ?? undefined;
33
31
  }
34
- /** Set the human-readable name for the org.
32
+ /** Get all keys in the org. */
33
+ get keys() {
34
+ return this.orgKeys.bind(this);
35
+ }
36
+ /**
37
+ * Set the human-readable name for the org.
35
38
  * @param {string} name The new human-readable name for the org (must be alphanumeric).
36
39
  * @example my_org_name
37
- * */
40
+ */
38
41
  async setName(name) {
39
42
  if (!/^[a-zA-Z0-9_]{3,30}$/.test(name)) {
40
43
  throw new Error("Org name must be alphanumeric and between 3 and 30 characters");
41
44
  }
42
- await this.update({ name });
45
+ await this.orgUpdate({ name });
43
46
  }
44
47
  /** Is the org enabled? */
45
48
  async enabled() {
46
- const data = await this.fetch();
47
- return data.enabled;
49
+ const org = await this.orgGet();
50
+ return org.enabled;
48
51
  }
49
52
  /** Enable the org. */
50
53
  async enable() {
51
- await this.update({ enabled: true });
54
+ await this.orgUpdate({ enabled: true });
52
55
  }
53
56
  /** Disable the org. */
54
57
  async disable() {
55
- await this.update({ enabled: false });
58
+ await this.orgUpdate({ enabled: false });
56
59
  }
57
60
  /** Get the policy for the org. */
58
61
  async policy() {
59
- const data = await this.fetch();
60
- return (data.policy ?? []);
62
+ const org = await this.orgGet();
63
+ return (org.policy ?? []);
61
64
  }
62
- /** Set the policy for the org.
65
+ /**
66
+ * Set the policy for the org.
63
67
  * @param {OrgPolicy[]} policy The new policy for the org.
64
- * */
68
+ */
65
69
  async setPolicy(policy) {
66
70
  const p = policy;
67
- await this.update({ policy: p });
68
- }
69
- /** Create a new signing key.
70
- * @param {KeyType} type The type of key to create.
71
- * @param {string?} ownerId The owner of the key. Defaults to the session's user.
72
- * @return {Key[]} The new keys.
73
- * */
74
- async createKey(type, ownerId) {
75
- return (await key_1.Key.createKeys(__classPrivateFieldGet(this, _Org_cs, "f"), this.id, type, 1, ownerId))[0];
76
- }
77
- /** Create new signing keys.
78
- * @param {KeyType} type The type of key to create.
79
- * @param {nummber} count The number of keys to create.
80
- * @param {string?} ownerId The owner of the keys. Defaults to the session's user.
81
- * @return {Key[]} The new keys.
82
- * */
83
- async createKeys(type, count, ownerId) {
84
- return key_1.Key.createKeys(__classPrivateFieldGet(this, _Org_cs, "f"), this.id, type, count, ownerId);
71
+ await this.orgUpdate({ policy: p });
85
72
  }
86
73
  /**
87
- * Derives a key of the given type using the given derivation path and mnemonic.
88
- * The owner of the derived key will be the owner of the mnemonic.
89
- *
90
- * @param {KeyType} type Type of key to derive from the mnemonic.
91
- * @param {string} derivationPath Mnemonic derivation path used to generate new key.
92
- * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.
93
- *
94
- * @return {Key} newly derived key.
74
+ * Retrieve the org associated with a session.
75
+ * @param {SessionStorage} storage The session
76
+ * @return {Org} An {@link Org} instance for the org associated with this session.
95
77
  */
96
- async deriveKey(type, derivationPath, mnemonicId) {
97
- return (await key_1.Key.deriveKeys(__classPrivateFieldGet(this, _Org_cs, "f"), this.id, type, [derivationPath], mnemonicId))[0];
78
+ static async retrieveFromStorage(storage) {
79
+ const sessionMgr = await _1.SignerSessionManager.loadFromStorage(storage);
80
+ return new Org(new client_1.CubeSignerClient(sessionMgr), sessionMgr.orgId);
98
81
  }
99
82
  /**
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.
83
+ * Constructor.
84
+ * @param {CubeSignerClient | SignerSessionManager} csc The CubeSigner instance.
85
+ * @param {OrgInfo| string} data Either org id or name or {@link OrgInfo}.
109
86
  */
110
- async deriveKeys(type, derivationPaths, mnemonicId) {
111
- return await key_1.Key.deriveKeys(__classPrivateFieldGet(this, _Org_cs, "f"), __classPrivateFieldGet(this, _Org_id, "f"), type, derivationPaths, mnemonicId);
112
- }
113
- /**
114
- * Create a new user in the organization and sends an invitation to that user
115
- * @param {string} email Email of the user
116
- * @param {string} name The full name of the user
117
- */
118
- async createUser(email, name) {
119
- const resp = await (await __classPrivateFieldGet(this, _Org_cs, "f").management()).post("/v0/org/{org_id}/invite", {
120
- params: { path: { org_id: this.id } },
121
- body: {
122
- email,
123
- name,
124
- skip_email: false,
125
- },
126
- parseAs: "json",
127
- });
128
- (0, util_1.assertOk)(resp);
129
- }
130
- /**
131
- * Create a new OIDC user
132
- * @param {OidcIdentity} identity The identity of the OIDC user
133
- * @param {string} email Email of the OIDC user
134
- * @param {CreateOidcUserOptions} opts Additional options for new OIDC users
135
- * @return {string} User id of the new user
136
- */
137
- async createOidcUser(identity, email, opts = {}) {
138
- const resp = await (await __classPrivateFieldGet(this, _Org_cs, "f").management()).post("/v0/org/{org_id}/users", {
139
- params: { path: { org_id: this.id } },
140
- body: {
141
- identity,
142
- role: opts.memberRole ?? "Alien",
143
- email: email,
144
- mfa_policy: opts.mfaPolicy ?? null,
145
- },
146
- parseAs: "json",
147
- });
148
- return (0, util_1.assertOk)(resp).user_id;
149
- }
150
- /**
151
- * Delete an existing OIDC user
152
- * @param {OidcIdentity} identity The identity of the OIDC user
153
- */
154
- async deleteOidcUser(identity) {
155
- const resp = await (await __classPrivateFieldGet(this, _Org_cs, "f").management()).del("/v0/org/{org_id}/users/oidc", {
156
- params: { path: { org_id: this.id } },
157
- body: identity,
158
- parseAs: "json",
159
- });
160
- return (0, util_1.assertOk)(resp);
161
- }
162
- /**
163
- * Checks if a given proof of OIDC authentication is valid.
164
- *
165
- * @param {IdentityProof} proof The proof of authentication.
166
- */
167
- async verifyIdentity(proof) {
168
- await __classPrivateFieldGet(this, _Org_cs, "f").verifyIdentity(this.id, proof);
169
- }
170
- /**
171
- * List users in the organization
172
- * @return {UserIdInfo[]} List of users
173
- */
174
- async users() {
175
- const resp = await (await __classPrivateFieldGet(this, _Org_cs, "f").management()).get("/v0/org/{org_id}/users", {
176
- params: { path: { org_id: this.id } },
177
- parseAs: "json",
178
- });
179
- return (0, util_1.assertOk)(resp).users;
180
- }
181
- /** Get a key by id.
182
- * @param {string} keyId The id of the key to get.
183
- * @return {Key} The key.
184
- * */
185
- async getKey(keyId) {
186
- return await key_1.Key.getKey(__classPrivateFieldGet(this, _Org_cs, "f"), this.id, keyId);
187
- }
188
- /** Get all keys in the org.
189
- * @param {KeyType?} type Optional key type to filter list for.
190
- * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.
191
- * @return {Key} The key.
192
- * */
193
- async keys(type, page) {
194
- page ??= _1.Page.default();
195
- const listFn = async (query) => {
196
- const client = await __classPrivateFieldGet(this, _Org_cs, "f").management();
197
- const resp = await client.get("/v0/org/{org_id}/keys", {
198
- params: {
199
- path: { org_id: this.id },
200
- query: {
201
- key_type: type,
202
- ...query,
203
- },
204
- },
205
- parseAs: "json",
206
- });
207
- return (0, util_1.assertOk)(resp);
208
- };
209
- const p = new _1.Paginator(page, listFn, (r) => r.keys, (r) => r.last_evaluated_key);
210
- const keys = await p.fetch();
211
- return keys.map((k) => new key_1.Key(__classPrivateFieldGet(this, _Org_cs, "f"), this.id, k));
212
- }
213
- /** Create a new role.
214
- * @param {string?} name The name of the role.
215
- * @return {Role} The new role.
216
- * */
217
- async createRole(name) {
218
- return role_1.Role.createRole(__classPrivateFieldGet(this, _Org_cs, "f"), this.id, name);
219
- }
220
- /** Get a role by id or name.
221
- * @param {string} roleId The id or name of the role to get.
222
- * @return {Role} The role.
223
- * */
224
- async getRole(roleId) {
225
- return role_1.Role.getRole(__classPrivateFieldGet(this, _Org_cs, "f"), this.id, roleId);
226
- }
227
- /**
228
- * List all roles in the org.
229
- *
230
- * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.
231
- * @return {Role[]} The roles.
232
- * */
233
- async listRoles(page) {
234
- return Org.roles(__classPrivateFieldGet(this, _Org_cs, "f"), this.id, page);
235
- }
236
- /** List all users in the org.
237
- * @return {User[]} The users.
238
- * */
239
- async listUsers() {
240
- return Org.users(__classPrivateFieldGet(this, _Org_cs, "f"), this.id);
241
- }
242
- /**
243
- * Get a pending MFA request by its id.
244
- * @param {string} mfaId The id of the MFA request.
245
- * @return {Promise<MfaRequestInfo>} The MFA request.
246
- *
247
- * @deprecated Use {@link getMfaInfo()} instead.
248
- */
249
- async mfaGet(mfaId) {
250
- return await this.getMfaInfo(mfaId);
251
- }
252
- /**
253
- * Approve a pending MFA request.
254
- *
255
- * @param {string} mfaId The id of the MFA request.
256
- * @return {Promise<MfaRequestInfo>} The MFA request.
257
- *
258
- * @deprecated Use {@link approveMfaRequest()} instead.
259
- */
260
- async mfaApprove(mfaId) {
261
- return await this.approveMfaRequest(mfaId);
262
- }
263
- /**
264
- * Get a pending MFA request by its id.
265
- * @param {string} mfaId The id of the MFA request.
266
- * @return {Promise<MfaRequestInfo>} The MFA request.
267
- */
268
- async getMfaInfo(mfaId) {
269
- return await __classPrivateFieldGet(this, _Org_cs, "f").mfaGet(this.id, mfaId);
270
- }
271
- /**
272
- * List pending MFA requests accessible to the current user.
273
- * @return {Promise<MfaRequestInfo[]>} The MFA requests.
274
- */
275
- async listMfaInfos() {
276
- return await __classPrivateFieldGet(this, _Org_cs, "f").mfaList(this.id);
277
- }
278
- /**
279
- * Approve a pending MFA request.
280
- *
281
- * @param {string} mfaId The id of the MFA request.
282
- * @return {Promise<MfaRequestInfo>} The MFA request.
283
- */
284
- async approveMfaRequest(mfaId) {
285
- return Org.mfaApprove(__classPrivateFieldGet(this, _Org_cs, "f"), __classPrivateFieldGet(this, _Org_id, "f"), mfaId);
286
- }
287
- // --------------------------------------------------------------------------
288
- // -- INTERNAL --------------------------------------------------------------
289
- // --------------------------------------------------------------------------
290
- /** Create a new org.
291
- * @param {CubeSigner} cs The CubeSigner instance.
292
- * @param {OrgInfo} data The JSON response from the API server.
293
- * @internal
294
- * */
295
- constructor(cs, data) {
296
- _Org_cs.set(this, void 0);
297
- /**
298
- * The ID of the organization.
299
- * @example Org#124dfe3e-3bbd-487d-80c0-53c55e8ab87a
300
- */
301
- _Org_id.set(this, void 0);
302
- __classPrivateFieldSet(this, _Org_cs, cs, "f");
303
- __classPrivateFieldSet(this, _Org_id, data.org_id, "f");
304
- }
305
- /**
306
- * Approve a pending MFA request.
307
- *
308
- * @param {CubeSigner} cs The CubeSigner instance to use for requests
309
- * @param {string} orgId The org id of the MFA request
310
- * @param {string} mfaId The id of the MFA request
311
- * @return {Promise<MfaRequestInfo>} The result of the MFA request
312
- */
313
- static async mfaApprove(cs, orgId, mfaId) {
314
- return await cs.mfaApprove(orgId, mfaId);
315
- }
316
- /** Fetch org info.
317
- * @return {OrgInfo} The org info.
318
- * */
319
- async fetch() {
320
- const resp = await (await __classPrivateFieldGet(this, _Org_cs, "f").management()).get("/v0/org/{org_id}", {
321
- params: { path: { org_id: this.id } },
322
- parseAs: "json",
323
- });
324
- const data = (0, util_1.assertOk)(resp);
325
- return data;
326
- }
327
- /** Update the org.
328
- * @param {UpdateOrgRequest} request The JSON request to send to the API server.
329
- * @return {UpdateOrgResponse} The JSON response from the API server.
330
- * */
331
- async update(request) {
332
- const resp = await (await __classPrivateFieldGet(this, _Org_cs, "f").management()).patch("/v0/org/{org_id}", {
333
- params: { path: { org_id: this.id } },
334
- body: request,
335
- parseAs: "json",
336
- });
337
- return (0, util_1.assertOk)(resp);
338
- }
339
- /** List roles.
340
- * @param {CubeSigner} cs The CubeSigner instance to use for signing.
341
- * @param {string} orgId The id of the organization to which the role belongs.
342
- * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.
343
- * @return {Role[]} Org roles.
344
- * @internal
345
- * */
346
- static async roles(cs, orgId, page) {
347
- page ??= _1.Page.default();
348
- const listFn = async (query) => {
349
- const resp = await (await cs.management()).get("/v0/org/{org_id}/roles", {
350
- params: {
351
- path: { org_id: orgId },
352
- query,
353
- },
354
- parseAs: "json",
355
- });
356
- return (0, util_1.assertOk)(resp);
357
- };
358
- const p = new _1.Paginator(page, listFn, (u) => u.roles, (u) => u.last_evaluated_key);
359
- const roles = await p.fetch();
360
- return roles.map((r) => new role_1.Role(cs, orgId, r));
361
- }
362
- /** List users.
363
- * @param {CubeSigner} cs The CubeSigner instance to use for signing.
364
- * @param {string} orgId The id of the organization to which the role belongs.
365
- * @return {User[]} Org users.
366
- * @internal
367
- * */
368
- static async users(cs, orgId) {
369
- const resp = await (await cs.management()).get("/v0/org/{org_id}/users", {
370
- params: { path: { org_id: orgId } },
371
- parseAs: "json",
372
- });
373
- const data = (0, util_1.assertOk)(resp);
374
- return data.users;
87
+ constructor(csc, data) {
88
+ const mgr = csc instanceof client_1.CubeSignerClient ? csc.sessionMgr : csc;
89
+ // NOTE: data can be OrgInfo for backward compatibility reasons
90
+ const orgId = typeof data === "string" ? data : data?.org_id;
91
+ super(mgr, orgId);
375
92
  }
376
93
  }
377
94
  exports.Org = Org;
378
- _Org_cs = new WeakMap(), _Org_id = new WeakMap();
379
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"org.js","sourceRoot":"","sources":["../../src/org.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  CubeSigner,\n  MfaRequestInfo,\n  IdentityProof,\n  PageOpts,\n  Page,\n  PageQueryArgs,\n  Paginator,\n} from \".\";\nimport { components, paths } from \"./client\";\nimport { assertOk } from \"./util\";\nimport { KeyType, Key } from \"./key\";\nimport { MfaPolicy, Role, RoleInfo } from \"./role\";\n\n/** Organization id */\nexport type OrgId = string;\n\n/** Org-wide policy */\nexport type OrgPolicy =\n  | SourceIpAllowlistPolicy\n  | OidcAuthSourcesPolicy\n  | OriginAllowlistPolicy\n  | MaxDailyUnstakePolicy;\n\n/**\n * Provides an allowlist of OIDC Issuers and audiences that are allowed to authenticate into this org.\n * @example {\"OidcAuthSources\": { \"https://accounts.google.com\": [ \"1234.apps.googleusercontent.com\" ]}}\n */\nexport interface OidcAuthSourcesPolicy {\n  OidcAuthSources: Record<string, string[]>;\n}\n\n/**\n * Only allow requests from the specified origins.\n * @example {\"OriginAllowlist\": \"*\"}\n */\nexport interface OriginAllowlistPolicy {\n  OriginAllowlist: string[] | \"*\";\n}\n\n/**\n * Restrict signing to specific source IP addresses.\n * @example {\"SourceIpAllowlist\": [\"10.1.2.3/8\", \"169.254.17.1/16\"]}\n */\nexport interface SourceIpAllowlistPolicy {\n  SourceIpAllowlist: string[];\n}\n\n/**\n * Restrict the number of unstakes per day.\n * @example {\"MaxDailyUnstake\": 5 }\n */\nexport interface MaxDailyUnstakePolicy {\n  MaxDailyUnstake: number;\n}\n\ntype OrgInfo = components[\"schemas\"][\"OrgInfo\"];\ntype UserIdInfo = components[\"schemas\"][\"UserIdInfo\"];\ntype UpdateOrgRequest =\n  paths[\"/v0/org/{org_id}\"][\"patch\"][\"requestBody\"][\"content\"][\"application/json\"];\ntype UpdateOrgResponse =\n  paths[\"/v0/org/{org_id}\"][\"patch\"][\"responses\"][\"200\"][\"content\"][\"application/json\"];\n\nexport type OidcIdentity = components[\"schemas\"][\"OIDCIdentity\"];\nexport type MemberRole = components[\"schemas\"][\"MemberRole\"];\n\n/** Options for a new OIDC user */\nexport interface CreateOidcUserOptions {\n  /** The role of an OIDC user, default is \"Alien\" */\n  memberRole?: MemberRole;\n  /** Optional MFA policy to associate with the user account */\n  mfaPolicy?: MfaPolicy;\n}\n\n/** An organization. */\nexport class Org {\n  readonly #cs: CubeSigner;\n  /**\n   * The ID of the organization.\n   * @example Org#124dfe3e-3bbd-487d-80c0-53c55e8ab87a\n   */\n  readonly #id: string;\n\n  /**\n   * @description The org id\n   * @example Org#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\n   * */\n  get id(): OrgId {\n    return this.#id;\n  }\n\n  /** Human-readable name for the org */\n  async name(): Promise<string | undefined> {\n    const data = await this.fetch();\n    return data.name ?? undefined;\n  }\n\n  /** Set the human-readable name for the org.\n   * @param {string} name The new human-readable name for the org (must be alphanumeric).\n   * @example my_org_name\n   * */\n  async setName(name: string) {\n    if (!/^[a-zA-Z0-9_]{3,30}$/.test(name)) {\n      throw new Error(\"Org name must be alphanumeric and between 3 and 30 characters\");\n    }\n    await this.update({ name });\n  }\n\n  /** Is the org enabled? */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /** Enable the org. */\n  async enable() {\n    await this.update({ enabled: true });\n  }\n\n  /** Disable the org. */\n  async disable() {\n    await this.update({ enabled: false });\n  }\n\n  /** Get the policy for the org. */\n  async policy(): Promise<OrgPolicy[]> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as OrgPolicy[];\n  }\n\n  /** Set the policy for the org.\n   * @param {OrgPolicy[]} policy The new policy for the org.\n   * */\n  async setPolicy(policy: OrgPolicy[]) {\n    const p = policy as unknown as Record<string, never>[];\n    await this.update({ policy: p });\n  }\n\n  /** Create a new signing key.\n   * @param {KeyType} type The type of key to create.\n   * @param {string?} ownerId The owner of the key. Defaults to the session's user.\n   * @return {Key[]} The new keys.\n   * */\n  async createKey(type: KeyType, ownerId?: string): Promise<Key> {\n    return (await Key.createKeys(this.#cs, this.id, type, 1, ownerId))[0];\n  }\n\n  /** Create new signing keys.\n   * @param {KeyType} type The type of key to create.\n   * @param {nummber} 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   * */\n  async createKeys(type: KeyType, count: number, ownerId?: string): Promise<Key[]> {\n    return Key.createKeys(this.#cs, this.id, type, count, ownerId);\n  }\n\n  /**\n   * Derives a key of the given type using the given derivation path and mnemonic.\n   * The owner of the derived key will be the owner of the mnemonic.\n   *\n   * @param {KeyType} type Type of key to derive from the mnemonic.\n   * @param {string} derivationPath Mnemonic derivation path used to generate new key.\n   * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.\n   *\n   * @return {Key} newly derived key.\n   */\n  async deriveKey(type: KeyType, derivationPath: string, mnemonicId: string): Promise<Key> {\n    return (await Key.deriveKeys(this.#cs, this.id, type, [derivationPath], mnemonicId))[0];\n  }\n\n  /**\n   * Derives a set of keys of the given type using the given derivation paths and mnemonic.\n   *\n   * The owner of the derived keys will be the owner of the mnemonic.\n   *\n   * @param {KeyType} type Type of key to derive from the mnemonic.\n   * @param {string[]} derivationPaths Mnemonic derivation paths used to generate new key.\n   * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.\n   *\n   * @return {Key[]} newly derived keys.\n   */\n  async deriveKeys(type: KeyType, derivationPaths: string[], mnemonicId: string): Promise<Key[]> {\n    return await Key.deriveKeys(this.#cs, this.#id, type, derivationPaths, mnemonicId);\n  }\n\n  /**\n   * Create a new user in the organization and sends an invitation to that user\n   * @param {string} email Email of the user\n   * @param {string} name The full name of the user\n   */\n  async createUser(email: string, name: string): Promise<void> {\n    const resp = await (\n      await this.#cs.management()\n    ).post(\"/v0/org/{org_id}/invite\", {\n      params: { path: { org_id: this.id } },\n      body: {\n        email,\n        name,\n        skip_email: false,\n      },\n      parseAs: \"json\",\n    });\n    assertOk(resp);\n  }\n\n  /**\n   * Create a new OIDC user\n   * @param {OidcIdentity} identity The identity of the OIDC user\n   * @param {string} email Email of the OIDC user\n   * @param {CreateOidcUserOptions} opts Additional options for new OIDC users\n   * @return {string} User id of the new user\n   */\n  async createOidcUser(\n    identity: OidcIdentity,\n    email: string,\n    opts: CreateOidcUserOptions = {},\n  ): Promise<string> {\n    const resp = await (\n      await this.#cs.management()\n    ).post(\"/v0/org/{org_id}/users\", {\n      params: { path: { org_id: this.id } },\n      body: {\n        identity,\n        role: opts.memberRole ?? \"Alien\",\n        email: email,\n        mfa_policy: opts.mfaPolicy ?? null,\n      },\n      parseAs: \"json\",\n    });\n    return assertOk(resp).user_id;\n  }\n\n  /**\n   * Delete an existing OIDC user\n   * @param {OidcIdentity} identity The identity of the OIDC user\n   */\n  async deleteOidcUser(identity: OidcIdentity) {\n    const resp = await (\n      await this.#cs.management()\n    ).del(\"/v0/org/{org_id}/users/oidc\", {\n      params: { path: { org_id: this.id } },\n      body: identity,\n      parseAs: \"json\",\n    });\n    return assertOk(resp);\n  }\n\n  /**\n   * Checks if a given proof of OIDC authentication is valid.\n   *\n   * @param {IdentityProof} proof The proof of authentication.\n   */\n  async verifyIdentity(proof: IdentityProof) {\n    await this.#cs.verifyIdentity(this.id, proof);\n  }\n\n  /**\n   * List users in the organization\n   * @return {UserIdInfo[]} List of users\n   */\n  async users(): Promise<UserIdInfo[]> {\n    const resp = await (\n      await this.#cs.management()\n    ).get(\"/v0/org/{org_id}/users\", {\n      params: { path: { org_id: this.id } },\n      parseAs: \"json\",\n    });\n    return assertOk(resp).users;\n  }\n\n  /** Get a key by id.\n   * @param {string} keyId The id of the key to get.\n   * @return {Key} The key.\n   * */\n  async getKey(keyId: string): Promise<Key> {\n    return await Key.getKey(this.#cs, this.id, keyId);\n  }\n\n  /** Get all keys in the org.\n   * @param {KeyType?} type Optional key type to filter list for.\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Key} The key.\n   * */\n  async keys(type?: KeyType, page?: PageOpts): Promise<Key[]> {\n    page ??= Page.default();\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.#cs.management();\n      const resp = await client.get(\"/v0/org/{org_id}/keys\", {\n        params: {\n          path: { org_id: this.id },\n          query: {\n            key_type: type,\n            ...query,\n          },\n        },\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    const p = new Paginator(\n      page,\n      listFn,\n      (r) => r.keys,\n      (r) => r.last_evaluated_key,\n    );\n    const keys = await p.fetch();\n    return keys.map((k) => new Key(this.#cs, this.id, k));\n  }\n\n  /** Create a new role.\n   * @param {string?} name The name of the role.\n   * @return {Role} The new role.\n   * */\n  async createRole(name?: string): Promise<Role> {\n    return Role.createRole(this.#cs, this.id, name);\n  }\n\n  /** Get a role by id or name.\n   * @param {string} roleId The id or name of the role to get.\n   * @return {Role} The role.\n   * */\n  async getRole(roleId: string): Promise<Role> {\n    return Role.getRole(this.#cs, this.id, roleId);\n  }\n\n  /**\n   * List all roles in the org.\n   *\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Role[]} The roles.\n   * */\n  async listRoles(page?: PageOpts): Promise<Role[]> {\n    return Org.roles(this.#cs, this.id, page);\n  }\n\n  /** List all users in the org.\n   * @return {User[]} The users.\n   * */\n  async listUsers(): Promise<UserIdInfo[]> {\n    return Org.users(this.#cs, this.id);\n  }\n\n  /**\n   * Get a pending MFA request by its id.\n   * @param {string} mfaId The id of the MFA request.\n   * @return {Promise<MfaRequestInfo>} The MFA request.\n   *\n   * @deprecated Use {@link getMfaInfo()} instead.\n   */\n  async mfaGet(mfaId: string): Promise<MfaRequestInfo> {\n    return await this.getMfaInfo(mfaId);\n  }\n\n  /**\n   * Approve a pending MFA request.\n   *\n   * @param {string} mfaId The id of the MFA request.\n   * @return {Promise<MfaRequestInfo>} The MFA request.\n   *\n   * @deprecated Use {@link approveMfaRequest()} instead.\n   */\n  async mfaApprove(mfaId: string): Promise<MfaRequestInfo> {\n    return await this.approveMfaRequest(mfaId);\n  }\n\n  /**\n   * Get a pending MFA request by its id.\n   * @param {string} mfaId The id of the MFA request.\n   * @return {Promise<MfaRequestInfo>} The MFA request.\n   */\n  async getMfaInfo(mfaId: string): Promise<MfaRequestInfo> {\n    return await this.#cs.mfaGet(this.id, mfaId);\n  }\n\n  /**\n   * List pending MFA requests accessible to the current user.\n   * @return {Promise<MfaRequestInfo[]>} The MFA requests.\n   */\n  async listMfaInfos(): Promise<MfaRequestInfo[]> {\n    return await this.#cs.mfaList(this.id);\n  }\n\n  /**\n   * Approve a pending MFA request.\n   *\n   * @param {string} mfaId The id of the MFA request.\n   * @return {Promise<MfaRequestInfo>} The MFA request.\n   */\n  async approveMfaRequest(mfaId: string): Promise<MfaRequestInfo> {\n    return Org.mfaApprove(this.#cs, this.#id, mfaId);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /** Create a new org.\n   * @param {CubeSigner} cs The CubeSigner instance.\n   * @param {OrgInfo} data The JSON response from the API server.\n   * @internal\n   * */\n  constructor(cs: CubeSigner, data: OrgInfo) {\n    this.#cs = cs;\n    this.#id = data.org_id;\n  }\n\n  /**\n   * Approve a pending MFA request.\n   *\n   * @param {CubeSigner} cs The CubeSigner instance to use for requests\n   * @param {string} orgId The org id of the MFA request\n   * @param {string} mfaId The id of the MFA request\n   * @return {Promise<MfaRequestInfo>} The result of the MFA request\n   */\n  static async mfaApprove(cs: CubeSigner, orgId: string, mfaId: string): Promise<MfaRequestInfo> {\n    return await cs.mfaApprove(orgId, mfaId);\n  }\n\n  /** Fetch org info.\n   * @return {OrgInfo} The org info.\n   * */\n  private async fetch(): Promise<OrgInfo> {\n    const resp = await (\n      await this.#cs.management()\n    ).get(\"/v0/org/{org_id}\", {\n      params: { path: { org_id: this.id } },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return data;\n  }\n\n  /** Update the org.\n   * @param {UpdateOrgRequest} request The JSON request to send to the API server.\n   * @return {UpdateOrgResponse} The JSON response from the API server.\n   * */\n  private async update(request: UpdateOrgRequest): Promise<UpdateOrgResponse> {\n    const resp = await (\n      await this.#cs.management()\n    ).patch(\"/v0/org/{org_id}\", {\n      params: { path: { org_id: this.id } },\n      body: request,\n      parseAs: \"json\",\n    });\n    return assertOk(resp);\n  }\n\n  /** List roles.\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 {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Role[]} Org roles.\n   * @internal\n   * */\n  private static async roles(cs: CubeSigner, orgId: string, page?: PageOpts): Promise<Role[]> {\n    page ??= Page.default();\n    const listFn = async (query: PageQueryArgs) => {\n      const resp = await (\n        await cs.management()\n      ).get(\"/v0/org/{org_id}/roles\", {\n        params: {\n          path: { org_id: orgId },\n          query,\n        },\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    const p = new Paginator(\n      page,\n      listFn,\n      (u) => u.roles,\n      (u) => u.last_evaluated_key,\n    );\n    const roles = await p.fetch();\n    return roles.map((r: RoleInfo) => new Role(cs, orgId, r));\n  }\n\n  /** List users.\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   * @return {User[]} Org users.\n   * @internal\n   * */\n  private static async users(cs: CubeSigner, orgId: string): Promise<UserIdInfo[]> {\n    const resp = await (\n      await cs.management()\n    ).get(\"/v0/org/{org_id}/users\", {\n      params: { path: { org_id: orgId } },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return data.users;\n  }\n}\n"]}
95
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"org.js","sourceRoot":"","sources":["../../src/org.ts"],"names":[],"mappings":";;;AAAA,qCAA4C;AAC5C,wBAAwE;AA4CxE;;;;GAIG;AACH,MAAa,GAAI,SAAQ,yBAAgB;IACvC;;;OAGG;IACH,IAAI,EAAE;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;;;OAIG;IACH,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED,sCAAsC;IACtC,KAAK,CAAC,IAAI;QACR,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC;QAChC,OAAO,GAAG,CAAC,IAAI,IAAI,SAAS,CAAC;IAC/B,CAAC;IAED,+BAA+B;IAC/B,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,OAAO,CAAC,IAAY;QACxB,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;YACvC,MAAM,IAAI,KAAK,CAAC,+DAA+D,CAAC,CAAC;QACnF,CAAC;QACD,MAAM,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;IACjC,CAAC;IAED,0BAA0B;IAC1B,KAAK,CAAC,OAAO;QACX,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC;QAChC,OAAO,GAAG,CAAC,OAAO,CAAC;IACrB,CAAC;IAED,sBAAsB;IACtB,KAAK,CAAC,MAAM;QACV,MAAM,IAAI,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;IAC1C,CAAC;IAED,uBAAuB;IACvB,KAAK,CAAC,OAAO;QACX,MAAM,IAAI,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;IAC3C,CAAC;IAED,kCAAkC;IAClC,KAAK,CAAC,MAAM;QACV,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC;QAChC,OAAO,CAAC,GAAG,CAAC,MAAM,IAAI,EAAE,CAA2B,CAAC;IACtD,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,SAAS,CAAC,MAAmB;QACjC,MAAM,CAAC,GAAG,MAA4C,CAAC;QACvD,MAAM,IAAI,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC;IACtC,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,KAAK,CAAC,mBAAmB,CAAC,OAA6B;QAC5D,MAAM,UAAU,GAAG,MAAM,uBAAoB,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QACvE,OAAO,IAAI,GAAG,CAAC,IAAI,yBAAgB,CAAC,UAAU,CAAC,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;IACrE,CAAC;IAED;;;;OAIG;IACH,YAAY,GAA4C,EAAE,IAAuB;QAC/E,MAAM,GAAG,GAAG,GAAG,YAAY,yBAAgB,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAE,GAA4B,CAAC;QAE7F,+DAA+D;QAC/D,MAAM,KAAK,GAAG,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE,MAAM,CAAC;QAC7D,KAAK,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACpB,CAAC;CACF;AA9FD,kBA8FC","sourcesContent":["import { CubeSignerClient } from \"./client\";\nimport { OrgInfo, SignerSessionManager, SignerSessionStorage } from \".\";\n\n/** Organization id */\nexport type OrgId = string;\n\n/** Org-wide policy */\nexport type OrgPolicy =\n  | SourceIpAllowlistPolicy\n  | OidcAuthSourcesPolicy\n  | OriginAllowlistPolicy\n  | MaxDailyUnstakePolicy;\n\n/**\n * Provides an allowlist of OIDC Issuers and audiences that are allowed to authenticate into this org.\n * @example {\"OidcAuthSources\": { \"https://accounts.google.com\": [ \"1234.apps.googleusercontent.com\" ]}}\n */\nexport interface OidcAuthSourcesPolicy {\n  OidcAuthSources: Record<string, string[]>;\n}\n\n/**\n * Only allow requests from the specified origins.\n * @example {\"OriginAllowlist\": \"*\"}\n */\nexport interface OriginAllowlistPolicy {\n  OriginAllowlist: string[] | \"*\";\n}\n\n/**\n * Restrict signing to specific source IP addresses.\n * @example {\"SourceIpAllowlist\": [\"10.1.2.3/8\", \"169.254.17.1/16\"]}\n */\nexport interface SourceIpAllowlistPolicy {\n  SourceIpAllowlist: string[];\n}\n\n/**\n * Restrict the number of unstakes per day.\n * @example {\"MaxDailyUnstake\": 5 }\n */\nexport interface MaxDailyUnstakePolicy {\n  MaxDailyUnstake: number;\n}\n\n/**\n * An organization.\n *\n * Extends {@link CubeSignerClient} and provides a few org-specific methods on top.\n */\nexport class Org extends CubeSignerClient {\n  /**\n   * @description The org id\n   * @example Org#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\n   */\n  get id(): OrgId {\n    return this.orgId;\n  }\n\n  /**\n   * Obtain information about the current organization.\n   *\n   * Same as {@link orgGet}.\n   */\n  get info() {\n    return this.orgGet.bind(this);\n  }\n\n  /** Human-readable name for the org */\n  async name(): Promise<string | undefined> {\n    const org = await this.orgGet();\n    return org.name ?? undefined;\n  }\n\n  /** Get all keys in the org. */\n  get keys() {\n    return this.orgKeys.bind(this);\n  }\n\n  /**\n   * Set the human-readable name for the org.\n   * @param {string} name The new human-readable name for the org (must be alphanumeric).\n   * @example my_org_name\n   */\n  async setName(name: string) {\n    if (!/^[a-zA-Z0-9_]{3,30}$/.test(name)) {\n      throw new Error(\"Org name must be alphanumeric and between 3 and 30 characters\");\n    }\n    await this.orgUpdate({ name });\n  }\n\n  /** Is the org enabled? */\n  async enabled(): Promise<boolean> {\n    const org = await this.orgGet();\n    return org.enabled;\n  }\n\n  /** Enable the org. */\n  async enable() {\n    await this.orgUpdate({ enabled: true });\n  }\n\n  /** Disable the org. */\n  async disable() {\n    await this.orgUpdate({ enabled: false });\n  }\n\n  /** Get the policy for the org. */\n  async policy(): Promise<OrgPolicy[]> {\n    const org = await this.orgGet();\n    return (org.policy ?? []) as unknown as OrgPolicy[];\n  }\n\n  /**\n   * Set the policy for the org.\n   * @param {OrgPolicy[]} policy The new policy for the org.\n   */\n  async setPolicy(policy: OrgPolicy[]) {\n    const p = policy as unknown as Record<string, never>[];\n    await this.orgUpdate({ policy: p });\n  }\n\n  /**\n   * Retrieve the org associated with a session.\n   * @param {SessionStorage} storage The session\n   * @return {Org} An {@link Org} instance for the org associated with this session.\n   */\n  static async retrieveFromStorage(storage: SignerSessionStorage): Promise<Org> {\n    const sessionMgr = await SignerSessionManager.loadFromStorage(storage);\n    return new Org(new CubeSignerClient(sessionMgr), sessionMgr.orgId);\n  }\n\n  /**\n   * Constructor.\n   * @param {CubeSignerClient | SignerSessionManager} csc The CubeSigner instance.\n   * @param {OrgInfo| string} data Either org id or name or {@link OrgInfo}.\n   */\n  constructor(csc: CubeSignerClient | SignerSessionManager, data?: OrgInfo | string) {\n    const mgr = csc instanceof CubeSignerClient ? csc.sessionMgr : (csc as SignerSessionManager);\n\n    // NOTE: data can be OrgInfo for backward compatibility reasons\n    const orgId = typeof data === \"string\" ? data : data?.org_id;\n    super(mgr, orgId);\n  }\n}\n"]}
@@ -96,4 +96,4 @@ class Paginator {
96
96
  }
97
97
  exports.Paginator = Paginator;
98
98
  _Paginator_listFn = new WeakMap(), _Paginator_itemsFn = new WeakMap(), _Paginator_lastFn = new WeakMap(), _Paginator_opts = new WeakMap(), _Paginator_last = new WeakMap(), _Paginator_done = new WeakMap();
99
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3BhZ2luYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7QUFhQSxzQ0FBc0M7QUFDdEMsTUFBYSxJQUFJO0lBQ2Y7Ozs7O09BS0c7SUFDSCxNQUFNLENBQUMsT0FBTztRQUNaLE9BQWlCO1lBQ2YsR0FBRyxFQUFFLElBQUk7U0FDVixDQUFDO0lBQ0osQ0FBQztDQUNGO0FBWkQsb0JBWUM7QUF5QkQ7O0dBRUc7QUFDSCxNQUFhLFNBQVM7SUFRcEI7Ozs7O09BS0c7SUFDSCxZQUFZLFFBQWtCLEVBQUUsTUFBaUIsRUFBRSxPQUFzQixFQUFFLE1BQWlCO1FBYm5GLG9DQUFtQjtRQUNuQixxQ0FBd0I7UUFDeEIsb0NBQW1CO1FBQzVCLGtDQUFnQjtRQUNoQixrQ0FBaUM7UUFDakMsa0NBQWU7UUFTYix1QkFBQSxJQUFJLHFCQUFXLE1BQU0sTUFBQSxDQUFDO1FBQ3RCLHVCQUFBLElBQUksc0JBQVksT0FBTyxNQUFBLENBQUM7UUFDeEIsdUJBQUEsSUFBSSxxQkFBVyxNQUFNLE1BQUEsQ0FBQztRQUN0Qix1QkFBQSxJQUFJLG1CQUFTLFFBQVEsTUFBQSxDQUFDO1FBQ3RCLHVCQUFBLElBQUksbUJBQVMsUUFBUSxDQUFDLEtBQUssTUFBQSxDQUFDO1FBQzVCLHVCQUFBLElBQUksbUJBQVMsS0FBSyxNQUFBLENBQUM7SUFDckIsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsS0FBSyxDQUFDLEtBQUs7UUFDVCxPQUFPLHVCQUFBLElBQUksdUJBQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLE1BQU0sSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUMsQ0FBQyxNQUFNLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUN6RSxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxLQUFLLENBQUMsU0FBUztRQUNiLElBQUksdUJBQUEsSUFBSSx1QkFBTSxFQUFFO1lBQ2QsT0FBTyxFQUFFLENBQUM7U0FDWDtRQUVELE1BQU0sSUFBSSxHQUFHLE1BQU0sdUJBQUEsSUFBSSx5QkFBUSxNQUFaLElBQUksRUFBUztZQUM5QixXQUFXLEVBQUUsdUJBQUEsSUFBSSx1QkFBTSxDQUFDLElBQUk7WUFDNUIsWUFBWSxFQUFFLHVCQUFBLElBQUksdUJBQU07U0FDekIsQ0FBQyxDQUFDO1FBQ0gsdUJBQUEsSUFBSSxtQkFBUyx1QkFBQSxJQUFJLHlCQUFRLE1BQVosSUFBSSxFQUFTLElBQUksQ0FBQyxNQUFBLENBQUM7UUFDaEMsdUJBQUEsSUFBSSxtQkFBUyxDQUFDLHVCQUFBLElBQUksdUJBQU0sTUFBQSxDQUFDO1FBQ3pCLE9BQU8sdUJBQUEsSUFBSSwwQkFBUyxNQUFiLElBQUksRUFBVSxJQUFJLENBQUMsQ0FBQztJQUM3QixDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxLQUFLLENBQUMsUUFBUTtRQUNaLE1BQU0sTUFBTSxHQUFHLEVBQUUsQ0FBQztRQUNsQixPQUFPLENBQUMsdUJBQUEsSUFBSSx1QkFBTSxFQUFFO1lBQ2xCLE1BQU0sS0FBSyxHQUFHLE1BQU0sSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ3JDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQztTQUN2QjtRQUNELE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUM7Q0FDRjtBQW5FRCw4QkFtRUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiogUGFnaW5hdGlvbiBvcHRpb25zLiAqL1xuZXhwb3J0IGludGVyZmFjZSBQYWdlT3B0cyB7XG4gIC8qKiBNYXggbnVtYmVyIG9mIGl0ZW1zIHBlciBwYWdlLiAqL1xuICBzaXplPzogbnVtYmVyO1xuICAvKipcbiAgICogU3RhcnRpbmcgcG9pbnQgKGkuZS4sICdsYXN0X2V2YWx1YXRlZF9rZXknIGZyb20gdGhlIHByZXZpb3VzIHBhZ2UpLlxuICAgKiBPbWl0IHRvIHN0YXJ0IGZyb20gdGhlIGJlZ2lubmluZy5cbiAgICovXG4gIHN0YXJ0Pzogc3RyaW5nO1xuICAvKiogSXRlcmF0ZSB1bnRpbCByZXRyaWV2aW5nIHRoZSBlbnRpcmUgcmVzdWx0IHNldC4gKi9cbiAgYWxsOiBib29sZWFuO1xufVxuXG4vKiogU3RhdGljIGNvbnN0cnVjdG9ycyBmb3IgYElQYWdlYCAqL1xuZXhwb3J0IGNsYXNzIFBhZ2Uge1xuICAvKipcbiAgICogVGhlIGRlZmF1bHQgaXMgdG8gZmV0Y2ggdGhlIGVudGlyZSByZXN1bHQgc2V0XG4gICAqIChieSByZXBlYXRlZGx5IGNhbGxpbmcgdGhlIHJlbW90ZSBlbmRwb2ludCB1bnRpbCBhbGwgcGFnZXMgYXJlIHJldHJpZXZlZCkuXG4gICAqXG4gICAqIEByZXR1cm4ge1BhZ2VPcHRzfSBQYWdpbmF0aW9uIG9wdGlvbnMuXG4gICAqL1xuICBzdGF0aWMgZGVmYXVsdCgpOiBQYWdlT3B0cyB7XG4gICAgcmV0dXJuIDxQYWdlT3B0cz57XG4gICAgICBhbGw6IHRydWUsXG4gICAgfTtcbiAgfVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBhZ2VRdWVyeUFyZ3Mge1xuICAvKipcbiAgICogTWF4IG51bWJlciBvZiBpdGVtcyB0byByZXR1cm4gcGVyIHBhZ2UuXG4gICAqXG4gICAqIFRoZSBhY3R1YWwgbnVtYmVyIG9mIHJldHVybmVkIGl0ZW1zIG1heSBiZSBsZXNzIHRoYXQgdGhpcywgZXZlbiBpZiB0aGVyZSBleGlzdCBtb3JlXG4gICAqIGRhdGEgaW4gdGhlIHJlc3VsdCBzZXQuIFRvIHJlbGlhYmx5IGRldGVybWluZSBpZiBtb3JlIGRhdGEgaXMgbGVmdCBpbiB0aGUgcmVzdWx0IHNldCxcbiAgICogaW5zcGVjdCB0aGUgW1VuZW5jcnlwdGVkTGFzdEV2YWxLZXldIHZhbHVlIGluIHRoZSByZXNwb25zZSBvYmplY3QuXG4gICAqL1xuICBcInBhZ2Uuc2l6ZVwiPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBUaGUgc3RhcnQgb2YgdGhlIHBhZ2UuXG4gICAqXG4gICAqIE9taXQgdG8gc3RhcnQgZnJvbSB0aGUgYmVnaW5uaW5nOyBvdGhlcndpc2UsIG9ubHkgc3BlY2lmeSB0aGUgZXhhY3RcbiAgICogdmFsdWUgcHJldmlvdXNseSByZXR1cm5lZCBhcyAnbGFzdF9ldmFsdWF0ZWRfa2V5JyBmcm9tIHRoZSBzYW1lIGVuZHBvaW50LlxuICAgKi9cbiAgXCJwYWdlLnN0YXJ0XCI/OiBzdHJpbmcgfCBudWxsO1xufVxuXG5leHBvcnQgdHlwZSBMaXN0Rm48VT4gPSAocGFnZVF1ZXJ5QXJnczogUGFnZVF1ZXJ5QXJncykgPT4gUHJvbWlzZTxVPjtcbmV4cG9ydCB0eXBlIEl0ZW1zRm48VSwgVD4gPSAocmVzcDogVSkgPT4gVFtdO1xuZXhwb3J0IHR5cGUgTGFzdEZuPFU+ID0gKHJlc3A6IFUpID0+IHN0cmluZyB8IG51bGwgfCB1bmRlZmluZWQ7XG5cbi8qKlxuICogSGVscGVyIGNsYXNzIGZvciBmZXRjaGluZyBwYWdpbmF0ZWQgcmVzdWx0cy5cbiAqL1xuZXhwb3J0IGNsYXNzIFBhZ2luYXRvcjxVLCBUPiB7XG4gIHJlYWRvbmx5ICNsaXN0Rm46IExpc3RGbjxVPjtcbiAgcmVhZG9ubHkgI2l0ZW1zRm46IEl0ZW1zRm48VSwgVD47XG4gIHJlYWRvbmx5ICNsYXN0Rm46IExhc3RGbjxVPjtcbiAgI29wdHM6IFBhZ2VPcHRzO1xuICAjbGFzdDogc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZDtcbiAgI2RvbmU6IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIEBwYXJhbSB7UGFnZU9wdHN9IHBhZ2VPcHRzIFBhZ2luYXRpb24gb3B0aW9uc1xuICAgKiBAcGFyYW0ge0xpc3RGbjxVPn0gbGlzdEZuIENhbGxzIGEgcmVtb3RlIGVuZHBvaW50IHRoYXQgcmV0dXJucyBhIHBhZ2luYXRlZCByZXNwb25zZVxuICAgKiBAcGFyYW0ge0l0ZW1zRm48VSwgVD59IGl0ZW1zRm4gRXh0cmFjdHMgaXRlbXMgZnJvbSB0aGUgcGFnaW5hdGVkIHJlc3BvbnNlXG4gICAqIEBwYXJhbSB7TGFzdEZuPFU+fSBsYXN0Rm4gRXh0cmFjdHMgdGhlIGxhc3QgZXZhbHVhdGVkIGtleSBmcm9tIHRoZSBwYWdpbmF0ZWQgcmVzcG9uc2VcbiAgICovXG4gIGNvbnN0cnVjdG9yKHBhZ2VPcHRzOiBQYWdlT3B0cywgbGlzdEZuOiBMaXN0Rm48VT4sIGl0ZW1zRm46IEl0ZW1zRm48VSwgVD4sIGxhc3RGbjogTGFzdEZuPFU+KSB7XG4gICAgdGhpcy4jbGlzdEZuID0gbGlzdEZuO1xuICAgIHRoaXMuI2l0ZW1zRm4gPSBpdGVtc0ZuO1xuICAgIHRoaXMuI2xhc3RGbiA9IGxhc3RGbjtcbiAgICB0aGlzLiNvcHRzID0gcGFnZU9wdHM7XG4gICAgdGhpcy4jbGFzdCA9IHBhZ2VPcHRzLnN0YXJ0O1xuICAgIHRoaXMuI2RvbmUgPSBmYWxzZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBGZXRjaGVzIGVpdGhlciBhIHNpbmdsZSBwYWdlIG9yIHRoZSBlbnRpcmUgcmVzdWx0IHNldCwgZGVwZW5kaW5nIG9uXG4gICAqIHRoZSBgYWxsYCBwcm9wZXJ0eSBvZiB0aGUgcGFnaW5hdGlvbiBvcHRpb25zLlxuICAgKlxuICAgKiBAcmV0dXJuIHtQcm9taXNlPFRbXT59IEEgc2luZ2xlIHBhZ2Ugb3IgdGhlIGVudGlyZSByZXN1bHQgc2V0LlxuICAgKi9cbiAgYXN5bmMgZmV0Y2goKTogUHJvbWlzZTxUW10+IHtcbiAgICByZXR1cm4gdGhpcy4jb3B0cy5hbGwgPyBhd2FpdCB0aGlzLmZldGNoQWxsKCkgOiBhd2FpdCB0aGlzLmZldGNoUGFnZSgpO1xuICB9XG5cbiAgLyoqXG4gICAqIEZldGNoZXMgYSBzaW5nbGUgcGFnZSBvZiB0aGUgcmVzdWx0IHNldCBmcm9tIHdoZXJlIGl0IHByZXZpb3VzbHkgbGVmdCBvZmYuXG4gICAqIE11dGF0ZXMgc2VsZiB0byByZW1lbWJlciB3aGVyZSBpdCBsZWZ0IG9mZi5cbiAgICpcbiAgICogQHJldHVybiB7UHJvbWlzZTxUW10+fSBUaGUgbmV4dCBwYWdlIG9mIHRoZSByZXN1bHQgc2V0LlxuICAgKi9cbiAgYXN5bmMgZmV0Y2hQYWdlKCk6IFByb21pc2U8VFtdPiB7XG4gICAgaWYgKHRoaXMuI2RvbmUpIHtcbiAgICAgIHJldHVybiBbXTtcbiAgICB9XG5cbiAgICBjb25zdCByZXNwID0gYXdhaXQgdGhpcy4jbGlzdEZuKHtcbiAgICAgIFwicGFnZS5zaXplXCI6IHRoaXMuI29wdHMuc2l6ZSxcbiAgICAgIFwicGFnZS5zdGFydFwiOiB0aGlzLiNsYXN0LFxuICAgIH0pO1xuICAgIHRoaXMuI2xhc3QgPSB0aGlzLiNsYXN0Rm4ocmVzcCk7XG4gICAgdGhpcy4jZG9uZSA9ICF0aGlzLiNsYXN0O1xuICAgIHJldHVybiB0aGlzLiNpdGVtc0ZuKHJlc3ApO1xuICB9XG5cbiAgLyoqXG4gICAqIEZldGNoZXMgdGhlIGVudGlyZSByZXN1bHQgc2V0IHN0YXJ0aW5nIGZyb20gd2hlcmUgaXQgcHJldmlvdXNseSBsZWZ0IG9mZlxuICAgKiBieSBpdGVyYXRpbmcgdGhyb3VnaCB0aGUgcGFnZXMgcmV0dXJuZWQgYnkgdGhlIHJlbW90ZSBlbmQuXG4gICAqXG4gICAqIEByZXR1cm4ge1Byb21pc2U8VFtdPn0gVGhlIGVudGlyZSByZXN1bHQgc2V0LlxuICAgKi9cbiAgYXN5bmMgZmV0Y2hBbGwoKTogUHJvbWlzZTxUW10+IHtcbiAgICBjb25zdCByZXN1bHQgPSBbXTtcbiAgICB3aGlsZSAoIXRoaXMuI2RvbmUpIHtcbiAgICAgIGNvbnN0IGl0ZW1zID0gYXdhaXQgdGhpcy5mZXRjaFBhZ2UoKTtcbiAgICAgIHJlc3VsdC5wdXNoKC4uLml0ZW1zKTtcbiAgICB9XG4gICAgcmV0dXJuIHJlc3VsdDtcbiAgfVxufVxuIl19
99
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3BhZ2luYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7QUFhQSxzQ0FBc0M7QUFDdEMsTUFBYSxJQUFJO0lBQ2Y7Ozs7O09BS0c7SUFDSCxNQUFNLENBQUMsT0FBTztRQUNaLE9BQWlCO1lBQ2YsR0FBRyxFQUFFLElBQUk7U0FDVixDQUFDO0lBQ0osQ0FBQztDQUNGO0FBWkQsb0JBWUM7QUF5QkQ7O0dBRUc7QUFDSCxNQUFhLFNBQVM7SUFRcEI7Ozs7O09BS0c7SUFDSCxZQUFZLFFBQWtCLEVBQUUsTUFBaUIsRUFBRSxPQUFzQixFQUFFLE1BQWlCO1FBYm5GLG9DQUFtQjtRQUNuQixxQ0FBd0I7UUFDeEIsb0NBQW1CO1FBQzVCLGtDQUFnQjtRQUNoQixrQ0FBaUM7UUFDakMsa0NBQWU7UUFTYix1QkFBQSxJQUFJLHFCQUFXLE1BQU0sTUFBQSxDQUFDO1FBQ3RCLHVCQUFBLElBQUksc0JBQVksT0FBTyxNQUFBLENBQUM7UUFDeEIsdUJBQUEsSUFBSSxxQkFBVyxNQUFNLE1BQUEsQ0FBQztRQUN0Qix1QkFBQSxJQUFJLG1CQUFTLFFBQVEsTUFBQSxDQUFDO1FBQ3RCLHVCQUFBLElBQUksbUJBQVMsUUFBUSxDQUFDLEtBQUssTUFBQSxDQUFDO1FBQzVCLHVCQUFBLElBQUksbUJBQVMsS0FBSyxNQUFBLENBQUM7SUFDckIsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsS0FBSyxDQUFDLEtBQUs7UUFDVCxPQUFPLHVCQUFBLElBQUksdUJBQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLE1BQU0sSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUMsQ0FBQyxNQUFNLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUN6RSxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxLQUFLLENBQUMsU0FBUztRQUNiLElBQUksdUJBQUEsSUFBSSx1QkFBTSxFQUFFLENBQUM7WUFDZixPQUFPLEVBQUUsQ0FBQztRQUNaLENBQUM7UUFFRCxNQUFNLElBQUksR0FBRyxNQUFNLHVCQUFBLElBQUkseUJBQVEsTUFBWixJQUFJLEVBQVM7WUFDOUIsV0FBVyxFQUFFLHVCQUFBLElBQUksdUJBQU0sQ0FBQyxJQUFJO1lBQzVCLFlBQVksRUFBRSx1QkFBQSxJQUFJLHVCQUFNO1NBQ3pCLENBQUMsQ0FBQztRQUNILHVCQUFBLElBQUksbUJBQVMsdUJBQUEsSUFBSSx5QkFBUSxNQUFaLElBQUksRUFBUyxJQUFJLENBQUMsTUFBQSxDQUFDO1FBQ2hDLHVCQUFBLElBQUksbUJBQVMsQ0FBQyx1QkFBQSxJQUFJLHVCQUFNLE1BQUEsQ0FBQztRQUN6QixPQUFPLHVCQUFBLElBQUksMEJBQVMsTUFBYixJQUFJLEVBQVUsSUFBSSxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsS0FBSyxDQUFDLFFBQVE7UUFDWixNQUFNLE1BQU0sR0FBRyxFQUFFLENBQUM7UUFDbEIsT0FBTyxDQUFDLHVCQUFBLElBQUksdUJBQU0sRUFBRSxDQUFDO1lBQ25CLE1BQU0sS0FBSyxHQUFHLE1BQU0sSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ3JDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQztRQUN4QixDQUFDO1FBQ0QsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztDQUNGO0FBbkVELDhCQW1FQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKiBQYWdpbmF0aW9uIG9wdGlvbnMuICovXG5leHBvcnQgaW50ZXJmYWNlIFBhZ2VPcHRzIHtcbiAgLyoqIE1heCBudW1iZXIgb2YgaXRlbXMgcGVyIHBhZ2UuICovXG4gIHNpemU/OiBudW1iZXI7XG4gIC8qKlxuICAgKiBTdGFydGluZyBwb2ludCAoaS5lLiwgJ2xhc3RfZXZhbHVhdGVkX2tleScgZnJvbSB0aGUgcHJldmlvdXMgcGFnZSkuXG4gICAqIE9taXQgdG8gc3RhcnQgZnJvbSB0aGUgYmVnaW5uaW5nLlxuICAgKi9cbiAgc3RhcnQ/OiBzdHJpbmc7XG4gIC8qKiBJdGVyYXRlIHVudGlsIHJldHJpZXZpbmcgdGhlIGVudGlyZSByZXN1bHQgc2V0LiAqL1xuICBhbGw6IGJvb2xlYW47XG59XG5cbi8qKiBTdGF0aWMgY29uc3RydWN0b3JzIGZvciBgSVBhZ2VgICovXG5leHBvcnQgY2xhc3MgUGFnZSB7XG4gIC8qKlxuICAgKiBUaGUgZGVmYXVsdCBpcyB0byBmZXRjaCB0aGUgZW50aXJlIHJlc3VsdCBzZXRcbiAgICogKGJ5IHJlcGVhdGVkbHkgY2FsbGluZyB0aGUgcmVtb3RlIGVuZHBvaW50IHVudGlsIGFsbCBwYWdlcyBhcmUgcmV0cmlldmVkKS5cbiAgICpcbiAgICogQHJldHVybiB7UGFnZU9wdHN9IFBhZ2luYXRpb24gb3B0aW9ucy5cbiAgICovXG4gIHN0YXRpYyBkZWZhdWx0KCk6IFBhZ2VPcHRzIHtcbiAgICByZXR1cm4gPFBhZ2VPcHRzPntcbiAgICAgIGFsbDogdHJ1ZSxcbiAgICB9O1xuICB9XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFnZVF1ZXJ5QXJncyB7XG4gIC8qKlxuICAgKiBNYXggbnVtYmVyIG9mIGl0ZW1zIHRvIHJldHVybiBwZXIgcGFnZS5cbiAgICpcbiAgICogVGhlIGFjdHVhbCBudW1iZXIgb2YgcmV0dXJuZWQgaXRlbXMgbWF5IGJlIGxlc3MgdGhhdCB0aGlzLCBldmVuIGlmIHRoZXJlIGV4aXN0IG1vcmVcbiAgICogZGF0YSBpbiB0aGUgcmVzdWx0IHNldC4gVG8gcmVsaWFibHkgZGV0ZXJtaW5lIGlmIG1vcmUgZGF0YSBpcyBsZWZ0IGluIHRoZSByZXN1bHQgc2V0LFxuICAgKiBpbnNwZWN0IHRoZSBbVW5lbmNyeXB0ZWRMYXN0RXZhbEtleV0gdmFsdWUgaW4gdGhlIHJlc3BvbnNlIG9iamVjdC5cbiAgICovXG4gIFwicGFnZS5zaXplXCI/OiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIFRoZSBzdGFydCBvZiB0aGUgcGFnZS5cbiAgICpcbiAgICogT21pdCB0byBzdGFydCBmcm9tIHRoZSBiZWdpbm5pbmc7IG90aGVyd2lzZSwgb25seSBzcGVjaWZ5IHRoZSBleGFjdFxuICAgKiB2YWx1ZSBwcmV2aW91c2x5IHJldHVybmVkIGFzICdsYXN0X2V2YWx1YXRlZF9rZXknIGZyb20gdGhlIHNhbWUgZW5kcG9pbnQuXG4gICAqL1xuICBcInBhZ2Uuc3RhcnRcIj86IHN0cmluZyB8IG51bGw7XG59XG5cbmV4cG9ydCB0eXBlIExpc3RGbjxVPiA9IChwYWdlUXVlcnlBcmdzOiBQYWdlUXVlcnlBcmdzKSA9PiBQcm9taXNlPFU+O1xuZXhwb3J0IHR5cGUgSXRlbXNGbjxVLCBUPiA9IChyZXNwOiBVKSA9PiBUW107XG5leHBvcnQgdHlwZSBMYXN0Rm48VT4gPSAocmVzcDogVSkgPT4gc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZDtcblxuLyoqXG4gKiBIZWxwZXIgY2xhc3MgZm9yIGZldGNoaW5nIHBhZ2luYXRlZCByZXN1bHRzLlxuICovXG5leHBvcnQgY2xhc3MgUGFnaW5hdG9yPFUsIFQ+IHtcbiAgcmVhZG9ubHkgI2xpc3RGbjogTGlzdEZuPFU+O1xuICByZWFkb25seSAjaXRlbXNGbjogSXRlbXNGbjxVLCBUPjtcbiAgcmVhZG9ubHkgI2xhc3RGbjogTGFzdEZuPFU+O1xuICAjb3B0czogUGFnZU9wdHM7XG4gICNsYXN0OiBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkO1xuICAjZG9uZTogYm9vbGVhbjtcblxuICAvKipcbiAgICogQHBhcmFtIHtQYWdlT3B0c30gcGFnZU9wdHMgUGFnaW5hdGlvbiBvcHRpb25zXG4gICAqIEBwYXJhbSB7TGlzdEZuPFU+fSBsaXN0Rm4gQ2FsbHMgYSByZW1vdGUgZW5kcG9pbnQgdGhhdCByZXR1cm5zIGEgcGFnaW5hdGVkIHJlc3BvbnNlXG4gICAqIEBwYXJhbSB7SXRlbXNGbjxVLCBUPn0gaXRlbXNGbiBFeHRyYWN0cyBpdGVtcyBmcm9tIHRoZSBwYWdpbmF0ZWQgcmVzcG9uc2VcbiAgICogQHBhcmFtIHtMYXN0Rm48VT59IGxhc3RGbiBFeHRyYWN0cyB0aGUgbGFzdCBldmFsdWF0ZWQga2V5IGZyb20gdGhlIHBhZ2luYXRlZCByZXNwb25zZVxuICAgKi9cbiAgY29uc3RydWN0b3IocGFnZU9wdHM6IFBhZ2VPcHRzLCBsaXN0Rm46IExpc3RGbjxVPiwgaXRlbXNGbjogSXRlbXNGbjxVLCBUPiwgbGFzdEZuOiBMYXN0Rm48VT4pIHtcbiAgICB0aGlzLiNsaXN0Rm4gPSBsaXN0Rm47XG4gICAgdGhpcy4jaXRlbXNGbiA9IGl0ZW1zRm47XG4gICAgdGhpcy4jbGFzdEZuID0gbGFzdEZuO1xuICAgIHRoaXMuI29wdHMgPSBwYWdlT3B0cztcbiAgICB0aGlzLiNsYXN0ID0gcGFnZU9wdHMuc3RhcnQ7XG4gICAgdGhpcy4jZG9uZSA9IGZhbHNlO1xuICB9XG5cbiAgLyoqXG4gICAqIEZldGNoZXMgZWl0aGVyIGEgc2luZ2xlIHBhZ2Ugb3IgdGhlIGVudGlyZSByZXN1bHQgc2V0LCBkZXBlbmRpbmcgb25cbiAgICogdGhlIGBhbGxgIHByb3BlcnR5IG9mIHRoZSBwYWdpbmF0aW9uIG9wdGlvbnMuXG4gICAqXG4gICAqIEByZXR1cm4ge1Byb21pc2U8VFtdPn0gQSBzaW5nbGUgcGFnZSBvciB0aGUgZW50aXJlIHJlc3VsdCBzZXQuXG4gICAqL1xuICBhc3luYyBmZXRjaCgpOiBQcm9taXNlPFRbXT4ge1xuICAgIHJldHVybiB0aGlzLiNvcHRzLmFsbCA/IGF3YWl0IHRoaXMuZmV0Y2hBbGwoKSA6IGF3YWl0IHRoaXMuZmV0Y2hQYWdlKCk7XG4gIH1cblxuICAvKipcbiAgICogRmV0Y2hlcyBhIHNpbmdsZSBwYWdlIG9mIHRoZSByZXN1bHQgc2V0IGZyb20gd2hlcmUgaXQgcHJldmlvdXNseSBsZWZ0IG9mZi5cbiAgICogTXV0YXRlcyBzZWxmIHRvIHJlbWVtYmVyIHdoZXJlIGl0IGxlZnQgb2ZmLlxuICAgKlxuICAgKiBAcmV0dXJuIHtQcm9taXNlPFRbXT59IFRoZSBuZXh0IHBhZ2Ugb2YgdGhlIHJlc3VsdCBzZXQuXG4gICAqL1xuICBhc3luYyBmZXRjaFBhZ2UoKTogUHJvbWlzZTxUW10+IHtcbiAgICBpZiAodGhpcy4jZG9uZSkge1xuICAgICAgcmV0dXJuIFtdO1xuICAgIH1cblxuICAgIGNvbnN0IHJlc3AgPSBhd2FpdCB0aGlzLiNsaXN0Rm4oe1xuICAgICAgXCJwYWdlLnNpemVcIjogdGhpcy4jb3B0cy5zaXplLFxuICAgICAgXCJwYWdlLnN0YXJ0XCI6IHRoaXMuI2xhc3QsXG4gICAgfSk7XG4gICAgdGhpcy4jbGFzdCA9IHRoaXMuI2xhc3RGbihyZXNwKTtcbiAgICB0aGlzLiNkb25lID0gIXRoaXMuI2xhc3Q7XG4gICAgcmV0dXJuIHRoaXMuI2l0ZW1zRm4ocmVzcCk7XG4gIH1cblxuICAvKipcbiAgICogRmV0Y2hlcyB0aGUgZW50aXJlIHJlc3VsdCBzZXQgc3RhcnRpbmcgZnJvbSB3aGVyZSBpdCBwcmV2aW91c2x5IGxlZnQgb2ZmXG4gICAqIGJ5IGl0ZXJhdGluZyB0aHJvdWdoIHRoZSBwYWdlcyByZXR1cm5lZCBieSB0aGUgcmVtb3RlIGVuZC5cbiAgICpcbiAgICogQHJldHVybiB7UHJvbWlzZTxUW10+fSBUaGUgZW50aXJlIHJlc3VsdCBzZXQuXG4gICAqL1xuICBhc3luYyBmZXRjaEFsbCgpOiBQcm9taXNlPFRbXT4ge1xuICAgIGNvbnN0IHJlc3VsdCA9IFtdO1xuICAgIHdoaWxlICghdGhpcy4jZG9uZSkge1xuICAgICAgY29uc3QgaXRlbXMgPSBhd2FpdCB0aGlzLmZldGNoUGFnZSgpO1xuICAgICAgcmVzdWx0LnB1c2goLi4uaXRlbXMpO1xuICAgIH1cbiAgICByZXR1cm4gcmVzdWx0O1xuICB9XG59XG4iXX0=
@@ -0,0 +1,101 @@
1
+ import { CubeSignerClient, SignerSession } from ".";
2
+ import { MfaReceipt } from "./mfa";
3
+ import { AcceptedResponse, NewSessionResponse } from "./schema_types";
4
+ /**
5
+ * Response type, which can be either a value of type {@link U}
6
+ * or {@link AcceptedResponse} (status code 202) which requires MFA.
7
+ */
8
+ export type Response<U> = U | AcceptedResponse;
9
+ /**
10
+ * Request function which optionally takes additional headers
11
+ * (which, for example, can be used to attach an MFA receipt).
12
+ */
13
+ export type RequestFn<U> = (headers?: HeadersInit) => Promise<Response<U>>;
14
+ /**
15
+ * Map function occasionally used to map a response from the API into a higher-level type.
16
+ */
17
+ export type MapFn<U, V> = (u: U) => V;
18
+ /**
19
+ * Take a {@link Response<U>} and a {@link MapFn<U, V>} function and return
20
+ * a {@link Response<V>} that maps the value of the original response when its status code is 200.
21
+ *
22
+ * @param {Response<U>} resp Original response
23
+ * @param {Map<U, V>} mapFn Map to apply to the response value when its status code is 200.
24
+ * @return {Response<V>} Response whose value for status code 200 is mapped from U to V
25
+ */
26
+ export declare function mapResponse<U, V>(resp: Response<U>, mapFn: MapFn<U, V>): Response<V>;
27
+ export interface MfaRequired {
28
+ /** Org id */
29
+ org_id: string;
30
+ /** MFA request id */
31
+ id: string;
32
+ /** Optional MFA session */
33
+ session?: NewSessionResponse | null;
34
+ }
35
+ /**
36
+ * A response of a CubeSigner request.
37
+ */
38
+ export declare class CubeSignerResponse<U> {
39
+ #private;
40
+ /** @return {string} The MFA id associated with this request (if any) */
41
+ mfaId(): string;
42
+ /** @return {boolean} True if this request requires an MFA approval */
43
+ requiresMfa(): boolean;
44
+ /**
45
+ * Return session information to use for any MFA approval requests (if any was included in the response).
46
+ * @return {ClientSessionInfo | undefined}
47
+ */
48
+ mfaSessionInfo(): NewSessionResponse | undefined;
49
+ /** @return {U} The response data, if no MFA is required */
50
+ data(): U;
51
+ /**
52
+ * Approve the MFA request using a given session and a TOTP code.
53
+ *
54
+ * @param {SignerSession} session Signer session to use
55
+ * @param {string} code 6-digit TOTP code
56
+ * @return {CubeSignerResponse<U>} The result of signing with the approval
57
+ */
58
+ approveTotp(session: SignerSession, code: string): Promise<CubeSignerResponse<U>>;
59
+ /**
60
+ * Approve the MFA request using a given `CubeSignerClient` instance (i.e., its session).
61
+ *
62
+ * @param {CubeSignerClient} cs CubeSigner whose session to use
63
+ * @return {CubeSignerResponse<U>} The result of signing with the approval
64
+ */
65
+ approve(cs: CubeSignerClient): Promise<CubeSignerResponse<U>>;
66
+ /**
67
+ * Resubmits the request with a given MFA receipt attached.
68
+ *
69
+ * @param {MfaReceipt} mfaReceipt The MFA receipt
70
+ * @return {Promise<CubeSignerResponse<U>>} The result of signing after MFA approval
71
+ */
72
+ signWithMfaApproval(mfaReceipt: MfaReceipt): Promise<CubeSignerResponse<U>>;
73
+ /**
74
+ * Constructor.
75
+ *
76
+ * @param {RequestFn} requestFn
77
+ * The signing function that this response is from.
78
+ * This argument is used to resend requests with different headers if needed.
79
+ * @param {U | AcceptedResponse} resp The response as returned by the OpenAPI client.
80
+ * @internal
81
+ */
82
+ constructor(requestFn: RequestFn<U>, resp: U | AcceptedResponse);
83
+ /**
84
+ * Static constructor.
85
+ * @param {RequestFn} requestFn
86
+ * The request function that this response is from.
87
+ * This argument is used to resend requests with different headers if needed.
88
+ * @param {MfaReceipt} mfaReceipt Optional MFA receipt
89
+ * @return {Promise<CubeSignerResponse<U>>} New instance of this class.
90
+ * @internal
91
+ */
92
+ static create<U>(requestFn: RequestFn<U>, mfaReceipt?: MfaReceipt): Promise<CubeSignerResponse<U>>;
93
+ /**
94
+ * Return HTTP headers containing a given MFA receipt.
95
+ *
96
+ * @param {MfaReceipt} mfaReceipt MFA receipt
97
+ * @return {HeadersInit} Headers including that receipt
98
+ * @internal
99
+ */
100
+ static getMfaHeaders(mfaReceipt?: MfaReceipt): HeadersInit | undefined;
101
+ }