@cubist-labs/cubesigner-sdk 0.4.236 → 0.4.239

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.
@@ -34,6 +34,8 @@ export * from "./contact";
34
34
  export * from "./scopes";
35
35
  /** Policies */
36
36
  export * from "./policy";
37
+ /** Buckets */
38
+ export * from "./bucket";
37
39
  /** Access control */
38
40
  export * from "./acl";
39
41
  /** Utils */
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,aAAa;AACb,cAAc,SAAS,CAAC;AACxB,UAAU;AACV,cAAc,qBAAqB,CAAC;AACpC,aAAa;AACb,cAAc,UAAU,CAAC;AACzB,gBAAgB;AAChB,OAAO,EAAE,UAAU,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AACvE,oBAAoB;AACpB,cAAc,OAAO,CAAC;AACtB,WAAW;AACX,cAAc,OAAO,CAAC;AACtB,aAAa;AACb,cAAc,UAAU,CAAC;AACzB,YAAY;AACZ,cAAc,QAAQ,CAAC;AACvB,UAAU;AACV,cAAc,OAAO,CAAC;AACtB,WAAW;AACX,cAAc,OAAO,CAAC;AACtB,iBAAiB;AACjB,cAAc,aAAa,CAAC;AAC5B,eAAe;AACf,cAAc,YAAY,CAAC;AAC3B,YAAY;AACZ,cAAc,gBAAgB,CAAC;AAC/B,eAAe;AACf,cAAc,kBAAkB,CAAC;AACjC,sBAAsB;AACtB,cAAc,kBAAkB,CAAC;AACjC,eAAe;AACf,cAAc,WAAW,CAAC;AAC1B,aAAa;AACb,cAAc,UAAU,CAAC;AACzB,eAAe;AACf,cAAc,UAAU,CAAC;AACzB,qBAAqB;AACrB,cAAc,OAAO,CAAC;AACtB,YAAY;AACZ,cAAc,QAAQ,CAAC;AACvB,oCAAoC;AACpC,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAClG,uCAAuC;AACvC,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AACxD,wBAAwB;AACxB,cAAc,OAAO,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,aAAa;AACb,cAAc,SAAS,CAAC;AACxB,UAAU;AACV,cAAc,qBAAqB,CAAC;AACpC,aAAa;AACb,cAAc,UAAU,CAAC;AACzB,gBAAgB;AAChB,OAAO,EAAE,UAAU,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AACvE,oBAAoB;AACpB,cAAc,OAAO,CAAC;AACtB,WAAW;AACX,cAAc,OAAO,CAAC;AACtB,aAAa;AACb,cAAc,UAAU,CAAC;AACzB,YAAY;AACZ,cAAc,QAAQ,CAAC;AACvB,UAAU;AACV,cAAc,OAAO,CAAC;AACtB,WAAW;AACX,cAAc,OAAO,CAAC;AACtB,iBAAiB;AACjB,cAAc,aAAa,CAAC;AAC5B,eAAe;AACf,cAAc,YAAY,CAAC;AAC3B,YAAY;AACZ,cAAc,gBAAgB,CAAC;AAC/B,eAAe;AACf,cAAc,kBAAkB,CAAC;AACjC,sBAAsB;AACtB,cAAc,kBAAkB,CAAC;AACjC,eAAe;AACf,cAAc,WAAW,CAAC;AAC1B,aAAa;AACb,cAAc,UAAU,CAAC;AACzB,eAAe;AACf,cAAc,UAAU,CAAC;AACzB,cAAc;AACd,cAAc,UAAU,CAAC;AACzB,qBAAqB;AACrB,cAAc,OAAO,CAAC;AACtB,YAAY;AACZ,cAAc,QAAQ,CAAC;AACvB,oCAAoC;AACpC,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAClG,uCAAuC;AACvC,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AACxD,wBAAwB;AACxB,cAAc,OAAO,CAAC"}
package/dist/src/index.js CHANGED
@@ -52,6 +52,8 @@ __exportStar(require("./contact"), exports);
52
52
  __exportStar(require("./scopes"), exports);
53
53
  /** Policies */
54
54
  __exportStar(require("./policy"), exports);
55
+ /** Buckets */
56
+ __exportStar(require("./bucket"), exports);
55
57
  /** Access control */
56
58
  __exportStar(require("./acl"), exports);
57
59
  /** Utils */
@@ -67,4 +69,4 @@ var diffie_hellman_1 = require("./diffie_hellman");
67
69
  Object.defineProperty(exports, "diffieHellmanDecrypt", { enumerable: true, get: function () { return diffie_hellman_1.diffieHellmanDecrypt; } });
68
70
  /** Ethers.js helpers */
