@zshannon/streamstore 0.22.3 → 0.22.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (178) hide show
  1. package/dist/cjs/auth/biscuit.d.ts +7 -5
  2. package/dist/cjs/auth/biscuit.d.ts.map +1 -1
  3. package/dist/cjs/auth/biscuit.js +136 -39
  4. package/dist/cjs/auth/biscuit.js.map +1 -1
  5. package/dist/cjs/auth/index.d.ts +3 -3
  6. package/dist/cjs/auth/index.d.ts.map +1 -1
  7. package/dist/cjs/auth/index.js +4 -4
  8. package/dist/cjs/auth/index.js.map +1 -1
  9. package/dist/cjs/auth/pki-auth.d.ts +1 -1
  10. package/dist/cjs/auth/pki-auth.d.ts.map +1 -1
  11. package/dist/cjs/auth/pki-auth.js +23 -5
  12. package/dist/cjs/auth/pki-auth.js.map +1 -1
  13. package/dist/cjs/auth/proto/schema_pb.d.ts +1052 -0
  14. package/dist/cjs/auth/proto/schema_pb.d.ts.map +1 -0
  15. package/dist/cjs/auth/proto/schema_pb.js +413 -0
  16. package/dist/cjs/auth/proto/schema_pb.js.map +1 -0
  17. package/dist/cjs/auth/sign.d.ts.map +1 -1
  18. package/dist/cjs/auth/sign.js +6 -1
  19. package/dist/cjs/auth/sign.js.map +1 -1
  20. package/dist/cjs/basin.d.ts.map +1 -1
  21. package/dist/cjs/basin.js.map +1 -1
  22. package/dist/cjs/basins.d.ts.map +1 -1
  23. package/dist/cjs/basins.js +6 -2
  24. package/dist/cjs/basins.js.map +1 -1
  25. package/dist/cjs/error.d.ts.map +1 -1
  26. package/dist/cjs/error.js +9 -1
  27. package/dist/cjs/error.js.map +1 -1
  28. package/dist/cjs/generated/types.gen.d.ts +4 -9
  29. package/dist/cjs/generated/types.gen.d.ts.map +1 -1
  30. package/dist/cjs/index.d.ts +1 -1
  31. package/dist/cjs/index.d.ts.map +1 -1
  32. package/dist/cjs/index.js +4 -4
  33. package/dist/cjs/index.js.map +1 -1
  34. package/dist/cjs/internal/mappers.d.ts +0 -1
  35. package/dist/cjs/internal/mappers.d.ts.map +1 -1
  36. package/dist/cjs/internal/mappers.js +0 -3
  37. package/dist/cjs/internal/mappers.js.map +1 -1
  38. package/dist/cjs/lib/event-stream.js +37 -11
  39. package/dist/cjs/lib/event-stream.js.map +1 -1
  40. package/dist/cjs/lib/paginate.d.ts +9 -0
  41. package/dist/cjs/lib/paginate.d.ts.map +1 -1
  42. package/dist/cjs/lib/paginate.js +20 -0
  43. package/dist/cjs/lib/paginate.js.map +1 -1
  44. package/dist/cjs/lib/retry.d.ts +1 -0
  45. package/dist/cjs/lib/retry.d.ts.map +1 -1
  46. package/dist/cjs/lib/retry.js +34 -32
  47. package/dist/cjs/lib/retry.js.map +1 -1
  48. package/dist/cjs/lib/stream/runtime.d.ts +1 -1
  49. package/dist/cjs/lib/stream/runtime.d.ts.map +1 -1
  50. package/dist/cjs/lib/stream/runtime.js +4 -1
  51. package/dist/cjs/lib/stream/runtime.js.map +1 -1
  52. package/dist/cjs/lib/stream/transport/fetch/index.d.ts.map +1 -1
  53. package/dist/cjs/lib/stream/transport/fetch/index.js +2 -18
  54. package/dist/cjs/lib/stream/transport/fetch/index.js.map +1 -1
  55. package/dist/cjs/lib/stream/transport/fetch/shared.js +6 -6
  56. package/dist/cjs/lib/stream/transport/fetch/shared.js.map +1 -1
  57. package/dist/cjs/lib/stream/transport/proto.d.ts +15 -1
  58. package/dist/cjs/lib/stream/transport/proto.d.ts.map +1 -1
  59. package/dist/cjs/lib/stream/transport/proto.js +33 -0
  60. package/dist/cjs/lib/stream/transport/proto.js.map +1 -1
  61. package/dist/cjs/lib/stream/transport/s2s/index.d.ts.map +1 -1
  62. package/dist/cjs/lib/stream/transport/s2s/index.js +5 -25
  63. package/dist/cjs/lib/stream/transport/s2s/index.js.map +1 -1
  64. package/dist/cjs/lib/stream/types.d.ts +1 -0
  65. package/dist/cjs/lib/stream/types.d.ts.map +1 -1
  66. package/dist/cjs/lib/stream/types.js.map +1 -1
  67. package/dist/cjs/s2.d.ts.map +1 -1
  68. package/dist/cjs/s2.js +5 -1
  69. package/dist/cjs/s2.js.map +1 -1
  70. package/dist/cjs/stream.d.ts.map +1 -1
  71. package/dist/cjs/stream.js +10 -1
  72. package/dist/cjs/stream.js.map +1 -1
  73. package/dist/cjs/streams.d.ts.map +1 -1
  74. package/dist/cjs/streams.js +6 -2
  75. package/dist/cjs/streams.js.map +1 -1
  76. package/dist/cjs/tests/helpers.d.ts +8 -0
  77. package/dist/cjs/tests/helpers.d.ts.map +1 -0
  78. package/dist/cjs/tests/helpers.js +42 -0
  79. package/dist/cjs/tests/helpers.js.map +1 -0
  80. package/dist/cjs/types.d.ts.map +1 -1
  81. package/dist/cjs/types.js +10 -0
  82. package/dist/cjs/types.js.map +1 -1
  83. package/dist/cjs/utils.d.ts +7 -0
  84. package/dist/cjs/utils.d.ts.map +1 -1
  85. package/dist/cjs/utils.js +22 -17
  86. package/dist/cjs/utils.js.map +1 -1
  87. package/dist/cjs/version.d.ts +1 -1
  88. package/dist/cjs/version.js +1 -1
  89. package/dist/esm/auth/biscuit.d.ts +7 -5
  90. package/dist/esm/auth/biscuit.d.ts.map +1 -1
  91. package/dist/esm/auth/biscuit.js +136 -39
  92. package/dist/esm/auth/biscuit.js.map +1 -1
  93. package/dist/esm/auth/index.d.ts +3 -3
  94. package/dist/esm/auth/index.d.ts.map +1 -1
  95. package/dist/esm/auth/index.js +3 -3
  96. package/dist/esm/auth/index.js.map +1 -1
  97. package/dist/esm/auth/pki-auth.d.ts +1 -1
  98. package/dist/esm/auth/pki-auth.d.ts.map +1 -1
  99. package/dist/esm/auth/pki-auth.js +24 -6
  100. package/dist/esm/auth/pki-auth.js.map +1 -1
  101. package/dist/esm/auth/proto/schema_pb.d.ts +1052 -0
  102. package/dist/esm/auth/proto/schema_pb.d.ts.map +1 -0
  103. package/dist/esm/auth/proto/schema_pb.js +410 -0
  104. package/dist/esm/auth/proto/schema_pb.js.map +1 -0
  105. package/dist/esm/auth/sign.d.ts.map +1 -1
  106. package/dist/esm/auth/sign.js +6 -1
  107. package/dist/esm/auth/sign.js.map +1 -1
  108. package/dist/esm/basin.d.ts.map +1 -1
  109. package/dist/esm/basin.js +2 -2
  110. package/dist/esm/basin.js.map +1 -1
  111. package/dist/esm/basins.d.ts.map +1 -1
  112. package/dist/esm/basins.js +7 -3
  113. package/dist/esm/basins.js.map +1 -1
  114. package/dist/esm/error.d.ts.map +1 -1
  115. package/dist/esm/error.js +9 -1
  116. package/dist/esm/error.js.map +1 -1
  117. package/dist/esm/generated/types.gen.d.ts +4 -9
  118. package/dist/esm/generated/types.gen.d.ts.map +1 -1
  119. package/dist/esm/index.d.ts +1 -1
  120. package/dist/esm/index.d.ts.map +1 -1
  121. package/dist/esm/index.js +1 -1
  122. package/dist/esm/index.js.map +1 -1
  123. package/dist/esm/internal/mappers.d.ts +0 -1
  124. package/dist/esm/internal/mappers.d.ts.map +1 -1
  125. package/dist/esm/internal/mappers.js +0 -3
  126. package/dist/esm/internal/mappers.js.map +1 -1
  127. package/dist/esm/lib/event-stream.js +37 -11
  128. package/dist/esm/lib/event-stream.js.map +1 -1
  129. package/dist/esm/lib/paginate.d.ts +9 -0
  130. package/dist/esm/lib/paginate.d.ts.map +1 -1
  131. package/dist/esm/lib/paginate.js +19 -0
  132. package/dist/esm/lib/paginate.js.map +1 -1
  133. package/dist/esm/lib/retry.d.ts +1 -0
  134. package/dist/esm/lib/retry.d.ts.map +1 -1
  135. package/dist/esm/lib/retry.js +35 -33
  136. package/dist/esm/lib/retry.js.map +1 -1
  137. package/dist/esm/lib/stream/runtime.d.ts +1 -1
  138. package/dist/esm/lib/stream/runtime.d.ts.map +1 -1
  139. package/dist/esm/lib/stream/runtime.js +4 -1
  140. package/dist/esm/lib/stream/runtime.js.map +1 -1
  141. package/dist/esm/lib/stream/transport/fetch/index.d.ts.map +1 -1
  142. package/dist/esm/lib/stream/transport/fetch/index.js +4 -20
  143. package/dist/esm/lib/stream/transport/fetch/index.js.map +1 -1
  144. package/dist/esm/lib/stream/transport/fetch/shared.js +6 -6
  145. package/dist/esm/lib/stream/transport/fetch/shared.js.map +1 -1
  146. package/dist/esm/lib/stream/transport/proto.d.ts +15 -1
  147. package/dist/esm/lib/stream/transport/proto.d.ts.map +1 -1
  148. package/dist/esm/lib/stream/transport/proto.js +32 -1
  149. package/dist/esm/lib/stream/transport/proto.js.map +1 -1
  150. package/dist/esm/lib/stream/transport/s2s/index.d.ts.map +1 -1
  151. package/dist/esm/lib/stream/transport/s2s/index.js +6 -26
  152. package/dist/esm/lib/stream/transport/s2s/index.js.map +1 -1
  153. package/dist/esm/lib/stream/types.d.ts +1 -0
  154. package/dist/esm/lib/stream/types.d.ts.map +1 -1
  155. package/dist/esm/lib/stream/types.js.map +1 -1
  156. package/dist/esm/s2.d.ts.map +1 -1
  157. package/dist/esm/s2.js +7 -3
  158. package/dist/esm/s2.js.map +1 -1
  159. package/dist/esm/stream.d.ts.map +1 -1
  160. package/dist/esm/stream.js +10 -1
  161. package/dist/esm/stream.js.map +1 -1
  162. package/dist/esm/streams.d.ts.map +1 -1
  163. package/dist/esm/streams.js +7 -3
  164. package/dist/esm/streams.js.map +1 -1
  165. package/dist/esm/tests/helpers.d.ts +8 -0
  166. package/dist/esm/tests/helpers.d.ts.map +1 -0
  167. package/dist/esm/tests/helpers.js +34 -0
  168. package/dist/esm/tests/helpers.js.map +1 -0
  169. package/dist/esm/types.d.ts.map +1 -1
  170. package/dist/esm/types.js +11 -1
  171. package/dist/esm/types.js.map +1 -1
  172. package/dist/esm/utils.d.ts +7 -0
  173. package/dist/esm/utils.d.ts.map +1 -1
  174. package/dist/esm/utils.js +21 -17
  175. package/dist/esm/utils.js.map +1 -1
  176. package/dist/esm/version.d.ts +1 -1
  177. package/dist/esm/version.js +1 -1
  178. package/package.json +7 -3
