@cubist-labs/cubesigner-sdk 0.4.195-0 → 0.4.201
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 +1 -1
- package/dist/src/key.d.ts +19 -3
- package/dist/src/key.d.ts.map +1 -1
- package/dist/src/key.js +25 -4
- package/dist/src/role.d.ts +16 -36
- package/dist/src/role.d.ts.map +1 -1
- package/dist/src/role.js +21 -2
- package/dist/src/schema_types.d.ts +4 -1
- package/dist/src/schema_types.d.ts.map +1 -1
- package/dist/src/schema_types.js +1 -1
- package/package.json +1 -1
- package/src/key.ts +27 -3
- package/src/role.ts +24 -37
- package/src/schema_types.ts +4 -1
package/dist/package.json
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
"url": "git+https://github.com/cubist-labs/CubeSigner-TypeScript-SDK.git",
|
|
6
6
|
"directory": "packages/sdk"
|
|
7
7
|
},
|
|
8
|
-
"version": "0.4.
|
|
8
|
+
"version": "0.4.201",
|
|
9
9
|
"description": "CubeSigner TypeScript SDK",
|
|
10
10
|
"license": "MIT OR Apache-2.0",
|
|
11
11
|
"author": "Cubist, Inc.",
|
package/dist/src/key.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { KeyPolicy } from "./role";
|
|
2
2
|
import type { PageOpts } from "./paginator";
|
|
3
3
|
import type { KeyInfo, SchemaKeyType, KeyInRoleInfo, EvmSignRequest, EvmSignResponse, Eip191SignRequest, Eip712SignRequest, Eth2SignRequest, Eth2UnstakeRequest, AvaTx, BlobSignRequest, BtcSignRequest, SolanaSignRequest, SolanaSignResponse, BtcMessageSignResponse, BtcSignResponse, BlobSignResponse, AvaSignResponse, Eth2UnstakeResponse, Eth2SignResponse, Eip191Or712SignResponse, PsbtSignRequest, PsbtSignResponse, DiffieHellmanResponse } from "./schema_types";
|
|
4
|
-
import type { ApiClient, AvaChain, BabylonRegistrationRequest, BabylonRegistrationResponse, BabylonStakingRequest, BabylonStakingResponse, CubeSignerResponse, Empty, HistoricalTx, JsonValue, MfaReceipts, SuiSignRequest, SuiSignResponse } from ".";
|
|
4
|
+
import type { ApiClient, AvaChain, BabylonRegistrationRequest, BabylonRegistrationResponse, BabylonStakingRequest, BabylonStakingResponse, CubeSignerResponse, EditPolicy, Empty, HistoricalTx, JsonValue, MfaReceipts, SuiSignRequest, SuiSignResponse } from ".";
|
|
5
5
|
import { CubeSignerClient } from ".";
|
|
6
6
|
/** Secp256k1 key type */
|
|
7
7
|
export declare enum Secp256k1 {
|
|
@@ -136,6 +136,14 @@ export declare class Key {
|
|
|
136
136
|
* @throws if MFA is required and no receipts are provided
|
|
137
137
|
*/
|
|
138
138
|
setPolicy(policy: KeyPolicy, mfaReceipt?: MfaReceipts): Promise<void>;
|
|
139
|
+
/**
|
|
140
|
+
* Set new edit policy (overwriting any edit policies previously set for this key)
|
|
141
|
+
*
|
|
142
|
+
* @param editPolicy The new edit policy to set
|
|
143
|
+
* @param mfaReceipt Optional MFA receipt(s)
|
|
144
|
+
* @throws if MFA is required and no receipts are provided
|
|
145
|
+
*/
|
|
146
|
+
setEditPolicy(editPolicy: EditPolicy, mfaReceipt?: MfaReceipts): Promise<void>;
|
|
139
147
|
/**
|
|
140
148
|
* Set key metadata. The metadata must be at most 1024 characters
|
|
141
149
|
* and must match the following regex: ^[A-Za-z0-9_=+/ \-\.\,]{0,1024}$.
|
|
@@ -182,17 +190,25 @@ export declare class Key {
|
|
|
182
190
|
/**
|
|
183
191
|
* Append to existing key policy. This append is not atomic -- it uses {@link policy}
|
|
184
192
|
* to fetch the current policy and then {@link setPolicy} to set the policy -- and
|
|
185
|
-
* should not be used
|
|
193
|
+
* should not be used across concurrent sessions.
|
|
186
194
|
*
|
|
187
195
|
* @param policy The policy to append to the existing one.
|
|
196
|
+
* @param mfaReceipt Optional MFA receipt(s)
|
|
197
|
+
* @throws If MFA is required and no MFA receipts are provided
|
|
188
198
|
*/
|
|
189
|
-
appendPolicy(policy: KeyPolicy): Promise<void>;
|
|
199
|
+
appendPolicy(policy: KeyPolicy, mfaReceipt?: MfaReceipts): Promise<void>;
|
|
190
200
|
/**
|
|
191
201
|
* Get the policy for the key.
|
|
192
202
|
*
|
|
193
203
|
* @returns The policy for the key.
|
|
194
204
|
*/
|
|
195
205
|
policy(): Promise<KeyPolicy>;
|
|
206
|
+
/**
|
|
207
|
+
* Get the edit policy for the key.
|
|
208
|
+
*
|
|
209
|
+
* @returns The edit policy for the key, undefined if there is no edit policy
|
|
210
|
+
*/
|
|
211
|
+
editPolicy(): Promise<EditPolicy | undefined>;
|
|
196
212
|
/**
|
|
197
213
|
* Fetch the metadata for the key.
|
|
198
214
|
*
|
package/dist/src/key.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"key.d.ts","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"key.d.ts","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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"}
|
package/dist/src/key.js
CHANGED
|
@@ -140,6 +140,16 @@ class Key {
|
|
|
140
140
|
async setPolicy(policy, mfaReceipt) {
|
|
141
141
|
await this.update({ policy }, mfaReceipt);
|
|
142
142
|
}
|
|
143
|
+
/**
|
|
144
|
+
* Set new edit policy (overwriting any edit policies previously set for this key)
|
|
145
|
+
*
|
|
146
|
+
* @param editPolicy The new edit policy to set
|
|
147
|
+
* @param mfaReceipt Optional MFA receipt(s)
|
|
148
|
+
* @throws if MFA is required and no receipts are provided
|
|
149
|
+
*/
|
|
150
|
+
async setEditPolicy(editPolicy, mfaReceipt) {
|
|
151
|
+
await this.update({ edit_policy: editPolicy }, mfaReceipt);
|
|
152
|
+
}
|
|
143
153
|
/**
|
|
144
154
|
* Set key metadata. The metadata must be at most 1024 characters
|
|
145
155
|
* and must match the following regex: ^[A-Za-z0-9_=+/ \-\.\,]{0,1024}$.
|
|
@@ -192,13 +202,15 @@ class Key {
|
|
|
192
202
|
/**
|
|
193
203
|
* Append to existing key policy. This append is not atomic -- it uses {@link policy}
|
|
194
204
|
* to fetch the current policy and then {@link setPolicy} to set the policy -- and
|
|
195
|
-
* should not be used
|
|
205
|
+
* should not be used across concurrent sessions.
|
|
196
206
|
*
|
|
197
207
|
* @param policy The policy to append to the existing one.
|
|
208
|
+
* @param mfaReceipt Optional MFA receipt(s)
|
|
209
|
+
* @throws If MFA is required and no MFA receipts are provided
|
|
198
210
|
*/
|
|
199
|
-
async appendPolicy(policy) {
|
|
211
|
+
async appendPolicy(policy, mfaReceipt) {
|
|
200
212
|
const existing = await this.policy();
|
|
201
|
-
await this.setPolicy([...existing, ...policy]);
|
|
213
|
+
await this.setPolicy([...existing, ...policy], mfaReceipt);
|
|
202
214
|
}
|
|
203
215
|
/**
|
|
204
216
|
* Get the policy for the key.
|
|
@@ -209,6 +221,15 @@ class Key {
|
|
|
209
221
|
const data = await this.fetch();
|
|
210
222
|
return (data.policy ?? []);
|
|
211
223
|
}
|
|
224
|
+
/**
|
|
225
|
+
* Get the edit policy for the key.
|
|
226
|
+
*
|
|
227
|
+
* @returns The edit policy for the key, undefined if there is no edit policy
|
|
228
|
+
*/
|
|
229
|
+
async editPolicy() {
|
|
230
|
+
const data = await this.fetch();
|
|
231
|
+
return data.edit_policy;
|
|
232
|
+
}
|
|
212
233
|
/**
|
|
213
234
|
* Fetch the metadata for the key.
|
|
214
235
|
*
|
|
@@ -623,4 +644,4 @@ function fromSchemaKeyType(ty) {
|
|
|
623
644
|
// NOTE: if you are adding a new key type, update the `create ${keyType} key` test in key.test.ts
|
|
624
645
|
}
|
|
625
646
|
}
|
|
626
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AA4sBA,8CAoFC;AAjvBD,wBAA4C;AAC5C,+CAAiD;AACjD,iCAAqD;AAErD,yBAAyB;AACzB,IAAY,SAuBX;AAvBD,WAAY,SAAS;IACnB,gCAAmB,CAAA;IACnB,4BAAe,CAAA;IACf,oCAAuB,CAAA;IACvB,4BAAe,CAAA;IACf,oCAAuB,CAAA;IACvB,gCAAmB,CAAA;IACnB,sCAAyB,CAAA;IACzB,mCAAsB,CAAA;IACtB,2CAA8B,CAAA;IAC9B,wCAA2B,CAAA;IAC3B,sCAAyB,CAAA;IACzB,gCAAmB,CAAA;IACnB,wCAA2B,CAAA;IAC3B,kCAAqB,CAAA;IACrB,wCAA2B,CAAA;IAC3B,gDAAmC,CAAA;IACnC,kCAAqB,CAAA;IACrB,0CAA6B,CAAA;IAC7B,oCAAuB,CAAA;IACvB,4CAA+B,CAAA;IAC/B,8CAAiC,CAAA;IACjC,sDAAyC,CAAA;AAC3C,CAAC,EAvBW,SAAS,yBAAT,SAAS,QAuBpB;AAED,mBAAmB;AACnB,IAAY,GAIX;AAJD,WAAY,GAAG;IACb,+BAAwB,CAAA;IACxB,mCAA4B,CAAA;IAC5B,2BAAoB,CAAA;AACtB,CAAC,EAJW,GAAG,mBAAH,GAAG,QAId;AAED,uBAAuB;AACvB,IAAY,OAUX;AAVD,WAAY,OAAO;IACjB,uCAA4B,CAAA;IAC5B,iCAAsB,CAAA;IACtB,qCAA0B,CAAA;IAC1B,2CAAgC,CAAA;IAChC,yCAA8B,CAAA;IAC9B,6CAAkC,CAAA;IAClC,+CAAoC,CAAA;IACpC,iCAAsB,CAAA;IACtB,iCAAsB,CAAA;AACxB,CAAC,EAVW,OAAO,uBAAP,OAAO,QAUlB;AAED,oBAAoB;AACpB,IAAY,IAIX;AAJD,WAAY,IAAI;IACd,iCAAyB,CAAA;IACzB,qCAA6B,CAAA;IAC7B,6BAAqB,CAAA;AACvB,CAAC,EAJW,IAAI,oBAAJ,IAAI,QAIf;AAED,wBAAwB;AACX,QAAA,QAAQ,GAAG,UAAmB,CAAC;AAG5C,qBAAqB;AACR,QAAA,KAAK,GAAG,OAAgB,CAAC;AAGtC,2BAA2B;AACd,QAAA,UAAU,GAAG,YAAqB,CAAC;AAMhD;;GAEG;AACH,MAAa,GAAG;IAId,oDAAoD;IACpD,IAAI,KAAK;QACP,OAAO,uBAAA,IAAI,sBAAW,CAAC,WAAW,CAAC,MAAM,CAAC;IAC5C,CAAC;IAgCD,gCAAgC;IAChC,KAAK,CAAC,IAAI;QACR,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QAChC,OAAO,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC1C,CAAC;IAED,0CAA0C;IAC1C,KAAK,CAAC,OAAO;QACX,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QAChC,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,MAAM,CAAC,UAAwB;QACnC,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,EAAE,UAAU,CAAC,CAAC;IACnD,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,OAAO,CAAC,UAAwB;QACpC,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,UAAU,CAAC,CAAC;IACpD,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,KAAK,CAAC,IAAe;QACzB,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC;IACnE,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,OAAO,CAAC,IAAe;QAC3B,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC;IACjE,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,SAAS,CAAC,MAAiB,EAAE,UAAwB;QACzD,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,EAAE,UAAU,CAAC,CAAC;IAC5C,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,WAAW,CAAC,QAAmB,EAAE,UAAwB;QAC7D,OAAO,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,QAAQ,EAAE,EAAE,UAAU,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;;;;;;;;;;OAeG;IACH,KAAK,CAAC,mBAAmB,CACvB,IAAY,EACZ,KAAgB,EAChB,UAAwB;QAExB,OAAO,MAAM,uBAAA,IAAI,gDAAqB,MAAzB,IAAI,EACf,IAAI,EACJ,KAAK,EACL,uBAAA,IAAI,sBAAW,CAAC,MAAM,CAAC,mBAAmB,EAC1C,UAAU,CACX,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;;;OAcG;IACH,KAAK,CAAC,sBAAsB,CAAC,IAAY,EAAE,UAAwB;QACjE,OAAO,MAAM,uBAAA,IAAI,gDAAqB,MAAzB,IAAI,EACf,IAAI,EACJ,SAAS,EACT,uBAAA,IAAI,sBAAW,CAAC,MAAM,CAAC,mBAAmB,EAC1C,UAAU,CACX,CAAC;IACJ,CAAC;IA4CD;;;;;;OAMG;IACH,KAAK,CAAC,YAAY,CAAC,MAAiB;QAClC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC;QACrC,MAAM,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,QAAQ,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC;IACjD,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,MAAM;QACV,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QAChC,OAAO,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAyB,CAAC;IACrD,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,QAAQ;QACZ,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QAChC,OAAO,IAAI,CAAC,QAAqB,CAAC;IACpC,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK;QACT,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QAChC,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,QAAQ,CAAC,KAAa,EAAE,UAAwB;QACpD,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,EAAE,UAAU,CAAC,CAAC;IAC3C,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,MAAM,CAAC,UAAwB;QACnC,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;IAC9D,CAAC;IAED,6EAA6E;IAC7E,6EAA6E;IAC7E,6EAA6E;IAE7E;;;;;;OAMG;IACH,YAAY,MAAoC,EAAE,IAAa;;QA1R/D,+DAA+D;QACtD,iCAAsB;QA0R7B,uBAAA,IAAI,kBAAc,MAAM,YAAY,mBAAgB,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,MAAA,CAAC;QACjF,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC;QACtB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC;QACnC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC;QACjC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IACrB,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,OAAO,CACX,GAAmB,EACnB,UAAwB;QAExB,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;IAC9D,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,qBAAqB,CACzB,GAA0B,EAC1B,UAAwB;QAExB,OAAO,uBAAA,IAAI,sBAAW,CAAC,qBAAqB,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;IACtE,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,uBAAuB,CAC3B,GAA+B,EAC/B,UAAwB;QAExB,OAAO,uBAAA,IAAI,sBAAW,CAAC,uBAAuB,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;IACxE,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,UAAU,CACd,GAAsB,EACtB,UAAwB;QAExB,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,UAAU,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;IACjE,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,UAAU,CACd,GAAsB,EACtB,UAAwB;QAExB,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,UAAU,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;IACjE,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,QAAQ,CACZ,GAAoB,EACpB,UAAwB;QAExB,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;IAC/D,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,OAAO,CACX,GAAuB,EACvB,UAAwB;QAExB,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,WAAW,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;IAClE,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,OAAO,CAAC,EAAS,EAAE,UAAwB;QAC/C,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,EAAE,UAAU,CAAC,CAAC;IAC7D,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,iBAAiB,CACrB,QAAkB,EAClB,EAAU,EACV,UAAwB;QAExB,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,iBAAiB,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,UAAU,CAAC,CAAC;IACjF,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;OAqBG;IACH,KAAK,CAAC,QAAQ,CACZ,GAAoB,EACpB,UAAwB;QAExB,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;IAC/D,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,KAAK,CAAC,qBAAqB,CACzB,MAAoB,EACpB,SAAoB,EACpB,UAAwB;QAExB,IAAI,MAAM,CAAC,MAAM,GAAG,EAAE,EAAE,CAAC;YACvB,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;QACzD,CAAC;QAED,wBAAwB;QACxB,MAAM,MAAM,GAAG,MAAM,IAAA,8BAAgB,GAAE,CAAC;QACxC,MAAM,GAAG,GAAyB;YAChC,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,IAAA,qBAAc,EAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;YAC3D,UAAU,EAAE,IAAA,qBAAc,EAAC,MAAM,CAAC,IAAI,CAAC,MAAM,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC;SAClF,CAAC;QAEF,OAAO;QACP,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,qBAAqB,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;IAC5E,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,OAAO,CACX,GAAmB,EACnB,UAAwB;QAExB,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;IAC9D,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,QAAQ,CACZ,GAAoB,EACpB,UAAwB;QAExB,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;IAC/D,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,cAAc,CAClB,GAAwB,EACxB,IAAsE;QAEtE,MAAM,OAAO,GAA0B;YACrC,IAAI,EAAE,IAAA,kBAAW,EAAC,GAAG,CAAC;YACtB,OAAO,EAAE,IAAI,CAAC,IAAI,IAAI,KAAK;YAC3B,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACxB,CAAC;QACF,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,cAAc,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAC9E,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,UAAU,CACd,GAAsB,EACtB,UAAwB;QAExB,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,UAAU,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;IACjE,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,OAAO,CACX,GAAmB,EACnB,UAAwB;QAExB,OAAO,MAAM,uBAAA,IAAI,sBAAW,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;IAC9D,CAAC;IAED;;;;;;;;OAQG;IACK,KAAK,CAAC,MAAM,CAAC,OAAyB,EAAE,UAAwB;QACtE,MAAM,IAAI,GAAG,MAAM,uBAAA,IAAI,sBAAW,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;QAC3E,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;QAC1B,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED;;;;;OAKG;IACK,KAAK,CAAC,KAAK;QACjB,IAAI,CAAC,MAAM,GAAG,MAAM,uBAAA,IAAI,sBAAW,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACpD,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;CACF;AAzkBD,kBAykBC;;AAjaC;;;;;;;;GAQG;AACH,KAAK,mCACH,IAAY,EACZ,KAA4B,EAC5B,QAAkB,EAClB,UAAwB;IAExB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;IAChC,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC;IACpC,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;QAChC,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;IAC3D,CAAC;IACD,MAAM,OAAO,GAAG;QACd,GAAG,OAAO;QACV,CAAC,IAAI,CAAC,EAAE,KAAK;KACd,CAAC;IACF,IAAI,CAAC;QACH,OAAO,MAAM,IAAI,CAAC,MAAM,CACtB;YACE,QAAQ,EAAE,OAAO;YACjB,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,EACD,UAAU,CACX,CAAC;IACJ,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,IAAK,CAAiB,CAAC,SAAS,KAAK,eAAe,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC5E,MAAM,IAAA,QAAK,EAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;YACzB,OAAO,MAAM,uBAAA,IAAI,gDAAqB,MAAzB,IAAI,EAAsB,IAAI,EAAE,KAAK,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACzE,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,CAAC;QACV,CAAC;IACH,CAAC;AACH,CAAC;AA2XH;;;;;;GAMG;AACH,SAAgB,iBAAiB,CAAC,EAAiB;IACjD,QAAQ,EAAE,EAAE,CAAC;QACX,KAAK,aAAa;YAChB,OAAO,SAAS,CAAC,GAAG,CAAC;QACvB,KAAK,gBAAgB;YACnB,OAAO,SAAS,CAAC,MAAM,CAAC;QAC1B,KAAK,SAAS;YACZ,OAAO,SAAS,CAAC,GAAG,CAAC;QACvB,KAAK,aAAa;YAChB,OAAO,SAAS,CAAC,OAAO,CAAC;QAC3B,KAAK,eAAe;YAClB,OAAO,SAAS,CAAC,SAAS,CAAC;QAC7B,KAAK,mBAAmB;YACtB,OAAO,SAAS,CAAC,aAAa,CAAC;QACjC,KAAK,aAAa;YAChB,OAAO,SAAS,CAAC,GAAG,CAAC;QACvB,KAAK,iBAAiB;YACpB,OAAO,SAAS,CAAC,OAAO,CAAC;QAC3B,KAAK,aAAa;YAChB,OAAO,SAAS,CAAC,WAAW,CAAC;QAC/B,KAAK,YAAY;YACf,OAAO,SAAS,CAAC,WAAW,CAAC;QAC/B,KAAK,YAAY;YACf,OAAO,SAAS,CAAC,OAAO,CAAC;QAC3B,KAAK,gBAAgB;YACnB,OAAO,SAAS,CAAC,WAAW,CAAC;QAC/B,KAAK,cAAc;YACjB,OAAO,SAAS,CAAC,IAAI,CAAC;QACxB,KAAK,cAAc;YACjB,OAAO,SAAS,CAAC,IAAI,CAAC;QACxB,KAAK,kBAAkB;YACrB,OAAO,SAAS,CAAC,QAAQ,CAAC;QAC5B,KAAK,eAAe;YAClB,OAAO,SAAS,CAAC,KAAK,CAAC;QACzB,KAAK,mBAAmB;YACtB,OAAO,SAAS,CAAC,SAAS,CAAC;QAC7B,KAAK,kBAAkB;YACrB,OAAO,SAAS,CAAC,YAAY,CAAC;QAChC,KAAK,sBAAsB;YACzB,OAAO,SAAS,CAAC,gBAAgB,CAAC;QACpC,KAAK,QAAQ;YACX,OAAO,GAAG,CAAC,aAAa,CAAC;QAC3B,KAAK,aAAa;YAChB,OAAO,GAAG,CAAC,YAAY,CAAC;QAC1B,KAAK,WAAW;YACd,OAAO,GAAG,CAAC,MAAM,CAAC;QACpB,KAAK,mBAAmB;YACtB,OAAO,OAAO,CAAC,MAAM,CAAC;QACxB,KAAK,gBAAgB;YACnB,OAAO,OAAO,CAAC,GAAG,CAAC;QACrB,KAAK,kBAAkB;YACrB,OAAO,OAAO,CAAC,KAAK,CAAC;QACvB,KAAK,sBAAsB;YACzB,OAAO,OAAO,CAAC,OAAO,CAAC;QACzB,KAAK,oBAAoB;YACvB,OAAO,OAAO,CAAC,OAAO,CAAC;QACzB,KAAK,sBAAsB;YACzB,OAAO,OAAO,CAAC,SAAS,CAAC;QAC3B,KAAK,uBAAuB;YAC1B,OAAO,OAAO,CAAC,UAAU,CAAC;QAC5B,KAAK,gBAAgB;YACnB,OAAO,OAAO,CAAC,GAAG,CAAC;QACrB,KAAK,OAAO;YACV,OAAO,aAAK,CAAC;QACf,KAAK,UAAU;YACb,OAAO,gBAAQ,CAAC;QAClB,KAAK,gBAAgB;YACnB,OAAO,IAAI,CAAC,MAAM,CAAC;QACrB,KAAK,kBAAkB;YACrB,OAAO,IAAI,CAAC,QAAQ,CAAC;QACvB,KAAK,cAAc;YACjB,OAAO,IAAI,CAAC,IAAI,CAAC;QACnB,KAAK,SAAS;YACZ,OAAO,SAAS,CAAC,GAAG,CAAC;QACvB,KAAK,aAAa;YAChB,OAAO,SAAS,CAAC,OAAO,CAAC;QAC3B,KAAK,aAAa;YAChB,OAAO,SAAS,CAAC,GAAG,CAAC;QACvB,KAAK,gBAAgB;YACnB,OAAO,OAAO,CAAC,GAAG,CAAC;QACrB,KAAK,YAAY;YACf,OAAO,kBAAU,CAAC;QACpB,iGAAiG;IACnG,CAAC;AACH,CAAC","sourcesContent":["import type { KeyPolicy } from \"./role\";\nimport type { PageOpts } from \"./paginator\";\nimport type {\n  KeyInfo,\n  UpdateKeyRequest,\n  SchemaKeyType,\n  KeyInRoleInfo,\n  EvmSignRequest,\n  EvmSignResponse,\n  Eip191SignRequest,\n  Eip712SignRequest,\n  Eth2SignRequest,\n  Eth2UnstakeRequest,\n  AvaTx,\n  BlobSignRequest,\n  BtcSignRequest,\n  SolanaSignRequest,\n  SolanaSignResponse,\n  BtcMessageSignResponse,\n  BtcSignResponse,\n  BlobSignResponse,\n  AvaSignResponse,\n  Eth2UnstakeResponse,\n  Eth2SignResponse,\n  Eip191Or712SignResponse,\n  PsbtSignRequest,\n  PsbtSignResponse,\n  DiffieHellmanRequest,\n  DiffieHellmanResponse,\n} from \"./schema_types\";\nimport type {\n  ApiClient,\n  AvaChain,\n  BabylonRegistrationRequest,\n  BabylonRegistrationResponse,\n  BabylonStakingRequest,\n  BabylonStakingResponse,\n  BtcMessageSignRequest,\n  CubeSignerResponse,\n  Empty,\n  ErrResponse,\n  HistoricalTx,\n  JsonValue,\n  MfaReceipts,\n  SuiSignRequest,\n  SuiSignResponse,\n} from \".\";\nimport { CubeSignerClient, delay } from \".\";\nimport { loadSubtleCrypto } from \"./user_export\";\nimport { encodeToHex, encodeToBase64 } from \"./util\";\n\n/** Secp256k1 key type */\nexport enum Secp256k1 {\n  Evm = \"SecpEthAddr\",\n  Btc = \"SecpBtc\",\n  BtcTest = \"SecpBtcTest\",\n  Ltc = \"SecpLtc\",\n  LtcTest = \"SecpLtcTest\",\n  Xrp = \"SecpXrpAddr\",\n  Cosmos = \"SecpCosmosAddr\",\n  Taproot = \"TaprootBtc\",\n  TaprootTest = \"TaprootBtcTest\",\n  BabylonEots = \"BabylonEots\",\n  BabylonCov = \"BabylonCov\",\n  Ava = \"SecpAvaAddr\",\n  AvaTest = \"SecpAvaTestAddr\",\n  Tron = \"SecpTronAddr\",\n  BtcLegacy = \"SecpBtcLegacy\",\n  BtcLegacyTest = \"SecpBtcLegacyTest\",\n  Doge = \"SecpDogeAddr\",\n  DogeTest = \"SecpDogeTestAddr\",\n  Kaspa = \"SecpKaspaAddr\",\n  KaspaTest = \"SecpKaspaTestAddr\",\n  KaspaSchnorr = \"SchnorrKaspaAddr\",\n  KaspaTestSchnorr = \"SchnorrKaspaTestAddr\",\n}\n\n/** BLS key type */\nexport enum Bls {\n  Eth2Deposited = \"BlsPub\",\n  Eth2Inactive = \"BlsInactive\",\n  AvaIcm = \"BlsAvaIcm\",\n}\n\n/** Ed25519 key type */\nexport enum Ed25519 {\n  Solana = \"Ed25519SolanaAddr\",\n  Sui = \"Ed25519SuiAddr\",\n  Aptos = \"Ed25519AptosAddr\",\n  Cardano = \"Ed25519CardanoAddrVk\",\n  Stellar = \"Ed25519StellarAddr\",\n  Substrate = \"Ed25519SubstrateAddr\",\n  Tendermint = \"Ed25519TendermintAddr\",\n  Ton = \"Ed25519TonAddr\",\n  Xrp = \"Ed25519XrpAddr\",\n}\n\n/** P256 key type */\nexport enum P256 {\n  Cosmos = \"P256CosmosAddr\",\n  Ontology = \"P256OntologyAddr\",\n  Neo3 = \"P256Neo3Addr\",\n}\n\n/** Mnemonic key type */\nexport const Mnemonic = \"Mnemonic\" as const;\nexport type Mnemonic = typeof Mnemonic;\n\n/** Stark key type */\nexport const Stark = \"Stark\" as const;\nexport type Stark = typeof Stark;\n\n/** Baby Jubjub key type */\nexport const BabyJubjub = \"BabyJubjub\" as const;\nexport type BabyJubjub = typeof BabyJubjub;\n\n/** Key type */\nexport type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark | P256 | BabyJubjub;\n\n/**\n * A representation of a signing key.\n */\nexport class Key {\n  /** The CubeSigner instance that this key is associated with */\n  readonly #apiClient: ApiClient;\n\n  /** @returns The organization that this key is in */\n  get orgId() {\n    return this.#apiClient.sessionMeta.org_id;\n  }\n\n  /**\n   * The id of the key: \"Key#\" followed by a unique identifier specific to\n   * the type of key (such as a public key for BLS or an ethereum address for Secp)\n   *\n   * @example Key#0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   */\n  readonly id: string;\n\n  /**\n   * A unique identifier specific to the type of key, such as a public key or an ethereum address\n   *\n   * @example 0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   */\n  readonly materialId!: string;\n\n  /**\n   * @description Hex-encoded, serialized public key. The format used depends on the key type:\n   * - secp256k1 keys use 65-byte uncompressed SECG format\n   * - BLS keys use 48-byte compressed BLS12-381 (ZCash) format\n   * @example 0x04d2688b6bc2ce7f9879b9e745f3c4dc177908c5cef0c1b64cff19ae7ff27dee623c64fe9d9c325c7fbbc748bbd5f607ce14dd83e28ebbbb7d3e7f2ffb70a79431\n   */\n  readonly publicKey: string;\n\n  /**\n   * Get the cached properties of this key. The cached properties reflect the\n   * state of the last fetch or update (e.g., after awaiting `Key.enabled()`\n   * or `Key.disable()`).\n   */\n  cached: KeyInfo;\n\n  /** @returns The type of key. */\n  async type(): Promise<KeyType> {\n    const data = await this.fetch();\n    return fromSchemaKeyType(data.key_type);\n  }\n\n  /** @returns Whether the key is enabled */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /**\n   * Enable the key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async enable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: true }, mfaReceipt);\n  }\n\n  /**\n   * Disable the key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async disable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: false }, mfaReceipt);\n  }\n\n  /**\n   * List roles this key is in.\n   *\n   * @param page Optional pagination options; by default, retrieves all roles this key is in.\n   * @returns Roles this key is in.\n   */\n  async roles(page?: PageOpts): Promise<KeyInRoleInfo[]> {\n    return await this.#apiClient.keyRolesList(this.id, page).fetch();\n  }\n\n  /**\n   * List historical transactions for this key.\n   *\n   * @param page Optional pagination options; by default, retrieves all historical transactions for this key.\n   * @returns Historical key transactions.\n   */\n  async history(page?: PageOpts): Promise<HistoricalTx[]> {\n    return await this.#apiClient.keyHistory(this.id, page).fetch();\n  }\n\n  /**\n   * Set new policy (overwriting any policies previously set for this key)\n   *\n   * @param policy The new policy to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setPolicy(policy: KeyPolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ policy }, mfaReceipt);\n  }\n\n  /**\n   * Set key metadata. The metadata must be at most 1024 characters\n   * and must match the following regex: ^[A-Za-z0-9_=+/ \\-\\.\\,]{0,1024}$.\n   *\n   * @param metadata The new metadata to set.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns The updated key info\n   */\n  async setMetadata(metadata: JsonValue, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    return await this.update({ metadata }, mfaReceipt);\n  }\n\n  /**\n   * Retrieves the existing metadata, asserts that it is an object (throws if it is not),\n   * then sets the value of the {@link name} property in that object to {@link value},\n   * and finally submits the request to update the metadata.\n   *\n   * This whole process is done atomically, meaning, that if the metadata changes between the\n   * time this method first retrieves it and the time it submits a request to update it, the\n   * request will be rejected. When that happens, this method will retry a few times, as per\n   * {@link ApiClient.config}.\n   *\n   * @param name The name of the property to set\n   * @param value The new value of the property\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   */\n  async setMetadataProperty(\n    name: string,\n    value: JsonValue,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(\n      name,\n      value,\n      this.#apiClient.config.updateRetryDelaysMs,\n      mfaReceipt,\n    );\n  }\n\n  /**\n   * Retrieves the existing metadata, asserts that it is in object (throws if it is not),\n   * then deletes the {@link name} property in that object, and finally submits the\n   * request to update the metadata.\n   *\n   * This whole process is done atomically, meaning, that if the metadata changes between the\n   * time this method first retrieves it and the time it submits a request to update it, the\n   * request will be rejected. When that happens, this method will retry a few times, as per\n   * {@link ApiClient.config}.\n   *\n   * @param name The name of the property to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   */\n  async deleteMetadataProperty(name: string, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(\n      name,\n      undefined,\n      this.#apiClient.config.updateRetryDelaysMs,\n      mfaReceipt,\n    );\n  }\n\n  /**\n   * @param name The name of the property to set\n   * @param value The new value of the property\n   * @param delaysMs Delays in milliseconds between retries\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   * @internal\n   */\n  async #setMetadataProperty(\n    name: string,\n    value: JsonValue | undefined,\n    delaysMs: number[],\n    mfaReceipt?: MfaReceipts,\n  ): Promise<KeyInfo> {\n    const data = await this.fetch();\n    const current = data.metadata ?? {};\n    if (typeof current !== \"object\") {\n      throw new Error(\"Current metadata is not a JSON object\");\n    }\n    const updated = {\n      ...current,\n      [name]: value,\n    };\n    try {\n      return await this.update(\n        {\n          metadata: updated,\n          version: data.version,\n        },\n        mfaReceipt,\n      );\n    } catch (e) {\n      if ((e as ErrResponse).errorCode === \"InvalidUpdate\" && delaysMs.length > 0) {\n        await delay(delaysMs[0]);\n        return await this.#setMetadataProperty(name, value, delaysMs.slice(1));\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  /**\n   * Append to existing key policy. This append is not atomic -- it uses {@link policy}\n   * to fetch the current policy and then {@link setPolicy} to set the policy -- and\n   * should not be used in across concurrent sessions.\n   *\n   * @param policy The policy to append to the existing one.\n   */\n  async appendPolicy(policy: KeyPolicy) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy]);\n  }\n\n  /**\n   * Get the policy for the key.\n   *\n   * @returns The policy for the key.\n   */\n  async policy(): Promise<KeyPolicy> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as KeyPolicy;\n  }\n\n  /**\n   * Fetch the metadata for the key.\n   *\n   * @returns The policy for the key.\n   */\n  async metadata(): Promise<JsonValue> {\n    const data = await this.fetch();\n    return data.metadata as JsonValue;\n  }\n\n  /**\n   * @returns The user id for the owner of the key\n   * @example User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\n   */\n  async owner(): Promise<string> {\n    const data = await this.fetch();\n    return data.owner;\n  }\n\n  /**\n   * Set the owner of the key. Only the key (or org) owner can change the owner of the key.\n   *\n   * @param owner The user-id of the new owner of the key.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setOwner(owner: string, mfaReceipt?: MfaReceipts) {\n    await this.update({ owner }, mfaReceipt);\n  }\n\n  /**\n   * Delete this key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns A response which can be used to approve MFA if needed\n   */\n  async delete(mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<Empty>> {\n    return await this.#apiClient.keyDelete(this.id, mfaReceipt);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Create a new key.\n   *\n   * @param client The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(client: ApiClient | CubeSignerClient, data: KeyInfo) {\n    this.#apiClient = client instanceof CubeSignerClient ? client.apiClient : client;\n    this.id = data.key_id;\n    this.materialId = data.material_id;\n    this.publicKey = data.public_key;\n    this.cached = data;\n  }\n\n  /**\n   * Sign an EVM transaction.\n   *\n   * @param req What to sign.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Signature (or MFA approval request).\n   */\n  async signEvm(\n    req: EvmSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<EvmSignResponse>> {\n    return await this.#apiClient.signEvm(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Babylon staking transaction.\n   *\n   * @param req The staking transaction to sign\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Signature (or MFA approval request).\n   */\n  async signBabylonStakingTxn(\n    req: BabylonStakingRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BabylonStakingResponse>> {\n    return this.#apiClient.signBabylonStakingTxn(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Babylon registration.\n   *\n   * @param req The registration request to sign\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Babylon staking registration data (or MFA approval request).\n   */\n  async signBabylonRegistration(\n    req: BabylonRegistrationRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BabylonRegistrationResponse>> {\n    return this.#apiClient.signBabylonRegistration(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign EIP-191 typed data.\n   *\n   * This requires the key to have a '\"AllowEip191Signing\"' {@link KeyPolicy}.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature (or MFA approval request).\n   */\n  async signEip191(\n    req: Eip191SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    return await this.#apiClient.signEip191(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign EIP-712 typed data.\n   *\n   * This requires the key to have a '\"AllowEip712Signing\"' {@link KeyPolicy}.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature (or MFA approval request).\n   */\n  async signEip712(\n    req: Eip712SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    return await this.#apiClient.signEip712(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain validation message.\n   *\n   * @param req What to sign.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature\n   */\n  async signEth2(\n    req: Eth2SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2SignResponse>> {\n    return await this.#apiClient.signEth2(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain unstake/exit request.\n   *\n   * @param req The request to sign.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async unstake(\n    req: Eth2UnstakeRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2UnstakeResponse>> {\n    return await this.#apiClient.signUnstake(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Avalanche P- or X-chain message.\n   *\n   * @param tx Avalanche message (transaction) to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signAva(tx: AvaTx, mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<AvaSignResponse>> {\n    return await this.#apiClient.signAva(this, tx, mfaReceipt);\n  }\n\n  /**\n   * Sign a serialized Avalanche C-/X-/P-chain message.\n   *\n   * @param avaChain Avalanche chain\n   * @param tx Hex encoded transaction\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signSerializedAva(\n    avaChain: AvaChain,\n    tx: string,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<AvaSignResponse>> {\n    return await this.#apiClient.signSerializedAva(this, avaChain, tx, mfaReceipt);\n  }\n\n  /**\n   * Sign a raw blob.\n   *\n   * This requires the key to have a '\"AllowRawBlobSigning\"' {@link KeyPolicy}. This is because\n   * signing arbitrary messages is, in general, dangerous (and you should instead\n   * prefer typed end-points as used by, for example, {@link signEvm}). For Secp256k1 keys,\n   * for example, you **must** call this function with a message that is 32 bytes long and\n   * the output of a secure hash function.\n   *\n   * This function returns signatures serialized as;\n   *\n   * - ECDSA signatures are serialized as big-endian r and s plus recovery-id\n   *    byte v, which can in general take any of the values 0, 1, 2, or 3.\n   *\n   * - EdDSA signatures are serialized in the standard format.\n   *\n   * - BLS signatures are not supported on the blob-sign endpoint.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signBlob(\n    req: BlobSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BlobSignResponse>> {\n    return await this.#apiClient.signBlob(this, req, mfaReceipt);\n  }\n\n  /**\n   * Perform a Diffie-Hellman exchange with one or more public keys.\n   *\n   * This requires the key to have a '\"AllowDiffieHellmanExchange\"' {@link KeyPolicy}.\n   * This is because performing arbitrary Diffie-Hellman exchanges using signing keys\n   * is, in general, dangerous. You should only use this API if you are 100% sure that\n   * you know what you're doing!\n   *\n   * @param points Up to 32 elliptic curve points with which to perform Diffie-Hellman exchanges. These points must be serialized in a key-type--specific format; see the CubeSigner documentation for more info.\n   * @param publicKey The NIST P-256 public key with which the responses will be encrypted. This should be the `publicKey` property of a value returned by `userExportKeygen`.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns The response. On success, the result can be decrypted with `diffieHellmanDecrypt`.\n   */\n  async diffieHellmanExchange(\n    points: Uint8Array[],\n    publicKey: CryptoKey,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<DiffieHellmanResponse>> {\n    if (points.length > 32) {\n      throw new Error(\"maximum 32 DH exchanges per request\");\n    }\n\n    // construct the request\n    const subtle = await loadSubtleCrypto();\n    const req: DiffieHellmanRequest = {\n      points: points.map((pt) => encodeToBase64(Buffer.from(pt))),\n      public_key: encodeToBase64(Buffer.from(await subtle.exportKey(\"raw\", publicKey))),\n    };\n\n    // send\n    return await this.#apiClient.diffieHellmanExchange(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin transaction.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signBtc(\n    req: BtcSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BtcSignResponse>> {\n    return await this.#apiClient.signBtc(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a PSBT.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response\n   */\n  async signPsbt(\n    req: PsbtSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<PsbtSignResponse>> {\n    return await this.#apiClient.signPsbt(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin message.\n   *\n   * @param req The message to sign\n   * @param opts Options for this request\n   * @param opts.p2sh If this is a segwit key and p2sh is true, sign as p2sh-p2wpkh instead of p2wpkh. Defaults to false if not specified.\n   * @param opts.metadata Optional arbitrary JSON metadata\n   * @param opts.mfaReceipt Optional MFA receipt(s)\n   * @returns The response\n   */\n  async signBtcMessage(\n    req: Uint8Array | string,\n    opts: { p2sh?: boolean; mfaReceipt?: MfaReceipts; metadata?: unknown },\n  ): Promise<CubeSignerResponse<BtcMessageSignResponse>> {\n    const request: BtcMessageSignRequest = {\n      data: encodeToHex(req),\n      is_p2sh: opts.p2sh ?? false,\n      metadata: opts.metadata,\n    };\n    return await this.#apiClient.signBtcMessage(this, request, opts.mfaReceipt);\n  }\n\n  /**\n   * Sign a Solana message.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signSolana(\n    req: SolanaSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SolanaSignResponse>> {\n    return await this.#apiClient.signSolana(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a SUI transaction.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signSui(\n    req: SuiSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SuiSignResponse>> {\n    return await this.#apiClient.signSui(this, req, mfaReceipt);\n  }\n\n  /**\n   * Update the key.\n   *\n   * @param request The JSON request to send to the API server.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The JSON response from the API server.\n   * @throws if MFA is required and no MFA receipts are provided\n   * @internal\n   */\n  private async update(request: UpdateKeyRequest, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    const resp = await this.#apiClient.keyUpdate(this.id, request, mfaReceipt);\n    this.cached = resp.data();\n    return this.cached;\n  }\n\n  /**\n   * Fetch the key information.\n   *\n   * @returns The key information.\n   * @internal\n   */\n  private async fetch(): Promise<KeyInfo> {\n    this.cached = await this.#apiClient.keyGet(this.id);\n    return this.cached;\n  }\n}\n\n/**\n * Convert a schema key type to a key type.\n *\n * @param ty The schema key type.\n * @returns The key type.\n * @internal\n */\nexport function fromSchemaKeyType(ty: SchemaKeyType): KeyType {\n  switch (ty) {\n    case \"SecpEthAddr\":\n      return Secp256k1.Evm;\n    case \"SecpCosmosAddr\":\n      return Secp256k1.Cosmos;\n    case \"SecpBtc\":\n      return Secp256k1.Btc;\n    case \"SecpBtcTest\":\n      return Secp256k1.BtcTest;\n    case \"SecpBtcLegacy\":\n      return Secp256k1.BtcLegacy;\n    case \"SecpBtcLegacyTest\":\n      return Secp256k1.BtcLegacyTest;\n    case \"SecpAvaAddr\":\n      return Secp256k1.Ava;\n    case \"SecpAvaTestAddr\":\n      return Secp256k1.AvaTest;\n    case \"BabylonEots\":\n      return Secp256k1.BabylonEots;\n    case \"BabylonCov\":\n      return Secp256k1.BabylonEots;\n    case \"TaprootBtc\":\n      return Secp256k1.Taproot;\n    case \"TaprootBtcTest\":\n      return Secp256k1.TaprootTest;\n    case \"SecpTronAddr\":\n      return Secp256k1.Tron;\n    case \"SecpDogeAddr\":\n      return Secp256k1.Doge;\n    case \"SecpDogeTestAddr\":\n      return Secp256k1.DogeTest;\n    case \"SecpKaspaAddr\":\n      return Secp256k1.Kaspa;\n    case \"SecpKaspaTestAddr\":\n      return Secp256k1.KaspaTest;\n    case \"SchnorrKaspaAddr\":\n      return Secp256k1.KaspaSchnorr;\n    case \"SchnorrKaspaTestAddr\":\n      return Secp256k1.KaspaTestSchnorr;\n    case \"BlsPub\":\n      return Bls.Eth2Deposited;\n    case \"BlsInactive\":\n      return Bls.Eth2Inactive;\n    case \"BlsAvaIcm\":\n      return Bls.AvaIcm;\n    case \"Ed25519SolanaAddr\":\n      return Ed25519.Solana;\n    case \"Ed25519SuiAddr\":\n      return Ed25519.Sui;\n    case \"Ed25519AptosAddr\":\n      return Ed25519.Aptos;\n    case \"Ed25519CardanoAddrVk\":\n      return Ed25519.Cardano;\n    case \"Ed25519StellarAddr\":\n      return Ed25519.Stellar;\n    case \"Ed25519SubstrateAddr\":\n      return Ed25519.Substrate;\n    case \"Ed25519TendermintAddr\":\n      return Ed25519.Tendermint;\n    case \"Ed25519TonAddr\":\n      return Ed25519.Ton;\n    case \"Stark\":\n      return Stark;\n    case \"Mnemonic\":\n      return Mnemonic;\n    case \"P256CosmosAddr\":\n      return P256.Cosmos;\n    case \"P256OntologyAddr\":\n      return P256.Ontology;\n    case \"P256Neo3Addr\":\n      return P256.Neo3;\n    case \"SecpLtc\":\n      return Secp256k1.Ltc;\n    case \"SecpLtcTest\":\n      return Secp256k1.LtcTest;\n    case \"SecpXrpAddr\":\n      return Secp256k1.Xrp;\n    case \"Ed25519XrpAddr\":\n      return Ed25519.Xrp;\n    case \"BabyJubjub\":\n      return BabyJubjub;\n    // NOTE: if you are adding a new key type, update the `create ${keyType} key` test in key.test.ts\n  }\n}\n"]}
|
|
647
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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","sourcesContent":["import type { KeyPolicy } from \"./role\";\nimport type { PageOpts } from \"./paginator\";\nimport type {\n  KeyInfo,\n  UpdateKeyRequest,\n  SchemaKeyType,\n  KeyInRoleInfo,\n  EvmSignRequest,\n  EvmSignResponse,\n  Eip191SignRequest,\n  Eip712SignRequest,\n  Eth2SignRequest,\n  Eth2UnstakeRequest,\n  AvaTx,\n  BlobSignRequest,\n  BtcSignRequest,\n  SolanaSignRequest,\n  SolanaSignResponse,\n  BtcMessageSignResponse,\n  BtcSignResponse,\n  BlobSignResponse,\n  AvaSignResponse,\n  Eth2UnstakeResponse,\n  Eth2SignResponse,\n  Eip191Or712SignResponse,\n  PsbtSignRequest,\n  PsbtSignResponse,\n  DiffieHellmanRequest,\n  DiffieHellmanResponse,\n} from \"./schema_types\";\nimport type {\n  ApiClient,\n  AvaChain,\n  BabylonRegistrationRequest,\n  BabylonRegistrationResponse,\n  BabylonStakingRequest,\n  BabylonStakingResponse,\n  BtcMessageSignRequest,\n  CubeSignerResponse,\n  EditPolicy,\n  Empty,\n  ErrResponse,\n  HistoricalTx,\n  JsonValue,\n  MfaReceipts,\n  SuiSignRequest,\n  SuiSignResponse,\n} from \".\";\nimport { CubeSignerClient, delay } from \".\";\nimport { loadSubtleCrypto } from \"./user_export\";\nimport { encodeToHex, encodeToBase64 } from \"./util\";\n\n/** Secp256k1 key type */\nexport enum Secp256k1 {\n  Evm = \"SecpEthAddr\",\n  Btc = \"SecpBtc\",\n  BtcTest = \"SecpBtcTest\",\n  Ltc = \"SecpLtc\",\n  LtcTest = \"SecpLtcTest\",\n  Xrp = \"SecpXrpAddr\",\n  Cosmos = \"SecpCosmosAddr\",\n  Taproot = \"TaprootBtc\",\n  TaprootTest = \"TaprootBtcTest\",\n  BabylonEots = \"BabylonEots\",\n  BabylonCov = \"BabylonCov\",\n  Ava = \"SecpAvaAddr\",\n  AvaTest = \"SecpAvaTestAddr\",\n  Tron = \"SecpTronAddr\",\n  BtcLegacy = \"SecpBtcLegacy\",\n  BtcLegacyTest = \"SecpBtcLegacyTest\",\n  Doge = \"SecpDogeAddr\",\n  DogeTest = \"SecpDogeTestAddr\",\n  Kaspa = \"SecpKaspaAddr\",\n  KaspaTest = \"SecpKaspaTestAddr\",\n  KaspaSchnorr = \"SchnorrKaspaAddr\",\n  KaspaTestSchnorr = \"SchnorrKaspaTestAddr\",\n}\n\n/** BLS key type */\nexport enum Bls {\n  Eth2Deposited = \"BlsPub\",\n  Eth2Inactive = \"BlsInactive\",\n  AvaIcm = \"BlsAvaIcm\",\n}\n\n/** Ed25519 key type */\nexport enum Ed25519 {\n  Solana = \"Ed25519SolanaAddr\",\n  Sui = \"Ed25519SuiAddr\",\n  Aptos = \"Ed25519AptosAddr\",\n  Cardano = \"Ed25519CardanoAddrVk\",\n  Stellar = \"Ed25519StellarAddr\",\n  Substrate = \"Ed25519SubstrateAddr\",\n  Tendermint = \"Ed25519TendermintAddr\",\n  Ton = \"Ed25519TonAddr\",\n  Xrp = \"Ed25519XrpAddr\",\n}\n\n/** P256 key type */\nexport enum P256 {\n  Cosmos = \"P256CosmosAddr\",\n  Ontology = \"P256OntologyAddr\",\n  Neo3 = \"P256Neo3Addr\",\n}\n\n/** Mnemonic key type */\nexport const Mnemonic = \"Mnemonic\" as const;\nexport type Mnemonic = typeof Mnemonic;\n\n/** Stark key type */\nexport const Stark = \"Stark\" as const;\nexport type Stark = typeof Stark;\n\n/** Baby Jubjub key type */\nexport const BabyJubjub = \"BabyJubjub\" as const;\nexport type BabyJubjub = typeof BabyJubjub;\n\n/** Key type */\nexport type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark | P256 | BabyJubjub;\n\n/**\n * A representation of a signing key.\n */\nexport class Key {\n  /** The CubeSigner instance that this key is associated with */\n  readonly #apiClient: ApiClient;\n\n  /** @returns The organization that this key is in */\n  get orgId() {\n    return this.#apiClient.sessionMeta.org_id;\n  }\n\n  /**\n   * The id of the key: \"Key#\" followed by a unique identifier specific to\n   * the type of key (such as a public key for BLS or an ethereum address for Secp)\n   *\n   * @example Key#0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   */\n  readonly id: string;\n\n  /**\n   * A unique identifier specific to the type of key, such as a public key or an ethereum address\n   *\n   * @example 0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   */\n  readonly materialId!: string;\n\n  /**\n   * @description Hex-encoded, serialized public key. The format used depends on the key type:\n   * - secp256k1 keys use 65-byte uncompressed SECG format\n   * - BLS keys use 48-byte compressed BLS12-381 (ZCash) format\n   * @example 0x04d2688b6bc2ce7f9879b9e745f3c4dc177908c5cef0c1b64cff19ae7ff27dee623c64fe9d9c325c7fbbc748bbd5f607ce14dd83e28ebbbb7d3e7f2ffb70a79431\n   */\n  readonly publicKey: string;\n\n  /**\n   * Get the cached properties of this key. The cached properties reflect the\n   * state of the last fetch or update (e.g., after awaiting `Key.enabled()`\n   * or `Key.disable()`).\n   */\n  cached: KeyInfo;\n\n  /** @returns The type of key. */\n  async type(): Promise<KeyType> {\n    const data = await this.fetch();\n    return fromSchemaKeyType(data.key_type);\n  }\n\n  /** @returns Whether the key is enabled */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /**\n   * Enable the key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async enable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: true }, mfaReceipt);\n  }\n\n  /**\n   * Disable the key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async disable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: false }, mfaReceipt);\n  }\n\n  /**\n   * List roles this key is in.\n   *\n   * @param page Optional pagination options; by default, retrieves all roles this key is in.\n   * @returns Roles this key is in.\n   */\n  async roles(page?: PageOpts): Promise<KeyInRoleInfo[]> {\n    return await this.#apiClient.keyRolesList(this.id, page).fetch();\n  }\n\n  /**\n   * List historical transactions for this key.\n   *\n   * @param page Optional pagination options; by default, retrieves all historical transactions for this key.\n   * @returns Historical key transactions.\n   */\n  async history(page?: PageOpts): Promise<HistoricalTx[]> {\n    return await this.#apiClient.keyHistory(this.id, page).fetch();\n  }\n\n  /**\n   * Set new policy (overwriting any policies previously set for this key)\n   *\n   * @param policy The new policy to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setPolicy(policy: KeyPolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ policy }, mfaReceipt);\n  }\n\n  /**\n   * Set new edit policy (overwriting any edit policies previously set for this key)\n   *\n   * @param editPolicy The new edit policy to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setEditPolicy(editPolicy: EditPolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ edit_policy: editPolicy }, mfaReceipt);\n  }\n\n  /**\n   * Set key metadata. The metadata must be at most 1024 characters\n   * and must match the following regex: ^[A-Za-z0-9_=+/ \\-\\.\\,]{0,1024}$.\n   *\n   * @param metadata The new metadata to set.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns The updated key info\n   */\n  async setMetadata(metadata: JsonValue, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    return await this.update({ metadata }, mfaReceipt);\n  }\n\n  /**\n   * Retrieves the existing metadata, asserts that it is an object (throws if it is not),\n   * then sets the value of the {@link name} property in that object to {@link value},\n   * and finally submits the request to update the metadata.\n   *\n   * This whole process is done atomically, meaning, that if the metadata changes between the\n   * time this method first retrieves it and the time it submits a request to update it, the\n   * request will be rejected. When that happens, this method will retry a few times, as per\n   * {@link ApiClient.config}.\n   *\n   * @param name The name of the property to set\n   * @param value The new value of the property\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   */\n  async setMetadataProperty(\n    name: string,\n    value: JsonValue,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(\n      name,\n      value,\n      this.#apiClient.config.updateRetryDelaysMs,\n      mfaReceipt,\n    );\n  }\n\n  /**\n   * Retrieves the existing metadata, asserts that it is in object (throws if it is not),\n   * then deletes the {@link name} property in that object, and finally submits the\n   * request to update the metadata.\n   *\n   * This whole process is done atomically, meaning, that if the metadata changes between the\n   * time this method first retrieves it and the time it submits a request to update it, the\n   * request will be rejected. When that happens, this method will retry a few times, as per\n   * {@link ApiClient.config}.\n   *\n   * @param name The name of the property to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   */\n  async deleteMetadataProperty(name: string, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(\n      name,\n      undefined,\n      this.#apiClient.config.updateRetryDelaysMs,\n      mfaReceipt,\n    );\n  }\n\n  /**\n   * @param name The name of the property to set\n   * @param value The new value of the property\n   * @param delaysMs Delays in milliseconds between retries\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   * @internal\n   */\n  async #setMetadataProperty(\n    name: string,\n    value: JsonValue | undefined,\n    delaysMs: number[],\n    mfaReceipt?: MfaReceipts,\n  ): Promise<KeyInfo> {\n    const data = await this.fetch();\n    const current = data.metadata ?? {};\n    if (typeof current !== \"object\") {\n      throw new Error(\"Current metadata is not a JSON object\");\n    }\n    const updated = {\n      ...current,\n      [name]: value,\n    };\n    try {\n      return await this.update(\n        {\n          metadata: updated,\n          version: data.version,\n        },\n        mfaReceipt,\n      );\n    } catch (e) {\n      if ((e as ErrResponse).errorCode === \"InvalidUpdate\" && delaysMs.length > 0) {\n        await delay(delaysMs[0]);\n        return await this.#setMetadataProperty(name, value, delaysMs.slice(1));\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  /**\n   * Append to existing key policy. This append is not atomic -- it uses {@link policy}\n   * to fetch the current policy and then {@link setPolicy} to set the policy -- and\n   * should not be used across concurrent sessions.\n   *\n   * @param policy The policy to append to the existing one.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   */\n  async appendPolicy(policy: KeyPolicy, mfaReceipt?: MfaReceipts) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy], mfaReceipt);\n  }\n\n  /**\n   * Get the policy for the key.\n   *\n   * @returns The policy for the key.\n   */\n  async policy(): Promise<KeyPolicy> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as KeyPolicy;\n  }\n\n  /**\n   * Get the edit policy for the key.\n   *\n   * @returns The edit policy for the key, undefined if there is no edit policy\n   */\n  async editPolicy(): Promise<EditPolicy | undefined> {\n    const data = await this.fetch();\n    return data.edit_policy;\n  }\n\n  /**\n   * Fetch the metadata for the key.\n   *\n   * @returns The policy for the key.\n   */\n  async metadata(): Promise<JsonValue> {\n    const data = await this.fetch();\n    return data.metadata as JsonValue;\n  }\n\n  /**\n   * @returns The user id for the owner of the key\n   * @example User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\n   */\n  async owner(): Promise<string> {\n    const data = await this.fetch();\n    return data.owner;\n  }\n\n  /**\n   * Set the owner of the key. Only the key (or org) owner can change the owner of the key.\n   *\n   * @param owner The user-id of the new owner of the key.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setOwner(owner: string, mfaReceipt?: MfaReceipts) {\n    await this.update({ owner }, mfaReceipt);\n  }\n\n  /**\n   * Delete this key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns A response which can be used to approve MFA if needed\n   */\n  async delete(mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<Empty>> {\n    return await this.#apiClient.keyDelete(this.id, mfaReceipt);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Create a new key.\n   *\n   * @param client The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(client: ApiClient | CubeSignerClient, data: KeyInfo) {\n    this.#apiClient = client instanceof CubeSignerClient ? client.apiClient : client;\n    this.id = data.key_id;\n    this.materialId = data.material_id;\n    this.publicKey = data.public_key;\n    this.cached = data;\n  }\n\n  /**\n   * Sign an EVM transaction.\n   *\n   * @param req What to sign.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Signature (or MFA approval request).\n   */\n  async signEvm(\n    req: EvmSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<EvmSignResponse>> {\n    return await this.#apiClient.signEvm(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Babylon staking transaction.\n   *\n   * @param req The staking transaction to sign\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Signature (or MFA approval request).\n   */\n  async signBabylonStakingTxn(\n    req: BabylonStakingRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BabylonStakingResponse>> {\n    return this.#apiClient.signBabylonStakingTxn(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Babylon registration.\n   *\n   * @param req The registration request to sign\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Babylon staking registration data (or MFA approval request).\n   */\n  async signBabylonRegistration(\n    req: BabylonRegistrationRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BabylonRegistrationResponse>> {\n    return this.#apiClient.signBabylonRegistration(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign EIP-191 typed data.\n   *\n   * This requires the key to have a '\"AllowEip191Signing\"' {@link KeyPolicy}.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature (or MFA approval request).\n   */\n  async signEip191(\n    req: Eip191SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    return await this.#apiClient.signEip191(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign EIP-712 typed data.\n   *\n   * This requires the key to have a '\"AllowEip712Signing\"' {@link KeyPolicy}.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature (or MFA approval request).\n   */\n  async signEip712(\n    req: Eip712SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    return await this.#apiClient.signEip712(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain validation message.\n   *\n   * @param req What to sign.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature\n   */\n  async signEth2(\n    req: Eth2SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2SignResponse>> {\n    return await this.#apiClient.signEth2(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain unstake/exit request.\n   *\n   * @param req The request to sign.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async unstake(\n    req: Eth2UnstakeRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2UnstakeResponse>> {\n    return await this.#apiClient.signUnstake(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Avalanche P- or X-chain message.\n   *\n   * @param tx Avalanche message (transaction) to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signAva(tx: AvaTx, mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<AvaSignResponse>> {\n    return await this.#apiClient.signAva(this, tx, mfaReceipt);\n  }\n\n  /**\n   * Sign a serialized Avalanche C-/X-/P-chain message.\n   *\n   * @param avaChain Avalanche chain\n   * @param tx Hex encoded transaction\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signSerializedAva(\n    avaChain: AvaChain,\n    tx: string,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<AvaSignResponse>> {\n    return await this.#apiClient.signSerializedAva(this, avaChain, tx, mfaReceipt);\n  }\n\n  /**\n   * Sign a raw blob.\n   *\n   * This requires the key to have a '\"AllowRawBlobSigning\"' {@link KeyPolicy}. This is because\n   * signing arbitrary messages is, in general, dangerous (and you should instead\n   * prefer typed end-points as used by, for example, {@link signEvm}). For Secp256k1 keys,\n   * for example, you **must** call this function with a message that is 32 bytes long and\n   * the output of a secure hash function.\n   *\n   * This function returns signatures serialized as;\n   *\n   * - ECDSA signatures are serialized as big-endian r and s plus recovery-id\n   *    byte v, which can in general take any of the values 0, 1, 2, or 3.\n   *\n   * - EdDSA signatures are serialized in the standard format.\n   *\n   * - BLS signatures are not supported on the blob-sign endpoint.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signBlob(\n    req: BlobSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BlobSignResponse>> {\n    return await this.#apiClient.signBlob(this, req, mfaReceipt);\n  }\n\n  /**\n   * Perform a Diffie-Hellman exchange with one or more public keys.\n   *\n   * This requires the key to have a '\"AllowDiffieHellmanExchange\"' {@link KeyPolicy}.\n   * This is because performing arbitrary Diffie-Hellman exchanges using signing keys\n   * is, in general, dangerous. You should only use this API if you are 100% sure that\n   * you know what you're doing!\n   *\n   * @param points Up to 32 elliptic curve points with which to perform Diffie-Hellman exchanges. These points must be serialized in a key-type--specific format; see the CubeSigner documentation for more info.\n   * @param publicKey The NIST P-256 public key with which the responses will be encrypted. This should be the `publicKey` property of a value returned by `userExportKeygen`.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns The response. On success, the result can be decrypted with `diffieHellmanDecrypt`.\n   */\n  async diffieHellmanExchange(\n    points: Uint8Array[],\n    publicKey: CryptoKey,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<DiffieHellmanResponse>> {\n    if (points.length > 32) {\n      throw new Error(\"maximum 32 DH exchanges per request\");\n    }\n\n    // construct the request\n    const subtle = await loadSubtleCrypto();\n    const req: DiffieHellmanRequest = {\n      points: points.map((pt) => encodeToBase64(Buffer.from(pt))),\n      public_key: encodeToBase64(Buffer.from(await subtle.exportKey(\"raw\", publicKey))),\n    };\n\n    // send\n    return await this.#apiClient.diffieHellmanExchange(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin transaction.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signBtc(\n    req: BtcSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BtcSignResponse>> {\n    return await this.#apiClient.signBtc(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a PSBT.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response\n   */\n  async signPsbt(\n    req: PsbtSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<PsbtSignResponse>> {\n    return await this.#apiClient.signPsbt(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin message.\n   *\n   * @param req The message to sign\n   * @param opts Options for this request\n   * @param opts.p2sh If this is a segwit key and p2sh is true, sign as p2sh-p2wpkh instead of p2wpkh. Defaults to false if not specified.\n   * @param opts.metadata Optional arbitrary JSON metadata\n   * @param opts.mfaReceipt Optional MFA receipt(s)\n   * @returns The response\n   */\n  async signBtcMessage(\n    req: Uint8Array | string,\n    opts: { p2sh?: boolean; mfaReceipt?: MfaReceipts; metadata?: unknown },\n  ): Promise<CubeSignerResponse<BtcMessageSignResponse>> {\n    const request: BtcMessageSignRequest = {\n      data: encodeToHex(req),\n      is_p2sh: opts.p2sh ?? false,\n      metadata: opts.metadata,\n    };\n    return await this.#apiClient.signBtcMessage(this, request, opts.mfaReceipt);\n  }\n\n  /**\n   * Sign a Solana message.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signSolana(\n    req: SolanaSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SolanaSignResponse>> {\n    return await this.#apiClient.signSolana(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a SUI transaction.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signSui(\n    req: SuiSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SuiSignResponse>> {\n    return await this.#apiClient.signSui(this, req, mfaReceipt);\n  }\n\n  /**\n   * Update the key.\n   *\n   * @param request The JSON request to send to the API server.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The JSON response from the API server.\n   * @throws if MFA is required and no MFA receipts are provided\n   * @internal\n   */\n  private async update(request: UpdateKeyRequest, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    const resp = await this.#apiClient.keyUpdate(this.id, request, mfaReceipt);\n    this.cached = resp.data();\n    return this.cached;\n  }\n\n  /**\n   * Fetch the key information.\n   *\n   * @returns The key information.\n   * @internal\n   */\n  private async fetch(): Promise<KeyInfo> {\n    this.cached = await this.#apiClient.keyGet(this.id);\n    return this.cached;\n  }\n}\n\n/**\n * Convert a schema key type to a key type.\n *\n * @param ty The schema key type.\n * @returns The key type.\n * @internal\n */\nexport function fromSchemaKeyType(ty: SchemaKeyType): KeyType {\n  switch (ty) {\n    case \"SecpEthAddr\":\n      return Secp256k1.Evm;\n    case \"SecpCosmosAddr\":\n      return Secp256k1.Cosmos;\n    case \"SecpBtc\":\n      return Secp256k1.Btc;\n    case \"SecpBtcTest\":\n      return Secp256k1.BtcTest;\n    case \"SecpBtcLegacy\":\n      return Secp256k1.BtcLegacy;\n    case \"SecpBtcLegacyTest\":\n      return Secp256k1.BtcLegacyTest;\n    case \"SecpAvaAddr\":\n      return Secp256k1.Ava;\n    case \"SecpAvaTestAddr\":\n      return Secp256k1.AvaTest;\n    case \"BabylonEots\":\n      return Secp256k1.BabylonEots;\n    case \"BabylonCov\":\n      return Secp256k1.BabylonEots;\n    case \"TaprootBtc\":\n      return Secp256k1.Taproot;\n    case \"TaprootBtcTest\":\n      return Secp256k1.TaprootTest;\n    case \"SecpTronAddr\":\n      return Secp256k1.Tron;\n    case \"SecpDogeAddr\":\n      return Secp256k1.Doge;\n    case \"SecpDogeTestAddr\":\n      return Secp256k1.DogeTest;\n    case \"SecpKaspaAddr\":\n      return Secp256k1.Kaspa;\n    case \"SecpKaspaTestAddr\":\n      return Secp256k1.KaspaTest;\n    case \"SchnorrKaspaAddr\":\n      return Secp256k1.KaspaSchnorr;\n    case \"SchnorrKaspaTestAddr\":\n      return Secp256k1.KaspaTestSchnorr;\n    case \"BlsPub\":\n      return Bls.Eth2Deposited;\n    case \"BlsInactive\":\n      return Bls.Eth2Inactive;\n    case \"BlsAvaIcm\":\n      return Bls.AvaIcm;\n    case \"Ed25519SolanaAddr\":\n      return Ed25519.Solana;\n    case \"Ed25519SuiAddr\":\n      return Ed25519.Sui;\n    case \"Ed25519AptosAddr\":\n      return Ed25519.Aptos;\n    case \"Ed25519CardanoAddrVk\":\n      return Ed25519.Cardano;\n    case \"Ed25519StellarAddr\":\n      return Ed25519.Stellar;\n    case \"Ed25519SubstrateAddr\":\n      return Ed25519.Substrate;\n    case \"Ed25519TendermintAddr\":\n      return Ed25519.Tendermint;\n    case \"Ed25519TonAddr\":\n      return Ed25519.Ton;\n    case \"Stark\":\n      return Stark;\n    case \"Mnemonic\":\n      return Mnemonic;\n    case \"P256CosmosAddr\":\n      return P256.Cosmos;\n    case \"P256OntologyAddr\":\n      return P256.Ontology;\n    case \"P256Neo3Addr\":\n      return P256.Neo3;\n    case \"SecpLtc\":\n      return Secp256k1.Ltc;\n    case \"SecpLtcTest\":\n      return Secp256k1.LtcTest;\n    case \"SecpXrpAddr\":\n      return Secp256k1.Xrp;\n    case \"Ed25519XrpAddr\":\n      return Ed25519.Xrp;\n    case \"BabyJubjub\":\n      return BabyJubjub;\n    // NOTE: if you are adding a new key type, update the `create ${keyType} key` test in key.test.ts\n  }\n}\n"]}
|
package/dist/src/role.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { ApiClient, ContractAddress, EvmTxCmp, SolanaTxCmp, KeyWithPoliciesInfo,
|
|
1
|
+
import type { ApiClient, ContractAddress, EvmTxCmp, SolanaTxCmp, KeyWithPoliciesInfo, PageOpts, RoleInfo, Scope, SessionData, SessionLifetime, BabylonStakingRequest, OperationKind, MfaReceipts, CubeSignerResponse, Empty, RestrictedActionsMap, GetRoleKeyOptions, EditPolicy, MfaPolicy } from ".";
|
|
2
2
|
import { Key, SignerSessionInfo } from ".";
|
|
3
3
|
type NameOrAddressOrNull = string | null;
|
|
4
4
|
/**
|
|
@@ -277,40 +277,6 @@ export type BtcSegwitValueLimitWindow = {
|
|
|
277
277
|
export type SourceIpAllowlist = {
|
|
278
278
|
SourceIpAllowlist: string[];
|
|
279
279
|
};
|
|
280
|
-
/**
|
|
281
|
-
* MFA policy
|
|
282
|
-
*
|
|
283
|
-
* @example {
|
|
284
|
-
* {
|
|
285
|
-
* count: 1,
|
|
286
|
-
* num_auth_factors: 1,
|
|
287
|
-
* allowed_mfa_types: [ "Totp" ],
|
|
288
|
-
* allowed_approvers: [ "User#123" ],
|
|
289
|
-
* }
|
|
290
|
-
*/
|
|
291
|
-
export type MfaPolicy = {
|
|
292
|
-
count?: number;
|
|
293
|
-
num_auth_factors?: number;
|
|
294
|
-
allowed_approvers?: string[];
|
|
295
|
-
allowed_mfa_types?: MfaType[];
|
|
296
|
-
restricted_operations?: OperationKind[];
|
|
297
|
-
/** Lifetime in seconds, defaults to 900 (15 minutes) */
|
|
298
|
-
lifetime?: number;
|
|
299
|
-
/**
|
|
300
|
-
* How to compare HTTP requests when verifying the MFA receipt.
|
|
301
|
-
* This specifies how we check equality between (1) the HTTP request when the 202 (MFA required)
|
|
302
|
-
* response is returned and (2) the HTTP request when the correspond MFA receipt is used.
|
|
303
|
-
*/
|
|
304
|
-
request_comparer?: HttpRequestComparer;
|
|
305
|
-
/**
|
|
306
|
-
* The amount of time in seconds before an MFA receipt can be redeemed.
|
|
307
|
-
* Defaults to 0, i.e., no delay. Approvers can vote to approve or veto
|
|
308
|
-
* before the delay expires. After approving, it is still possible for
|
|
309
|
-
* anyone to veto the request until the delay expires and the receipt
|
|
310
|
-
* is redeemed.
|
|
311
|
-
*/
|
|
312
|
-
time_delay?: number;
|
|
313
|
-
};
|
|
314
280
|
export type HttpRequestComparer = "Eq" | {
|
|
315
281
|
EvmTx: EvmTxCmp;
|
|
316
282
|
} | {
|
|
@@ -543,7 +509,7 @@ export declare class Role {
|
|
|
543
509
|
/**
|
|
544
510
|
* Append to existing role policy. This append is not atomic---it uses
|
|
545
511
|
* {@link policy} to fetch the current policy and then {@link setPolicy}
|
|
546
|
-
* to set the policy---and should not be used
|
|
512
|
+
* to set the policy---and should not be used across concurrent sessions.
|
|
547
513
|
*
|
|
548
514
|
* @param policy The policy to append to the existing one.
|
|
549
515
|
* @param mfaReceipt Optional MFA receipt(s)
|
|
@@ -556,6 +522,20 @@ export declare class Role {
|
|
|
556
522
|
* @returns The policy for the role.
|
|
557
523
|
*/
|
|
558
524
|
policy(): Promise<RolePolicy>;
|
|
525
|
+
/**
|
|
526
|
+
* Set new edit policy (overwriting any edit policies previously set for this role)
|
|
527
|
+
*
|
|
528
|
+
* @param editPolicy The new edit policy to set
|
|
529
|
+
* @param mfaReceipt Optional MFA receipt(s)
|
|
530
|
+
* @throws if MFA is required and no receipts are provided
|
|
531
|
+
*/
|
|
532
|
+
setEditPolicy(editPolicy: EditPolicy, mfaReceipt?: MfaReceipts): Promise<void>;
|
|
533
|
+
/**
|
|
534
|
+
* Get the edit policy for the role.
|
|
535
|
+
*
|
|
536
|
+
* @returns The edit policy for the role, undefined if there is no edit policy
|
|
537
|
+
*/
|
|
538
|
+
editPolicy(): Promise<EditPolicy | undefined>;
|
|
559
539
|
/**
|
|
560
540
|
* Sets the restricted actions on the role.
|
|
561
541
|
*
|
package/dist/src/role.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"role.d.ts","sourceRoot":"","sources":["../../src/role.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,SAAS,EACT,eAAe,EACf,QAAQ,EACR,WAAW,EACX,mBAAmB,EACnB,
|
|
1
|
+
{"version":3,"file":"role.d.ts","sourceRoot":"","sources":["../../src/role.ts"],"names":[],"mappings":"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"}
|
package/dist/src/role.js
CHANGED
|
@@ -136,7 +136,7 @@ class Role {
|
|
|
136
136
|
/**
|
|
137
137
|
* Append to existing role policy. This append is not atomic---it uses
|
|
138
138
|
* {@link policy} to fetch the current policy and then {@link setPolicy}
|
|
139
|
-
* to set the policy---and should not be used
|
|
139
|
+
* to set the policy---and should not be used across concurrent sessions.
|
|
140
140
|
*
|
|
141
141
|
* @param policy The policy to append to the existing one.
|
|
142
142
|
* @param mfaReceipt Optional MFA receipt(s)
|
|
@@ -155,6 +155,25 @@ class Role {
|
|
|
155
155
|
const data = await this.fetch();
|
|
156
156
|
return (data.policy ?? []);
|
|
157
157
|
}
|
|
158
|
+
/**
|
|
159
|
+
* Set new edit policy (overwriting any edit policies previously set for this role)
|
|
160
|
+
*
|
|
161
|
+
* @param editPolicy The new edit policy to set
|
|
162
|
+
* @param mfaReceipt Optional MFA receipt(s)
|
|
163
|
+
* @throws if MFA is required and no receipts are provided
|
|
164
|
+
*/
|
|
165
|
+
async setEditPolicy(editPolicy, mfaReceipt) {
|
|
166
|
+
await this.update({ edit_policy: editPolicy }, mfaReceipt);
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* Get the edit policy for the role.
|
|
170
|
+
*
|
|
171
|
+
* @returns The edit policy for the role, undefined if there is no edit policy
|
|
172
|
+
*/
|
|
173
|
+
async editPolicy() {
|
|
174
|
+
const data = await this.fetch();
|
|
175
|
+
return data.edit_policy;
|
|
176
|
+
}
|
|
158
177
|
/**
|
|
159
178
|
* Sets the restricted actions on the role.
|
|
160
179
|
*
|
|
@@ -324,4 +343,4 @@ class Role {
|
|
|
324
343
|
}
|
|
325
344
|
exports.Role = Role;
|
|
326
345
|
_Role_apiClient = new WeakMap(), _Role_data = new WeakMap();
|
|
327
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role.js","sourceRoot":"","sources":["../../src/role.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  ApiClient,\n  ContractAddress,\n  EvmTxCmp,\n  SolanaTxCmp,\n  KeyWithPoliciesInfo,\n  MfaType,\n  PageOpts,\n  RoleInfo,\n  Scope,\n  SessionData,\n  SessionLifetime,\n  UpdateRoleRequest,\n  BabylonStakingRequest,\n  OperationKind,\n  MfaReceipts,\n  CubeSignerResponse,\n  Empty,\n  RestrictedActionsMap,\n  GetRoleKeyOptions,\n} from \".\";\nimport { Key, SignerSessionInfo } from \".\";\n\ntype NameOrAddressOrNull = string | null;\n\n/**\n * Restrict the receiver for EVM transactions.\n *\n * @example { TxReceiver: \"0x8c594691c0e592ffa21f153a16ae41db5befcaaa\" }\n * @example { TxReceiver: null }\n * @example { TxReceiver: [null, \"0x8c594691c0e592ffa21f153a16ae41db5befcaaa\"] }\n */\nexport type TxReceiver = { TxReceiver: NameOrAddressOrNull | NameOrAddressOrNull[] };\n\n/**\n * Restrict the receiver for SUI transactions.\n *\n * @example { SuiTxReceiver: [ \"0xc9837a0ad2d11468bbf847e3af4e3ede837bcc02a1be6faee621df1a8a403cbf\" ] }\n */\nexport type SuiTxReceivers = { SuiTxReceivers: string[] };\n\n/**\n * Restrict the receiver for BTC transactions.\n *\n * @example { BtcTxReceivers: [ \"bc1q3qdavl37dnj6hjuazdzdxk0aanwjsg44mguq66\", \"bc1qfrjtxm8g20g97qzgadg7v9s3ftjkq02qfssk87\" ] }\n */\nexport type BtcTxReceivers = { BtcTxReceivers: string[] };\n\n/** The kind of deposit contracts. */\nexport enum DepositContract {\n  /** Canonical deposit contract */\n  Canonical,\n  /** Wrapper deposit contract */\n  Wrapper,\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/**\n * Restrict transaction values to amounts at or below the given limit in wei.\n * Currently, this only applies to EVM transactions.\n */\nexport type TxValueLimit = TxValueLimitPerTx | TxValueLimitWindow;\n\n/**\n * Restrict individual transaction values to amounts at or below the given limit in wei.\n * Currently, this only applies to EVM transactions.\n *\n * @example { TxValueLimit: \"0x12A05F200\" }\n */\nexport type TxValueLimitPerTx = { TxValueLimit: string };\n\n/**\n * Restrict transaction values, in wei, over a time window.\n * Currently, this only applies to EVM transactions.\n *\n * @example { TxValueLimit: { limit: \"0x12A05F200\", window: 86400 }}\n * @example { TxValueLimit: { limit: \"0x12A05F200\", window: 604800, chain_ids: [ \"1\", \"5\" ] }}\n * @example { TxValueLimit: { limit: \"0x12A05F200\", window: 604800, except_chain_ids: [ \"1\" ] }}\n */\nexport type TxValueLimitWindow = {\n  TxValueLimit: {\n    /**\n     * Max allowed value in wei\n     */\n    limit: string;\n    /**\n     * Optional sliding time window (in seconds).\n     *\n     * If specified, the `limit` applies to the aggregate value of all transactions within that\n     * time window; otherwise, the window is 0, i.e., the limit applies to individual transactions.\n     */\n    window?: number;\n    /**\n     * Optional chain ids.\n     *\n     * If specified, the policy applies only if a transaction is on one of the\n     * given chains (otherwise it applies to all transactions). If a 'window' is\n     * also defined, the policy limit applies cumulatively across all specified chains.\n     *\n     * Must not be specified together with `except_chain_ids`.\n     */\n    chain_ids?: string[];\n    /**\n     * Optional chain ids to exclude.\n     *\n     * If specified, the policy applies only if a transaction is on a chain id not\n     * included in this list. If a 'window' is also defined, the policy limit applies\n     * cumulatively across all chains other than the listed ones.\n     *\n     * Must not be specified together with `chain_ids`.\n     */\n    except_chain_ids?: string[];\n  };\n};\n\n/**\n * Restrict transaction max gas costs to amounts at or below the given limit in wei.\n *\n * @example { TxGasCostLimit: \"0x27CA57357C000\" }\n */\nexport type TxGasCostLimit = { TxGasCostLimit: string };\n\n/**\n * Restrict ERC-20 method calls according to the {@link Erc20Policy}.\n * Only applies to EVM transactions that call a valid ERC-20 method.\n * Non-ERC-20 transactions are ignored by this policy.\n *\n * @example { IfErc20Tx: { transfer_limits: [{ limit: \"0xE8D4A51000\" }] } }\n * @example { IfErc20Tx: { allowed_contracts: [ { address: \"0x0000000000000000000000034a20b809008afeb0\", \"chain_id\": \"1\" } ] } }\n */\nexport type IfErc20Tx = { IfErc20Tx: Erc20Policy };\n\n/**\n * Restrict transactions to only allow valid ERC-20 method calls.\n */\nexport type AssertErc20Tx = \"AssertErc20Tx\";\n\n/**\n * Restrict transactions to only allow native token transfers.\n */\nexport type AssertTransferOnlyTx = \"AssertTransferOnlyTx\";\n\n/**\n * Restrict ERC-20 `transfer` and `transferFrom` transaction values and receivers.\n * Only applies to contracts defined in `applies_to_contracts`,\n * or to all contracts if not defined.\n * The limit is in the token's unit.\n */\nexport type Erc20TransferLimit = {\n  limit?: string;\n  receivers?: string[];\n  applies_to_contracts?: ContractAddress[];\n};\n\n/**\n * Restrict ERC-20 `approve` transaction values and spenders.\n * Only applies to contracts defined in `applies_to_contracts`,\n * or to all contracts if not defined.\n * The limit is in the token's unit.\n */\nexport type Erc20ApproveLimit = {\n  limit?: string;\n  spenders?: string[];\n  applies_to_contracts?: ContractAddress[];\n};\n\n/**\n * Restricts ERC-20 policies to a set of known contracts,\n * and can define limits on `transfer`, `transferFrom` and `approve` method calls.\n */\nexport type Erc20Policy = {\n  allowed_contracts?: ContractAddress[];\n  transfer_limits?: Erc20TransferLimit[];\n  approve_limits?: Erc20ApproveLimit[];\n};\n\n/**\n * Restrict transactions to only allow calling the given methods in the given contracts.\n *\n * @example { AssertContractTx: {\n *   allowlist: [{\n *     address: { address: \"0x0000000000000000000000034a20b809008afeb0\", \"chain_id\": \"1\" },\n *     methods: [\n *       \"function name() public view returns (string)\",\n *       \"function transfer(address to, uint256 value) public returns (bool success)\"\n *     ]\n *   }]\n * }\n */\nexport type AssertContractTx = {\n  AssertContractTx: {\n    allowlist: {\n      address: ContractAddress;\n      methods: string[];\n    }[];\n  };\n};\n\n/**\n * Solana address matcher.\n * Can be either the pubkey of the account using base58 encoding,\n * or the index of the pubkey of an address lookup table and the\n * index of the account in that table.\n */\nexport type SolanaAddressMatcher =\n  | string\n  | {\n      alt_address: string;\n      index: number;\n    };\n\n/**\n * Solana instruction matcher.\n */\nexport type SolanaInstructionMatcher = {\n  program_id: string;\n  index?: number;\n  accounts?: (\n    | {\n        address: SolanaAddressMatcher | SolanaAddressMatcher[];\n      }\n    | ({\n        /** @deprecated use `address` instead. */\n        pubkey: string;\n      } & {\n        index: number;\n      })\n  )[];\n  data?:\n    | string\n    | {\n        data: string;\n        start_index: number;\n      }[];\n};\n\n/**\n * Restricts Solana transaction instructions. Can limit the number of instructions,\n * the list of allowed instructions, and a set of required instructions in all transactions.\n */\nexport type SolanaInstructionPolicy = {\n  SolanaInstructionPolicy: {\n    count?: {\n      min?: number;\n      max?: number;\n    };\n    allowlist?: SolanaInstructionMatcher[];\n    required?: SolanaInstructionMatcher[];\n  };\n};\n\n/**\n * Restrict the total value transferred out of the inputs in a Bitcoin Segwit transaction\n * to amounts at or below the given limit.\n */\nexport type BtcSegwitValueLimit = BtcSegwitValueLimitPerTx | BtcSegwitValueLimitWindow;\n\n/**\n * Restrict individual Bitcoin Segwit transaction values to amounts at or below\n * the given limit.\n *\n * @example { BtcSegwitValueLimit: \"1000000\" }\n */\nexport type BtcSegwitValueLimitPerTx = {\n  BtcSegwitValueLimit: number;\n};\n\n/**\n * Restrict the total value transferred out of the inputs in Bitcoin Segwit transactions\n * over a time window.\n *\n * @example { BtcSegwitValueLimit: { limit: \"1000000\", window: 86400 }}\n */\nexport type BtcSegwitValueLimitWindow = {\n  BtcSegwitValueLimit: {\n    limit: number;\n    window?: number;\n  };\n};\n\n/**\n * Only allow connections from clients whose IP addresses match any of these IPv4 CIDR blocks.\n *\n * @example { SourceIpAllowlist: [ \"123.456.78.9/16\" ] }\n */\nexport type SourceIpAllowlist = { SourceIpAllowlist: string[] };\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  /** Lifetime in seconds, defaults to 900 (15 minutes) */\n  lifetime?: number;\n  /**\n   * How to compare HTTP requests when verifying the MFA receipt.\n   * This specifies how we check equality between (1) the HTTP request when the 202 (MFA required)\n   * response is returned and (2) the HTTP request when the correspond MFA receipt is used.\n   */\n  request_comparer?: HttpRequestComparer;\n  /**\n   * The amount of time in seconds before an MFA receipt can be redeemed.\n   * Defaults to 0, i.e., no delay. Approvers can vote to approve or veto\n   * before the delay expires. After approving, it is still possible for\n   * anyone to veto the request until the delay expires and the receipt\n   * is redeemed.\n   */\n  time_delay?: number;\n};\n\nexport type HttpRequestComparer = \"Eq\" | { EvmTx: EvmTxCmp } | { SolanaTx: SolanaTxCmp };\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/**\n * Require that the key is accessed via a role session.\n *\n * @example { \"RequireRoleSession\": \"*\" }\n * @example { \"RequireRoleSession\": [\n *   \"Role#34dfb654-f36d-48ea-bdf6-833c0d94b759\",\n *   \"Role#98d87633-d1a7-4612-b6b4-b2fa2b43cd3d\"\n * ]}\n */\nexport type RequireRoleSession = {\n  /** Require either any role session or any one of the approved roles */\n  RequireRoleSession: \"*\" | string[];\n};\n\n/**\n * Forwards the request parameters to this webhook which determines\n * whether the request is allowed to be executed.\n */\nexport type WebhookPolicy = {\n  Webhook: {\n    /** The url of the webhook */\n    url: string;\n\n    /** Optional HTTP method to use. Defaults to POST. */\n    method?: string;\n\n    /** Optional HTTP headers to set */\n    headers?: Record<string, string>;\n\n    /**\n     * Request execution timeout in seconds; must be at least 1 not exceed 5 seconds.\n     * Defaults to 5.\n     */\n    timeout?: number;\n\n    /**\n     * CubeSigner operations to which this policy should apply.\n     * When omitted, applies to all operations.\n     */\n    restricted_operations?: OperationKind[];\n  };\n};\n\n/** Babylon staking policy */\nexport type BabylonStaking = {\n  BabylonStaking: {\n    /**\n     * Public keys that can be used for staking. Must be defined if the policy is being applied\n     * to a SegWit key; otherwise, if `undefined`, only the key to which the policy is being\n     * applied can be used as the staking public key when creating Babylon-related transactions.\n     *\n     * Hex-encoded public keys, WITHOUT the leading '0x'.\n     */\n    allowed_staker_pks?: string[];\n\n    /**\n     * Finality providers that can be used for staking. If `undefined`, any finality\n     * provider can be used.\n     *\n     * Hex-encoded public keys, WITHOUT the leading '0x'.\n     */\n    allowed_finality_provider_pks?: string[];\n\n    /**\n     * Change addresses that can be used in staking transactions. If `undefined`, only\n     * the key to which the policy is being applied can be used as the change address.\n     */\n    allowed_change_addrs?: string[];\n\n    /**\n     * Withdrawal addresses that can be used in withdrawal txns. If `undefined`, only\n     * the key to which the policy is being applied can be used as the withdrawal address.\n     */\n    allowed_withdrawal_addrs?: string[];\n\n    /** Babylon networks that this key can be used with. If `undefined`, any network. */\n    allowed_network_ids?: BabylonStakingRequest[\"network\"][];\n\n    /**\n     * Max fee allowed in a staking or withdrawal txn. If `undefined`, there is no fee limit.\n     * Note that the fee for voluntary unbonding and slashing are fixed by the Babylon\n     * params, and this limit is not enforced in those cases.\n     */\n    max_fee?: number;\n\n    /** Min staking time in seconds. If `undefined`, uses the limit defined by the Babylon staking params. */\n    min_lock_time?: number;\n\n    /** Max staking time in seconds. If `undefined`, uses the limit defined by the Babylon staking params. */\n    max_lock_time?: number;\n\n    /** Min staking amount in SAT. If `undefined`, uses the limit defined by the Babylon staking params. */\n    min_staking_value?: number;\n\n    /** Max staking amount in SAT. If `undefined`, uses the limit defined by the Babylon staking params. */\n    max_staking_value?: number;\n\n    /** Minimum network parameters version allowed. */\n    min_params_version?: number;\n\n    /** Maximum network parameters version allowed. */\n    max_params_version?: number;\n  };\n};\n\n/** Allow raw blob signing */\nexport const AllowRawBlobSigning = \"AllowRawBlobSigning\" as const;\nexport type AllowRawBlobSigning = typeof AllowRawBlobSigning;\n\n/** Allow Diffie-Hellman exchange */\nexport const AllowDiffieHellmanExchange = \"AllowDiffieHellmanExchange\" as const;\nexport type AllowDiffieHellmanExchange = typeof AllowDiffieHellmanExchange;\n\n/** Allow EIP-191 signing */\nexport const AllowEip191Signing = \"AllowEip191Signing\" as const;\nexport type AllowEip191Signing = typeof AllowEip191Signing;\n\n/** Allow EIP-712 signing */\nexport const AllowEip712Signing = \"AllowEip712Signing\" as const;\nexport type AllowEip712Signing = typeof AllowEip712Signing;\n\n/** Allow BTC message signing */\nexport const AllowBtcMessageSigning = \"AllowBtcMessageSigning\" as const;\nexport type AllowBtcMessageSigning = typeof AllowBtcMessageSigning;\n\n/** A reference to an org-level named policy and its version */\nexport type PolicyReference = `${string}/v${number}` | `${string}/latest`;\n\n/** Key policies that restrict the requests that the signing endpoints accept */\nexport type KeyDenyPolicy =\n  | TxReceiver\n  | TxDeposit\n  | TxValueLimit\n  | TxGasCostLimit\n  | IfErc20Tx\n  | AssertErc20Tx\n  | AssertTransferOnlyTx\n  | AssertContractTx\n  | SuiTxReceivers\n  | BtcTxReceivers\n  | SourceIpAllowlist\n  | SolanaInstructionPolicy\n  | BtcSegwitValueLimit\n  | RequireMfa\n  | RequireRoleSession\n  | BabylonStaking\n  | WebhookPolicy;\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 *\n * @example [\"AssertErc20Tx\", { \"IfErc20Tx\": \"transfer_limits\": [ { \"limit\": \"0x3B9ACA00\" } ] }]\n */\nexport type KeyPolicy = KeyPolicyRule[];\n\nexport type KeyPolicyRule =\n  | KeyDenyPolicy\n  | AllowRawBlobSigning\n  | AllowDiffieHellmanExchange\n  | AllowEip191Signing\n  | AllowEip712Signing\n  | AllowBtcMessageSigning\n  | PolicyReference;\n\n/** Role policy */\nexport type RolePolicy = RolePolicyRule[];\n\nexport type RolePolicyRule = KeyDenyPolicy | PolicyReference;\n\n/** A key guarded by a policy. */\nexport class KeyWithPolicies {\n  readonly #apiClient: ApiClient;\n  readonly roleId: string;\n  readonly keyId: string;\n  /** The cached properties of this key/policies */\n  #cached: KeyWithPoliciesInfo;\n\n  /** @returns The cached information */\n  get cached(): KeyWithPoliciesInfo {\n    return this.#cached;\n  }\n\n  /** @returns The cached policy */\n  get policy(): KeyPolicy | undefined {\n    return this.cached.policy as KeyPolicy | undefined;\n  }\n\n  /** @returns The key */\n  async getKey(): Promise<Key> {\n    if (this.#cached.key_info === undefined || this.#cached.key_info === null) {\n      this.#cached = await this.#apiClient.roleKeyGet(this.roleId, this.keyId, { details: true });\n    }\n    return new Key(this.#apiClient, this.#cached.key_info!);\n  }\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param keyWithPolicies The key and its policies\n   * @internal\n   */\n  constructor(apiClient: ApiClient, keyWithPolicies: KeyWithPoliciesInfo) {\n    this.#apiClient = apiClient;\n    this.roleId = keyWithPolicies.role_id;\n    this.keyId = keyWithPolicies.key_id;\n    this.#cached = keyWithPolicies;\n  }\n}\n\n/** Roles. */\nexport class Role {\n  readonly #apiClient: ApiClient;\n  /** The role information */\n  #data: RoleInfo;\n\n  /** @returns Human-readable name for the role */\n  get name(): string | undefined {\n    return this.#data.name ?? undefined;\n  }\n\n  /**\n   * @returns The ID of the role.\n   *\n   * @example Role#bfe3eccb-731e-430d-b1e5-ac1363e6b06b\n   */\n  get id(): string {\n    return this.#data.role_id;\n  }\n\n  /**\n   * @returns the cached properties of this role. The cached properties\n   * reflect the state of the last fetch or update (e.g., after awaiting\n   * `Role.enabled()` or `Role.disable()`).\n   */\n  get cached(): RoleInfo {\n    return this.#data;\n  }\n\n  /**\n   * Delete the role.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   * @returns A response which can be used to approve MFA if needed\n   */\n  async delete(mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<Empty>> {\n    return await this.#apiClient.roleDelete(this.id, mfaReceipt);\n  }\n\n  /** @returns Whether the role is enabled */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /**\n   * Enable the role.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   */\n  async enable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: true }, mfaReceipt);\n  }\n\n  /**\n   * Disable the role.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   */\n  async disable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: false }, mfaReceipt);\n  }\n\n  /**\n   * Set new policy (overwriting any policies previously set for this role)\n   *\n   * @param policy The new policy to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   */\n  async setPolicy(policy: RolePolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ policy }, mfaReceipt);\n  }\n\n  /**\n   * Append to existing role policy. This append is not atomic---it uses\n   * {@link policy} to fetch the current policy and then {@link setPolicy}\n   * to set the policy---and should not be used in across concurrent sessions.\n   *\n   * @param policy The policy to append to the existing one.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   */\n  async appendPolicy(policy: RolePolicy, mfaReceipt?: MfaReceipts) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy], mfaReceipt);\n  }\n\n  /**\n   * Get the policy for the role.\n   *\n   * @returns The policy for the role.\n   */\n  async policy(): Promise<RolePolicy> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as RolePolicy;\n  }\n\n  /**\n   * Sets the restricted actions on the role.\n   *\n   * @param restrictedActions The map of restricted actions\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   */\n  async setRestrictedActions(restrictedActions: RestrictedActionsMap, mfaReceipt?: MfaReceipts) {\n    const restricted_actions = Object.fromEntries(\n      Object.entries(restrictedActions).map(([key, value]) => [key.toString(), value]),\n    );\n\n    await this.update({ restricted_actions }, mfaReceipt);\n  }\n\n  /**\n   * @returns The list of all users with access to the role.\n   *\n   * @example [\n   *   \"User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\",\n   *   \"User#5593c25b-52e2-4fb5-b39b-96d41d681d82\"\n   * ]\n   *\n   * @param page Optional pagination options; by default, retrieves all users.\n   */\n  async users(page?: PageOpts): Promise<string[]> {\n    const users = await this.#apiClient.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 userId The user-id of the user to add to the role.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns an empty response, or a response that can be used to approve MFA if needed.\n   */\n  async addUser(userId: string, mfaReceipt?: MfaReceipts) {\n    return await this.#apiClient.roleUserAdd(this.id, userId, mfaReceipt);\n  }\n\n  /**\n   * Remove an existing user from an existing role.\n   *\n   * @param userId The user-id of the user to remove from the role.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns an empty response, or a response that can be used to approve MFA if needed.\n   */\n  async removeUser(userId: string, mfaReceipt?: MfaReceipts) {\n    return await this.#apiClient.roleUserRemove(this.id, userId, mfaReceipt);\n  }\n\n  /**\n   * @returns The list of keys in the role.\n   *\n   * @example [\n   *    {\n   *     id: \"Key#bfe3eccb-731e-430d-b1e5-ac1363e6b06b\",\n   *     policy: { TxReceiver: \"0x8c594691c0e592ffa21f153a16ae41db5befcaaa\" }\n   *    },\n   *  ]\n   *\n   * @param 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.#apiClient.roleKeysList(this.id, page).fetch();\n    return keysInRole.map((k) => new KeyWithPolicies(this.#apiClient, k));\n  }\n\n  /**\n   * Get a key in the role by its ID.\n   *\n   * @param keyId The ID of the key to get.\n   * @param opts Optional options for getting the key.\n   * @returns The key with its policies.\n   */\n  async getKey(keyId: string, opts?: GetRoleKeyOptions): Promise<KeyWithPolicies> {\n    const kwp = await this.#apiClient.roleKeyGet(this.id, keyId, opts);\n    return new KeyWithPolicies(this.#apiClient, kwp);\n  }\n\n  /**\n   * Add a list of existing keys to an existing role.\n   *\n   * @param keys The list of keys to add to the role.\n   * @param policy The optional policy to apply to each key.\n   *\n   * @returns A CubeSigner response indicating success or failure.\n   */\n  async addKeys(keys: Key[], policy?: KeyPolicy): Promise<CubeSignerResponse<Empty>> {\n    return await this.#apiClient.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 The key to add to the role.\n   * @param policy The optional policy to apply to the key.\n   *\n   * @returns A CubeSigner response indicating success or failure.\n   */\n  async addKey(key: Key, policy?: KeyPolicy): Promise<CubeSignerResponse<Empty>> {\n    return await this.addKeys([key], policy);\n  }\n\n  /**\n   * Remove an existing key from an existing role.\n   *\n   * @param key The key to remove from the role.\n   *\n   * @returns A CubeSigner response indicating success or failure.\n   */\n  async removeKey(key: Key): Promise<CubeSignerResponse<Empty>> {\n    return await this.#apiClient.roleKeysRemove(this.id, key.id);\n  }\n\n  /**\n   * Create a new session for this role.\n   *\n   * @param purpose Descriptive purpose.\n   * @param lifetimes Optional session lifetimes.\n   * @param scopes Session scopes. Only `sign:*` scopes are allowed.\n   * @returns New session.\n   */\n  async createSession(\n    purpose: string,\n    lifetimes?: SessionLifetime,\n    scopes?: Scope[],\n  ): Promise<SessionData> {\n    return await this.#apiClient.sessionCreateForRole(this.id, purpose, scopes, lifetimes);\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 page Optional pagination options; by default, retrieves all sessions.\n   * @returns Signer sessions for this role.\n   */\n  async sessions(page?: PageOpts): Promise<SignerSessionInfo[]> {\n    const sessions = await this.#apiClient.sessionsList({ role: this.id }, page).fetch();\n    return sessions.map((t) => new SignerSessionInfo(this.#apiClient, t.session_id, t.purpose));\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(apiClient: ApiClient, data: RoleInfo) {\n    this.#apiClient = apiClient;\n    this.#data = data;\n  }\n\n  /**\n   * Update the role.\n   *\n   * @param request The JSON request to send to the API server.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   * @returns The updated role information.\n   */\n  private async update(request: UpdateRoleRequest, mfaReceipt?: MfaReceipts): Promise<RoleInfo> {\n    const resp = await this.#apiClient.roleUpdate(this.id, request, mfaReceipt);\n    this.#data = resp.data();\n    return this.#data;\n  }\n\n  /**\n   * Fetches the role information.\n   *\n   * @returns The role information.\n   * @internal\n   */\n  private async fetch(): Promise<RoleInfo> {\n    this.#data = await this.#apiClient.roleGet(this.id);\n    return this.#data;\n  }\n}\n"]}
|
|
346
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role.js","sourceRoot":"","sources":["../../src/role.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  ApiClient,\n  ContractAddress,\n  EvmTxCmp,\n  SolanaTxCmp,\n  KeyWithPoliciesInfo,\n  PageOpts,\n  RoleInfo,\n  Scope,\n  SessionData,\n  SessionLifetime,\n  UpdateRoleRequest,\n  BabylonStakingRequest,\n  OperationKind,\n  MfaReceipts,\n  CubeSignerResponse,\n  Empty,\n  RestrictedActionsMap,\n  GetRoleKeyOptions,\n  EditPolicy,\n  MfaPolicy,\n} from \".\";\nimport { Key, SignerSessionInfo } from \".\";\n\ntype NameOrAddressOrNull = string | null;\n\n/**\n * Restrict the receiver for EVM transactions.\n *\n * @example { TxReceiver: \"0x8c594691c0e592ffa21f153a16ae41db5befcaaa\" }\n * @example { TxReceiver: null }\n * @example { TxReceiver: [null, \"0x8c594691c0e592ffa21f153a16ae41db5befcaaa\"] }\n */\nexport type TxReceiver = { TxReceiver: NameOrAddressOrNull | NameOrAddressOrNull[] };\n\n/**\n * Restrict the receiver for SUI transactions.\n *\n * @example { SuiTxReceiver: [ \"0xc9837a0ad2d11468bbf847e3af4e3ede837bcc02a1be6faee621df1a8a403cbf\" ] }\n */\nexport type SuiTxReceivers = { SuiTxReceivers: string[] };\n\n/**\n * Restrict the receiver for BTC transactions.\n *\n * @example { BtcTxReceivers: [ \"bc1q3qdavl37dnj6hjuazdzdxk0aanwjsg44mguq66\", \"bc1qfrjtxm8g20g97qzgadg7v9s3ftjkq02qfssk87\" ] }\n */\nexport type BtcTxReceivers = { BtcTxReceivers: string[] };\n\n/** The kind of deposit contracts. */\nexport enum DepositContract {\n  /** Canonical deposit contract */\n  Canonical,\n  /** Wrapper deposit contract */\n  Wrapper,\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/**\n * Restrict transaction values to amounts at or below the given limit in wei.\n * Currently, this only applies to EVM transactions.\n */\nexport type TxValueLimit = TxValueLimitPerTx | TxValueLimitWindow;\n\n/**\n * Restrict individual transaction values to amounts at or below the given limit in wei.\n * Currently, this only applies to EVM transactions.\n *\n * @example { TxValueLimit: \"0x12A05F200\" }\n */\nexport type TxValueLimitPerTx = { TxValueLimit: string };\n\n/**\n * Restrict transaction values, in wei, over a time window.\n * Currently, this only applies to EVM transactions.\n *\n * @example { TxValueLimit: { limit: \"0x12A05F200\", window: 86400 }}\n * @example { TxValueLimit: { limit: \"0x12A05F200\", window: 604800, chain_ids: [ \"1\", \"5\" ] }}\n * @example { TxValueLimit: { limit: \"0x12A05F200\", window: 604800, except_chain_ids: [ \"1\" ] }}\n */\nexport type TxValueLimitWindow = {\n  TxValueLimit: {\n    /**\n     * Max allowed value in wei\n     */\n    limit: string;\n    /**\n     * Optional sliding time window (in seconds).\n     *\n     * If specified, the `limit` applies to the aggregate value of all transactions within that\n     * time window; otherwise, the window is 0, i.e., the limit applies to individual transactions.\n     */\n    window?: number;\n    /**\n     * Optional chain ids.\n     *\n     * If specified, the policy applies only if a transaction is on one of the\n     * given chains (otherwise it applies to all transactions). If a 'window' is\n     * also defined, the policy limit applies cumulatively across all specified chains.\n     *\n     * Must not be specified together with `except_chain_ids`.\n     */\n    chain_ids?: string[];\n    /**\n     * Optional chain ids to exclude.\n     *\n     * If specified, the policy applies only if a transaction is on a chain id not\n     * included in this list. If a 'window' is also defined, the policy limit applies\n     * cumulatively across all chains other than the listed ones.\n     *\n     * Must not be specified together with `chain_ids`.\n     */\n    except_chain_ids?: string[];\n  };\n};\n\n/**\n * Restrict transaction max gas costs to amounts at or below the given limit in wei.\n *\n * @example { TxGasCostLimit: \"0x27CA57357C000\" }\n */\nexport type TxGasCostLimit = { TxGasCostLimit: string };\n\n/**\n * Restrict ERC-20 method calls according to the {@link Erc20Policy}.\n * Only applies to EVM transactions that call a valid ERC-20 method.\n * Non-ERC-20 transactions are ignored by this policy.\n *\n * @example { IfErc20Tx: { transfer_limits: [{ limit: \"0xE8D4A51000\" }] } }\n * @example { IfErc20Tx: { allowed_contracts: [ { address: \"0x0000000000000000000000034a20b809008afeb0\", \"chain_id\": \"1\" } ] } }\n */\nexport type IfErc20Tx = { IfErc20Tx: Erc20Policy };\n\n/**\n * Restrict transactions to only allow valid ERC-20 method calls.\n */\nexport type AssertErc20Tx = \"AssertErc20Tx\";\n\n/**\n * Restrict transactions to only allow native token transfers.\n */\nexport type AssertTransferOnlyTx = \"AssertTransferOnlyTx\";\n\n/**\n * Restrict ERC-20 `transfer` and `transferFrom` transaction values and receivers.\n * Only applies to contracts defined in `applies_to_contracts`,\n * or to all contracts if not defined.\n * The limit is in the token's unit.\n */\nexport type Erc20TransferLimit = {\n  limit?: string;\n  receivers?: string[];\n  applies_to_contracts?: ContractAddress[];\n};\n\n/**\n * Restrict ERC-20 `approve` transaction values and spenders.\n * Only applies to contracts defined in `applies_to_contracts`,\n * or to all contracts if not defined.\n * The limit is in the token's unit.\n */\nexport type Erc20ApproveLimit = {\n  limit?: string;\n  spenders?: string[];\n  applies_to_contracts?: ContractAddress[];\n};\n\n/**\n * Restricts ERC-20 policies to a set of known contracts,\n * and can define limits on `transfer`, `transferFrom` and `approve` method calls.\n */\nexport type Erc20Policy = {\n  allowed_contracts?: ContractAddress[];\n  transfer_limits?: Erc20TransferLimit[];\n  approve_limits?: Erc20ApproveLimit[];\n};\n\n/**\n * Restrict transactions to only allow calling the given methods in the given contracts.\n *\n * @example { AssertContractTx: {\n *   allowlist: [{\n *     address: { address: \"0x0000000000000000000000034a20b809008afeb0\", \"chain_id\": \"1\" },\n *     methods: [\n *       \"function name() public view returns (string)\",\n *       \"function transfer(address to, uint256 value) public returns (bool success)\"\n *     ]\n *   }]\n * }\n */\nexport type AssertContractTx = {\n  AssertContractTx: {\n    allowlist: {\n      address: ContractAddress;\n      methods: string[];\n    }[];\n  };\n};\n\n/**\n * Solana address matcher.\n * Can be either the pubkey of the account using base58 encoding,\n * or the index of the pubkey of an address lookup table and the\n * index of the account in that table.\n */\nexport type SolanaAddressMatcher =\n  | string\n  | {\n      alt_address: string;\n      index: number;\n    };\n\n/**\n * Solana instruction matcher.\n */\nexport type SolanaInstructionMatcher = {\n  program_id: string;\n  index?: number;\n  accounts?: (\n    | {\n        address: SolanaAddressMatcher | SolanaAddressMatcher[];\n      }\n    | ({\n        /** @deprecated use `address` instead. */\n        pubkey: string;\n      } & {\n        index: number;\n      })\n  )[];\n  data?:\n    | string\n    | {\n        data: string;\n        start_index: number;\n      }[];\n};\n\n/**\n * Restricts Solana transaction instructions. Can limit the number of instructions,\n * the list of allowed instructions, and a set of required instructions in all transactions.\n */\nexport type SolanaInstructionPolicy = {\n  SolanaInstructionPolicy: {\n    count?: {\n      min?: number;\n      max?: number;\n    };\n    allowlist?: SolanaInstructionMatcher[];\n    required?: SolanaInstructionMatcher[];\n  };\n};\n\n/**\n * Restrict the total value transferred out of the inputs in a Bitcoin Segwit transaction\n * to amounts at or below the given limit.\n */\nexport type BtcSegwitValueLimit = BtcSegwitValueLimitPerTx | BtcSegwitValueLimitWindow;\n\n/**\n * Restrict individual Bitcoin Segwit transaction values to amounts at or below\n * the given limit.\n *\n * @example { BtcSegwitValueLimit: \"1000000\" }\n */\nexport type BtcSegwitValueLimitPerTx = {\n  BtcSegwitValueLimit: number;\n};\n\n/**\n * Restrict the total value transferred out of the inputs in Bitcoin Segwit transactions\n * over a time window.\n *\n * @example { BtcSegwitValueLimit: { limit: \"1000000\", window: 86400 }}\n */\nexport type BtcSegwitValueLimitWindow = {\n  BtcSegwitValueLimit: {\n    limit: number;\n    window?: number;\n  };\n};\n\n/**\n * Only allow connections from clients whose IP addresses match any of these IPv4 CIDR blocks.\n *\n * @example { SourceIpAllowlist: [ \"123.456.78.9/16\" ] }\n */\nexport type SourceIpAllowlist = { SourceIpAllowlist: string[] };\n\nexport type HttpRequestComparer = \"Eq\" | { EvmTx: EvmTxCmp } | { SolanaTx: SolanaTxCmp };\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/**\n * Require that the key is accessed via a role session.\n *\n * @example { \"RequireRoleSession\": \"*\" }\n * @example { \"RequireRoleSession\": [\n *   \"Role#34dfb654-f36d-48ea-bdf6-833c0d94b759\",\n *   \"Role#98d87633-d1a7-4612-b6b4-b2fa2b43cd3d\"\n * ]}\n */\nexport type RequireRoleSession = {\n  /** Require either any role session or any one of the approved roles */\n  RequireRoleSession: \"*\" | string[];\n};\n\n/**\n * Forwards the request parameters to this webhook which determines\n * whether the request is allowed to be executed.\n */\nexport type WebhookPolicy = {\n  Webhook: {\n    /** The url of the webhook */\n    url: string;\n\n    /** Optional HTTP method to use. Defaults to POST. */\n    method?: string;\n\n    /** Optional HTTP headers to set */\n    headers?: Record<string, string>;\n\n    /**\n     * Request execution timeout in seconds; must be at least 1 not exceed 5 seconds.\n     * Defaults to 5.\n     */\n    timeout?: number;\n\n    /**\n     * CubeSigner operations to which this policy should apply.\n     * When omitted, applies to all operations.\n     */\n    restricted_operations?: OperationKind[];\n  };\n};\n\n/** Babylon staking policy */\nexport type BabylonStaking = {\n  BabylonStaking: {\n    /**\n     * Public keys that can be used for staking. Must be defined if the policy is being applied\n     * to a SegWit key; otherwise, if `undefined`, only the key to which the policy is being\n     * applied can be used as the staking public key when creating Babylon-related transactions.\n     *\n     * Hex-encoded public keys, WITHOUT the leading '0x'.\n     */\n    allowed_staker_pks?: string[];\n\n    /**\n     * Finality providers that can be used for staking. If `undefined`, any finality\n     * provider can be used.\n     *\n     * Hex-encoded public keys, WITHOUT the leading '0x'.\n     */\n    allowed_finality_provider_pks?: string[];\n\n    /**\n     * Change addresses that can be used in staking transactions. If `undefined`, only\n     * the key to which the policy is being applied can be used as the change address.\n     */\n    allowed_change_addrs?: string[];\n\n    /**\n     * Withdrawal addresses that can be used in withdrawal txns. If `undefined`, only\n     * the key to which the policy is being applied can be used as the withdrawal address.\n     */\n    allowed_withdrawal_addrs?: string[];\n\n    /** Babylon networks that this key can be used with. If `undefined`, any network. */\n    allowed_network_ids?: BabylonStakingRequest[\"network\"][];\n\n    /**\n     * Max fee allowed in a staking or withdrawal txn. If `undefined`, there is no fee limit.\n     * Note that the fee for voluntary unbonding and slashing are fixed by the Babylon\n     * params, and this limit is not enforced in those cases.\n     */\n    max_fee?: number;\n\n    /** Min staking time in seconds. If `undefined`, uses the limit defined by the Babylon staking params. */\n    min_lock_time?: number;\n\n    /** Max staking time in seconds. If `undefined`, uses the limit defined by the Babylon staking params. */\n    max_lock_time?: number;\n\n    /** Min staking amount in SAT. If `undefined`, uses the limit defined by the Babylon staking params. */\n    min_staking_value?: number;\n\n    /** Max staking amount in SAT. If `undefined`, uses the limit defined by the Babylon staking params. */\n    max_staking_value?: number;\n\n    /** Minimum network parameters version allowed. */\n    min_params_version?: number;\n\n    /** Maximum network parameters version allowed. */\n    max_params_version?: number;\n  };\n};\n\n/** Allow raw blob signing */\nexport const AllowRawBlobSigning = \"AllowRawBlobSigning\" as const;\nexport type AllowRawBlobSigning = typeof AllowRawBlobSigning;\n\n/** Allow Diffie-Hellman exchange */\nexport const AllowDiffieHellmanExchange = \"AllowDiffieHellmanExchange\" as const;\nexport type AllowDiffieHellmanExchange = typeof AllowDiffieHellmanExchange;\n\n/** Allow EIP-191 signing */\nexport const AllowEip191Signing = \"AllowEip191Signing\" as const;\nexport type AllowEip191Signing = typeof AllowEip191Signing;\n\n/** Allow EIP-712 signing */\nexport const AllowEip712Signing = \"AllowEip712Signing\" as const;\nexport type AllowEip712Signing = typeof AllowEip712Signing;\n\n/** Allow BTC message signing */\nexport const AllowBtcMessageSigning = \"AllowBtcMessageSigning\" as const;\nexport type AllowBtcMessageSigning = typeof AllowBtcMessageSigning;\n\n/** A reference to an org-level named policy and its version */\nexport type PolicyReference = `${string}/v${number}` | `${string}/latest`;\n\n/** Key policies that restrict the requests that the signing endpoints accept */\nexport type KeyDenyPolicy =\n  | TxReceiver\n  | TxDeposit\n  | TxValueLimit\n  | TxGasCostLimit\n  | IfErc20Tx\n  | AssertErc20Tx\n  | AssertTransferOnlyTx\n  | AssertContractTx\n  | SuiTxReceivers\n  | BtcTxReceivers\n  | SourceIpAllowlist\n  | SolanaInstructionPolicy\n  | BtcSegwitValueLimit\n  | RequireMfa\n  | RequireRoleSession\n  | BabylonStaking\n  | WebhookPolicy;\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 *\n * @example [\"AssertErc20Tx\", { \"IfErc20Tx\": \"transfer_limits\": [ { \"limit\": \"0x3B9ACA00\" } ] }]\n */\nexport type KeyPolicy = KeyPolicyRule[];\n\nexport type KeyPolicyRule =\n  | KeyDenyPolicy\n  | AllowRawBlobSigning\n  | AllowDiffieHellmanExchange\n  | AllowEip191Signing\n  | AllowEip712Signing\n  | AllowBtcMessageSigning\n  | PolicyReference;\n\n/** Role policy */\nexport type RolePolicy = RolePolicyRule[];\n\nexport type RolePolicyRule = KeyDenyPolicy | PolicyReference;\n\n/** A key guarded by a policy. */\nexport class KeyWithPolicies {\n  readonly #apiClient: ApiClient;\n  readonly roleId: string;\n  readonly keyId: string;\n  /** The cached properties of this key/policies */\n  #cached: KeyWithPoliciesInfo;\n\n  /** @returns The cached information */\n  get cached(): KeyWithPoliciesInfo {\n    return this.#cached;\n  }\n\n  /** @returns The cached policy */\n  get policy(): KeyPolicy | undefined {\n    return this.cached.policy as KeyPolicy | undefined;\n  }\n\n  /** @returns The key */\n  async getKey(): Promise<Key> {\n    if (this.#cached.key_info === undefined || this.#cached.key_info === null) {\n      this.#cached = await this.#apiClient.roleKeyGet(this.roleId, this.keyId, { details: true });\n    }\n    return new Key(this.#apiClient, this.#cached.key_info!);\n  }\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param keyWithPolicies The key and its policies\n   * @internal\n   */\n  constructor(apiClient: ApiClient, keyWithPolicies: KeyWithPoliciesInfo) {\n    this.#apiClient = apiClient;\n    this.roleId = keyWithPolicies.role_id;\n    this.keyId = keyWithPolicies.key_id;\n    this.#cached = keyWithPolicies;\n  }\n}\n\n/** Roles. */\nexport class Role {\n  readonly #apiClient: ApiClient;\n  /** The role information */\n  #data: RoleInfo;\n\n  /** @returns Human-readable name for the role */\n  get name(): string | undefined {\n    return this.#data.name ?? undefined;\n  }\n\n  /**\n   * @returns The ID of the role.\n   *\n   * @example Role#bfe3eccb-731e-430d-b1e5-ac1363e6b06b\n   */\n  get id(): string {\n    return this.#data.role_id;\n  }\n\n  /**\n   * @returns the cached properties of this role. The cached properties\n   * reflect the state of the last fetch or update (e.g., after awaiting\n   * `Role.enabled()` or `Role.disable()`).\n   */\n  get cached(): RoleInfo {\n    return this.#data;\n  }\n\n  /**\n   * Delete the role.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   * @returns A response which can be used to approve MFA if needed\n   */\n  async delete(mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<Empty>> {\n    return await this.#apiClient.roleDelete(this.id, mfaReceipt);\n  }\n\n  /** @returns Whether the role is enabled */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /**\n   * Enable the role.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   */\n  async enable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: true }, mfaReceipt);\n  }\n\n  /**\n   * Disable the role.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   */\n  async disable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: false }, mfaReceipt);\n  }\n\n  /**\n   * Set new policy (overwriting any policies previously set for this role)\n   *\n   * @param policy The new policy to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   */\n  async setPolicy(policy: RolePolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ policy }, mfaReceipt);\n  }\n\n  /**\n   * Append to existing role policy. This append is not atomic---it uses\n   * {@link policy} to fetch the current policy and then {@link setPolicy}\n   * to set the policy---and should not be used across concurrent sessions.\n   *\n   * @param policy The policy to append to the existing one.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   */\n  async appendPolicy(policy: RolePolicy, mfaReceipt?: MfaReceipts) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy], mfaReceipt);\n  }\n\n  /**\n   * Get the policy for the role.\n   *\n   * @returns The policy for the role.\n   */\n  async policy(): Promise<RolePolicy> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as RolePolicy;\n  }\n\n  /**\n   * Set new edit policy (overwriting any edit policies previously set for this role)\n   *\n   * @param editPolicy The new edit policy to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setEditPolicy(editPolicy: EditPolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ edit_policy: editPolicy }, mfaReceipt);\n  }\n\n  /**\n   * Get the edit policy for the role.\n   *\n   * @returns The edit policy for the role, undefined if there is no edit policy\n   */\n  async editPolicy(): Promise<EditPolicy | undefined> {\n    const data = await this.fetch();\n    return data.edit_policy;\n  }\n\n  /**\n   * Sets the restricted actions on the role.\n   *\n   * @param restrictedActions The map of restricted actions\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   */\n  async setRestrictedActions(restrictedActions: RestrictedActionsMap, mfaReceipt?: MfaReceipts) {\n    const restricted_actions = Object.fromEntries(\n      Object.entries(restrictedActions).map(([key, value]) => [key.toString(), value]),\n    );\n\n    await this.update({ restricted_actions }, mfaReceipt);\n  }\n\n  /**\n   * @returns The list of all users with access to the role.\n   *\n   * @example [\n   *   \"User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\",\n   *   \"User#5593c25b-52e2-4fb5-b39b-96d41d681d82\"\n   * ]\n   *\n   * @param page Optional pagination options; by default, retrieves all users.\n   */\n  async users(page?: PageOpts): Promise<string[]> {\n    const users = await this.#apiClient.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 userId The user-id of the user to add to the role.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns an empty response, or a response that can be used to approve MFA if needed.\n   */\n  async addUser(userId: string, mfaReceipt?: MfaReceipts) {\n    return await this.#apiClient.roleUserAdd(this.id, userId, mfaReceipt);\n  }\n\n  /**\n   * Remove an existing user from an existing role.\n   *\n   * @param userId The user-id of the user to remove from the role.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns an empty response, or a response that can be used to approve MFA if needed.\n   */\n  async removeUser(userId: string, mfaReceipt?: MfaReceipts) {\n    return await this.#apiClient.roleUserRemove(this.id, userId, mfaReceipt);\n  }\n\n  /**\n   * @returns The list of keys in the role.\n   *\n   * @example [\n   *    {\n   *     id: \"Key#bfe3eccb-731e-430d-b1e5-ac1363e6b06b\",\n   *     policy: { TxReceiver: \"0x8c594691c0e592ffa21f153a16ae41db5befcaaa\" }\n   *    },\n   *  ]\n   *\n   * @param 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.#apiClient.roleKeysList(this.id, page).fetch();\n    return keysInRole.map((k) => new KeyWithPolicies(this.#apiClient, k));\n  }\n\n  /**\n   * Get a key in the role by its ID.\n   *\n   * @param keyId The ID of the key to get.\n   * @param opts Optional options for getting the key.\n   * @returns The key with its policies.\n   */\n  async getKey(keyId: string, opts?: GetRoleKeyOptions): Promise<KeyWithPolicies> {\n    const kwp = await this.#apiClient.roleKeyGet(this.id, keyId, opts);\n    return new KeyWithPolicies(this.#apiClient, kwp);\n  }\n\n  /**\n   * Add a list of existing keys to an existing role.\n   *\n   * @param keys The list of keys to add to the role.\n   * @param policy The optional policy to apply to each key.\n   *\n   * @returns A CubeSigner response indicating success or failure.\n   */\n  async addKeys(keys: Key[], policy?: KeyPolicy): Promise<CubeSignerResponse<Empty>> {\n    return await this.#apiClient.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 The key to add to the role.\n   * @param policy The optional policy to apply to the key.\n   *\n   * @returns A CubeSigner response indicating success or failure.\n   */\n  async addKey(key: Key, policy?: KeyPolicy): Promise<CubeSignerResponse<Empty>> {\n    return await this.addKeys([key], policy);\n  }\n\n  /**\n   * Remove an existing key from an existing role.\n   *\n   * @param key The key to remove from the role.\n   *\n   * @returns A CubeSigner response indicating success or failure.\n   */\n  async removeKey(key: Key): Promise<CubeSignerResponse<Empty>> {\n    return await this.#apiClient.roleKeysRemove(this.id, key.id);\n  }\n\n  /**\n   * Create a new session for this role.\n   *\n   * @param purpose Descriptive purpose.\n   * @param lifetimes Optional session lifetimes.\n   * @param scopes Session scopes. Only `sign:*` scopes are allowed.\n   * @returns New session.\n   */\n  async createSession(\n    purpose: string,\n    lifetimes?: SessionLifetime,\n    scopes?: Scope[],\n  ): Promise<SessionData> {\n    return await this.#apiClient.sessionCreateForRole(this.id, purpose, scopes, lifetimes);\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 page Optional pagination options; by default, retrieves all sessions.\n   * @returns Signer sessions for this role.\n   */\n  async sessions(page?: PageOpts): Promise<SignerSessionInfo[]> {\n    const sessions = await this.#apiClient.sessionsList({ role: this.id }, page).fetch();\n    return sessions.map((t) => new SignerSessionInfo(this.#apiClient, t.session_id, t.purpose));\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(apiClient: ApiClient, data: RoleInfo) {\n    this.#apiClient = apiClient;\n    this.#data = data;\n  }\n\n  /**\n   * Update the role.\n   *\n   * @param request The JSON request to send to the API server.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   * @returns The updated role information.\n   */\n  private async update(request: UpdateRoleRequest, mfaReceipt?: MfaReceipts): Promise<RoleInfo> {\n    const resp = await this.#apiClient.roleUpdate(this.id, request, mfaReceipt);\n    this.#data = resp.data();\n    return this.#data;\n  }\n\n  /**\n   * Fetches the role information.\n   *\n   * @returns The role information.\n   * @internal\n   */\n  private async fetch(): Promise<RoleInfo> {\n    this.#data = await this.#apiClient.roleGet(this.id);\n    return this.#data;\n  }\n}\n"]}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import type { MfaPolicy } from "./role";
|
|
2
1
|
import type { components, operations } from "./schema";
|
|
3
2
|
import type { JsonMap, JsonValue } from "./util";
|
|
4
3
|
export type schemas = components["schemas"];
|
|
@@ -124,6 +123,10 @@ export type ErrorResponse = schemas["ErrorResponse"];
|
|
|
124
123
|
export type BtcSignatureKind = schemas["BtcSignatureKind"];
|
|
125
124
|
export type CsErrCode = schemas["SignerErrorCode"];
|
|
126
125
|
export type MfaType = "CubeSigner" | "Fido" | `FidoKey#${string}` | "Totp" | "EmailOtp" | `EmailOtp#${number}`;
|
|
126
|
+
export type MfaPolicy = Omit<schemas["MfaPolicy"], "allowed_mfa_types"> & {
|
|
127
|
+
/** Allowed approval types. When omitted, defaults to any. */
|
|
128
|
+
allowed_mfa_types?: MfaType[] | null;
|
|
129
|
+
};
|
|
127
130
|
export type MfaVote = schemas["MfaVote"];
|
|
128
131
|
export type MfaRequestInfo = schemas["MfaRequestInfo"];
|
|
129
132
|
export type MfaProtectedAction = schemas["MfaProtectedAction"];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schema_types.d.ts","sourceRoot":"","sources":["../../src/schema_types.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"schema_types.d.ts","sourceRoot":"","sources":["../../src/schema_types.ts"],"names":[],"mappings":"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"}
|
package/dist/src/schema_types.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema_types.js","sourceRoot":"","sources":["../../src/schema_types.ts"],"names":[],"mappings":"","sourcesContent":["import type { MfaPolicy } from \"./role\";\nimport type { components, operations } from \"./schema\";\nimport type { JsonMap, JsonValue } from \"./util\";\n\nexport type schemas = components[\"schemas\"];\n\nexport type UserInfo = schemas[\"UserInfo\"];\nexport type UserInOrgMembership = schemas[\"UserInOrgMembership\"];\nexport type ConfiguredMfa = schemas[\"ConfiguredMfa\"];\nexport type RatchetConfig = schemas[\"RatchetConfig\"];\nexport type IdentityProof = schemas[\"IdentityProof\"];\nexport type AddIdentityRequest = schemas[\"AddIdentityRequest\"];\nexport type ListIdentityResponse = schemas[\"ListIdentitiesResponse\"];\nexport type TotpInfo = schemas[\"TotpInfo\"];\n\nexport type OidcAuthResponse = schemas[\"NewSessionResponse\"];\nexport type ApiAddFidoChallenge = schemas[\"FidoCreateChallengeResponse\"];\nexport type ApiMfaFidoChallenge = schemas[\"FidoAssertChallenge\"];\n\nexport type PublicKeyCredentialCreationOptions = schemas[\"PublicKeyCredentialCreationOptions\"];\nexport type PublicKeyCredentialRequestOptions = schemas[\"PublicKeyCredentialRequestOptions\"];\nexport type PublicKeyCredentialParameters = schemas[\"PublicKeyCredentialParameters\"];\nexport type PublicKeyCredentialDescriptor = schemas[\"PublicKeyCredentialDescriptor\"];\nexport type AuthenticatorSelectionCriteria = schemas[\"AuthenticatorSelectionCriteria\"];\nexport type PublicKeyCredentialUserEntity = schemas[\"PublicKeyCredentialUserEntity\"];\nexport type PublicKeyCredential = schemas[\"PublicKeyCredential\"];\n\nexport type OrgInfo = schemas[\"OrgInfo\"];\nexport type PublicOrgInfo = schemas[\"PublicOrgInfo\"];\nexport type UserInOrgInfo = schemas[\"UserInOrgInfo\"];\nexport type UpdateOrgRequest = schemas[\"UpdateOrgRequest\"];\nexport type UpdateOrgResponse = schemas[\"UpdateOrgResponse\"];\nexport type UpdateUserMembershipRequest = schemas[\"UpdateUserMembershipRequest\"];\nexport type NotificationEndpointConfiguration = schemas[\"NotificationEndpointConfiguration\"];\nexport type OrgEvents = schemas[\"OrgEventDiscriminants\"];\nexport type BillingEvent = schemas[\"BillingEvent\"];\nexport type OperationKind = schemas[\"OperationKind\"];\n\nexport type OrgData = schemas[\"OrgData\"];\nexport type UserOrgsResponse = schemas[\"UserOrgsResponse\"];\n\nexport type OidcIdentity = schemas[\"OidcIdentity\"];\nexport type MemberRole = schemas[\"MemberRole\"];\n\nexport type SchemaKeyType = schemas[\"KeyType\"];\n\nexport type ListKeysResponse = schemas[\"PaginatedListKeysResponse\"];\nexport type UpdateKeyRequest = schemas[\"UpdateKeyRequest\"];\nexport type KeyProperties = schemas[\"CreateAndUpdateKeyProperties\"];\nexport type CreateKeyRequest = schemas[\"CreateKeyRequest\"];\nexport type KeyInfo = schemas[\"KeyInfo\"];\nexport type KeyInRoleInfo = schemas[\"KeyInRoleInfo\"];\nexport type GetUsersInOrgResponse = schemas[\"PaginatedGetUsersInOrgResponse\"];\nexport type GetUserByEmailResponse = schemas[\"GetUserByEmailResponse\"];\nexport type GetUserByOidcResponse = schemas[\"GetUserByOidcResponse\"];\n\nexport type UserInRoleInfo = schemas[\"UserInRoleInfo\"];\nexport type KeyTypeApi = schemas[\"KeyType\"];\n\nexport type ListKeyRolesResponse = schemas[\"PaginatedListKeyRolesResponse\"];\nexport type ListRolesResponse = schemas[\"PaginatedListRolesResponse\"];\nexport type ListRoleKeysResponse = schemas[\"PaginatedListRoleKeysResponse\"];\nexport type ListRoleUsersResponse = schemas[\"PaginatedListRoleUsersResponse\"];\nexport type UpdateRoleRequest = schemas[\"UpdateRoleRequest\"];\nexport type KeyWithPoliciesInfo = schemas[\"KeyInRoleInfo\"];\nexport type RoleInfo = schemas[\"RoleInfo\"];\nexport type RoleAction = schemas[\"RoleAction\"];\nexport type RestrictedActionsMap = Partial<Record<RoleAction, MemberRole[]>>;\n\nexport type SessionInfo = schemas[\"SessionInfo\"];\nexport type ClientSessionInfo = schemas[\"ClientSessionInfo\"];\nexport type NewSessionResponse = schemas[\"NewSessionResponse\"];\nexport type SessionsResponse = schemas[\"PaginatedSessionsResponse\"];\n\nexport type EditPolicy = schemas[\"EditPolicy\"];\n\nexport type ContactInfo = schemas[\"ContactInfoResponse\"];\nexport type AddressMap = schemas[\"AddressMap\"];\nexport type BtcChain = schemas[\"BtcChain\"];\nexport type SuiChain = schemas[\"SuiChain\"];\nexport type CreateContactRequest = schemas[\"CreateContactRequest\"];\nexport type UpdateContactRequest = schemas[\"UpdateContactRequest\"];\nexport type ListContactsResponse = schemas[\"PaginatedListContactsResponse\"];\n\nexport type CreateSignerSessionRequest = schemas[\"CreateTokenRequest\"];\nexport type RefreshSignerSessionRequest = schemas[\"AuthData\"];\n\nexport type EvmSignRequest = schemas[\"Eth1SignRequest\"];\nexport type EvmSignResponse = schemas[\"Eth1SignResponse\"];\nexport type Eip191SignRequest = schemas[\"Eip191SignRequest\"];\nexport type Eip712SignRequest = schemas[\"Eip712SignRequest\"];\nexport type Eip191Or712SignResponse = schemas[\"SignResponse\"];\nexport type Eth2SignRequest = schemas[\"Eth2SignRequest\"];\nexport type Eth2SignResponse = schemas[\"Eth2SignResponse\"];\nexport type Eth2StakeRequest = schemas[\"StakeRequest\"];\nexport type Eth2StakeResponse = schemas[\"StakeResponse\"];\nexport type Eth2UnstakeRequest = schemas[\"UnstakeRequest\"];\nexport type Eth2UnstakeResponse = schemas[\"UnstakeResponse\"];\nexport type BlobSignRequest = schemas[\"BlobSignRequest\"];\nexport type BlobSignResponse = schemas[\"SignResponse\"];\nexport type BtcSignRequest = schemas[\"BtcSignRequest\"];\nexport type BtcSignResponse = schemas[\"SignResponse\"];\nexport type BtcMessageSignRequest = schemas[\"BtcMessageSignRequest\"];\nexport type BtcMessageSignResponse = schemas[\"BtcMessageSignResponse\"];\nexport type PsbtSignRequest = schemas[\"PsbtSignRequest\"];\nexport type PsbtSignResponse = schemas[\"PsbtSignResponse\"];\nexport type TaprootSignRequest = schemas[\"TaprootSignRequest\"];\nexport type TaprootSignResponse = schemas[\"SignResponse\"];\nexport type EotsSignRequest = schemas[\"EotsSignRequest\"];\nexport type EotsSignResponse = schemas[\"SignResponse\"];\nexport type EotsCreateNonceRequest = schemas[\"EotsCreateNonceRequest\"];\nexport type EotsCreateNonceResponse = schemas[\"EotsCreateNonceResponse\"];\nexport type BabylonStakingRequest = schemas[\"BabylonStakingRequest\"];\nexport type BabylonStakingResponse = schemas[\"BabylonStakingResponse\"];\nexport type BabylonStakingEarlyUnbond = schemas[\"BabylonStakingEarlyUnbond\"];\nexport type BabylonStakingWithdrawal = schemas[\"BabylonStakingWithdrawal\"];\nexport type BabylonRegistrationRequest = schemas[\"BabylonRegistrationRequest\"];\nexport type BabylonRegistrationResponse = schemas[\"BabylonRegistrationResponse\"];\nexport type SolanaSignRequest = schemas[\"SolanaSignRequest\"];\nexport type SolanaSignResponse = schemas[\"SignResponse\"];\nexport type AvaSignRequest = schemas[\"AvaSignRequest\"];\nexport type AvaSignResponse = schemas[\"SignResponse\"];\nexport type AvaSerializedTxSignRequest = schemas[\"AvaSerializedTxSignRequest\"];\nexport type SuiSignRequest = schemas[\"SuiSignRequest\"];\nexport type SuiSignResponse = schemas[\"SignResponse\"];\n\nexport type PendingMessageSignResponse = schemas[\"PendingMessageSignResponse\"];\nexport type PendingMessageInfo = schemas[\"PendingMessageInfo\"];\nexport type EvmTransaction = schemas[\"Transaction\"];\nexport type TypedTransaction = schemas[\"TypedTransaction\"];\nexport type TransactionAndStatus = schemas[\"TransactionAndStatus\"];\nexport type SignedMessage = schemas[\"SignedMessage\"];\nexport type MmiMetadata = schemas[\"MmiMetadata\"];\nexport type MmiStatus = schemas[\"MmiStatus\"];\nexport type Eip191Message = NonNullable<PendingMessageInfo[\"message_eip191\"]>;\nexport type Eip712Message = NonNullable<PendingMessageInfo[\"message_eip712\"]>;\n\nexport type JrpcResponse = schemas[\"JrpcResponse\"];\nexport type MmiJrpcMethod =\n  | \"custodian_listAccounts\"\n  | \"custodian_listAccountsSigned\"\n  | \"custodian_listAccountChainIds\"\n  | \"custodian_createTransaction\"\n  | \"custodian_sign\"\n  | \"custodian_signTypedData\"\n  | \"custodian_getSignedMessageById\"\n  | \"custodian_getTransactionById\"\n  | \"custodian_getCustomerProof\"\n  | \"custodian_replaceTransaction\"\n  | \"custodian_getTransactionLink\"\n  | \"custodian_getSignedMessageLink\";\n\nexport type AcceptedResponse = schemas[\"AcceptedResponse\"];\nexport type ErrorResponse = schemas[\"ErrorResponse\"];\nexport type BtcSignatureKind = schemas[\"BtcSignatureKind\"];\nexport type CsErrCode = schemas[\"SignerErrorCode\"];\n\nexport type MfaType =\n  | \"CubeSigner\"\n  | \"Fido\"\n  | `FidoKey#${string}`\n  | \"Totp\"\n  | \"EmailOtp\"\n  | `EmailOtp#${number}`;\nexport type MfaVote = schemas[\"MfaVote\"];\nexport type MfaRequestInfo = schemas[\"MfaRequestInfo\"];\nexport type MfaProtectedAction = schemas[\"MfaProtectedAction\"];\nexport type MfaRequired = schemas[\"AcceptedValue\"][\"MfaRequired\"];\nexport type EvmTxCmp = schemas[\"EvmTxCmp\"];\nexport type SolanaTxCmp = schemas[\"SolanaTxCmp\"];\n\nexport type CreateOrgRequest = schemas[\"CreateOrgRequest\"];\nexport type OrgMetricName = schemas[\"MetricName\"];\nexport type QueryMetricsRequest = schemas[\"QueryMetricsRequest\"];\nexport type QueryMetricsResponse = schemas[\"QueryMetricsResponse\"];\n\nexport type DiffieHellmanRequest = schemas[\"DiffieHellmanRequest\"];\nexport type DiffieHellmanResponse = schemas[\"DiffieHellmanResponse\"];\n\nexport type UserExportInitRequest = schemas[\"UserExportInitRequest\"];\nexport type UserExportInitResponse = schemas[\"UserExportInitResponse\"];\nexport type UserExportCompleteRequest = schemas[\"UserExportCompleteRequest\"];\nexport type UserExportCompleteResponse = schemas[\"UserExportCompleteResponse\"];\nexport type UserExportListResponse = schemas[\"PaginatedUserExportListResponse\"];\nexport type UserExportKeyMaterial = schemas[\"JsonKeyPackage\"];\n\nexport type HistoricalTx = schemas[\"HistoricalTx\"];\nexport type ListHistoricalTxResponse = schemas[\"PaginatedListHistoricalTxResponse\"];\n\nexport type LoginRequest = schemas[\"LoginRequest\"];\nexport type PasskeyAssertChallenge = schemas[\"PasskeyAssertChallenge\"];\nexport type PasskeyAssertAnswer = schemas[\"PasskeyAssertAnswer\"];\nexport type AuthenticationRequest = schemas[\"AuthenticationRequest\"];\nexport type AuthenticationResponse = schemas[\"AuthenticationResponse\"];\nexport type PasswordResetRequest = schemas[\"PasswordResetRequest\"];\nexport type PasswordResetConfirmRequest = schemas[\"PasswordResetConfirmRequest\"];\nexport type EmailOtpResponse = schemas[\"EmailOtpResponse\"];\nexport type EmailTemplatePurpose = schemas[\"Purpose\"];\n\nexport type Empty = schemas[\"EmptyImpl\"];\n\nexport type Scope = schemas[\"Scope\"];\n\n/** Options for a new OIDC user */\nexport interface CreateOidcUserOptions {\n  /** Optional name */\n  name?: string | null;\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\nexport type GetRoleKeyOptions = operations[\"getRoleKey\"][\"parameters\"][\"query\"];\n\n/** Ava P- or X-chain transaction */\nexport type AvaTx = { P: AvaPChainTx } | { X: AvaXChainTx };\n\n/** Ava P-chain transaction */\nexport type AvaPChainTx =\n  | { AddPermissionlessValidator: JsonMap }\n  | { AddSubnetValidator: JsonMap }\n  | { AddValidator: JsonMap }\n  | { CreateChain: JsonMap }\n  | { CreateSubnet: JsonMap }\n  | { Export: JsonMap }\n  | { Import: JsonMap };\n\n/** Ava X-chain transaction */\nexport type AvaXChainTx = { Base: JsonMap } | { Export: JsonMap } | { Import: JsonMap };\n\n/** Ava chains */\nexport type AvaChain = \"C\" | \"X\" | \"P\";\n\n/** Key import */\nexport type CreateKeyImportKeyResponse = schemas[\"CreateKeyImportKeyResponse\"];\nexport type ImportKeyRequest = schemas[\"ImportKeyRequest\"];\nexport type ImportKeyRequestMaterial = schemas[\"ImportKeyRequestMaterial\"];\n\nexport type InvitationAcceptRequest = schemas[\"InvitationAcceptRequest\"];\n\nexport type KeyTypeAndDerivationPath = schemas[\"KeyTypeAndDerivationPath\"];\n\nexport type PolicyInfo = schemas[\"PolicyInfo\"];\nexport type UpdatePolicyRequest = schemas[\"UpdatePolicyRequest\"] & {\n  rules?: JsonValue[];\n};\nexport type ListPoliciesResponse = schemas[\"PaginatedListPoliciesResponse\"];\nexport type PolicyType = schemas[\"PolicyType\"];\nexport type PolicyAttachedToId = schemas[\"PolicyAttachedToId\"];\n\nexport type UploadWasmPolicyRequest = schemas[\"UploadWasmPolicyRequest\"];\nexport type UploadWasmPolicyResponse = schemas[\"UploadWasmPolicyResponse\"];\nexport type InvokePolicyRequest = schemas[\"InvokePolicyRequest\"];\nexport type InvokePolicyResponse = schemas[\"InvokePolicyResponse\"];\nexport type WasmPolicyResponse = schemas[\"WasmPolicyResponse\"];\nexport type WasmRule = schemas[\"WasmRule\"];\n\nexport type PolicyEngineConfiguration = schemas[\"PolicyEngineConfiguration\"];\n"]}
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema_types.js","sourceRoot":"","sources":["../../src/schema_types.ts"],"names":[],"mappings":"","sourcesContent":["import type { components, operations } from \"./schema\";\nimport type { JsonMap, JsonValue } from \"./util\";\n\nexport type schemas = components[\"schemas\"];\n\nexport type UserInfo = schemas[\"UserInfo\"];\nexport type UserInOrgMembership = schemas[\"UserInOrgMembership\"];\nexport type ConfiguredMfa = schemas[\"ConfiguredMfa\"];\nexport type RatchetConfig = schemas[\"RatchetConfig\"];\nexport type IdentityProof = schemas[\"IdentityProof\"];\nexport type AddIdentityRequest = schemas[\"AddIdentityRequest\"];\nexport type ListIdentityResponse = schemas[\"ListIdentitiesResponse\"];\nexport type TotpInfo = schemas[\"TotpInfo\"];\n\nexport type OidcAuthResponse = schemas[\"NewSessionResponse\"];\nexport type ApiAddFidoChallenge = schemas[\"FidoCreateChallengeResponse\"];\nexport type ApiMfaFidoChallenge = schemas[\"FidoAssertChallenge\"];\n\nexport type PublicKeyCredentialCreationOptions = schemas[\"PublicKeyCredentialCreationOptions\"];\nexport type PublicKeyCredentialRequestOptions = schemas[\"PublicKeyCredentialRequestOptions\"];\nexport type PublicKeyCredentialParameters = schemas[\"PublicKeyCredentialParameters\"];\nexport type PublicKeyCredentialDescriptor = schemas[\"PublicKeyCredentialDescriptor\"];\nexport type AuthenticatorSelectionCriteria = schemas[\"AuthenticatorSelectionCriteria\"];\nexport type PublicKeyCredentialUserEntity = schemas[\"PublicKeyCredentialUserEntity\"];\nexport type PublicKeyCredential = schemas[\"PublicKeyCredential\"];\n\nexport type OrgInfo = schemas[\"OrgInfo\"];\nexport type PublicOrgInfo = schemas[\"PublicOrgInfo\"];\nexport type UserInOrgInfo = schemas[\"UserInOrgInfo\"];\nexport type UpdateOrgRequest = schemas[\"UpdateOrgRequest\"];\nexport type UpdateOrgResponse = schemas[\"UpdateOrgResponse\"];\nexport type UpdateUserMembershipRequest = schemas[\"UpdateUserMembershipRequest\"];\nexport type NotificationEndpointConfiguration = schemas[\"NotificationEndpointConfiguration\"];\nexport type OrgEvents = schemas[\"OrgEventDiscriminants\"];\nexport type BillingEvent = schemas[\"BillingEvent\"];\nexport type OperationKind = schemas[\"OperationKind\"];\n\nexport type OrgData = schemas[\"OrgData\"];\nexport type UserOrgsResponse = schemas[\"UserOrgsResponse\"];\n\nexport type OidcIdentity = schemas[\"OidcIdentity\"];\nexport type MemberRole = schemas[\"MemberRole\"];\n\nexport type SchemaKeyType = schemas[\"KeyType\"];\n\nexport type ListKeysResponse = schemas[\"PaginatedListKeysResponse\"];\nexport type UpdateKeyRequest = schemas[\"UpdateKeyRequest\"];\nexport type KeyProperties = schemas[\"CreateAndUpdateKeyProperties\"];\nexport type CreateKeyRequest = schemas[\"CreateKeyRequest\"];\nexport type KeyInfo = schemas[\"KeyInfo\"];\nexport type KeyInRoleInfo = schemas[\"KeyInRoleInfo\"];\nexport type GetUsersInOrgResponse = schemas[\"PaginatedGetUsersInOrgResponse\"];\nexport type GetUserByEmailResponse = schemas[\"GetUserByEmailResponse\"];\nexport type GetUserByOidcResponse = schemas[\"GetUserByOidcResponse\"];\n\nexport type UserInRoleInfo = schemas[\"UserInRoleInfo\"];\nexport type KeyTypeApi = schemas[\"KeyType\"];\n\nexport type ListKeyRolesResponse = schemas[\"PaginatedListKeyRolesResponse\"];\nexport type ListRolesResponse = schemas[\"PaginatedListRolesResponse\"];\nexport type ListRoleKeysResponse = schemas[\"PaginatedListRoleKeysResponse\"];\nexport type ListRoleUsersResponse = schemas[\"PaginatedListRoleUsersResponse\"];\nexport type UpdateRoleRequest = schemas[\"UpdateRoleRequest\"];\nexport type KeyWithPoliciesInfo = schemas[\"KeyInRoleInfo\"];\nexport type RoleInfo = schemas[\"RoleInfo\"];\nexport type RoleAction = schemas[\"RoleAction\"];\nexport type RestrictedActionsMap = Partial<Record<RoleAction, MemberRole[]>>;\n\nexport type SessionInfo = schemas[\"SessionInfo\"];\nexport type ClientSessionInfo = schemas[\"ClientSessionInfo\"];\nexport type NewSessionResponse = schemas[\"NewSessionResponse\"];\nexport type SessionsResponse = schemas[\"PaginatedSessionsResponse\"];\n\nexport type EditPolicy = schemas[\"EditPolicy\"];\n\nexport type ContactInfo = schemas[\"ContactInfoResponse\"];\nexport type AddressMap = schemas[\"AddressMap\"];\nexport type BtcChain = schemas[\"BtcChain\"];\nexport type SuiChain = schemas[\"SuiChain\"];\nexport type CreateContactRequest = schemas[\"CreateContactRequest\"];\nexport type UpdateContactRequest = schemas[\"UpdateContactRequest\"];\nexport type ListContactsResponse = schemas[\"PaginatedListContactsResponse\"];\n\nexport type CreateSignerSessionRequest = schemas[\"CreateTokenRequest\"];\nexport type RefreshSignerSessionRequest = schemas[\"AuthData\"];\n\nexport type EvmSignRequest = schemas[\"Eth1SignRequest\"];\nexport type EvmSignResponse = schemas[\"Eth1SignResponse\"];\nexport type Eip191SignRequest = schemas[\"Eip191SignRequest\"];\nexport type Eip712SignRequest = schemas[\"Eip712SignRequest\"];\nexport type Eip191Or712SignResponse = schemas[\"SignResponse\"];\nexport type Eth2SignRequest = schemas[\"Eth2SignRequest\"];\nexport type Eth2SignResponse = schemas[\"Eth2SignResponse\"];\nexport type Eth2StakeRequest = schemas[\"StakeRequest\"];\nexport type Eth2StakeResponse = schemas[\"StakeResponse\"];\nexport type Eth2UnstakeRequest = schemas[\"UnstakeRequest\"];\nexport type Eth2UnstakeResponse = schemas[\"UnstakeResponse\"];\nexport type BlobSignRequest = schemas[\"BlobSignRequest\"];\nexport type BlobSignResponse = schemas[\"SignResponse\"];\nexport type BtcSignRequest = schemas[\"BtcSignRequest\"];\nexport type BtcSignResponse = schemas[\"SignResponse\"];\nexport type BtcMessageSignRequest = schemas[\"BtcMessageSignRequest\"];\nexport type BtcMessageSignResponse = schemas[\"BtcMessageSignResponse\"];\nexport type PsbtSignRequest = schemas[\"PsbtSignRequest\"];\nexport type PsbtSignResponse = schemas[\"PsbtSignResponse\"];\nexport type TaprootSignRequest = schemas[\"TaprootSignRequest\"];\nexport type TaprootSignResponse = schemas[\"SignResponse\"];\nexport type EotsSignRequest = schemas[\"EotsSignRequest\"];\nexport type EotsSignResponse = schemas[\"SignResponse\"];\nexport type EotsCreateNonceRequest = schemas[\"EotsCreateNonceRequest\"];\nexport type EotsCreateNonceResponse = schemas[\"EotsCreateNonceResponse\"];\nexport type BabylonStakingRequest = schemas[\"BabylonStakingRequest\"];\nexport type BabylonStakingResponse = schemas[\"BabylonStakingResponse\"];\nexport type BabylonStakingEarlyUnbond = schemas[\"BabylonStakingEarlyUnbond\"];\nexport type BabylonStakingWithdrawal = schemas[\"BabylonStakingWithdrawal\"];\nexport type BabylonRegistrationRequest = schemas[\"BabylonRegistrationRequest\"];\nexport type BabylonRegistrationResponse = schemas[\"BabylonRegistrationResponse\"];\nexport type SolanaSignRequest = schemas[\"SolanaSignRequest\"];\nexport type SolanaSignResponse = schemas[\"SignResponse\"];\nexport type AvaSignRequest = schemas[\"AvaSignRequest\"];\nexport type AvaSignResponse = schemas[\"SignResponse\"];\nexport type AvaSerializedTxSignRequest = schemas[\"AvaSerializedTxSignRequest\"];\nexport type SuiSignRequest = schemas[\"SuiSignRequest\"];\nexport type SuiSignResponse = schemas[\"SignResponse\"];\n\nexport type PendingMessageSignResponse = schemas[\"PendingMessageSignResponse\"];\nexport type PendingMessageInfo = schemas[\"PendingMessageInfo\"];\nexport type EvmTransaction = schemas[\"Transaction\"];\nexport type TypedTransaction = schemas[\"TypedTransaction\"];\nexport type TransactionAndStatus = schemas[\"TransactionAndStatus\"];\nexport type SignedMessage = schemas[\"SignedMessage\"];\nexport type MmiMetadata = schemas[\"MmiMetadata\"];\nexport type MmiStatus = schemas[\"MmiStatus\"];\nexport type Eip191Message = NonNullable<PendingMessageInfo[\"message_eip191\"]>;\nexport type Eip712Message = NonNullable<PendingMessageInfo[\"message_eip712\"]>;\n\nexport type JrpcResponse = schemas[\"JrpcResponse\"];\nexport type MmiJrpcMethod =\n  | \"custodian_listAccounts\"\n  | \"custodian_listAccountsSigned\"\n  | \"custodian_listAccountChainIds\"\n  | \"custodian_createTransaction\"\n  | \"custodian_sign\"\n  | \"custodian_signTypedData\"\n  | \"custodian_getSignedMessageById\"\n  | \"custodian_getTransactionById\"\n  | \"custodian_getCustomerProof\"\n  | \"custodian_replaceTransaction\"\n  | \"custodian_getTransactionLink\"\n  | \"custodian_getSignedMessageLink\";\n\nexport type AcceptedResponse = schemas[\"AcceptedResponse\"];\nexport type ErrorResponse = schemas[\"ErrorResponse\"];\nexport type BtcSignatureKind = schemas[\"BtcSignatureKind\"];\nexport type CsErrCode = schemas[\"SignerErrorCode\"];\n\nexport type MfaType =\n  | \"CubeSigner\"\n  | \"Fido\"\n  | `FidoKey#${string}`\n  | \"Totp\"\n  | \"EmailOtp\"\n  | `EmailOtp#${number}`;\nexport type MfaPolicy = Omit<schemas[\"MfaPolicy\"], \"allowed_mfa_types\"> & {\n  /** Allowed approval types. When omitted, defaults to any. */\n  allowed_mfa_types?: MfaType[] | null; // overriding to use a stronger `MfaType` type\n};\nexport type MfaVote = schemas[\"MfaVote\"];\nexport type MfaRequestInfo = schemas[\"MfaRequestInfo\"];\nexport type MfaProtectedAction = schemas[\"MfaProtectedAction\"];\nexport type MfaRequired = schemas[\"AcceptedValue\"][\"MfaRequired\"];\nexport type EvmTxCmp = schemas[\"EvmTxCmp\"];\nexport type SolanaTxCmp = schemas[\"SolanaTxCmp\"];\n\nexport type CreateOrgRequest = schemas[\"CreateOrgRequest\"];\nexport type OrgMetricName = schemas[\"MetricName\"];\nexport type QueryMetricsRequest = schemas[\"QueryMetricsRequest\"];\nexport type QueryMetricsResponse = schemas[\"QueryMetricsResponse\"];\n\nexport type DiffieHellmanRequest = schemas[\"DiffieHellmanRequest\"];\nexport type DiffieHellmanResponse = schemas[\"DiffieHellmanResponse\"];\n\nexport type UserExportInitRequest = schemas[\"UserExportInitRequest\"];\nexport type UserExportInitResponse = schemas[\"UserExportInitResponse\"];\nexport type UserExportCompleteRequest = schemas[\"UserExportCompleteRequest\"];\nexport type UserExportCompleteResponse = schemas[\"UserExportCompleteResponse\"];\nexport type UserExportListResponse = schemas[\"PaginatedUserExportListResponse\"];\nexport type UserExportKeyMaterial = schemas[\"JsonKeyPackage\"];\n\nexport type HistoricalTx = schemas[\"HistoricalTx\"];\nexport type ListHistoricalTxResponse = schemas[\"PaginatedListHistoricalTxResponse\"];\n\nexport type LoginRequest = schemas[\"LoginRequest\"];\nexport type PasskeyAssertChallenge = schemas[\"PasskeyAssertChallenge\"];\nexport type PasskeyAssertAnswer = schemas[\"PasskeyAssertAnswer\"];\nexport type AuthenticationRequest = schemas[\"AuthenticationRequest\"];\nexport type AuthenticationResponse = schemas[\"AuthenticationResponse\"];\nexport type PasswordResetRequest = schemas[\"PasswordResetRequest\"];\nexport type PasswordResetConfirmRequest = schemas[\"PasswordResetConfirmRequest\"];\nexport type EmailOtpResponse = schemas[\"EmailOtpResponse\"];\nexport type EmailTemplatePurpose = schemas[\"Purpose\"];\n\nexport type Empty = schemas[\"EmptyImpl\"];\n\nexport type Scope = schemas[\"Scope\"];\n\n/** Options for a new OIDC user */\nexport interface CreateOidcUserOptions {\n  /** Optional name */\n  name?: string | null;\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\nexport type GetRoleKeyOptions = operations[\"getRoleKey\"][\"parameters\"][\"query\"];\n\n/** Ava P- or X-chain transaction */\nexport type AvaTx = { P: AvaPChainTx } | { X: AvaXChainTx };\n\n/** Ava P-chain transaction */\nexport type AvaPChainTx =\n  | { AddPermissionlessValidator: JsonMap }\n  | { AddSubnetValidator: JsonMap }\n  | { AddValidator: JsonMap }\n  | { CreateChain: JsonMap }\n  | { CreateSubnet: JsonMap }\n  | { Export: JsonMap }\n  | { Import: JsonMap };\n\n/** Ava X-chain transaction */\nexport type AvaXChainTx = { Base: JsonMap } | { Export: JsonMap } | { Import: JsonMap };\n\n/** Ava chains */\nexport type AvaChain = \"C\" | \"X\" | \"P\";\n\n/** Key import */\nexport type CreateKeyImportKeyResponse = schemas[\"CreateKeyImportKeyResponse\"];\nexport type ImportKeyRequest = schemas[\"ImportKeyRequest\"];\nexport type ImportKeyRequestMaterial = schemas[\"ImportKeyRequestMaterial\"];\n\nexport type InvitationAcceptRequest = schemas[\"InvitationAcceptRequest\"];\n\nexport type KeyTypeAndDerivationPath = schemas[\"KeyTypeAndDerivationPath\"];\n\nexport type PolicyInfo = schemas[\"PolicyInfo\"];\nexport type UpdatePolicyRequest = schemas[\"UpdatePolicyRequest\"] & {\n  rules?: JsonValue[];\n};\nexport type ListPoliciesResponse = schemas[\"PaginatedListPoliciesResponse\"];\nexport type PolicyType = schemas[\"PolicyType\"];\nexport type PolicyAttachedToId = schemas[\"PolicyAttachedToId\"];\n\nexport type UploadWasmPolicyRequest = schemas[\"UploadWasmPolicyRequest\"];\nexport type UploadWasmPolicyResponse = schemas[\"UploadWasmPolicyResponse\"];\nexport type InvokePolicyRequest = schemas[\"InvokePolicyRequest\"];\nexport type InvokePolicyResponse = schemas[\"InvokePolicyResponse\"];\nexport type WasmPolicyResponse = schemas[\"WasmPolicyResponse\"];\nexport type WasmRule = schemas[\"WasmRule\"];\n\nexport type PolicyEngineConfiguration = schemas[\"PolicyEngineConfiguration\"];\n"]}
|
package/package.json
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
"url": "git+https://github.com/cubist-labs/CubeSigner-TypeScript-SDK.git",
|
|
6
6
|
"directory": "packages/sdk"
|
|
7
7
|
},
|
|
8
|
-
"version": "0.4.
|
|
8
|
+
"version": "0.4.201",
|
|
9
9
|
"description": "CubeSigner TypeScript SDK",
|
|
10
10
|
"license": "MIT OR Apache-2.0",
|
|
11
11
|
"author": "Cubist, Inc.",
|
package/src/key.ts
CHANGED
|
@@ -37,6 +37,7 @@ import type {
|
|
|
37
37
|
BabylonStakingResponse,
|
|
38
38
|
BtcMessageSignRequest,
|
|
39
39
|
CubeSignerResponse,
|
|
40
|
+
EditPolicy,
|
|
40
41
|
Empty,
|
|
41
42
|
ErrResponse,
|
|
42
43
|
HistoricalTx,
|
|
@@ -222,6 +223,17 @@ export class Key {
|
|
|
222
223
|
await this.update({ policy }, mfaReceipt);
|
|
223
224
|
}
|
|
224
225
|
|
|
226
|
+
/**
|
|
227
|
+
* Set new edit policy (overwriting any edit policies previously set for this key)
|
|
228
|
+
*
|
|
229
|
+
* @param editPolicy The new edit policy to set
|
|
230
|
+
* @param mfaReceipt Optional MFA receipt(s)
|
|
231
|
+
* @throws if MFA is required and no receipts are provided
|
|
232
|
+
*/
|
|
233
|
+
async setEditPolicy(editPolicy: EditPolicy, mfaReceipt?: MfaReceipts) {
|
|
234
|
+
await this.update({ edit_policy: editPolicy }, mfaReceipt);
|
|
235
|
+
}
|
|
236
|
+
|
|
225
237
|
/**
|
|
226
238
|
* Set key metadata. The metadata must be at most 1024 characters
|
|
227
239
|
* and must match the following regex: ^[A-Za-z0-9_=+/ \-\.\,]{0,1024}$.
|
|
@@ -333,13 +345,15 @@ export class Key {
|
|
|
333
345
|
/**
|
|
334
346
|
* Append to existing key policy. This append is not atomic -- it uses {@link policy}
|
|
335
347
|
* to fetch the current policy and then {@link setPolicy} to set the policy -- and
|
|
336
|
-
* should not be used
|
|
348
|
+
* should not be used across concurrent sessions.
|
|
337
349
|
*
|
|
338
350
|
* @param policy The policy to append to the existing one.
|
|
351
|
+
* @param mfaReceipt Optional MFA receipt(s)
|
|
352
|
+
* @throws If MFA is required and no MFA receipts are provided
|
|
339
353
|
*/
|
|
340
|
-
async appendPolicy(policy: KeyPolicy) {
|
|
354
|
+
async appendPolicy(policy: KeyPolicy, mfaReceipt?: MfaReceipts) {
|
|
341
355
|
const existing = await this.policy();
|
|
342
|
-
await this.setPolicy([...existing, ...policy]);
|
|
356
|
+
await this.setPolicy([...existing, ...policy], mfaReceipt);
|
|
343
357
|
}
|
|
344
358
|
|
|
345
359
|
/**
|
|
@@ -352,6 +366,16 @@ export class Key {
|
|
|
352
366
|
return (data.policy ?? []) as unknown as KeyPolicy;
|
|
353
367
|
}
|
|
354
368
|
|
|
369
|
+
/**
|
|
370
|
+
* Get the edit policy for the key.
|
|
371
|
+
*
|
|
372
|
+
* @returns The edit policy for the key, undefined if there is no edit policy
|
|
373
|
+
*/
|
|
374
|
+
async editPolicy(): Promise<EditPolicy | undefined> {
|
|
375
|
+
const data = await this.fetch();
|
|
376
|
+
return data.edit_policy;
|
|
377
|
+
}
|
|
378
|
+
|
|
355
379
|
/**
|
|
356
380
|
* Fetch the metadata for the key.
|
|
357
381
|
*
|
package/src/role.ts
CHANGED
|
@@ -4,7 +4,6 @@ import type {
|
|
|
4
4
|
EvmTxCmp,
|
|
5
5
|
SolanaTxCmp,
|
|
6
6
|
KeyWithPoliciesInfo,
|
|
7
|
-
MfaType,
|
|
8
7
|
PageOpts,
|
|
9
8
|
RoleInfo,
|
|
10
9
|
Scope,
|
|
@@ -18,6 +17,8 @@ import type {
|
|
|
18
17
|
Empty,
|
|
19
18
|
RestrictedActionsMap,
|
|
20
19
|
GetRoleKeyOptions,
|
|
20
|
+
EditPolicy,
|
|
21
|
+
MfaPolicy,
|
|
21
22
|
} from ".";
|
|
22
23
|
import { Key, SignerSessionInfo } from ".";
|
|
23
24
|
|
|
@@ -304,41 +305,6 @@ export type BtcSegwitValueLimitWindow = {
|
|
|
304
305
|
*/
|
|
305
306
|
export type SourceIpAllowlist = { SourceIpAllowlist: string[] };
|
|
306
307
|
|
|
307
|
-
/**
|
|
308
|
-
* MFA policy
|
|
309
|
-
*
|
|
310
|
-
* @example {
|
|
311
|
-
* {
|
|
312
|
-
* count: 1,
|
|
313
|
-
* num_auth_factors: 1,
|
|
314
|
-
* allowed_mfa_types: [ "Totp" ],
|
|
315
|
-
* allowed_approvers: [ "User#123" ],
|
|
316
|
-
* }
|
|
317
|
-
*/
|
|
318
|
-
export type MfaPolicy = {
|
|
319
|
-
count?: number;
|
|
320
|
-
num_auth_factors?: number;
|
|
321
|
-
allowed_approvers?: string[];
|
|
322
|
-
allowed_mfa_types?: MfaType[];
|
|
323
|
-
restricted_operations?: OperationKind[];
|
|
324
|
-
/** Lifetime in seconds, defaults to 900 (15 minutes) */
|
|
325
|
-
lifetime?: number;
|
|
326
|
-
/**
|
|
327
|
-
* How to compare HTTP requests when verifying the MFA receipt.
|
|
328
|
-
* This specifies how we check equality between (1) the HTTP request when the 202 (MFA required)
|
|
329
|
-
* response is returned and (2) the HTTP request when the correspond MFA receipt is used.
|
|
330
|
-
*/
|
|
331
|
-
request_comparer?: HttpRequestComparer;
|
|
332
|
-
/**
|
|
333
|
-
* The amount of time in seconds before an MFA receipt can be redeemed.
|
|
334
|
-
* Defaults to 0, i.e., no delay. Approvers can vote to approve or veto
|
|
335
|
-
* before the delay expires. After approving, it is still possible for
|
|
336
|
-
* anyone to veto the request until the delay expires and the receipt
|
|
337
|
-
* is redeemed.
|
|
338
|
-
*/
|
|
339
|
-
time_delay?: number;
|
|
340
|
-
};
|
|
341
|
-
|
|
342
308
|
export type HttpRequestComparer = "Eq" | { EvmTx: EvmTxCmp } | { SolanaTx: SolanaTxCmp };
|
|
343
309
|
|
|
344
310
|
/**
|
|
@@ -671,7 +637,7 @@ export class Role {
|
|
|
671
637
|
/**
|
|
672
638
|
* Append to existing role policy. This append is not atomic---it uses
|
|
673
639
|
* {@link policy} to fetch the current policy and then {@link setPolicy}
|
|
674
|
-
* to set the policy---and should not be used
|
|
640
|
+
* to set the policy---and should not be used across concurrent sessions.
|
|
675
641
|
*
|
|
676
642
|
* @param policy The policy to append to the existing one.
|
|
677
643
|
* @param mfaReceipt Optional MFA receipt(s)
|
|
@@ -692,6 +658,27 @@ export class Role {
|
|
|
692
658
|
return (data.policy ?? []) as unknown as RolePolicy;
|
|
693
659
|
}
|
|
694
660
|
|
|
661
|
+
/**
|
|
662
|
+
* Set new edit policy (overwriting any edit policies previously set for this role)
|
|
663
|
+
*
|
|
664
|
+
* @param editPolicy The new edit policy to set
|
|
665
|
+
* @param mfaReceipt Optional MFA receipt(s)
|
|
666
|
+
* @throws if MFA is required and no receipts are provided
|
|
667
|
+
*/
|
|
668
|
+
async setEditPolicy(editPolicy: EditPolicy, mfaReceipt?: MfaReceipts) {
|
|
669
|
+
await this.update({ edit_policy: editPolicy }, mfaReceipt);
|
|
670
|
+
}
|
|
671
|
+
|
|
672
|
+
/**
|
|
673
|
+
* Get the edit policy for the role.
|
|
674
|
+
*
|
|
675
|
+
* @returns The edit policy for the role, undefined if there is no edit policy
|
|
676
|
+
*/
|
|
677
|
+
async editPolicy(): Promise<EditPolicy | undefined> {
|
|
678
|
+
const data = await this.fetch();
|
|
679
|
+
return data.edit_policy;
|
|
680
|
+
}
|
|
681
|
+
|
|
695
682
|
/**
|
|
696
683
|
* Sets the restricted actions on the role.
|
|
697
684
|
*
|
package/src/schema_types.ts
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import type { MfaPolicy } from "./role";
|
|
2
1
|
import type { components, operations } from "./schema";
|
|
3
2
|
import type { JsonMap, JsonValue } from "./util";
|
|
4
3
|
|
|
@@ -162,6 +161,10 @@ export type MfaType =
|
|
|
162
161
|
| "Totp"
|
|
163
162
|
| "EmailOtp"
|
|
164
163
|
| `EmailOtp#${number}`;
|
|
164
|
+
export type MfaPolicy = Omit<schemas["MfaPolicy"], "allowed_mfa_types"> & {
|
|
165
|
+
/** Allowed approval types. When omitted, defaults to any. */
|
|
166
|
+
allowed_mfa_types?: MfaType[] | null; // overriding to use a stronger `MfaType` type
|
|
167
|
+
};
|
|
165
168
|
export type MfaVote = schemas["MfaVote"];
|
|
166
169
|
export type MfaRequestInfo = schemas["MfaRequestInfo"];
|
|
167
170
|
export type MfaProtectedAction = schemas["MfaProtectedAction"];
|