69
71
  __exportStar(require("./evm"), exports);
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxhQUFhO0FBQ2IsMENBQXdCO0FBQ3hCLFVBQVU7QUFDVixzREFBb0M7QUFDcEMsYUFBYTtBQUNiLDJDQUF5QjtBQUN6QixnQkFBZ0I7QUFDaEIsb0RBQXVFO0FBQWxELGtIQUFBLG1CQUFtQixPQUFBO0FBQ3hDLG9CQUFvQjtBQUNwQix3Q0FBc0I7QUFDdEIsV0FBVztBQUNYLHdDQUFzQjtBQUN0QixhQUFhO0FBQ2IsMkNBQXlCO0FBQ3pCLFlBQVk7QUFDWix5Q0FBdUI7QUFDdkIsVUFBVTtBQUNWLHdDQUFzQjtBQUN0QixXQUFXO0FBQ1gsd0NBQXNCO0FBQ3RCLGlCQUFpQjtBQUNqQiw4Q0FBNEI7QUFDNUIsZUFBZTtBQUNmLDZDQUEyQjtBQUMzQixZQUFZO0FBQ1osaURBQStCO0FBQy9CLGVBQWU7QUFDZixtREFBaUM7QUFDakMsc0JBQXNCO0FBQ3RCLG1EQUFpQztBQUNqQyxlQUFlO0FBQ2YsNENBQTBCO0FBQzFCLGFBQWE7QUFDYiwyQ0FBeUI7QUFDekIsZUFBZTtBQUNmLDJDQUF5QjtBQUN6QixxQkFBcUI7QUFDckIsd0NBQXNCO0FBQ3RCLFlBQVk7QUFDWix5Q0FBdUI7QUFDdkIsb0NBQW9DO0FBQ3BDLDZDQUFrRztBQUF6Rix5R0FBQSxVQUFVLE9BQUE7QUFBRSwrR0FBQSxnQkFBZ0IsT0FBQTtBQUFFLGdIQUFBLGlCQUFpQixPQUFBO0FBQUUsK0dBQUEsZ0JBQWdCLE9BQUE7QUFDMUUsdUNBQXVDO0FBQ3ZDLG1EQUF3RDtBQUEvQyxzSEFBQSxvQkFBb0IsT0FBQTtBQUM3Qix3QkFBd0I7QUFDeEIsd0NBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqIEVycm9ycyAqL1xuZXhwb3J0ICogZnJvbSBcIi4vZXJyb3JcIjtcbi8qKiBBUEkgKi9cbmV4cG9ydCAqIGZyb20gXCIuL2NsaWVudC9hcGlfY2xpZW50XCI7XG4vKiogQ2xpZW50ICovXG5leHBvcnQgKiBmcm9tIFwiLi9jbGllbnRcIjtcbi8qKiBDYWxsYmFja3MgKi9cbmV4cG9ydCB7IEVycm9yRXZlbnQsIFNlc3Npb25FeHBpcmVkRXZlbnQgfSBmcm9tIFwiLi9jbGllbnQvYmFzZV9jbGllbnRcIjtcbi8qKiBPcmdhbml6YXRpb25zICovXG5leHBvcnQgKiBmcm9tIFwiLi9vcmdcIjtcbi8qKiBLZXlzICovXG5leHBvcnQgKiBmcm9tIFwiLi9rZXlcIjtcbi8qKiBFdmVudHMgKi9cbmV4cG9ydCAqIGZyb20gXCIuL2V2ZW50c1wiO1xuLyoqIFJvbGVzICovXG5leHBvcnQgKiBmcm9tIFwiLi9yb2xlXCI7XG4vKiogRW52ICovXG5leHBvcnQgKiBmcm9tIFwiLi9lbnZcIjtcbi8qKiBGaWRvICovXG5leHBvcnQgKiBmcm9tIFwiLi9tZmFcIjtcbi8qKiBQYWdpbmF0aW9uICovXG5leHBvcnQgKiBmcm9tIFwiLi9wYWdpbmF0b3JcIjtcbi8qKiBSZXNwb25zZSAqL1xuZXhwb3J0ICogZnJvbSBcIi4vcmVzcG9uc2VcIjtcbi8qKiBUeXBlcyAqL1xuZXhwb3J0ICogZnJvbSBcIi4vc2NoZW1hX3R5cGVzXCI7XG4vKiogU2Vzc2lvbnMgKi9cbmV4cG9ydCAqIGZyb20gXCIuL3NpZ25lcl9zZXNzaW9uXCI7XG4vKiogU2Vzc2lvbiBzdG9yYWdlICovXG5leHBvcnQgKiBmcm9tIFwiLi9jbGllbnQvc2Vzc2lvblwiO1xuLyoqIENvbnRhY3RzICovXG5leHBvcnQgKiBmcm9tIFwiLi9jb250YWN0XCI7XG4vKiogU2NvcGVzICovXG5leHBvcnQgKiBmcm9tIFwiLi9zY29wZXNcIjtcbi8qKiBQb2xpY2llcyAqL1xuZXhwb3J0ICogZnJvbSBcIi4vcG9saWN5XCI7XG4vKiogQWNjZXNzIGNvbnRyb2wgKi9cbmV4cG9ydCAqIGZyb20gXCIuL2FjbFwiO1xuLyoqIFV0aWxzICovXG5leHBvcnQgKiBmcm9tIFwiLi91dGlsXCI7XG4vKiogVXNlci1leHBvcnQgZGVjcnlwdGlvbiBoZWxwZXIgKi9cbmV4cG9ydCB7IGxvYWRDcnlwdG8sIGxvYWRTdWJ0bGVDcnlwdG8sIHVzZXJFeHBvcnREZWNyeXB0LCB1c2VyRXhwb3J0S2V5Z2VuIH0gZnJvbSBcIi4vdXNlcl9leHBvcnRcIjtcbi8qKiBEaWZmaWUtSGVsbG1hbiBkZWNyeXB0aW9uIGhlbHBlciAqL1xuZXhwb3J0IHsgZGlmZmllSGVsbG1hbkRlY3J5cHQgfSBmcm9tIFwiLi9kaWZmaWVfaGVsbG1hblwiO1xuLyoqIEV0aGVycy5qcyBoZWxwZXJzICovXG5leHBvcnQgKiBmcm9tIFwiLi9ldm1cIjtcbiJdfQ==
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxhQUFhO0FBQ2IsMENBQXdCO0FBQ3hCLFVBQVU7QUFDVixzREFBb0M7QUFDcEMsYUFBYTtBQUNiLDJDQUF5QjtBQUN6QixnQkFBZ0I7QUFDaEIsb0RBQXVFO0FBQWxELGtIQUFBLG1CQUFtQixPQUFBO0FBQ3hDLG9CQUFvQjtBQUNwQix3Q0FBc0I7QUFDdEIsV0FBVztBQUNYLHdDQUFzQjtBQUN0QixhQUFhO0FBQ2IsMkNBQXlCO0FBQ3pCLFlBQVk7QUFDWix5Q0FBdUI7QUFDdkIsVUFBVTtBQUNWLHdDQUFzQjtBQUN0QixXQUFXO0FBQ1gsd0NBQXNCO0FBQ3RCLGlCQUFpQjtBQUNqQiw4Q0FBNEI7QUFDNUIsZUFBZTtBQUNmLDZDQUEyQjtBQUMzQixZQUFZO0FBQ1osaURBQStCO0FBQy9CLGVBQWU7QUFDZixtREFBaUM7QUFDakMsc0JBQXNCO0FBQ3RCLG1EQUFpQztBQUNqQyxlQUFlO0FBQ2YsNENBQTBCO0FBQzFCLGFBQWE7QUFDYiwyQ0FBeUI7QUFDekIsZUFBZTtBQUNmLDJDQUF5QjtBQUN6QixjQUFjO0FBQ2QsMkNBQXlCO0FBQ3pCLHFCQUFxQjtBQUNyQix3Q0FBc0I7QUFDdEIsWUFBWTtBQUNaLHlDQUF1QjtBQUN2QixvQ0FBb0M7QUFDcEMsNkNBQWtHO0FBQXpGLHlHQUFBLFVBQVUsT0FBQTtBQUFFLCtHQUFBLGdCQUFnQixPQUFBO0FBQUUsZ0hBQUEsaUJBQWlCLE9BQUE7QUFBRSwrR0FBQSxnQkFBZ0IsT0FBQTtBQUMxRSx1Q0FBdUM7QUFDdkMsbURBQXdEO0FBQS9DLHNIQUFBLG9CQUFvQixPQUFBO0FBQzdCLHdCQUF3QjtBQUN4Qix3Q0FBc0IiLCJzb3VyY2VzQ29udGVudCI6WyIvKiogRXJyb3JzICovXG5leHBvcnQgKiBmcm9tIFwiLi9lcnJvclwiO1xuLyoqIEFQSSAqL1xuZXhwb3J0ICogZnJvbSBcIi4vY2xpZW50L2FwaV9jbGllbnRcIjtcbi8qKiBDbGllbnQgKi9cbmV4cG9ydCAqIGZyb20gXCIuL2NsaWVudFwiO1xuLyoqIENhbGxiYWNrcyAqL1xuZXhwb3J0IHsgRXJyb3JFdmVudCwgU2Vzc2lvbkV4cGlyZWRFdmVudCB9IGZyb20gXCIuL2NsaWVudC9iYXNlX2NsaWVudFwiO1xuLyoqIE9yZ2FuaXphdGlvbnMgKi9cbmV4cG9ydCAqIGZyb20gXCIuL29yZ1wiO1xuLyoqIEtleXMgKi9cbmV4cG9ydCAqIGZyb20gXCIuL2tleVwiO1xuLyoqIEV2ZW50cyAqL1xuZXhwb3J0ICogZnJvbSBcIi4vZXZlbnRzXCI7XG4vKiogUm9sZXMgKi9cbmV4cG9ydCAqIGZyb20gXCIuL3JvbGVcIjtcbi8qKiBFbnYgKi9cbmV4cG9ydCAqIGZyb20gXCIuL2VudlwiO1xuLyoqIEZpZG8gKi9cbmV4cG9ydCAqIGZyb20gXCIuL21mYVwiO1xuLyoqIFBhZ2luYXRpb24gKi9cbmV4cG9ydCAqIGZyb20gXCIuL3BhZ2luYXRvclwiO1xuLyoqIFJlc3BvbnNlICovXG5leHBvcnQgKiBmcm9tIFwiLi9yZXNwb25zZVwiO1xuLyoqIFR5cGVzICovXG5leHBvcnQgKiBmcm9tIFwiLi9zY2hlbWFfdHlwZXNcIjtcbi8qKiBTZXNzaW9ucyAqL1xuZXhwb3J0ICogZnJvbSBcIi4vc2lnbmVyX3Nlc3Npb25cIjtcbi8qKiBTZXNzaW9uIHN0b3JhZ2UgKi9cbmV4cG9ydCAqIGZyb20gXCIuL2NsaWVudC9zZXNzaW9uXCI7XG4vKiogQ29udGFjdHMgKi9cbmV4cG9ydCAqIGZyb20gXCIuL2NvbnRhY3RcIjtcbi8qKiBTY29wZXMgKi9cbmV4cG9ydCAqIGZyb20gXCIuL3Njb3Blc1wiO1xuLyoqIFBvbGljaWVzICovXG5leHBvcnQgKiBmcm9tIFwiLi9wb2xpY3lcIjtcbi8qKiBCdWNrZXRzICovXG5leHBvcnQgKiBmcm9tIFwiLi9idWNrZXRcIjtcbi8qKiBBY2Nlc3MgY29udHJvbCAqL1xuZXhwb3J0ICogZnJvbSBcIi4vYWNsXCI7XG4vKiogVXRpbHMgKi9cbmV4cG9ydCAqIGZyb20gXCIuL3V0aWxcIjtcbi8qKiBVc2VyLWV4cG9ydCBkZWNyeXB0aW9uIGhlbHBlciAqL1xuZXhwb3J0IHsgbG9hZENyeXB0bywgbG9hZFN1YnRsZUNyeXB0bywgdXNlckV4cG9ydERlY3J5cHQsIHVzZXJFeHBvcnRLZXlnZW4gfSBmcm9tIFwiLi91c2VyX2V4cG9ydFwiO1xuLyoqIERpZmZpZS1IZWxsbWFuIGRlY3J5cHRpb24gaGVscGVyICovXG5leHBvcnQgeyBkaWZmaWVIZWxsbWFuRGVjcnlwdCB9IGZyb20gXCIuL2RpZmZpZV9oZWxsbWFuXCI7XG4vKiogRXRoZXJzLmpzIGhlbHBlcnMgKi9cbmV4cG9ydCAqIGZyb20gXCIuL2V2bVwiO1xuIl19
@@ -1,4 +1,4 @@
1
- import type { ApiClient, C2FResponse, CubeSignerResponse, EditPolicy, Empty, InvokeC2FResponse, JsonValue, KeyPolicy, KeyPolicyRule, MfaReceipts, PolicyAttachedToId, PolicyInfo, PolicyType, RolePolicy, RolePolicyRule, UpdatePolicyRequest, WasmRule, Acl, AceAttribute, PolicyAction } from ".";
1
+ import type { ApiClient, C2FResponse, CubeSignerResponse, EditPolicy, Empty, InvokeC2FResponse, JsonValue, KeyPolicy, KeyPolicyRule, MfaReceipts, PolicyAttachedToId, PolicyType, RolePolicy, RolePolicyRule, UpdatePolicyRequest, WasmRule, AceAttribute, PolicyAction, Ace, PolicyInfo } from ".";
2
2
  /**
3
3
  * Named policy rule type.
4
4
  */