@@ -1,3 +1,7 @@
1
+ /**
2
+ * Native TypeScript Biscuit token creation using @bufbuild/protobuf + @noble/curves.
3
+ * No WASM dependency.
4
+ */
1
5
  export type BiscuitTokenOptions = {
2
6
  /** P256 private key as base58-encoded 32 bytes */
3
7
  privateKey: string;
@@ -7,8 +11,8 @@ export type BiscuitTokenOptions = {
7
11
  expiresIn?: number;
8
12
  /** Operation groups to grant (default: all read+write) */
9
13
  opGroups?: Array<{
10
- level: string;
11
14
  access: string;
15
+ level: string;
12
16
  }>;
13
17
  /** Basin scope (default: prefix "" = all basins) */
14
18
  basinScope?: {
@@ -27,12 +31,10 @@ export type BiscuitTokenOptions = {
27
31
  };
28
32
  };
29
33
  /**
30
- * Creates an admin Biscuit token from a root private key.
31
- * This enables bootstrap mode where the admin can operate without a pre-existing token.
32
- *
34
+ * Creates a Biscuit authority token signed with P-256.
33
35
  * @returns Base64-encoded Biscuit token
34
36
  */
35
- export declare function createBiscuitToken(options: BiscuitTokenOptions): Promise<string>;
37
+ export declare function createBiscuitToken(options: BiscuitTokenOptions): string;
36
38
  /**
37
39
  * Derives the public key from a private key.
38
40
  * @param privateKey Base58-encoded P256 private key (32 bytes)
@@ -1 +1 @@
1
- {"version":3,"file":"biscuit.d.ts","sourceRoot":"","sources":["../../../src/auth/biscuit.ts"],"names":[],"mappings":"AAkBA,MAAM,MAAM,mBAAmB,GAAG;IACjC,kDAAkD;IAClD,UAAU,EAAE,MAAM,CAAC;IACnB,0FAA0F;IAC1F,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gEAAgE;IAChE,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,0DAA0D;IAC1D,QAAQ,CAAC,EAAE,KAAK,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACpD,oDAAoD;IACpD,UAAU,CAAC,EAAE;QAAE,IAAI,EAAE,QAAQ,GAAG,OAAO,GAAG,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;IAClE,sDAAsD;IACtD,WAAW,CAAC,EAAE;QAAE,IAAI,EAAE,QAAQ,GAAG,OAAO,GAAG,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;IACnE,2DAA2D;IAC3D,gBAAgB,CAAC,EAAE;QAAE,IAAI,EAAE,QAAQ,GAAG,OAAO,GAAG,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;CACxE,CAAC;AAEF;;;;;GAKG;AACH,wBAAsB,kBAAkB,CAAC,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAAC,MAAM,CAAC,CAyDtF;AAED;;;;GAIG;AACH,wBAAgB,eAAe,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,CAE1D"}
1
+ {"version":3,"file":"biscuit.d.ts","sourceRoot":"","sources":["../../../src/auth/biscuit.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAgGH,MAAM,MAAM,mBAAmB,GAAG;IACjC,kDAAkD;IAClD,UAAU,EAAE,MAAM,CAAC;IACnB,0FAA0F;IAC1F,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gEAAgE;IAChE,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,0DAA0D;IAC1D,QAAQ,CAAC,EAAE,KAAK,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACpD,oDAAoD;IACpD,UAAU,CAAC,EAAE;QAAE,IAAI,EAAE,QAAQ,GAAG,OAAO,GAAG,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;IAClE,sDAAsD;IACtD,WAAW,CAAC,EAAE;QAAE,IAAI,EAAE,QAAQ,GAAG,OAAO,GAAG,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;IACnE,2DAA2D;IAC3D,gBAAgB,CAAC,EAAE;QAAE,IAAI,EAAE,QAAQ,GAAG,OAAO,GAAG,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;CACxE,CAAC;AAEF;;;GAGG;AACH,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,mBAAmB,GAAG,MAAM,CA+FvE;AAED;;;;GAIG;AACH,wBAAgB,eAAe,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,CAE1D"}
@@ -1,25 +1,72 @@
1
+ /**
2
+ * Native TypeScript Biscuit token creation using @bufbuild/protobuf + @noble/curves.
3
+ * No WASM dependency.
4
+ */
5
+ import { create, toBinary } from "@bufbuild/protobuf";
6
+ import { p256 } from "@noble/curves/nist.js";
1
7
  import { base64 } from "@scure/base";
8
+ import { BiscuitSchema, BlockSchema, CheckSchema, Check_Kind, ExpressionSchema, FactSchema, OpBinary_Kind, OpSchema, PredicateSchema, ProofSchema, PublicKeySchema, PublicKey_Algorithm, RuleSchema, SignedBlockSchema, TermSchema, } from "./proto/schema_pb.js";
2
9
  import { SigningKey } from "./signing-key.js";
3
- // Dynamic import for biscuit-wasm to handle WASM initialization
4
- let biscuitModule = null;
5
- let initPromise = null;
6
- async function getBiscuit() {
7
- if (!biscuitModule) {
8
- biscuitModule = await import("@biscuit-auth/biscuit-wasm");
9
- if (!initPromise) {
10
- initPromise = Promise.resolve(biscuitModule.init());
10
+ // ─── Symbol table ───
11
+ const DEFAULT_SYMBOLS = [
12
+ "read", "write", "resource", "operation", "right", "time", "role", "owner",
13
+ "tenant", "namespace", "user", "team", "service", "admin", "email", "group",
14
+ "member", "ip_address", "client", "client_ip", "domain", "path", "version",
15
+ "cluster", "node", "hostname", "nonce", "query",
16
+ ];
17
+ const CUSTOM_SYMBOL_START = 1024;
18
+ class SymbolTable {
19
+ #symbols = [...DEFAULT_SYMBOLS];
20
+ #nextCustom = CUSTOM_SYMBOL_START;
21
+ intern(name) {
22
+ const defaultIdx = DEFAULT_SYMBOLS.indexOf(name);
23
+ if (defaultIdx !== -1)
24
+ return defaultIdx;
25
+ for (let i = DEFAULT_SYMBOLS.length; i < this.#symbols.length; i++) {
26
+ if (this.#symbols[i] === name)
27
+ return CUSTOM_SYMBOL_START + (i - DEFAULT_SYMBOLS.length);
11
28
  }
12
- await initPromise;
29
+ this.#symbols.push(name);
30
+ return this.#nextCustom++;
31
+ }
32
+ customSymbols() {
33
+ return this.#symbols.slice(DEFAULT_SYMBOLS.length);
34
+ }
35
+ }
36
+ // ─── Signature payload (V1 tagged format) ───
37
+ const encoder = new TextEncoder();
38
+ function tagged(tag, data) {
39
+ const tagBytes = encoder.encode(`\0${tag}\0`);
40
+ const result = new Uint8Array(tagBytes.length + data.length);
41
+ result.set(tagBytes);
42
+ result.set(data, tagBytes.length);
43
+ return result;
44
+ }
45
+ function u32le(n) {
46
+ const buf = new Uint8Array(4);
47
+ new DataView(buf.buffer).setUint32(0, n, true);
48
+ return buf;
49
+ }
50
+ function concat(...arrays) {
51
+ let length = 0;
52
+ for (const arr of arrays)
53
+ length += arr.length;
54
+ const result = new Uint8Array(length);
55
+ let offset = 0;
56
+ for (const arr of arrays) {
57
+ result.set(arr, offset);
58
+ offset += arr.length;
13
59
  }
14
- return biscuitModule;
60
+ return result;
61
+ }
62
+ function signaturePayloadV1(blockData, nextKeyAlgorithm, nextKeyBytes) {
63
+ return concat(tagged("BLOCK", tagged("VERSION", u32le(1))), tagged("PAYLOAD", blockData), tagged("ALGORITHM", u32le(nextKeyAlgorithm)), tagged("NEXTKEY", nextKeyBytes));
15
64
  }
16
65
  /**
17
- * Creates an admin Biscuit token from a root private key.
18
- * This enables bootstrap mode where the admin can operate without a pre-existing token.
19
- *
66
+ * Creates a Biscuit authority token signed with P-256.
20
67
  * @returns Base64-encoded Biscuit token
21
68
  */
22
- export async function createBiscuitToken(options) {
69
+ export function createBiscuitToken(options) {
23
70
  const { privateKey, publicKey: providedPublicKey, expiresIn = 3600, opGroups = [
24
71
  { level: "account", access: "read" },
25
72
  { level: "account", access: "write" },
@@ -28,34 +75,71 @@ export async function createBiscuitToken(options) {
28
75
  { level: "stream", access: "read" },
29
76
  { level: "stream", access: "write" },
30
77
  ], basinScope = { type: "prefix", value: "" }, streamScope = { type: "prefix", value: "" }, accessTokenScope = { type: "prefix", value: "" }, } = options;
31
- const biscuit = await getBiscuit();
32
- // Use SigningKey for validation and key derivation
33
78
  const signingKey = SigningKey.fromBase58(privateKey);
34
- const privateKeyBytes = signingKey.getPrivateKeyBytes();
79
+ const rootKeyBytes = signingKey.getPrivateKeyBytes();
35
80
  const publicKeyBase58 = providedPublicKey ?? signingKey.publicKeyBase58();
36
- // Create Biscuit private key (P256 = secp256r1)
37
- const biscuitPrivateKey = biscuit.PrivateKey.fromBytes(privateKeyBytes, biscuit.SignatureAlgorithm.Secp256r1);
38
- // Build the token
39
81
  const expiresTs = Math.floor(Date.now() / 1000) + expiresIn;
40
- const builder = biscuit.biscuit `
41
- public_key(${publicKeyBase58});
42
- expires(${expiresTs});
43
- `;
44
- builder.merge(biscuit.block `
45
- check if time($t), $t < ${expiresTs};
46
- `);
47
- for (const { level, access } of opGroups) {
48
- builder.merge(biscuit.block `
49
- op_group(${level}, ${access});
50
- `);
51
- }
52
- builder.merge(biscuit.block `
53
- basin_scope(${basinScope.type}, ${basinScope.value});
54
- stream_scope(${streamScope.type}, ${streamScope.value});
55
- access_token_scope(${accessTokenScope.type}, ${accessTokenScope.value});
56
- `);
57
- const token = builder.build(biscuitPrivateKey);
58
- return base64.encode(token.toBytes());
82
+ // Build authority block
83
+ const symbols = new SymbolTable();
84
+ const facts = [
85
+ makeFact(symbols, "public_key", [{ type: "string", value: publicKeyBase58 }]),
86
+ makeFact(symbols, "expires", [{ type: "integer", value: expiresTs }]),
87
+ ...opGroups.map(({ level, access }) => makeFact(symbols, "op_group", [{ type: "string", value: level }, { type: "string", value: access }])),
88
+ makeFact(symbols, "basin_scope", [{ type: "string", value: basinScope.type }, { type: "string", value: basinScope.value }]),
89
+ makeFact(symbols, "stream_scope", [{ type: "string", value: streamScope.type }, { type: "string", value: streamScope.value }]),
90
+ makeFact(symbols, "access_token_scope", [{ type: "string", value: accessTokenScope.type }, { type: "string", value: accessTokenScope.value }]),
91
+ ];
92
+ // check if time($t), $t < expiresTs
93
+ const tVar = symbols.intern("t");
94
+ const checks = [create(CheckSchema, {
95
+ kind: Check_Kind.One,
96
+ queries: [create(RuleSchema, {
97
+ body: [create(PredicateSchema, {
98
+ name: BigInt(symbols.intern("time")),
99
+ terms: [create(TermSchema, { Content: { case: "variable", value: tVar } })],
100
+ })],
101
+ expressions: [create(ExpressionSchema, {
102
+ ops: [
103
+ create(OpSchema, { Content: { case: "value", value: create(TermSchema, { Content: { case: "variable", value: tVar } }) } }),
104
+ create(OpSchema, { Content: { case: "value", value: create(TermSchema, { Content: { case: "integer", value: BigInt(expiresTs) } }) } }),
105
+ create(OpSchema, { Content: { case: "Binary", value: { kind: OpBinary_Kind.LessThan, ffiName: 0n, $typeName: "biscuit.format.schema.OpBinary" } } }),
106
+ ],
107
+ })],
108
+ head: create(PredicateSchema, { name: BigInt(symbols.intern("query")), terms: [] }),
109
+ scope: [],
110
+ })],
111
+ })];
112
+ const blockData = toBinary(BlockSchema, create(BlockSchema, {
113
+ checks,
114
+ facts,
115
+ publicKeys: [],
116
+ rules: [],
117
+ scope: [],
118
+ symbols: symbols.customSymbols(),
119
+ version: 3,
120
+ }));
121
+ // Ephemeral next key
122
+ const nextPrivKey = p256.utils.randomSecretKey();
123
+ const nextPubKey = p256.getPublicKey(nextPrivKey, true);
124
+ // Sign
125
+ const payload = signaturePayloadV1(blockData, PublicKey_Algorithm.SECP256R1, nextPubKey);
126
+ const signature = p256.sign(payload, rootKeyBytes, { format: "der", lowS: true });
127
+ // Assemble
128
+ const signedBlock = create(SignedBlockSchema, {
129
+ block: blockData,
130
+ nextKey: create(PublicKeySchema, { algorithm: PublicKey_Algorithm.SECP256R1, key: nextPubKey }),
131
+ signature,
132
+ version: 1,
133
+ });
134
+ const proof = create(ProofSchema, {
135
+ Content: { case: "nextSecret", value: nextPrivKey },
136
+ });
137
+ const biscuit = create(BiscuitSchema, {
138
+ authority: signedBlock,
139
+ blocks: [],
140
+ proof,
141
+ });
142
+ return base64.encode(toBinary(BiscuitSchema, biscuit));
59
143
  }
60
144
  /**
61
145
  * Derives the public key from a private key.
@@ -65,4 +149,17 @@ export async function createBiscuitToken(options) {
65
149
  export function derivePublicKey(privateKey) {
66
150
  return SigningKey.fromBase58(privateKey).publicKeyBase58();
67
151
  }
152
+ function makeFact(symbols, name, terms) {
153
+ return create(FactSchema, {
154
+ predicate: create(PredicateSchema, {
155
+ name: BigInt(symbols.intern(name)),
156
+ terms: terms.map((t) => {
157
+ if (t.type === "string") {
158
+ return create(TermSchema, { Content: { case: "string", value: BigInt(symbols.intern(t.value)) } });
159
+ }
160
+ return create(TermSchema, { Content: { case: "integer", value: BigInt(t.value) } });
161
+ }),
162
+ }),
163
+ });
164
+ }
68
165
  //# sourceMappingURL=biscuit.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"biscuit.js","sourceRoot":"","sources":["../../../src/auth/biscuit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C,gEAAgE;AAChE,IAAI,aAAa,GAAuD,IAAI,CAAC;AAC7E,IAAI,WAAW,GAAyB,IAAI,CAAC;AAE7C,KAAK,UAAU,UAAU;IACxB,IAAI,CAAC,aAAa,EAAE,CAAC;QACpB,aAAa,GAAG,MAAM,MAAM,CAAC,4BAA4B,CAAC,CAAC;QAC3D,IAAI,CAAC,WAAW,EAAE,CAAC;YAClB,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC,CAAC;QACrD,CAAC;QACD,MAAM,WAAW,CAAC;IACnB,CAAC;IACD,OAAO,aAAa,CAAC;AACtB,CAAC;AAmBD;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,kBAAkB,CAAC,OAA4B;IACpE,MAAM,EACL,UAAU,EACV,SAAS,EAAE,iBAAiB,EAC5B,SAAS,GAAG,IAAI,EAChB,QAAQ,GAAG;QACV,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE;QACpC,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE;QACrC,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE;QAClC,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE;QACnC,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE;QACnC,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE;KACpC,EACD,UAAU,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,EAAE,EAC1C,WAAW,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,EAAE,EAC3C,gBAAgB,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,EAAE,GAChD,GAAG,OAAO,CAAC;IAEZ,MAAM,OAAO,GAAG,MAAM,UAAU,EAAE,CAAC;IAEnC,mDAAmD;IACnD,MAAM,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IACrD,MAAM,eAAe,GAAG,UAAU,CAAC,kBAAkB,EAAE,CAAC;IACxD,MAAM,eAAe,GAAG,iBAAiB,IAAI,UAAU,CAAC,eAAe,EAAE,CAAC;IAE1E,gDAAgD;IAChD,MAAM,iBAAiB,GAAG,OAAO,CAAC,UAAU,CAAC,SAAS,CACrD,eAAe,EACf,OAAO,CAAC,kBAAkB,CAAC,SAAS,CACpC,CAAC;IAEF,kBAAkB;IAClB,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,SAAS,CAAC;IAE5D,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAA;eACjB,eAAe;YAClB,SAAS;EACnB,CAAC;IAEF,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAA;4BACA,SAAS;EACnC,CAAC,CAAC;IAEH,KAAK,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,QAAQ,EAAE,CAAC;QAC1C,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAA;cACf,KAAK,KAAK,MAAM;GAC3B,CAAC,CAAC;IACJ,CAAC;IAED,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAA;gBACZ,UAAU,CAAC,IAAI,KAAK,UAAU,CAAC,KAAK;iBACnC,WAAW,CAAC,IAAI,KAAK,WAAW,CAAC,KAAK;uBAChC,gBAAgB,CAAC,IAAI,KAAK,gBAAgB,CAAC,KAAK;EACrE,CAAC,CAAC;IAEH,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;IAC/C,OAAO,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;AACvC,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,eAAe,CAAC,UAAkB;IACjD,OAAO,UAAU,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,eAAe,EAAE,CAAC;AAC5D,CAAC"}
1
+ {"version":3,"file":"biscuit.js","sourceRoot":"","sources":["../../../src/auth/biscuit.ts"],"names":[],"mappings":"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"}
@@ -1,5 +1,5 @@
1
- export { createBiscuitToken, derivePublicKey, type BiscuitTokenOptions } from "./biscuit.js";
2
- export { signRequest, signHeaders, type SignRequestOptions, type SignHeadersOptions } from "./sign.js";
3
- export { createPkiAuth, type PkiAuthConfig, type PkiAuthContext } from "./pki-auth.js";
1
+ export { type BiscuitTokenOptions, createBiscuitToken, derivePublicKey, } from "./biscuit.js";
2
+ export { createPkiAuth, type PkiAuthConfig, type PkiAuthContext, } from "./pki-auth.js";
3
+ export { type SignHeadersOptions, type SignRequestOptions, signHeaders, signRequest, } from "./sign.js";
4
4
  export { SigningKey } from "./signing-key.js";
5
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,KAAK,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAC7F,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,KAAK,kBAAkB,EAAE,KAAK,kBAAkB,EAAE,MAAM,WAAW,CAAC;AACvG,OAAO,EAAE,aAAa,EAAE,KAAK,aAAa,EAAE,KAAK,cAAc,EAAE,MAAM,eAAe,CAAC;AACvF,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,KAAK,mBAAmB,EACxB,kBAAkB,EAClB,eAAe,GACf,MAAM,cAAc,CAAC;AACtB,OAAO,EACN,aAAa,EACb,KAAK,aAAa,EAClB,KAAK,cAAc,GACnB,MAAM,eAAe,CAAC;AACvB,OAAO,EACN,KAAK,kBAAkB,EACvB,KAAK,kBAAkB,EACvB,WAAW,EACX,WAAW,GACX,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC"}
@@ -1,5 +1,5 @@
1
- export { createBiscuitToken, derivePublicKey } from "./biscuit.js";
2
- export { signRequest, signHeaders } from "./sign.js";
3
- export { createPkiAuth } from "./pki-auth.js";
1
+ export { createBiscuitToken, derivePublicKey, } from "./biscuit.js";
2
+ export { createPkiAuth, } from "./pki-auth.js";
3
+ export { signHeaders, signRequest, } from "./sign.js";
4
4
  export { SigningKey } from "./signing-key.js";
5
5
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAA4B,MAAM,cAAc,CAAC;AAC7F,OAAO,EAAE,WAAW,EAAE,WAAW,EAAoD,MAAM,WAAW,CAAC;AACvG,OAAO,EAAE,aAAa,EAA2C,MAAM,eAAe,CAAC;AACvF,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAEN,kBAAkB,EAClB,eAAe,GACf,MAAM,cAAc,CAAC;AACtB,OAAO,EACN,aAAa,GAGb,MAAM,eAAe,CAAC;AACvB,OAAO,EAGN,WAAW,EACX,WAAW,GACX,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC"}
@@ -1,5 +1,5 @@
1
- import { SigningKey } from "./signing-key.js";
2
1
  import type { SignHeadersOptions } from "./sign.js";
2
+ import { SigningKey } from "./signing-key.js";
3
3
  /**
4
4
  * Configuration for PKI authentication.
5
5
  *
@@ -1 +1 @@
1
- {"version":3,"file":"pki-auth.d.ts","sourceRoot":"","sources":["../../../src/auth/pki-auth.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAEpD;;;;;;;;;;GAUG;AACH,MAAM,MAAM,aAAa,GAAG;IAC3B,6DAA6D;IAC7D,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,iEAAiE;IACjE,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,6DAA6D;IAC7D,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,uDAAuD;IACvD,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,6DAA6D;IAC7D,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC5B,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,WAAW,GAAG,MAAM,GAAG,OAAO,CAAC;AAE3C,MAAM,MAAM,cAAc,GAAG;IAC5B,oBAAoB;IACpB,IAAI,EAAE,WAAW,CAAC;IAClB,4CAA4C;IAC5C,SAAS,EAAE,MAAM,CAAC;IAClB,wBAAwB;IACxB,QAAQ,EAAE,MAAM,OAAO,CAAC,MAAM,CAAC,CAAC;IAChC,2DAA2D;IAC3D,WAAW,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;IACpD,yDAAyD;IACzD,WAAW,EAAE,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,EAAE,YAAY,GAAG,WAAW,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9F,wEAAwE;IACxE,UAAU,EAAE,UAAU,CAAC;CACvB,CAAC;AAEF;;;;;;;;;;;;;;GAcG;AACH,wBAAgB,aAAa,CAAC,MAAM,EAAE,aAAa,GAAG,cAAc,CAcnE"}
1
+ {"version":3,"file":"pki-auth.d.ts","sourceRoot":"","sources":["../../../src/auth/pki-auth.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAEpD,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C;;;;;;;;;;GAUG;AACH,MAAM,MAAM,aAAa,GAAG;IAC3B,6DAA6D;IAC7D,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,iEAAiE;IACjE,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,6DAA6D;IAC7D,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,uDAAuD;IACvD,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,6DAA6D;IAC7D,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC5B,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,WAAW,GAAG,MAAM,GAAG,OAAO,CAAC;AAE3C,MAAM,MAAM,cAAc,GAAG;IAC5B,oBAAoB;IACpB,IAAI,EAAE,WAAW,CAAC;IAClB,4CAA4C;IAC5C,SAAS,EAAE,MAAM,CAAC;IAClB,wBAAwB;IACxB,QAAQ,EAAE,MAAM,OAAO,CAAC,MAAM,CAAC,CAAC;IAChC,2DAA2D;IAC3D,WAAW,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;IACpD,yDAAyD;IACzD,WAAW,EAAE,CACZ,OAAO,EAAE,IAAI,CAAC,kBAAkB,EAAE,YAAY,GAAG,WAAW,CAAC,KACzD,OAAO,CAAC,IAAI,CAAC,CAAC;IACnB,wEAAwE;IACxE,UAAU,EAAE,UAAU,CAAC;CACvB,CAAC;AAEF;;;;;;;;;;;;;;GAcG;AACH,wBAAgB,aAAa,CAAC,MAAM,EAAE,aAAa,GAAG,cAAc,CAoBnE"}
@@ -1,5 +1,5 @@
1
1
  import { createBiscuitToken } from "./biscuit.js";
2
- import { signRequest, signHeaders } from "./sign.js";
2
+ import { signHeaders, signRequest } from "./sign.js";
3
3
  import { SigningKey } from "./signing-key.js";
4
4
  /**
5
5
  * Creates a PKI auth context.
@@ -40,7 +40,9 @@ function createTokenAuth(token, signingKey, signatureExpiresIn) {
40
40
  return /^\/v\d+\/access-tokens(\/[^\/]+)?$/.test(path);
41
41
  }
42
42
  function extractPath(urlOrRequest) {
43
- const url = typeof urlOrRequest === "string" ? new URL(urlOrRequest) : new URL(urlOrRequest.url);
43
+ const url = typeof urlOrRequest === "string"
44
+ ? new URL(urlOrRequest)
45
+ : new URL(urlOrRequest.url);
44
46
  return url.pathname;
45
47
  }
46
48
  return {
@@ -55,14 +57,22 @@ function createTokenAuth(token, signingKey, signatureExpiresIn) {
55
57
  if (isAccessTokenEndpoint(path)) {
56
58
  throw new Error("Token mode cannot be used for access token endpoints. Use root key mode instead.");
57
59
  }
58
- return signRequest({ request, signingKey, expiresIn: signatureExpiresIn });
60
+ return signRequest({
61
+ request,
62
+ signingKey,
63
+ expiresIn: signatureExpiresIn,
64
+ });
59
65
  },
60
66
  async signHeaders(options) {
61
67
  const path = extractPath(options.url);
62
68
  if (isAccessTokenEndpoint(path)) {
63
69
  throw new Error("Token mode cannot be used for access token endpoints. Use root key mode instead.");
64
70
  }
65
- return signHeaders({ ...options, signingKey, expiresIn: signatureExpiresIn });
71
+ return signHeaders({
72
+ ...options,
73
+ signingKey,
74
+ expiresIn: signatureExpiresIn,
75
+ });
66
76
  },
67
77
  };
68
78
  }
@@ -89,10 +99,18 @@ function createRootKeyAuth(rootKey, tokenExpiresIn, signatureExpiresIn) {
89
99
  signingKey: clientKey,
90
100
  getToken,
91
101
  async signRequest(request) {
92
- return signRequest({ request, signingKey: clientKey, expiresIn: signatureExpiresIn });
102
+ return signRequest({
103
+ request,
104
+ signingKey: clientKey,
105
+ expiresIn: signatureExpiresIn,
106
+ });
93
107
  },
94
108
  async signHeaders(options) {
95
- return signHeaders({ ...options, signingKey: clientKey, expiresIn: signatureExpiresIn });
109
+ return signHeaders({
110
+ ...options,
111
+ signingKey: clientKey,
112
+ expiresIn: signatureExpiresIn,
113
+ });
96
114
  },
97
115
  };
98
116
  }
@@ -1 +1 @@
1
- {"version":3,"file":"pki-auth.js","sourceRoot":"","sources":["../../../src/auth/pki-auth.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"pki-auth.js","sourceRoot":"","sources":["../../../src/auth/pki-auth.ts"],"names":[],"mappings":"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"}