@cubist-labs/cubesigner-sdk 0.4.128-0 → 0.4.129-0
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/role.d.ts +25 -1
- package/dist/src/role.d.ts.map +1 -1
- package/dist/src/role.js +1 -1
- package/package.json +1 -1
- package/src/role.ts +31 -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.129-0",
|
|
9
9
|
"description": "CubeSigner TypeScript SDK",
|
|
10
10
|
"license": "MIT OR Apache-2.0",
|
|
11
11
|
"author": "Cubist, Inc.",
|
package/dist/src/role.d.ts
CHANGED
|
@@ -311,6 +311,30 @@ export type RequireRoleSession = {
|
|
|
311
311
|
/** Require either any role session or any one of the approved roles */
|
|
312
312
|
RequireRoleSession: "*" | string[];
|
|
313
313
|
};
|
|
314
|
+
/**
|
|
315
|
+
* Forwards the request parameters to this webhook which determines
|
|
316
|
+
* whether the request is allowed to be executed.
|
|
317
|
+
*/
|
|
318
|
+
export type WebhookPolicy = {
|
|
319
|
+
Webhook: {
|
|
320
|
+
/** The url of the webhook */
|
|
321
|
+
url: string;
|
|
322
|
+
/** Optional HTTP method to use. Defaults to POST. */
|
|
323
|
+
method?: string;
|
|
324
|
+
/** Optional HTTP headers to set */
|
|
325
|
+
headers?: Record<string, string>;
|
|
326
|
+
/**
|
|
327
|
+
* Request execution timeout in seconds; must be at least 1 not exceed 5 seconds.
|
|
328
|
+
* Defaults to 5.
|
|
329
|
+
*/
|
|
330
|
+
timeout?: number;
|
|
331
|
+
/**
|
|
332
|
+
* CubeSigner operations to which this policy should apply.
|
|
333
|
+
* When omitted, applies to all operations.
|
|
334
|
+
*/
|
|
335
|
+
restricted_operations?: OperationKind[];
|
|
336
|
+
};
|
|
337
|
+
};
|
|
314
338
|
/** Babylon staking policy */
|
|
315
339
|
export type BabylonStaking = {
|
|
316
340
|
BabylonStaking: {
|
|
@@ -374,7 +398,7 @@ export type AllowEip712Signing = typeof AllowEip712Signing;
|
|
|
374
398
|
export declare const AllowBtcMessageSigning: "AllowBtcMessageSigning";
|
|
375
399
|
export type AllowBtcMessageSigning = typeof AllowBtcMessageSigning;
|
|
376
400
|
/** Key policies that restrict the requests that the signing endpoints accept */
|
|
377
|
-
export type KeyDenyPolicy = TxReceiver | TxDeposit | TxValueLimit | TxGasCostLimit | IfErc20Tx | AssertErc20Tx | AssertContractTx | SuiTxReceivers | BtcTxReceivers | SourceIpAllowlist | SolanaInstructionPolicy | BtcSegwitValueLimit | RequireMfa | RequireRoleSession | BabylonStaking;
|
|
401
|
+
export type KeyDenyPolicy = TxReceiver | TxDeposit | TxValueLimit | TxGasCostLimit | IfErc20Tx | AssertErc20Tx | AssertContractTx | SuiTxReceivers | BtcTxReceivers | SourceIpAllowlist | SolanaInstructionPolicy | BtcSegwitValueLimit | RequireMfa | RequireRoleSession | BabylonStaking | WebhookPolicy;
|
|
378
402
|
/**
|
|
379
403
|
* Key policy
|
|
380
404
|
*
|
package/dist/src/role.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"role.d.ts","sourceRoot":"","sources":["../../src/role.ts"],"names":[],"mappings":"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
|
|
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,OAAO,EACP,QAAQ,EACR,QAAQ,EACR,KAAK,EACL,WAAW,EACX,eAAe,EAEf,qBAAqB,EACrB,aAAa,EACd,MAAM,GAAG,CAAC;AACX,OAAO,EAAE,GAAG,EAAE,iBAAiB,EAAE,MAAM,GAAG,CAAC;AAE3C;;;;GAIG;AACH,MAAM,MAAM,UAAU,GAAG;IAAE,UAAU,EAAE,MAAM,CAAA;CAAE,CAAC;AAEhD;;;;GAIG;AACH,MAAM,MAAM,cAAc,GAAG;IAAE,cAAc,EAAE,MAAM,EAAE,CAAA;CAAE,CAAC;AAE1D;;;;GAIG;AACH,MAAM,MAAM,cAAc,GAAG;IAAE,cAAc,EAAE,MAAM,EAAE,CAAA;CAAE,CAAC;AAE1D,qCAAqC;AACrC,oBAAY,eAAe;IACzB,iCAAiC;IACjC,SAAS,IAAA;IACT,+BAA+B;IAC/B,OAAO,IAAA;CACR;AAED,0DAA0D;AAC1D,MAAM,MAAM,SAAS,GAAG,aAAa,GAAG,eAAe,GAAG,aAAa,CAAC;AAExE,wDAAwD;AACxD,MAAM,MAAM,aAAa,GAAG;IAAE,SAAS,EAAE;QAAE,IAAI,EAAE,eAAe,CAAA;KAAE,CAAA;CAAE,CAAC;AAErE;;;;GAIG;AACH,MAAM,MAAM,eAAe,GAAG;IAAE,SAAS,EAAE;QAAE,IAAI,EAAE,eAAe,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAA;CAAE,CAAC;AAEvF;;;;GAIG;AACH,MAAM,MAAM,aAAa,GAAG;IAAE,SAAS,EAAE;QAAE,IAAI,EAAE,eAAe,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAA;CAAE,CAAC;AAEtF;;;GAGG;AACH,MAAM,MAAM,YAAY,GAAG,iBAAiB,GAAG,kBAAkB,CAAC;AAElE;;;;;GAKG;AACH,MAAM,MAAM,iBAAiB,GAAG;IAAE,YAAY,EAAE,MAAM,CAAA;CAAE,CAAC;AAEzD;;;;;;GAMG;AACH,MAAM,MAAM,kBAAkB,GAAG;IAC/B,YAAY,EAAE;QACZ,KAAK,EAAE,MAAM,CAAC;QACd,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;KACtB,CAAC;CACH,CAAC;AAEF;;;;GAIG;AACH,MAAM,MAAM,cAAc,GAAG;IAAE,cAAc,EAAE,MAAM,CAAA;CAAE,CAAC;AAExD;;;;;;;GAOG;AACH,MAAM,MAAM,SAAS,GAAG;IAAE,SAAS,EAAE,WAAW,CAAA;CAAE,CAAC;AAEnD;;GAEG;AACH,MAAM,MAAM,aAAa,GAAG,eAAe,CAAC;AAE5C;;;;;GAKG;AACH,MAAM,MAAM,kBAAkB,GAAG;IAC/B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,oBAAoB,CAAC,EAAE,eAAe,EAAE,CAAC;CAC1C,CAAC;AAEF;;;;;GAKG;AACH,MAAM,MAAM,iBAAiB,GAAG;IAC9B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,oBAAoB,CAAC,EAAE,eAAe,EAAE,CAAC;CAC1C,CAAC;AAEF;;;GAGG;AACH,MAAM,MAAM,WAAW,GAAG;IACxB,iBAAiB,CAAC,EAAE,eAAe,EAAE,CAAC;IACtC,eAAe,CAAC,EAAE,kBAAkB,EAAE,CAAC;IACvC,cAAc,CAAC,EAAE,iBAAiB,EAAE,CAAC;CACtC,CAAC;AAEF;;;;;;;;;;;;GAYG;AACH,MAAM,MAAM,gBAAgB,GAAG;IAC7B,gBAAgB,EAAE;QAChB,SAAS,EAAE;YACT,OAAO,EAAE,eAAe,CAAC;YACzB,OAAO,EAAE,MAAM,EAAE,CAAC;SACnB,EAAE,CAAC;KACL,CAAC;CACH,CAAC;AAEF;;;;;GAKG;AACH,MAAM,MAAM,oBAAoB,GAC5B,MAAM,GACN;IACE,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEN;;GAEG;AACH,MAAM,MAAM,wBAAwB,GAAG;IACrC,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,CACP;QACE,OAAO,EAAE,oBAAoB,GAAG,oBAAoB,EAAE,CAAC;KACxD,GACD,CAAC;QACC,yCAAyC;QACzC,MAAM,EAAE,MAAM,CAAC;KAChB,GAAG;QACF,KAAK,EAAE,MAAM,CAAC;KACf,CAAC,CACL,EAAE,CAAC;IACJ,IAAI,CAAC,EACD,MAAM,GACN;QACE,IAAI,EAAE,MAAM,CAAC;QACb,WAAW,EAAE,MAAM,CAAC;KACrB,EAAE,CAAC;CACT,CAAC;AAEF;;;GAGG;AACH,MAAM,MAAM,uBAAuB,GAAG;IACpC,uBAAuB,EAAE;QACvB,KAAK,CAAC,EAAE;YACN,GAAG,CAAC,EAAE,MAAM,CAAC;YACb,GAAG,CAAC,EAAE,MAAM,CAAC;SACd,CAAC;QACF,SAAS,CAAC,EAAE,wBAAwB,EAAE,CAAC;QACvC,QAAQ,CAAC,EAAE,wBAAwB,EAAE,CAAC;KACvC,CAAC;CACH,CAAC;AAEF;;;GAGG;AACH,MAAM,MAAM,mBAAmB,GAAG,wBAAwB,GAAG,yBAAyB,CAAC;AAEvF;;;;;GAKG;AACH,MAAM,MAAM,wBAAwB,GAAG;IACrC,mBAAmB,EAAE,MAAM,CAAC;CAC7B,CAAC;AAEF;;;;;GAKG;AACH,MAAM,MAAM,yBAAyB,GAAG;IACtC,mBAAmB,EAAE;QACnB,KAAK,EAAE,MAAM,CAAC;QACd,MAAM,CAAC,EAAE,MAAM,CAAC;KACjB,CAAC;CACH,CAAC;AAEF;;;;GAIG;AACH,MAAM,MAAM,iBAAiB,GAAG;IAAE,iBAAiB,EAAE,MAAM,EAAE,CAAA;CAAE,CAAC;AAEhE;;;;;;;;;;GAUG;AACH,MAAM,MAAM,SAAS,GAAG;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,iBAAiB,CAAC,EAAE,MAAM,EAAE,CAAC;IAC7B,iBAAiB,CAAC,EAAE,OAAO,EAAE,CAAC;IAC9B,qBAAqB,CAAC,EAAE,aAAa,EAAE,CAAC;IACxC,wDAAwD;IACxD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB;;;;OAIG;IACH,gBAAgB,CAAC,EAAE,mBAAmB,CAAC;IACvC;;;;;;OAMG;IACH,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG,IAAI,GAAG;IAAE,KAAK,EAAE,QAAQ,CAAA;CAAE,GAAG;IAAE,QAAQ,EAAE,WAAW,CAAA;CAAE,CAAC;AAEzF;;;;;;;;;;;;;;GAcG;AACH,MAAM,MAAM,UAAU,GAAG;IACvB,UAAU,EAAE,SAAS,CAAC;CACvB,CAAC;AAEF;;;;;;;;GAQG;AACH,MAAM,MAAM,kBAAkB,GAAG;IAC/B,uEAAuE;IACvE,kBAAkB,EAAE,GAAG,GAAG,MAAM,EAAE,CAAC;CACpC,CAAC;AAEF;;;GAGG;AACH,MAAM,MAAM,aAAa,GAAG;IAC1B,OAAO,EAAE;QACP,6BAA6B;QAC7B,GAAG,EAAE,MAAM,CAAC;QAEZ,qDAAqD;QACrD,MAAM,CAAC,EAAE,MAAM,CAAC;QAEhB,mCAAmC;QACnC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QAEjC;;;WAGG;QACH,OAAO,CAAC,EAAE,MAAM,CAAC;QAEjB;;;WAGG;QACH,qBAAqB,CAAC,EAAE,aAAa,EAAE,CAAC;KACzC,CAAC;CACH,CAAC;AAEF,6BAA6B;AAC7B,MAAM,MAAM,cAAc,GAAG;IAC3B,cAAc,EAAE;QACd;;;;;;WAMG;QACH,kBAAkB,CAAC,EAAE,MAAM,EAAE,CAAC;QAE9B;;;;;WAKG;QACH,6BAA6B,CAAC,EAAE,MAAM,EAAE,CAAC;QAEzC;;;WAGG;QACH,oBAAoB,CAAC,EAAE,MAAM,EAAE,CAAC;QAEhC;;;WAGG;QACH,wBAAwB,CAAC,EAAE,MAAM,EAAE,CAAC;QAEpC,oFAAoF;QACpF,mBAAmB,CAAC,EAAE,qBAAqB,CAAC,SAAS,CAAC,EAAE,CAAC;QAEzD;;;;WAIG;QACH,OAAO,CAAC,EAAE,MAAM,CAAC;QAEjB,yGAAyG;QACzG,aAAa,CAAC,EAAE,MAAM,CAAC;QAEvB,yGAAyG;QACzG,aAAa,CAAC,EAAE,MAAM,CAAC;QAEvB,uGAAuG;QACvG,iBAAiB,CAAC,EAAE,MAAM,CAAC;QAE3B,uGAAuG;QACvG,iBAAiB,CAAC,EAAE,MAAM,CAAC;QAE3B,kDAAkD;QAClD,kBAAkB,CAAC,EAAE,MAAM,CAAC;QAE5B,kDAAkD;QAClD,kBAAkB,CAAC,EAAE,MAAM,CAAC;KAC7B,CAAC;CACH,CAAC;AAEF,6BAA6B;AAC7B,eAAO,MAAM,mBAAmB,uBAAiC,CAAC;AAClE,MAAM,MAAM,mBAAmB,GAAG,OAAO,mBAAmB,CAAC;AAE7D,4BAA4B;AAC5B,eAAO,MAAM,kBAAkB,sBAAgC,CAAC;AAChE,MAAM,MAAM,kBAAkB,GAAG,OAAO,kBAAkB,CAAC;AAE3D,4BAA4B;AAC5B,eAAO,MAAM,kBAAkB,sBAAgC,CAAC;AAChE,MAAM,MAAM,kBAAkB,GAAG,OAAO,kBAAkB,CAAC;AAE3D,gCAAgC;AAChC,eAAO,MAAM,sBAAsB,0BAAoC,CAAC;AACxE,MAAM,MAAM,sBAAsB,GAAG,OAAO,sBAAsB,CAAC;AAEnE,gFAAgF;AAChF,MAAM,MAAM,aAAa,GACrB,UAAU,GACV,SAAS,GACT,YAAY,GACZ,cAAc,GACd,SAAS,GACT,aAAa,GACb,gBAAgB,GAChB,cAAc,GACd,cAAc,GACd,iBAAiB,GACjB,uBAAuB,GACvB,mBAAmB,GACnB,UAAU,GACV,kBAAkB,GAClB,cAAc,GACd,aAAa,CAAC;AAElB;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,MAAM,MAAM,SAAS,GAAG,aAAa,EAAE,CAAC;AAExC,MAAM,MAAM,aAAa,GACrB,aAAa,GACb,mBAAmB,GACnB,kBAAkB,GAClB,kBAAkB,GAClB,sBAAsB,CAAC;AAE3B,kBAAkB;AAClB,MAAM,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;AAEzC,iCAAiC;AACjC,qBAAa,eAAe;;IAE1B,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,MAAM,CAAC,EAAE,SAAS,CAAC;IAE5B,uBAAuB;IACjB,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC;IAK5B;;;;;;OAMG;gBACS,SAAS,EAAE,SAAS,EAAE,eAAe,EAAE,mBAAmB;CAKvE;AAED,aAAa;AACb,qBAAa,IAAI;;IAKf,gDAAgD;IAChD,IAAI,IAAI,IAAI,MAAM,GAAG,SAAS,CAE7B;IAED;;;;OAIG;IACH,IAAI,EAAE,IAAI,MAAM,CAEf;IAED;;;;OAIG;IACH,IAAI,MAAM,IAAI,QAAQ,CAErB;IAED,uBAAuB;IACjB,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;IAI7B,2CAA2C;IACrC,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC;IAKjC,uBAAuB;IACjB,MAAM;IAIZ,wBAAwB;IAClB,OAAO;IAIb;;;;OAIG;IACG,SAAS,CAAC,MAAM,EAAE,UAAU;IAIlC;;;;;;OAMG;IACG,YAAY,CAAC,MAAM,EAAE,UAAU;IAKrC;;;;OAIG;IACG,MAAM,IAAI,OAAO,CAAC,UAAU,CAAC;IAKnC;;;;;;;;;OASG;IACG,KAAK,CAAC,IAAI,CAAC,EAAE,QAAQ,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAK/C;;;;OAIG;IACG,OAAO,CAAC,MAAM,EAAE,MAAM;IAI5B;;;;OAIG;IACG,UAAU,CAAC,MAAM,EAAE,MAAM;IAI/B;;;;;;;;;;;OAWG;IACG,IAAI,CAAC,IAAI,CAAC,EAAE,QAAQ,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;IAKvD;;;;;OAKG;IACG,OAAO,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,MAAM,CAAC,EAAE,SAAS;IAQ7C;;;;;OAKG;IACG,MAAM,CAAC,GAAG,EAAE,GAAG,EAAE,MAAM,CAAC,EAAE,SAAS;IAIzC;;;;OAIG;IACG,SAAS,CAAC,GAAG,EAAE,GAAG;IAIxB;;;;;;;OAOG;IACG,aAAa,CACjB,OAAO,EAAE,MAAM,EACf,SAAS,CAAC,EAAE,eAAe,EAC3B,MAAM,CAAC,EAAE,KAAK,EAAE,GACf,OAAO,CAAC,WAAW,CAAC;IAIvB;;;;;;OAMG;IACG,QAAQ,CAAC,IAAI,CAAC,EAAE,QAAQ,GAAG,OAAO,CAAC,iBAAiB,EAAE,CAAC;IAS7D;;;;;;OAMG;gBACS,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,QAAQ;IAKhD;;;;;OAKG;YACW,MAAM;IAKpB;;;;;OAKG;YACW,KAAK;CAIpB"}
|
package/dist/src/role.js
CHANGED
|
@@ -254,4 +254,4 @@ class Role {
|
|
|
254
254
|
}
|
|
255
255
|
exports.Role = Role;
|
|
256
256
|
_Role_apiClient = new WeakMap(), _Role_data = new WeakMap();
|
|
257
|
-
//# 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} from \".\";\nimport { Key, SignerSessionInfo } from \".\";\n\n/**\n * Restrict the receiver for EVM transactions.\n *\n * @example { TxReceiver: \"0x8c594691c0e592ffa21f153a16ae41db5befcaaa\" }\n */\nexport type TxReceiver = { TxReceiver: string };\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: [ \"012345\" ] }}\n */\nexport type TxValueLimitWindow = {\n  TxValueLimit: {\n    limit: string;\n    window?: number;\n    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 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/** 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 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/** 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  | AssertContractTx\n  | SuiTxReceivers\n  | BtcTxReceivers\n  | SourceIpAllowlist\n  | SolanaInstructionPolicy\n  | BtcSegwitValueLimit\n  | RequireMfa\n  | RequireRoleSession\n  | BabylonStaking;\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  | AllowEip191Signing\n  | AllowEip712Signing\n  | AllowBtcMessageSigning;\n\n/** Role policy */\nexport type RolePolicy = KeyDenyPolicy[];\n\n/** A key guarded by a policy. */\nexport class KeyWithPolicies {\n  readonly #apiClient: ApiClient;\n  readonly keyId: string;\n  readonly policy?: KeyPolicy;\n\n  /** @returns The key */\n  async getKey(): Promise<Key> {\n    const keyInfo = await this.#apiClient.keyGet(this.keyId);\n    return new Key(this.#apiClient, keyInfo);\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.keyId = keyWithPolicies.key_id;\n    this.policy = keyWithPolicies.policy as unknown as KeyPolicy;\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  /** Delete the role. */\n  async delete(): Promise<void> {\n    await this.#apiClient.roleDelete(this.id);\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  /** Enable the role. */\n  async enable() {\n    await this.update({ enabled: true });\n  }\n\n  /** Disable the role. */\n  async disable() {\n    await this.update({ enabled: false });\n  }\n\n  /**\n   * Set new policy (overwriting any policies previously set for this role)\n   *\n   * @param policy The new policy to set\n   */\n  async setPolicy(policy: RolePolicy) {\n    await this.update({ policy: policy as unknown as Record<string, never>[] });\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   */\n  async appendPolicy(policy: RolePolicy) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy]);\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   * @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   */\n  async addUser(userId: string) {\n    await this.#apiClient.roleUserAdd(this.id, userId);\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   */\n  async removeUser(userId: string) {\n    await this.#apiClient.roleUserRemove(this.id, userId);\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   * 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  async addKeys(keys: Key[], policy?: KeyPolicy) {\n    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  async addKey(key: Key, policy?: KeyPolicy) {\n    await this.addKeys([key], policy);\n  }\n\n  /**\n   * Remove an existing key from an existing role.\n   *\n   * @param key The key to remove from the role.\n   */\n  async removeKey(key: Key) {\n    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   * @returns The updated role information.\n   */\n  private async update(request: UpdateRoleRequest): Promise<RoleInfo> {\n    this.#data = await this.#apiClient.roleUpdate(this.id, request);\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"]}
|
|
257
|
+
//# 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} from \".\";\nimport { Key, SignerSessionInfo } from \".\";\n\n/**\n * Restrict the receiver for EVM transactions.\n *\n * @example { TxReceiver: \"0x8c594691c0e592ffa21f153a16ae41db5befcaaa\" }\n */\nexport type TxReceiver = { TxReceiver: string };\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: [ \"012345\" ] }}\n */\nexport type TxValueLimitWindow = {\n  TxValueLimit: {\n    limit: string;\n    window?: number;\n    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 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 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/** 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  | 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  | AllowEip191Signing\n  | AllowEip712Signing\n  | AllowBtcMessageSigning;\n\n/** Role policy */\nexport type RolePolicy = KeyDenyPolicy[];\n\n/** A key guarded by a policy. */\nexport class KeyWithPolicies {\n  readonly #apiClient: ApiClient;\n  readonly keyId: string;\n  readonly policy?: KeyPolicy;\n\n  /** @returns The key */\n  async getKey(): Promise<Key> {\n    const keyInfo = await this.#apiClient.keyGet(this.keyId);\n    return new Key(this.#apiClient, keyInfo);\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.keyId = keyWithPolicies.key_id;\n    this.policy = keyWithPolicies.policy as unknown as KeyPolicy;\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  /** Delete the role. */\n  async delete(): Promise<void> {\n    await this.#apiClient.roleDelete(this.id);\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  /** Enable the role. */\n  async enable() {\n    await this.update({ enabled: true });\n  }\n\n  /** Disable the role. */\n  async disable() {\n    await this.update({ enabled: false });\n  }\n\n  /**\n   * Set new policy (overwriting any policies previously set for this role)\n   *\n   * @param policy The new policy to set\n   */\n  async setPolicy(policy: RolePolicy) {\n    await this.update({ policy: policy as unknown as Record<string, never>[] });\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   */\n  async appendPolicy(policy: RolePolicy) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy]);\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   * @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   */\n  async addUser(userId: string) {\n    await this.#apiClient.roleUserAdd(this.id, userId);\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   */\n  async removeUser(userId: string) {\n    await this.#apiClient.roleUserRemove(this.id, userId);\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   * 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  async addKeys(keys: Key[], policy?: KeyPolicy) {\n    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  async addKey(key: Key, policy?: KeyPolicy) {\n    await this.addKeys([key], policy);\n  }\n\n  /**\n   * Remove an existing key from an existing role.\n   *\n   * @param key The key to remove from the role.\n   */\n  async removeKey(key: Key) {\n    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   * @returns The updated role information.\n   */\n  private async update(request: UpdateRoleRequest): Promise<RoleInfo> {\n    this.#data = await this.#apiClient.roleUpdate(this.id, request);\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"]}
|
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.129-0",
|
|
9
9
|
"description": "CubeSigner TypeScript SDK",
|
|
10
10
|
"license": "MIT OR Apache-2.0",
|
|
11
11
|
"author": "Cubist, Inc.",
|
package/src/role.ts
CHANGED
|
@@ -331,6 +331,35 @@ export type RequireRoleSession = {
|
|
|
331
331
|
RequireRoleSession: "*" | string[];
|
|
332
332
|
};
|
|
333
333
|
|
|
334
|
+
/**
|
|
335
|
+
* Forwards the request parameters to this webhook which determines
|
|
336
|
+
* whether the request is allowed to be executed.
|
|
337
|
+
*/
|
|
338
|
+
export type WebhookPolicy = {
|
|
339
|
+
Webhook: {
|
|
340
|
+
/** The url of the webhook */
|
|
341
|
+
url: string;
|
|
342
|
+
|
|
343
|
+
/** Optional HTTP method to use. Defaults to POST. */
|
|
344
|
+
method?: string;
|
|
345
|
+
|
|
346
|
+
/** Optional HTTP headers to set */
|
|
347
|
+
headers?: Record<string, string>;
|
|
348
|
+
|
|
349
|
+
/**
|
|
350
|
+
* Request execution timeout in seconds; must be at least 1 not exceed 5 seconds.
|
|
351
|
+
* Defaults to 5.
|
|
352
|
+
*/
|
|
353
|
+
timeout?: number;
|
|
354
|
+
|
|
355
|
+
/**
|
|
356
|
+
* CubeSigner operations to which this policy should apply.
|
|
357
|
+
* When omitted, applies to all operations.
|
|
358
|
+
*/
|
|
359
|
+
restricted_operations?: OperationKind[];
|
|
360
|
+
};
|
|
361
|
+
};
|
|
362
|
+
|
|
334
363
|
/** Babylon staking policy */
|
|
335
364
|
export type BabylonStaking = {
|
|
336
365
|
BabylonStaking: {
|
|
@@ -425,7 +454,8 @@ export type KeyDenyPolicy =
|
|
|
425
454
|
| BtcSegwitValueLimit
|
|
426
455
|
| RequireMfa
|
|
427
456
|
| RequireRoleSession
|
|
428
|
-
| BabylonStaking
|
|
457
|
+
| BabylonStaking
|
|
458
|
+
| WebhookPolicy;
|
|
429
459
|
|
|
430
460
|
/**
|
|
431
461
|
* Key policy
|