@@ -7,7 +7,7 @@ export type PolicyRule = KeyPolicyRule | RolePolicyRule | WasmRule;
7
7
  * A helper type for {@link PolicyInfo} with a more detailed `acl` type.
8
8
  */
9
9
  type NamedPolicyInfo = PolicyInfo & {
10
- acl?: Acl<PolicyAction, PolicyCtx>;
10
+ acl?: PolicyAcl;
11
11
  };
12
12
  /**
13
13
  * The policy info for a named key policy.
@@ -36,7 +36,9 @@ export type C2FInfo = WasmPolicyInfo;
36
36
  */
37
37
  export type Version = `v${number}` | `latest`;
38
38
  /** A policy access control entry. */
39
- export type PolicyAcl = Acl<PolicyAction, PolicyCtx>;
39
+ export type PolicyAce = Ace<PolicyAction, PolicyCtx>;
40
+ /** A policy access control list. */
41
+ export type PolicyAcl = PolicyAce[];
40
42
  /** Additional contexts when using policies. */
41
43
  export type PolicyCtx = {
42
44
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"policy.d.ts","sourceRoot":"","sources":["../../src/policy.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"policy.d.ts","sourceRoot":"","sources":["../../src/policy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,SAAS,EACT,WAAW,EACX,kBAAkB,EAClB,UAAU,EACV,KAAK,EACL,iBAAiB,EACjB,SAAS,EACT,SAAS,EACT,aAAa,EACb,WAAW,EACX,kBAAkB,EAClB,UAAU,EACV,UAAU,EACV,cAAc,EACd,mBAAmB,EACnB,QAAQ,EACR,YAAY,EACZ,YAAY,EACZ,GAAG,EACH,UAAU,EACX,MAAM,GAAG,CAAC;AAIX;;GAEG;AACH,MAAM,MAAM,UAAU,GAAG,aAAa,GAAG,cAAc,GAAG,QAAQ,CAAC;AAEnE;;GAEG;AACH,KAAK,eAAe,GAAG,UAAU,GAAG;IAClC,GAAG,CAAC,EAAE,SAAS,CAAC;CACjB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,aAAa,GAAG,eAAe,GAAG;IAC5C,WAAW,EAAE,KAAK,CAAC;CACpB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG,eAAe,GAAG;IAC7C,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG,eAAe,GAAG;IAC7C,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,OAAO,GAAG,cAAc,CAAC;AAErC;;GAEG;AACH,MAAM,MAAM,OAAO,GAAG,IAAI,MAAM,EAAE,GAAG,QAAQ,CAAC;AAE9C,qCAAqC;AACrC,MAAM,MAAM,SAAS,GAAG,GAAG,CAAC,YAAY,EAAE,SAAS,CAAC,CAAC;AAErD,oCAAoC;AACpC,MAAM,MAAM,SAAS,GAAG,SAAS,EAAE,CAAC;AAEpC,+CAA+C;AAC/C,MAAM,MAAM,SAAS,GAAG;IACtB;;;OAGG;IACH,SAAS,EAAE,YAAY,CAAC,cAAc,CAAC,CAAC;CACzC,CAAC;AAEF,0DAA0D;AAC1D,MAAM,MAAM,cAAc;AACxB,wBAAwB;AACtB,MAAM;AACR,8BAA8B;GAC5B;IAAE,OAAO,EAAE,GAAG,GAAG,MAAM,EAAE,CAAC;IAAC,QAAQ,EAAE,GAAG,GAAG,MAAM,EAAE,CAAA;CAAE,CAAC;AAE1D;;;;;;;;GAQG;AACH,wBAAsB,kBAAkB,CACtC,SAAS,EAAE,SAAS,EACpB,MAAM,EAAE,UAAU,GACjB,OAAO,CAAC,MAAM,CAAC,CAoBjB;AAED;;;;;;;;GAQG;AACH,eAAO,MAAM,gBAAgB,2BAAqB,CAAC;AAEnD;;GAEG;AACH,8BAAsB,WAAW;IAC/B,SAAS,CAAC,QAAQ,CAAC,SAAS,EAAE,SAAS,CAAC;IACxC,SAAS,CAAC,IAAI,EAAE,eAAe,CAAC;IAEhC;;;;;;OAMG;IACH,MAAM,CAAC,QAAQ,CAAC,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,UAAU,GAAG,WAAW;IAWpE,6BAA6B;IAC7B,IAAI,EAAE,IAAI,MAAM,CAEf;IAED,+BAA+B;IAC/B,IAAI,UAAU,IAAI,UAAU,CAE3B;IAED;;;;;OAKG;IACG,OAAO,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAY1D;;;;OAIG;IACG,MAAM,IAAI,OAAO,CAAC,gBAAgB,CAAC;IAKzC;;;;OAIG;IACG,IAAI,IAAI,OAAO,CAAC,MAAM,CAAC;IAK7B;;;;;;OAMG;IACG,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,WAAW;IAIpD;;;;;OAKG;IACG,KAAK,IAAI,OAAO,CAAC,MAAM,CAAC;IAK9B;;;;;;OAMG;IACG,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,WAAW;IAItD;;;;OAIG;IACG,QAAQ,IAAI,OAAO,CAAC,SAAS,CAAC;IAKpC;;;;;;OAMG;IACG,WAAW,CAAC,QAAQ,EAAE,SAAS,EAAE,UAAU,CAAC,EAAE,WAAW;IAI/D;;;;OAIG;IACG,UAAU,IAAI,OAAO,CAAC,UAAU,GAAG,SAAS,CAAC;IAKnD;;;;;;OAMG;IACG,aAAa,CAAC,UAAU,EAAE,UAAU,EAAE,UAAU,CAAC,EAAE,WAAW;IAIpE;;;;OAIG;IACG,GAAG,IAAI,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC;IAK3C;;;;;;OAMG;IACG,MAAM,CAAC,GAAG,EAAE,SAAS,EAAE,UAAU,CAAC,EAAE,WAAW;IAIrD;;;OAGG;IACG,WAAW,IAAI,OAAO,CAAC,kBAAkB,EAAE,CAAC;IAwBlD;;;;;;;;OAQG;IACG,MAAM,CAAC,UAAU,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;IAQ1E;;;;;;OAMG;IACH,SAAS,aAAa,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,eAAe;IAKjE;;;;;;;;OAQG;cACa,MAAM,CACpB,OAAO,EAAE,mBAAmB,EAC5B,UAAU,CAAC,EAAE,WAAW,GACvB,OAAO,CAAC,eAAe,CAAC;IAM3B;;;;;;OAMG;cACa,KAAK,CAAC,OAAO,GAAE,OAAkB,GAAG,OAAO,CAAC,eAAe,CAAC;CAI7E;AAED;;GAEG;AACH,qBAAa,cAAe,SAAQ,WAAW;IACpC,IAAI,EAAE,aAAa,CAAC;IAE7B;;;;;;OAMG;IACG,QAAQ,CAAC,KAAK,EAAE,SAAS,EAAE,UAAU,CAAC,EAAE,WAAW;IAQzD;;;;;;OAMG;gBACS,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,aAAa;CAItD;AAED;;GAEG;AACH,qBAAa,eAAgB,SAAQ,WAAW;IACrC,IAAI,EAAE,cAAc,CAAC;IAE9B;;;;;;OAMG;IACG,QAAQ,CAAC,KAAK,EAAE,UAAU,EAAE,UAAU,CAAC,EAAE,WAAW;IAQ1D;;;;;;OAMG;gBACS,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,cAAc;CAIvD;AAED;;;;;GAKG;AACH,qBAAa,WAAY,SAAQ,WAAW;IACjC,IAAI,EAAE,OAAO,CAAC;IAEvB;;;;;;;OAOG;IACG,eAAe,CAAC,MAAM,EAAE,UAAU,EAAE,UAAU,CAAC,EAAE,WAAW;IASlE;;;;;;;;;OASG;IACG,MAAM,CACV,KAAK,CAAC,EAAE,MAAM,EACd,OAAO,GAAE,OAAkB,EAC3B,OAAO,CAAC,EAAE,SAAS,EACnB,MAAM,CAAC,EAAE,MAAM,GACd,OAAO,CAAC,aAAa,CAAC;IAYzB;;;;;;;OAOG;IACH,aAAa,WA5CiB,UAAU,eAAe,WAAW,mBA4C7B;IAMrC;;;;;;OAMG;gBACS,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO;CAIhD;AAED;;GAEG;AACH,qBAAa,gBAAgB;;IAK3B;;;;OAIG;IACH,IAAI,EAAE,IAAI,MAAM,CAEf;IAED;;OAEG;IACH,IAAI,OAAO,IAAI,OAAO,CAErB;IAED;;;;OAIG;IACH,IAAI,KAAK,IAAI,UAAU,EAAE,CAExB;IAED;;;OAGG;IACG,WAAW,IAAI,OAAO,CAAC,kBAAkB,EAAE,CAAC;IASlD;;;;;;OAMG;gBACS,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,eAAe;IAKvD;;;;;OAKG;YACW,KAAK;CAIpB;AAED;;GAEG;AACH,qBAAa,aAAa;;IAGxB,2CAA2C;IAC3C,IAAI,QAAQ,IAAI,WAAW,CAE1B;IAED,2EAA2E;IAC3E,IAAI,MAAM,IAAI,MAAM,CAEnB;IAED,0EAA0E;IAC1E,IAAI,MAAM,IAAI,MAAM,CAEnB;IAMD;;;;;OAKG;IACH,OAAO,CAAC,OAAO;IAIf;;;;;OAKG;gBACS,IAAI,EAAE,iBAAiB;CAGpC;AAID,yCAAyC;AACzC,MAAM,MAAM,eAAe,GAAG,WAAW,CAAC;AAC1C,yCAAyC;AACzC,eAAO,MAAM,eAAe,oBAAc,CAAC;AAE3C,kDAAkD;AAClD,MAAM,MAAM,gBAAgB,GAAG,aAAa,CAAC;AAC7C,kDAAkD;AAClD,eAAO,MAAM,gBAAgB,sBAAgB,CAAC"}
@@ -354,7 +354,7 @@ class C2FFunction extends NamedPolicy {
354
354
  async setWasmFunction(policy, mfaReceipt) {
355
355
  // upload the policy object
356
356
  const hash = await uploadWasmFunction(this.apiClient, policy);
357
- // update this policy with the new policy verison.
357
+ // update this policy with the new policy version.
358
358
  const body = { rules: [{ hash }] };
359
359
  this.data = (await this.update(body, mfaReceipt));
360
360
  }
@@ -513,4 +513,4 @@ _C2FInvocation_data = new WeakMap();
513
513
  exports.NamedWasmPolicy = C2FFunction;
514
514
  /** The result of invoking a named WASM policy. */
515
515
  exports.PolicyInvocation = C2FInvocation;
516
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy.js","sourceRoot":"","sources":["../../src/policy.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  ApiClient,\n  C2FResponse,\n  CubeSignerResponse,\n  EditPolicy,\n  Empty,\n  InvokeC2FResponse,\n  JsonValue,\n  KeyPolicy,\n  KeyPolicyRule,\n  MfaReceipts,\n  PolicyAttachedToId,\n  PolicyInfo,\n  PolicyType,\n  RolePolicy,\n  RolePolicyRule,\n  UpdatePolicyRequest,\n  WasmRule,\n  Acl,\n  AceAttribute,\n  PolicyAction,\n} from \".\";\n\nimport { loadSubtleCrypto } from \".\";\n\n/**\n * Named policy rule type.\n */\nexport type PolicyRule = KeyPolicyRule | RolePolicyRule | WasmRule;\n\n/**\n * A helper type for {@link PolicyInfo} with a more detailed `acl` type.\n */\ntype NamedPolicyInfo = PolicyInfo & {\n  acl?: Acl<PolicyAction, PolicyCtx>;\n};\n\n/**\n * The policy info for a named key policy.\n */\nexport type KeyPolicyInfo = NamedPolicyInfo & {\n  policy_type: \"Key\";\n};\n\n/**\n * The policy info for a named role policy.\n */\nexport type RolePolicyInfo = NamedPolicyInfo & {\n  policy_type: \"Role\";\n};\n\n/**\n * The policy info for a named wasm policy.\n */\nexport type WasmPolicyInfo = NamedPolicyInfo & {\n  policy_type: \"Wasm\";\n};\n\n/**\n * The policy info for a Confidential Cloud Function.\n */\nexport type C2FInfo = WasmPolicyInfo;\n\n/**\n * A helper type for valid named policy version strings.\n */\nexport type Version = `v${number}` | `latest`;\n\n/** A policy access control entry. */\nexport type PolicyAcl = Acl<PolicyAction, PolicyCtx>;\n\n/** Additional contexts when using policies. */\nexport type PolicyCtx = {\n  /**\n   * The resources (keys, roles, and key-in-roles) that the access control entry\n   * applies to.\n   */\n  resources: AceAttribute<PolicyResource>;\n};\n\n/** A resource a policy is invoked with or attached to. */\nexport type PolicyResource =\n  /** A key or role id. */\n  | string\n  /** Keys attached to roles. */\n  | { key_ids: \"*\" | string[]; role_ids: \"*\" | string[] };\n\n/**\n * Upload the given Wasm Confidential Cloud Function.\n *\n * @param apiClient The API client to use.\n * @param policy The Wasm function.\n * @returns The Wasm function object hash to use for creating/updating C2F policies.\n * @throws if uploading the policy fails.\n * @internal\n */\nexport async function uploadWasmFunction(\n  apiClient: ApiClient,\n  policy: Uint8Array,\n): Promise<string> {\n  // get the SHA-256 hash of the function to get the upload url.\n  const subtle = await loadSubtleCrypto();\n  const hashBytes = await subtle.digest(\"SHA-256\", policy);\n  const hash = \"0x\" + Buffer.from(hashBytes).toString(\"hex\");\n\n  // get the upload URL\n  const { signed_url } = await apiClient.wasmPolicyUpload({ hash });\n\n  // upload the wasm object\n  const resp = await fetch(signed_url, {\n    method: \"PUT\",\n    body: policy,\n  });\n\n  if (!resp.ok) {\n    throw new Error(`Failed to upload function with status: ${resp.status}: ${resp.statusText}`);\n  }\n\n  return hash;\n}\n\n/**\n * Upload the given Wasm policy.\n *\n * @param apiClient The API client to use.\n * @param policy The Wasm function.\n * @returns The Wasm function object hash to use for creating/updating C2F policies.\n * @throws if uploading the policy fails.\n * @internal\n */\nexport const uploadWasmPolicy = uploadWasmFunction;\n\n/**\n * Abstract class for shared methods between key, role and Wasm policies.\n */\nexport abstract class NamedPolicy {\n  protected readonly apiClient: ApiClient;\n  protected data: NamedPolicyInfo;\n\n  /**\n   * Helper method for creating a named policy from a policy info.\n   *\n   * @param apiClient The api client to use.\n   * @param info The policy info.\n   * @returns The named policy object for the given info.\n   */\n  static fromInfo(apiClient: ApiClient, info: PolicyInfo): NamedPolicy {\n    switch (info.policy_type) {\n      case \"Key\":\n        return new NamedKeyPolicy(apiClient, info as KeyPolicyInfo);\n      case \"Role\":\n        return new NamedRolePolicy(apiClient, info as RolePolicyInfo);\n      case \"Wasm\":\n        return new C2FFunction(apiClient, info as C2FInfo);\n    }\n  }\n\n  /** @returns The policy id */\n  get id(): string {\n    return this.data.policy_id;\n  }\n\n  /** @returns The policy type */\n  get policyType(): PolicyType {\n    return this.data.policy_type;\n  }\n\n  /**\n   * Get a specific version of the policy.\n   *\n   * @param version The policy version to get.\n   * @returns The specific version of the policy.\n   */\n  async version(version: Version): Promise<NamedPolicyRules> {\n    let versionInfo;\n\n    if (version == `v${this.data.version}`) {\n      versionInfo = this.data;\n    } else {\n      versionInfo = (await this.apiClient.policyGet(this.id, version)) as NamedPolicyInfo;\n    }\n\n    return new NamedPolicyRules(this.apiClient, versionInfo);\n  }\n\n  /**\n   * Get the latest version of the policy.\n   *\n   * @returns The latest version of the policy.\n   */\n  async latest(): Promise<NamedPolicyRules> {\n    const data = await this.fetch(\"latest\");\n    return new NamedPolicyRules(this.apiClient, data);\n  }\n\n  /**\n   * Fetch and return the current name of the policy.\n   *\n   * @returns The policy name.\n   */\n  async name(): Promise<string> {\n    const data = await this.fetch();\n    return data.name;\n  }\n\n  /**\n   * Set a new name for the policy.\n   *\n   * @param name The new policy name.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setName(name: string, mfaReceipt?: MfaReceipts) {\n    await this.update({ name }, mfaReceipt);\n  }\n\n  /**\n   * Fetch and return the current owner of the policy.\n   *\n   * @returns The user id of the policy owner.\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 a new owner for the policy.\n   *\n   * @param owner The new owner of the policy.\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   * Fetch and return the metadata value for the policy.\n   *\n   * @returns The policy metadata.\n   */\n  async metadata(): Promise<JsonValue> {\n    const data = await this.fetch();\n    return data.metadata as JsonValue;\n  }\n\n  /**\n   * Sets a new metadata value for the named policy (overwriting the existing value).\n   *\n   * @param metadata The new metadata for the named policy.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setMetadata(metadata: JsonValue, mfaReceipt?: MfaReceipts) {\n    await this.update({ metadata }, mfaReceipt);\n  }\n\n  /**\n   * Fetch and return the edit policy for the named policy.\n   *\n   * @returns The edit policy for this named policy.\n   */\n  async editPolicy(): Promise<EditPolicy | undefined> {\n    const data = await this.fetch();\n    return data.edit_policy;\n  }\n\n  /**\n   * Set a new edit policy for the named policy.\n   *\n   * @param editPolicy The new edit policy.\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   * Fetch and return the access control entries for the named policy.\n   *\n   * @returns The access control entries for this named policy.\n   */\n  async acl(): Promise<PolicyAcl | undefined> {\n    const data = await this.fetch();\n    return data.acl;\n  }\n\n  /**\n   * Sets new access control entries for the named policy (overwriting the existing entries).\n   *\n   * @param acl The access control entries to set.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setAcl(acl: PolicyAcl, mfaReceipt?: MfaReceipts) {\n    await this.update({ acl }, mfaReceipt);\n  }\n\n  /**\n   * @returns a list of all keys, roles, and key-in-roles that all versions of this policy\n   * are attached to.\n   */\n  async allAttached(): Promise<PolicyAttachedToId[]> {\n    // there is no single-call way to achieve this. So instead, we\n    // 1. Get the latest version of the policy\n    // 2. For all versions `v0` to `latest`, fetch the policy info\n    // 3. Join all policy `attached_to` arrays\n    const data = await this.fetch(\"latest\");\n\n    const latest = data.version;\n    const versions = Array.from(Array(latest + 1).keys());\n    const batchSize = 10;\n    let allAttached: PolicyAttachedToId[] = [];\n\n    for (let batch = 0; batch < versions.length; batch += batchSize) {\n      const rs = await Promise.all(\n        versions.slice(batch, batch + batchSize).map((version) => {\n          return this.apiClient.policyGet(this.id, `v${version}`);\n        }),\n      );\n      allAttached = allAttached.concat(rs.flatMap((policy) => policy.attached_to));\n    }\n\n    return allAttached.concat(data.attached_to);\n  }\n\n  /**\n   * Delete this policy.\n   *\n   * This can fail if the policy is still attached to any key, role, or key in role.\n   *\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns A response which can be used to approve MFA if needed\n   * @throws if MFA is required and no receipts are provided\n   */\n  async delete(mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<Empty>> {\n    return await this.apiClient.policyDelete(this.id, mfaReceipt);\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  protected constructor(apiClient: ApiClient, data: NamedPolicyInfo) {\n    this.apiClient = apiClient;\n    this.data = data;\n  }\n\n  /**\n   * Update the policy.\n   *\n   * @param request The JSON request to send to the API server.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns The updated policy information.\n   * @throws if MFA is required and no receipts are provided\n   * @internal\n   */\n  protected async update(\n    request: UpdatePolicyRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<NamedPolicyInfo> {\n    const resp = await this.apiClient.policyUpdate(this.id, request, mfaReceipt);\n    this.data = resp.data() as NamedPolicyInfo;\n    return this.data;\n  }\n\n  /**\n   * Fetch the policy information.\n   *\n   * @param version The version of the policy to fetch. Defaults to \"latest\".\n   * @returns The policy information.\n   * @internal\n   */\n  protected async fetch(version: Version = \"latest\"): Promise<NamedPolicyInfo> {\n    this.data = (await this.apiClient.policyGet(this.id, version)) as NamedPolicyInfo;\n    return this.data;\n  }\n}\n\n/**\n * A representation of a named key policy.\n */\nexport class NamedKeyPolicy extends NamedPolicy {\n  override data: KeyPolicyInfo;\n\n  /**\n   * Update the policy with new rules.\n   *\n   * @param rules The new rules to update the policy with.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setRules(rules: KeyPolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ rules }, mfaReceipt);\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: KeyPolicyInfo) {\n    super(apiClient, data);\n    this.data = data;\n  }\n}\n\n/**\n * A representation of a named role policy.\n */\nexport class NamedRolePolicy extends NamedPolicy {\n  override data: RolePolicyInfo;\n\n  /**\n   * Update the policy with new rules.\n   *\n   * @param rules The new rules to update the policy with.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setRules(rules: RolePolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ rules }, mfaReceipt);\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: RolePolicyInfo) {\n    super(apiClient, data);\n    this.data = data;\n  }\n}\n\n/**\n * A representation of a Confidential Cloud Function (C2F).\n *\n * This class extends NamedPolicy because C2F functions can be attached\n * to keys and roles like a named policy.\n */\nexport class C2FFunction extends NamedPolicy {\n  override data: C2FInfo;\n\n  /**\n   * Update this C2F function with a new Wasm function.\n   *\n   * @param policy The new Wasm function.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if uploading the function fails.\n   * @throws if MFA is required and no receipts are provided.\n   */\n  async setWasmFunction(policy: Uint8Array, mfaReceipt?: MfaReceipts) {\n    // upload the policy object\n    const hash = await uploadWasmFunction(this.apiClient, policy);\n\n    // update this policy with the new policy verison.\n    const body: UpdatePolicyRequest = { rules: [{ hash }] };\n    this.data = (await this.update(body, mfaReceipt)) as C2FInfo;\n  }\n\n  /**\n   * Invoke this Confidential Cloud Function.\n   *\n   * @param keyId The optional key id that the function will be invoked with.\n   * @param version The version of the function to invoke. Defaults to \"latest\".\n   * @param request The optional sign request body that will be sent to the function.\n   * @param roleId The optional role id that the function will be invoked by.\n   * If `undefined`, the policy will be invoked by the user session.\n   * @returns The result of invoking the function.\n   */\n  async invoke(\n    keyId?: string,\n    version: Version = \"latest\",\n    request?: JsonValue,\n    roleId?: string,\n  ): Promise<C2FInvocation> {\n    // TODO Ideally, `version` should be the first parameter. But for backwards\n    // compatibility, we keep `keyId` as the first parameter for now.\n    const resp = await this.apiClient.policyInvoke(this.id, version, {\n      key_id: keyId,\n      request,\n      role_id: roleId,\n    });\n    return new PolicyInvocation(resp);\n  }\n\n  // Backwards compability with Named Wasm Policy names\n  /**\n   * Update the policy with the new Wasm policy.\n   *\n   * @param policy The new Wasm policy object.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if uploading the policy object fails.\n   * @throws if MFA is required and no receipts are provided.\n   */\n  setWasmPolicy = this.setWasmFunction;\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: C2FInfo) {\n    super(apiClient, data);\n    this.data = data;\n  }\n}\n\n/**\n * A specific version of a named policy.\n */\nexport class NamedPolicyRules {\n  /** The CubeSigner instance that this policy is associated with */\n  readonly #apiClient: ApiClient;\n  #data: NamedPolicyInfo;\n\n  /**\n   * @returns The ID of the policy.\n   *\n   * @example NamedPolicy#a4a45cc2-0642-4c98-b6bd-0da347d608a4\n   */\n  get id(): string {\n    return this.#data.policy_id;\n  }\n\n  /**\n   * @returns The version of the policy this object contains.\n   */\n  get version(): Version {\n    return `v${this.#data.version}`;\n  }\n\n  /**\n   * @returns The policy rules.\n   *\n   * @example [ \"AssertErc20Tx\" ]\n   */\n  get rules(): PolicyRule[] {\n    return this.#data.rules as PolicyRule[];\n  }\n\n  /**\n   * @returns a list of all keys, roles, and key-in-roles this version of the policy\n   *          is attached to.\n   */\n  async allAttached(): Promise<PolicyAttachedToId[]> {\n    const data = await this.fetch();\n    return data.attached_to;\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: NamedPolicyInfo) {\n    this.#apiClient = apiClient;\n    this.#data = data;\n  }\n\n  /**\n   * Fetch the policy information.\n   *\n   * @returns The policy information.\n   * @internal\n   */\n  private async fetch(): Promise<NamedPolicyInfo> {\n    this.#data = (await this.#apiClient.policyGet(this.id, this.version)) as NamedPolicyInfo;\n    return this.#data;\n  }\n}\n\n/**\n * The result of invoking a Confidential Cloud Function.\n */\nexport class C2FInvocation {\n  readonly #data: InvokeC2FResponse;\n\n  /** @returns The policy response itself. */\n  get response(): C2FResponse {\n    return this.#data.response;\n  }\n\n  /** @returns The standard output stream. Usually a UTF-8 encoded string. */\n  get stdout(): Buffer {\n    return this.fromHex(this.#data.stdout);\n  }\n\n  /** @returns The standard error stream. Usually a UTF-8 encoded string. */\n  get stderr(): Buffer {\n    return this.fromHex(this.#data.stderr);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Helper method for converting hex-encoded data to a `Buffer`.\n   *\n   * @param hex The hex-encoded data.\n   * @returns The data.\n   */\n  private fromHex(hex: string): Buffer {\n    return Buffer.from(hex.startsWith(\"0x\") ? hex.slice(2) : hex, \"hex\");\n  }\n\n  /**\n   * Constructor.\n   *\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(data: InvokeC2FResponse) {\n    this.#data = data;\n  }\n}\n\n// Backwards compability with Named Wasm Policy names\n\n/** A representation of a Wasm policy. */\nexport type NamedWasmPolicy = C2FFunction;\n/** A representation of a Wasm policy. */\nexport const NamedWasmPolicy = C2FFunction;\n\n/** The result of invoking a named WASM policy. */\nexport type PolicyInvocation = C2FInvocation;\n/** The result of invoking a named WASM policy. */\nexport const PolicyInvocation = C2FInvocation;\n"]}
516
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy.js","sourceRoot":"","sources":["../../src/policy.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  ApiClient,\n  C2FResponse,\n  CubeSignerResponse,\n  EditPolicy,\n  Empty,\n  InvokeC2FResponse,\n  JsonValue,\n  KeyPolicy,\n  KeyPolicyRule,\n  MfaReceipts,\n  PolicyAttachedToId,\n  PolicyType,\n  RolePolicy,\n  RolePolicyRule,\n  UpdatePolicyRequest,\n  WasmRule,\n  AceAttribute,\n  PolicyAction,\n  Ace,\n  PolicyInfo,\n} from \".\";\n\nimport { loadSubtleCrypto } from \".\";\n\n/**\n * Named policy rule type.\n */\nexport type PolicyRule = KeyPolicyRule | RolePolicyRule | WasmRule;\n\n/**\n * A helper type for {@link PolicyInfo} with a more detailed `acl` type.\n */\ntype NamedPolicyInfo = PolicyInfo & {\n  acl?: PolicyAcl;\n};\n\n/**\n * The policy info for a named key policy.\n */\nexport type KeyPolicyInfo = NamedPolicyInfo & {\n  policy_type: \"Key\";\n};\n\n/**\n * The policy info for a named role policy.\n */\nexport type RolePolicyInfo = NamedPolicyInfo & {\n  policy_type: \"Role\";\n};\n\n/**\n * The policy info for a named wasm policy.\n */\nexport type WasmPolicyInfo = NamedPolicyInfo & {\n  policy_type: \"Wasm\";\n};\n\n/**\n * The policy info for a Confidential Cloud Function.\n */\nexport type C2FInfo = WasmPolicyInfo;\n\n/**\n * A helper type for valid named policy version strings.\n */\nexport type Version = `v${number}` | `latest`;\n\n/** A policy access control entry. */\nexport type PolicyAce = Ace<PolicyAction, PolicyCtx>;\n\n/** A policy access control list. */\nexport type PolicyAcl = PolicyAce[];\n\n/** Additional contexts when using policies. */\nexport type PolicyCtx = {\n  /**\n   * The resources (keys, roles, and key-in-roles) that the access control entry\n   * applies to.\n   */\n  resources: AceAttribute<PolicyResource>;\n};\n\n/** A resource a policy is invoked with or attached to. */\nexport type PolicyResource =\n  /** A key or role id. */\n  | string\n  /** Keys attached to roles. */\n  | { key_ids: \"*\" | string[]; role_ids: \"*\" | string[] };\n\n/**\n * Upload the given Wasm Confidential Cloud Function.\n *\n * @param apiClient The API client to use.\n * @param policy The Wasm function.\n * @returns The Wasm function object hash to use for creating/updating C2F policies.\n * @throws if uploading the policy fails.\n * @internal\n */\nexport async function uploadWasmFunction(\n  apiClient: ApiClient,\n  policy: Uint8Array,\n): Promise<string> {\n  // get the SHA-256 hash of the function to get the upload url.\n  const subtle = await loadSubtleCrypto();\n  const hashBytes = await subtle.digest(\"SHA-256\", policy);\n  const hash = \"0x\" + Buffer.from(hashBytes).toString(\"hex\");\n\n  // get the upload URL\n  const { signed_url } = await apiClient.wasmPolicyUpload({ hash });\n\n  // upload the wasm object\n  const resp = await fetch(signed_url, {\n    method: \"PUT\",\n    body: policy,\n  });\n\n  if (!resp.ok) {\n    throw new Error(`Failed to upload function with status: ${resp.status}: ${resp.statusText}`);\n  }\n\n  return hash;\n}\n\n/**\n * Upload the given Wasm policy.\n *\n * @param apiClient The API client to use.\n * @param policy The Wasm function.\n * @returns The Wasm function object hash to use for creating/updating C2F policies.\n * @throws if uploading the policy fails.\n * @internal\n */\nexport const uploadWasmPolicy = uploadWasmFunction;\n\n/**\n * Abstract class for shared methods between key, role and Wasm policies.\n */\nexport abstract class NamedPolicy {\n  protected readonly apiClient: ApiClient;\n  protected data: NamedPolicyInfo;\n\n  /**\n   * Helper method for creating a named policy from a policy info.\n   *\n   * @param apiClient The api client to use.\n   * @param info The policy info.\n   * @returns The named policy object for the given info.\n   */\n  static fromInfo(apiClient: ApiClient, info: PolicyInfo): NamedPolicy {\n    switch (info.policy_type) {\n      case \"Key\":\n        return new NamedKeyPolicy(apiClient, info as KeyPolicyInfo);\n      case \"Role\":\n        return new NamedRolePolicy(apiClient, info as RolePolicyInfo);\n      case \"Wasm\":\n        return new C2FFunction(apiClient, info as C2FInfo);\n    }\n  }\n\n  /** @returns The policy id */\n  get id(): string {\n    return this.data.policy_id;\n  }\n\n  /** @returns The policy type */\n  get policyType(): PolicyType {\n    return this.data.policy_type;\n  }\n\n  /**\n   * Get a specific version of the policy.\n   *\n   * @param version The policy version to get.\n   * @returns The specific version of the policy.\n   */\n  async version(version: Version): Promise<NamedPolicyRules> {\n    let versionInfo;\n\n    if (version == `v${this.data.version}`) {\n      versionInfo = this.data;\n    } else {\n      versionInfo = (await this.apiClient.policyGet(this.id, version)) as NamedPolicyInfo;\n    }\n\n    return new NamedPolicyRules(this.apiClient, versionInfo);\n  }\n\n  /**\n   * Get the latest version of the policy.\n   *\n   * @returns The latest version of the policy.\n   */\n  async latest(): Promise<NamedPolicyRules> {\n    const data = await this.fetch(\"latest\");\n    return new NamedPolicyRules(this.apiClient, data);\n  }\n\n  /**\n   * Fetch and return the current name of the policy.\n   *\n   * @returns The policy name.\n   */\n  async name(): Promise<string> {\n    const data = await this.fetch();\n    return data.name;\n  }\n\n  /**\n   * Set a new name for the policy.\n   *\n   * @param name The new policy name.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setName(name: string, mfaReceipt?: MfaReceipts) {\n    await this.update({ name }, mfaReceipt);\n  }\n\n  /**\n   * Fetch and return the current owner of the policy.\n   *\n   * @returns The user id of the policy owner.\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 a new owner for the policy.\n   *\n   * @param owner The new owner of the policy.\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   * Fetch and return the metadata value for the policy.\n   *\n   * @returns The policy metadata.\n   */\n  async metadata(): Promise<JsonValue> {\n    const data = await this.fetch();\n    return data.metadata as JsonValue;\n  }\n\n  /**\n   * Sets a new metadata value for the named policy (overwriting the existing value).\n   *\n   * @param metadata The new metadata for the named policy.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setMetadata(metadata: JsonValue, mfaReceipt?: MfaReceipts) {\n    await this.update({ metadata }, mfaReceipt);\n  }\n\n  /**\n   * Fetch and return the edit policy for the named policy.\n   *\n   * @returns The edit policy for this named policy.\n   */\n  async editPolicy(): Promise<EditPolicy | undefined> {\n    const data = await this.fetch();\n    return data.edit_policy;\n  }\n\n  /**\n   * Set a new edit policy for the named policy.\n   *\n   * @param editPolicy The new edit policy.\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   * Fetch and return the access control entries for the named policy.\n   *\n   * @returns The access control entries for this named policy.\n   */\n  async acl(): Promise<PolicyAcl | undefined> {\n    const data = await this.fetch();\n    return data.acl;\n  }\n\n  /**\n   * Sets new access control entries for the named policy (overwriting the existing entries).\n   *\n   * @param acl The access control entries to set.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setAcl(acl: PolicyAcl, mfaReceipt?: MfaReceipts) {\n    await this.update({ acl }, mfaReceipt);\n  }\n\n  /**\n   * @returns a list of all keys, roles, and key-in-roles that all versions of this policy\n   * are attached to.\n   */\n  async allAttached(): Promise<PolicyAttachedToId[]> {\n    // there is no single-call way to achieve this. So instead, we\n    // 1. Get the latest version of the policy\n    // 2. For all versions `v0` to `latest`, fetch the policy info\n    // 3. Join all policy `attached_to` arrays\n    const data = await this.fetch(\"latest\");\n\n    const latest = data.version;\n    const versions = Array.from(Array(latest + 1).keys());\n    const batchSize = 10;\n    let allAttached: PolicyAttachedToId[] = [];\n\n    for (let batch = 0; batch < versions.length; batch += batchSize) {\n      const rs = await Promise.all(\n        versions.slice(batch, batch + batchSize).map((version) => {\n          return this.apiClient.policyGet(this.id, `v${version}`);\n        }),\n      );\n      allAttached = allAttached.concat(rs.flatMap((policy) => policy.attached_to));\n    }\n\n    return allAttached.concat(data.attached_to);\n  }\n\n  /**\n   * Delete this policy.\n   *\n   * This can fail if the policy is still attached to any key, role, or key in role.\n   *\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns A response which can be used to approve MFA if needed\n   * @throws if MFA is required and no receipts are provided\n   */\n  async delete(mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<Empty>> {\n    return await this.apiClient.policyDelete(this.id, mfaReceipt);\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  protected constructor(apiClient: ApiClient, data: NamedPolicyInfo) {\n    this.apiClient = apiClient;\n    this.data = data;\n  }\n\n  /**\n   * Update the policy.\n   *\n   * @param request The JSON request to send to the API server.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns The updated policy information.\n   * @throws if MFA is required and no receipts are provided\n   * @internal\n   */\n  protected async update(\n    request: UpdatePolicyRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<NamedPolicyInfo> {\n    const resp = await this.apiClient.policyUpdate(this.id, request, mfaReceipt);\n    this.data = resp.data() as NamedPolicyInfo;\n    return this.data;\n  }\n\n  /**\n   * Fetch the policy information.\n   *\n   * @param version The version of the policy to fetch. Defaults to \"latest\".\n   * @returns The policy information.\n   * @internal\n   */\n  protected async fetch(version: Version = \"latest\"): Promise<NamedPolicyInfo> {\n    this.data = (await this.apiClient.policyGet(this.id, version)) as NamedPolicyInfo;\n    return this.data;\n  }\n}\n\n/**\n * A representation of a named key policy.\n */\nexport class NamedKeyPolicy extends NamedPolicy {\n  override data: KeyPolicyInfo;\n\n  /**\n   * Update the policy with new rules.\n   *\n   * @param rules The new rules to update the policy with.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setRules(rules: KeyPolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ rules }, mfaReceipt);\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: KeyPolicyInfo) {\n    super(apiClient, data);\n    this.data = data;\n  }\n}\n\n/**\n * A representation of a named role policy.\n */\nexport class NamedRolePolicy extends NamedPolicy {\n  override data: RolePolicyInfo;\n\n  /**\n   * Update the policy with new rules.\n   *\n   * @param rules The new rules to update the policy with.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setRules(rules: RolePolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ rules }, mfaReceipt);\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: RolePolicyInfo) {\n    super(apiClient, data);\n    this.data = data;\n  }\n}\n\n/**\n * A representation of a Confidential Cloud Function (C2F).\n *\n * This class extends NamedPolicy because C2F functions can be attached\n * to keys and roles like a named policy.\n */\nexport class C2FFunction extends NamedPolicy {\n  override data: C2FInfo;\n\n  /**\n   * Update this C2F function with a new Wasm function.\n   *\n   * @param policy The new Wasm function.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if uploading the function fails.\n   * @throws if MFA is required and no receipts are provided.\n   */\n  async setWasmFunction(policy: Uint8Array, mfaReceipt?: MfaReceipts) {\n    // upload the policy object\n    const hash = await uploadWasmFunction(this.apiClient, policy);\n\n    // update this policy with the new policy version.\n    const body: UpdatePolicyRequest = { rules: [{ hash }] };\n    this.data = (await this.update(body, mfaReceipt)) as C2FInfo;\n  }\n\n  /**\n   * Invoke this Confidential Cloud Function.\n   *\n   * @param keyId The optional key id that the function will be invoked with.\n   * @param version The version of the function to invoke. Defaults to \"latest\".\n   * @param request The optional sign request body that will be sent to the function.\n   * @param roleId The optional role id that the function will be invoked by.\n   * If `undefined`, the policy will be invoked by the user session.\n   * @returns The result of invoking the function.\n   */\n  async invoke(\n    keyId?: string,\n    version: Version = \"latest\",\n    request?: JsonValue,\n    roleId?: string,\n  ): Promise<C2FInvocation> {\n    // TODO Ideally, `version` should be the first parameter. But for backwards\n    // compatibility, we keep `keyId` as the first parameter for now.\n    const resp = await this.apiClient.policyInvoke(this.id, version, {\n      key_id: keyId,\n      request,\n      role_id: roleId,\n    });\n    return new PolicyInvocation(resp);\n  }\n\n  // Backwards compability with Named Wasm Policy names\n  /**\n   * Update the policy with the new Wasm policy.\n   *\n   * @param policy The new Wasm policy object.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if uploading the policy object fails.\n   * @throws if MFA is required and no receipts are provided.\n   */\n  setWasmPolicy = this.setWasmFunction;\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: C2FInfo) {\n    super(apiClient, data);\n    this.data = data;\n  }\n}\n\n/**\n * A specific version of a named policy.\n */\nexport class NamedPolicyRules {\n  /** The CubeSigner instance that this policy is associated with */\n  readonly #apiClient: ApiClient;\n  #data: NamedPolicyInfo;\n\n  /**\n   * @returns The ID of the policy.\n   *\n   * @example NamedPolicy#a4a45cc2-0642-4c98-b6bd-0da347d608a4\n   */\n  get id(): string {\n    return this.#data.policy_id;\n  }\n\n  /**\n   * @returns The version of the policy this object contains.\n   */\n  get version(): Version {\n    return `v${this.#data.version}`;\n  }\n\n  /**\n   * @returns The policy rules.\n   *\n   * @example [ \"AssertErc20Tx\" ]\n   */\n  get rules(): PolicyRule[] {\n    return this.#data.rules as PolicyRule[];\n  }\n\n  /**\n   * @returns a list of all keys, roles, and key-in-roles this version of the policy\n   *          is attached to.\n   */\n  async allAttached(): Promise<PolicyAttachedToId[]> {\n    const data = await this.fetch();\n    return data.attached_to;\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: NamedPolicyInfo) {\n    this.#apiClient = apiClient;\n    this.#data = data;\n  }\n\n  /**\n   * Fetch the policy information.\n   *\n   * @returns The policy information.\n   * @internal\n   */\n  private async fetch(): Promise<NamedPolicyInfo> {\n    this.#data = (await this.#apiClient.policyGet(this.id, this.version)) as NamedPolicyInfo;\n    return this.#data;\n  }\n}\n\n/**\n * The result of invoking a Confidential Cloud Function.\n */\nexport class C2FInvocation {\n  readonly #data: InvokeC2FResponse;\n\n  /** @returns The policy response itself. */\n  get response(): C2FResponse {\n    return this.#data.response;\n  }\n\n  /** @returns The standard output stream. Usually a UTF-8 encoded string. */\n  get stdout(): Buffer {\n    return this.fromHex(this.#data.stdout);\n  }\n\n  /** @returns The standard error stream. Usually a UTF-8 encoded string. */\n  get stderr(): Buffer {\n    return this.fromHex(this.#data.stderr);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Helper method for converting hex-encoded data to a `Buffer`.\n   *\n   * @param hex The hex-encoded data.\n   * @returns The data.\n   */\n  private fromHex(hex: string): Buffer {\n    return Buffer.from(hex.startsWith(\"0x\") ? hex.slice(2) : hex, \"hex\");\n  }\n\n  /**\n   * Constructor.\n   *\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(data: InvokeC2FResponse) {\n    this.#data = data;\n  }\n}\n\n// Backwards compability with Named Wasm Policy names\n\n/** A representation of a Wasm policy. */\nexport type NamedWasmPolicy = C2FFunction;\n/** A representation of a Wasm policy. */\nexport const NamedWasmPolicy = C2FFunction;\n\n/** The result of invoking a named WASM policy. */\nexport type PolicyInvocation = C2FInvocation;\n/** The result of invoking a named WASM policy. */\nexport const PolicyInvocation = C2FInvocation;\n"]}