keri 0.0.0-dev.bf75350 → 0.0.0-dev.de65374

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 (200) hide show
  1. package/README.md +1 -1
  2. package/dist/cesr/__main__.d.ts +10 -0
  3. package/dist/cesr/__main__.js +11 -0
  4. package/dist/cesr/__main__.js.map +1 -0
  5. package/dist/cesr/array-utils.d.ts +3 -0
  6. package/dist/cesr/array-utils.js +29 -0
  7. package/dist/cesr/array-utils.js.map +1 -0
  8. package/dist/cesr/attachments-reader.d.ts +10 -0
  9. package/dist/cesr/attachments-reader.js +273 -0
  10. package/dist/cesr/attachments-reader.js.map +1 -0
  11. package/dist/cesr/attachments.d.ts +68 -0
  12. package/dist/cesr/attachments.js +116 -0
  13. package/dist/cesr/attachments.js.map +1 -0
  14. package/dist/cesr/codec.d.ts +26 -0
  15. package/dist/cesr/codec.js +26 -0
  16. package/dist/cesr/codec.js.map +1 -0
  17. package/dist/cesr/codes.d.ts +1208 -0
  18. package/dist/cesr/codes.js +309 -0
  19. package/dist/cesr/codes.js.map +1 -0
  20. package/dist/cesr/counter.d.ts +117 -0
  21. package/dist/cesr/counter.js +93 -0
  22. package/dist/cesr/counter.js.map +1 -0
  23. package/dist/cesr/frame.d.ts +36 -0
  24. package/dist/cesr/frame.js +97 -0
  25. package/dist/cesr/frame.js.map +1 -0
  26. package/dist/cesr/genus.d.ts +21 -0
  27. package/dist/cesr/genus.js +66 -0
  28. package/dist/cesr/genus.js.map +1 -0
  29. package/dist/cesr/groups/generic-map.d.ts +11 -0
  30. package/dist/cesr/groups/generic-map.js +59 -0
  31. package/dist/cesr/groups/generic-map.js.map +1 -0
  32. package/dist/cesr/indexer.d.ts +70 -0
  33. package/dist/cesr/indexer.js +177 -0
  34. package/dist/cesr/indexer.js.map +1 -0
  35. package/dist/cesr/matter.d.ts +163 -0
  36. package/dist/cesr/matter.js +311 -0
  37. package/dist/cesr/matter.js.map +1 -0
  38. package/dist/cesr/message.d.ts +17 -0
  39. package/dist/cesr/message.js +81 -0
  40. package/dist/cesr/message.js.map +1 -0
  41. package/dist/cesr/parse.d.ts +37 -0
  42. package/dist/cesr/parse.js +137 -0
  43. package/dist/cesr/parse.js.map +1 -0
  44. package/dist/cesr/shifting.d.ts +7 -0
  45. package/dist/cesr/shifting.js +10 -0
  46. package/dist/cesr/shifting.js.map +1 -0
  47. package/dist/cesr/version-string.d.ts +35 -0
  48. package/dist/cesr/version-string.js +147 -0
  49. package/dist/cesr/version-string.js.map +1 -0
  50. package/dist/cli/cli.d.ts +5 -0
  51. package/dist/cli/cli.js +73 -0
  52. package/dist/cli/cli.js.map +1 -0
  53. package/dist/cli/input.d.ts +1 -0
  54. package/dist/cli/input.js +22 -0
  55. package/dist/cli/input.js.map +1 -0
  56. package/dist/cli/node-cli.d.ts +2 -0
  57. package/dist/cli/node-cli.js +19 -0
  58. package/dist/cli/node-cli.js.map +1 -0
  59. package/dist/controller/controller.d.ts +101 -0
  60. package/dist/controller/controller.js +549 -0
  61. package/dist/controller/controller.js.map +1 -0
  62. package/dist/controller/encrypt.d.ts +45 -0
  63. package/dist/controller/encrypt.js +120 -0
  64. package/dist/controller/encrypt.js.map +1 -0
  65. package/dist/core/credential-event.d.ts +54 -0
  66. package/dist/core/credential-event.js +28 -0
  67. package/dist/core/credential-event.js.map +1 -0
  68. package/dist/core/credential.d.ts +79 -0
  69. package/dist/core/credential.js +25 -0
  70. package/dist/core/credential.js.map +1 -0
  71. package/dist/core/digest.d.ts +1 -0
  72. package/dist/core/digest.js +7 -0
  73. package/dist/core/digest.js.map +1 -0
  74. package/dist/core/endpoint-discovery.d.ts +20 -0
  75. package/dist/core/endpoint-discovery.js +60 -0
  76. package/dist/core/endpoint-discovery.js.map +1 -0
  77. package/dist/core/events.d.ts +12 -0
  78. package/dist/core/events.js +25 -0
  79. package/dist/core/events.js.map +1 -0
  80. package/dist/core/kawa.d.ts +17 -0
  81. package/dist/core/kawa.js +87 -0
  82. package/dist/core/kawa.js.map +1 -0
  83. package/dist/core/key-event-log.d.ts +13 -0
  84. package/dist/core/key-event-log.js +153 -0
  85. package/dist/core/key-event-log.js.map +1 -0
  86. package/dist/core/key-event.d.ts +94 -0
  87. package/dist/core/key-event.js +88 -0
  88. package/dist/core/key-event.js.map +1 -0
  89. package/dist/core/keys.d.ts +9 -0
  90. package/dist/core/keys.js +17 -0
  91. package/dist/core/keys.js.map +1 -0
  92. package/dist/core/mailbox-client.d.ts +23 -0
  93. package/dist/core/mailbox-client.js +59 -0
  94. package/dist/core/mailbox-client.js.map +1 -0
  95. package/dist/core/main.d.ts +51 -0
  96. package/dist/core/main.js +43 -0
  97. package/dist/core/main.js.map +1 -0
  98. package/dist/core/receipt-event.d.ts +15 -0
  99. package/dist/core/receipt-event.js +13 -0
  100. package/dist/core/receipt-event.js.map +1 -0
  101. package/dist/core/registry-event.d.ts +26 -0
  102. package/dist/core/registry-event.js +18 -0
  103. package/dist/core/registry-event.js.map +1 -0
  104. package/dist/core/routed-event.d.ts +67 -0
  105. package/dist/core/routed-event.js +53 -0
  106. package/dist/core/routed-event.js.map +1 -0
  107. package/dist/core/said.d.ts +4 -0
  108. package/dist/core/said.js +26 -0
  109. package/dist/core/said.js.map +1 -0
  110. package/dist/core/sign.d.ts +5 -0
  111. package/dist/core/sign.js +10 -0
  112. package/dist/core/sign.js.map +1 -0
  113. package/dist/core/threshold.d.ts +6 -0
  114. package/dist/core/threshold.js +58 -0
  115. package/dist/core/threshold.js.map +1 -0
  116. package/dist/core/verify.d.ts +15 -0
  117. package/dist/core/verify.js +43 -0
  118. package/dist/core/verify.js.map +1 -0
  119. package/dist/encoding/base64.d.ts +4 -0
  120. package/dist/encoding/base64.js +82 -0
  121. package/dist/encoding/base64.js.map +1 -0
  122. package/dist/encoding/utf8.d.ts +2 -0
  123. package/dist/encoding/utf8.js +9 -0
  124. package/dist/encoding/utf8.js.map +1 -0
  125. package/dist/main.d.ts +3 -6
  126. package/dist/main.js +3 -6
  127. package/dist/main.js.map +1 -1
  128. package/dist/nodejs-utils/serve.d.ts +5 -0
  129. package/dist/nodejs-utils/serve.js +76 -0
  130. package/dist/nodejs-utils/serve.js.map +1 -0
  131. package/dist/storage/credential-storage.d.ts +8 -0
  132. package/dist/storage/credential-storage.js +2 -0
  133. package/dist/storage/credential-storage.js.map +1 -0
  134. package/dist/storage/key-event-storage.d.ts +10 -0
  135. package/dist/storage/key-event-storage.js +2 -0
  136. package/dist/storage/key-event-storage.js.map +1 -0
  137. package/dist/storage/mailbox-storage.d.ts +4 -0
  138. package/dist/storage/mailbox-storage.js +2 -0
  139. package/dist/storage/mailbox-storage.js.map +1 -0
  140. package/dist/storage/private-key-storage.d.ts +5 -0
  141. package/dist/storage/private-key-storage.js +2 -0
  142. package/dist/storage/private-key-storage.js.map +1 -0
  143. package/dist/storage/sqlite/node-sqlite.d.ts +12 -0
  144. package/dist/storage/sqlite/node-sqlite.js +25 -0
  145. package/dist/storage/sqlite/node-sqlite.js.map +1 -0
  146. package/dist/storage/sqlite/schema.d.ts +2 -0
  147. package/dist/storage/sqlite/schema.js +55 -0
  148. package/dist/storage/sqlite/schema.js.map +1 -0
  149. package/dist/storage/sqlite/sqlite-database.d.ts +13 -0
  150. package/dist/storage/sqlite/sqlite-database.js +2 -0
  151. package/dist/storage/sqlite/sqlite-database.js.map +1 -0
  152. package/dist/storage/sqlite/storage-sqlite.d.ts +29 -0
  153. package/dist/storage/sqlite/storage-sqlite.js +213 -0
  154. package/dist/storage/sqlite/storage-sqlite.js.map +1 -0
  155. package/dist/witness/main.d.ts +2 -0
  156. package/dist/witness/main.js +3 -0
  157. package/dist/witness/main.js.map +1 -0
  158. package/dist/witness/parser.d.ts +3 -0
  159. package/dist/witness/parser.js +7 -0
  160. package/dist/witness/parser.js.map +1 -0
  161. package/dist/witness/seed.d.ts +1 -0
  162. package/dist/witness/seed.js +5 -0
  163. package/dist/witness/seed.js.map +1 -0
  164. package/dist/witness/witness-router.d.ts +2 -0
  165. package/dist/witness/witness-router.js +90 -0
  166. package/dist/witness/witness-router.js.map +1 -0
  167. package/dist/witness/witness.d.ts +23 -0
  168. package/dist/witness/witness.js +92 -0
  169. package/dist/witness/witness.js.map +1 -0
  170. package/package.json +34 -23
  171. package/dist/cli/main.d.ts +0 -2
  172. package/dist/cli/main.js +0 -177
  173. package/dist/cli/main.js.map +0 -1
  174. package/dist/client.d.ts +0 -21
  175. package/dist/client.js +0 -72
  176. package/dist/client.js.map +0 -1
  177. package/dist/controller.d.ts +0 -65
  178. package/dist/controller.js +0 -475
  179. package/dist/controller.js.map +0 -1
  180. package/dist/data-type.d.ts +0 -9
  181. package/dist/data-type.js +0 -2
  182. package/dist/data-type.js.map +0 -1
  183. package/dist/db/storage-sqlite.d.ts +0 -12
  184. package/dist/db/storage-sqlite.js +0 -57
  185. package/dist/db/storage-sqlite.js.map +0 -1
  186. package/dist/db/storage.d.ts +0 -18
  187. package/dist/db/storage.js +0 -37
  188. package/dist/db/storage.js.map +0 -1
  189. package/dist/events/event-store.d.ts +0 -133
  190. package/dist/events/event-store.js +0 -215
  191. package/dist/events/event-store.js.map +0 -1
  192. package/dist/events/events.d.ts +0 -251
  193. package/dist/events/events.js +0 -184
  194. package/dist/events/events.js.map +0 -1
  195. package/dist/keystore/encrypt.d.ts +0 -10
  196. package/dist/keystore/encrypt.js +0 -39
  197. package/dist/keystore/encrypt.js.map +0 -1
  198. package/dist/keystore/keystore.d.ts +0 -29
  199. package/dist/keystore/keystore.js +0 -72
  200. package/dist/keystore/keystore.js.map +0 -1
@@ -0,0 +1,67 @@
1
+ import { Message } from "../cesr/__main__.ts";
2
+ export interface QueryEventInit {
3
+ dt?: Date;
4
+ r?: string;
5
+ rr?: string;
6
+ q: Record<string, unknown>;
7
+ }
8
+ export type QueryEventBody = {
9
+ v: string;
10
+ t: "qry";
11
+ d: string;
12
+ dt: string;
13
+ r: string;
14
+ rr: string;
15
+ q: Record<string, unknown>;
16
+ };
17
+ export interface ReplyEventInit {
18
+ dt?: string;
19
+ r: string;
20
+ a: Record<string, unknown>;
21
+ }
22
+ export type ReplyEventBody = {
23
+ v: string;
24
+ t: "rpy";
25
+ d: string;
26
+ dt: string;
27
+ r: string;
28
+ a: Record<string, unknown>;
29
+ };
30
+ export type RoutedEventBody = {
31
+ v: string;
32
+ t: string;
33
+ d: string;
34
+ r: string;
35
+ [key: string]: unknown;
36
+ };
37
+ export type RoutedEvent = Message<RoutedEventBody>;
38
+ export declare function query(args: QueryEventInit): Message<QueryEventBody>;
39
+ export declare function reply(args: ReplyEventInit): Message<ReplyEventBody>;
40
+ export interface ExchangeEventInit {
41
+ sender: string;
42
+ recipient?: string;
43
+ p?: string;
44
+ timestamp?: string;
45
+ route: string;
46
+ query?: Record<string, unknown>;
47
+ anchor?: Record<string, unknown>;
48
+ embeds?: Record<string, Message>;
49
+ }
50
+ export interface ExchangeEmbedding {
51
+ d: string;
52
+ [key: string]: string | Record<string, unknown>;
53
+ }
54
+ export interface ExchangeEventBody extends Record<string, unknown> {
55
+ v: string;
56
+ t: "exn";
57
+ d: string;
58
+ i: string;
59
+ rp: string;
60
+ p: string;
61
+ dt: string;
62
+ r: string;
63
+ q: Record<string, unknown>;
64
+ a: Record<string, unknown>;
65
+ e: Record<string, string | Record<string, unknown>>;
66
+ }
67
+ export declare function exchange(args: ExchangeEventInit): Message<ExchangeEventBody>;
@@ -0,0 +1,53 @@
1
+ import { Attachments, Message } from "../cesr/__main__.js";
2
+ import { DUMMY_VERSION, encodeEvent, formatDate } from "./events.js";
3
+ import { saidify } from "./said.js";
4
+ export function query(args) {
5
+ const body = encodeEvent({
6
+ v: DUMMY_VERSION,
7
+ t: "qry",
8
+ d: "",
9
+ dt: formatDate(args.dt ?? new Date()),
10
+ r: args.r ?? "",
11
+ rr: args.rr ?? "",
12
+ q: args.q,
13
+ });
14
+ return new Message(body);
15
+ }
16
+ export function reply(args) {
17
+ const body = encodeEvent({
18
+ v: DUMMY_VERSION,
19
+ t: "rpy",
20
+ d: "",
21
+ dt: args.dt ?? formatDate(new Date()),
22
+ r: args.r,
23
+ a: args.a,
24
+ });
25
+ return new Message(body);
26
+ }
27
+ export function exchange(args) {
28
+ const embeds = { d: "" };
29
+ const attachments = new Attachments();
30
+ for (const [key, message] of Object.entries(args.embeds ?? {})) {
31
+ embeds[key] = message.body;
32
+ attachments.PathedMaterialCouples.push({
33
+ path: `-${["e", key].join("-")}`,
34
+ attachments: message.attachments,
35
+ grouped: true,
36
+ });
37
+ }
38
+ const body = encodeEvent({
39
+ v: DUMMY_VERSION,
40
+ t: "exn",
41
+ d: "",
42
+ i: args.sender,
43
+ rp: args.recipient ?? "",
44
+ p: args.p ?? "",
45
+ dt: args.timestamp ?? formatDate(new Date()),
46
+ r: args.route,
47
+ q: args.query ?? {},
48
+ a: args.anchor ?? {},
49
+ e: args.embeds ? saidify(embeds, ["d"]) : {},
50
+ });
51
+ return new Message(body, attachments);
52
+ }
53
+ //# sourceMappingURL=routed-event.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"routed-event.js","sourceRoot":"","sources":["../../src/core/routed-event.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACrE,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AA4CpC,MAAM,UAAU,KAAK,CAAC,IAAoB;IACxC,MAAM,IAAI,GAAG,WAAW,CAAiB;QACvC,CAAC,EAAE,aAAa;QAChB,CAAC,EAAE,KAAK;QACR,CAAC,EAAE,EAAE;QACL,EAAE,EAAE,UAAU,CAAC,IAAI,CAAC,EAAE,IAAI,IAAI,IAAI,EAAE,CAAC;QACrC,CAAC,EAAE,IAAI,CAAC,CAAC,IAAI,EAAE;QACf,EAAE,EAAE,IAAI,CAAC,EAAE,IAAI,EAAE;QACjB,CAAC,EAAE,IAAI,CAAC,CAAC;KACV,CAAC,CAAC;IAEH,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;AAC3B,CAAC;AAED,MAAM,UAAU,KAAK,CAAC,IAAoB;IACxC,MAAM,IAAI,GAAG,WAAW,CAAiB;QACvC,CAAC,EAAE,aAAa;QAChB,CAAC,EAAE,KAAK;QACR,CAAC,EAAE,EAAE;QACL,EAAE,EAAE,IAAI,CAAC,EAAE,IAAI,UAAU,CAAC,IAAI,IAAI,EAAE,CAAC;QACrC,CAAC,EAAE,IAAI,CAAC,CAAC;QACT,CAAC,EAAE,IAAI,CAAC,CAAC;KACV,CAAC,CAAC;IAEH,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;AAC3B,CAAC;AAgCD,MAAM,UAAU,QAAQ,CAAC,IAAuB;IAC9C,MAAM,MAAM,GAAsB,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC;IAC5C,MAAM,WAAW,GAAG,IAAI,WAAW,EAAE,CAAC;IAEtC,KAAK,MAAM,CAAC,GAAG,EAAE,OAAO,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC,EAAE,CAAC;QAC/D,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;QAC3B,WAAW,CAAC,qBAAqB,CAAC,IAAI,CAAC;YACrC,IAAI,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;YAChC,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,OAAO,EAAE,IAAI;SACd,CAAC,CAAC;IACL,CAAC;IAED,MAAM,IAAI,GAAG,WAAW,CAAoB;QAC1C,CAAC,EAAE,aAAa;QAChB,CAAC,EAAE,KAAK;QACR,CAAC,EAAE,EAAE;QACL,CAAC,EAAE,IAAI,CAAC,MAAM;QACd,EAAE,EAAE,IAAI,CAAC,SAAS,IAAI,EAAE;QACxB,CAAC,EAAE,IAAI,CAAC,CAAC,IAAI,EAAE;QACf,EAAE,EAAE,IAAI,CAAC,SAAS,IAAI,UAAU,CAAC,IAAI,IAAI,EAAE,CAAC;QAC5C,CAAC,EAAE,IAAI,CAAC,KAAK;QACb,CAAC,EAAE,IAAI,CAAC,KAAK,IAAI,EAAE;QACnB,CAAC,EAAE,IAAI,CAAC,MAAM,IAAI,EAAE;QACpB,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE;KAC7C,CAAC,CAAC;IAEH,OAAO,IAAI,OAAO,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;AACxC,CAAC"}
@@ -0,0 +1,4 @@
1
+ export interface SaidArgs {
2
+ labels?: string[];
3
+ }
4
+ export declare function saidify<T extends Record<string, unknown>>(event: T, labels?: string[]): T;
@@ -0,0 +1,26 @@
1
+ import { blake3 } from "@noble/hashes/blake3.js";
2
+ import { cesr } from "../cesr/__main__.js";
3
+ function calculateSaid(event) {
4
+ const digest = cesr.crypto.blake3_256(blake3
5
+ .create({ dkLen: 32 })
6
+ .update(new TextEncoder().encode(JSON.stringify(event)))
7
+ .digest());
8
+ return digest.text();
9
+ }
10
+ export function saidify(event, labels) {
11
+ if (!labels?.length) {
12
+ return event;
13
+ }
14
+ const digest = calculateSaid(event);
15
+ const result = {};
16
+ for (const [key, value] of Object.entries(event)) {
17
+ if (labels.includes(key)) {
18
+ result[key] = digest;
19
+ }
20
+ else {
21
+ result[key] = value;
22
+ }
23
+ }
24
+ return result;
25
+ }
26
+ //# sourceMappingURL=said.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"said.js","sourceRoot":"","sources":["../../src/core/said.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAE3C,SAAS,aAAa,CAAC,KAA8B;IACnD,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CACnC,MAAM;SACH,MAAM,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;SACrB,MAAM,CAAC,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;SACvD,MAAM,EAAE,CACZ,CAAC;IAEF,OAAO,MAAM,CAAC,IAAI,EAAE,CAAC;AACvB,CAAC;AAMD,MAAM,UAAU,OAAO,CAAoC,KAAQ,EAAE,MAAiB;IACpF,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;QACpB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,MAAM,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;IACpC,MAAM,MAAM,GAA4B,EAAE,CAAC;IAE3C,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACjD,IAAI,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YACzB,MAAM,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC;QACvB,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QACtB,CAAC;IACH,CAAC;IAED,OAAO,MAAW,CAAC;AACrB,CAAC"}
@@ -0,0 +1,5 @@
1
+ export interface SignOptions {
2
+ key: Uint8Array;
3
+ index?: number;
4
+ }
5
+ export declare function sign(payload: Uint8Array, options: SignOptions): string;
@@ -0,0 +1,10 @@
1
+ import { ed25519 } from "@noble/curves/ed25519.js";
2
+ import { cesr, Indexer } from "../cesr/__main__.js";
3
+ export function sign(payload, options) {
4
+ const signature = ed25519.sign(payload, options.key);
5
+ if (options.index !== undefined && options.index !== null) {
6
+ return Indexer.crypto.ed25519_sig(signature, options.index).text();
7
+ }
8
+ return cesr.crypto.ed25519_sig(signature).text();
9
+ }
10
+ //# sourceMappingURL=sign.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sign.js","sourceRoot":"","sources":["../../src/core/sign.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAOpD,MAAM,UAAU,IAAI,CAAC,OAAmB,EAAE,OAAoB;IAC5D,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;IAErD,IAAI,OAAO,CAAC,KAAK,KAAK,SAAS,IAAI,OAAO,CAAC,KAAK,KAAK,IAAI,EAAE,CAAC;QAC1D,OAAO,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,SAAS,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,CAAC;IACrE,CAAC;IAED,OAAO,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,CAAC;AACnD,CAAC"}
@@ -0,0 +1,6 @@
1
+ export type Threshold = string | string[];
2
+ export interface WeightedThreshold {
3
+ weights: number[];
4
+ required: number;
5
+ }
6
+ export declare function parseThreshold(threshold: Threshold, numKeys: number): WeightedThreshold;
@@ -0,0 +1,58 @@
1
+ function greatestCommonDivisor(a, b) {
2
+ let x = Math.abs(a);
3
+ let y = Math.abs(b);
4
+ while (y !== 0) {
5
+ const remainder = x % y;
6
+ x = y;
7
+ y = remainder;
8
+ }
9
+ return x;
10
+ }
11
+ function findLeastCommonDenominator(denominators) {
12
+ if (denominators.length === 0) {
13
+ throw new Error("At least one denominator is required");
14
+ }
15
+ return denominators.reduce((lcm, value) => {
16
+ if (!Number.isInteger(value) || value <= 0) {
17
+ throw new Error(`Invalid denominator: ${value}`);
18
+ }
19
+ return (lcm * value) / greatestCommonDivisor(lcm, value);
20
+ }, 1);
21
+ }
22
+ function parsePositiveInteger(value, errorMessage) {
23
+ if (!/^\d+$/.test(value)) {
24
+ throw new Error(errorMessage);
25
+ }
26
+ const parsed = Number.parseInt(value, 10);
27
+ if (parsed <= 0) {
28
+ throw new Error(errorMessage);
29
+ }
30
+ return parsed;
31
+ }
32
+ function parseFraction(fraction) {
33
+ const parts = fraction.split("/", 2);
34
+ if (parts.length !== 2) {
35
+ throw new Error(`Invalid threshold: ${fraction}`);
36
+ }
37
+ const numerator = parsePositiveInteger(parts[0], `Invalid threshold: ${fraction}`);
38
+ const denominator = parsePositiveInteger(parts[1], `Invalid threshold: ${fraction}`);
39
+ return [numerator, denominator];
40
+ }
41
+ export function parseThreshold(threshold, numKeys) {
42
+ if (typeof threshold === "string") {
43
+ const required = parsePositiveInteger(threshold, `Invalid threshold: ${threshold}`);
44
+ if (required > numKeys) {
45
+ throw new Error(`Invalid threshold: ${threshold} exceeds number of parties: ${numKeys}`);
46
+ }
47
+ return {
48
+ required,
49
+ weights: Array.from({ length: numKeys }, () => 1),
50
+ };
51
+ }
52
+ const values = threshold.map((t) => parseFraction(t));
53
+ const denominators = values.map(([, denom]) => denom);
54
+ const required = findLeastCommonDenominator(denominators);
55
+ const weights = values.map(([num, denom]) => (num * required) / denom);
56
+ return { weights, required };
57
+ }
58
+ //# sourceMappingURL=threshold.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"threshold.js","sourceRoot":"","sources":["../../src/core/threshold.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import { type Threshold } from "./threshold.ts";
2
+ export interface VerifyOptions {
3
+ threshold: Threshold;
4
+ keys: string[];
5
+ sigs: string[];
6
+ }
7
+ export type VerifyResult = {
8
+ ok: true;
9
+ error?: null;
10
+ } | {
11
+ ok: false;
12
+ error: string;
13
+ };
14
+ export declare function verify(payload: Uint8Array, options: VerifyOptions): VerifyResult;
15
+ export declare function verifyOrThrow(payload: Uint8Array, options: VerifyOptions): void;
@@ -0,0 +1,43 @@
1
+ import { ed25519 } from "@noble/curves/ed25519.js";
2
+ import { Indexer, Matter } from "../cesr/__main__.js";
3
+ import { parseThreshold } from "./threshold.js";
4
+ function verifySignature(payload, key, sig) {
5
+ switch (key.code) {
6
+ case Matter.Code.Ed25519:
7
+ case Matter.Code.Ed25519N:
8
+ // TODO:
9
+ // We can check the code of the signature,
10
+ // but it does not really matter since it will be verified correctly regardless.
11
+ // Anyway, revisit later
12
+ return ed25519.verify(sig.raw, payload, key.raw);
13
+ default:
14
+ throw new Error(`Unsupported key code: ${key.code}`);
15
+ }
16
+ }
17
+ export function verify(payload, options) {
18
+ const keys = options.keys.map((key) => Matter.parse(key));
19
+ const sigs = options.sigs.map((sig) => Indexer.parse(sig));
20
+ const threshold = parseThreshold(options.threshold, options.keys.length);
21
+ let sum = 0;
22
+ for (let idx = 0; idx < keys.length; idx++) {
23
+ const sig = sigs.find((s) => s.index === idx);
24
+ if (!sig) {
25
+ continue;
26
+ }
27
+ if (!verifySignature(payload, keys[idx], sig)) {
28
+ return { ok: false, error: `Invalid signature for key at index ${idx}` };
29
+ }
30
+ sum += threshold.weights[idx];
31
+ }
32
+ if (sum < threshold.required) {
33
+ return { ok: false, error: `Threshold not met: ${sum} weight provided, but ${threshold.required} required` };
34
+ }
35
+ return { ok: true };
36
+ }
37
+ export function verifyOrThrow(payload, options) {
38
+ const result = verify(payload, options);
39
+ if (!result.ok) {
40
+ throw new Error(result.error);
41
+ }
42
+ }
43
+ //# sourceMappingURL=verify.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"verify.js","sourceRoot":"","sources":["../../src/core/verify.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAkB,MAAM,gBAAgB,CAAC;AAkBhE,SAAS,eAAe,CAAC,OAAmB,EAAE,GAAW,EAAE,GAAqB;IAC9E,QAAQ,GAAG,CAAC,IAAI,EAAE,CAAC;QACjB,KAAK,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;QACzB,KAAK,MAAM,CAAC,IAAI,CAAC,QAAQ;YACvB,QAAQ;YACR,0CAA0C;YAC1C,gFAAgF;YAChF,wBAAwB;YACxB,OAAO,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC;QACnD;YACE,MAAM,IAAI,KAAK,CAAC,yBAAyB,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;IACzD,CAAC;AACH,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,OAAmB,EAAE,OAAsB;IAChE,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;IAC1D,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;IAC3D,MAAM,SAAS,GAAG,cAAc,CAAC,OAAO,CAAC,SAAS,EAAE,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAEzE,IAAI,GAAG,GAAG,CAAC,CAAC;IAEZ,KAAK,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC;QAC3C,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,GAAG,CAAC,CAAC;QAC9C,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,SAAS;QACX,CAAC;QAED,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;YAC9C,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,sCAAsC,GAAG,EAAE,EAAE,CAAC;QAC3E,CAAC;QAED,GAAG,IAAI,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAChC,CAAC;IAED,IAAI,GAAG,GAAG,SAAS,CAAC,QAAQ,EAAE,CAAC;QAC7B,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,sBAAsB,GAAG,yBAAyB,SAAS,CAAC,QAAQ,WAAW,EAAE,CAAC;IAC/G,CAAC;IAED,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC;AACtB,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,OAAmB,EAAE,OAAsB;IACvE,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IACxC,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;AACH,CAAC"}
@@ -0,0 +1,4 @@
1
+ export declare function decodeBase64Int(str: string): number;
2
+ export declare function encodeBase64Int(value: number, length?: number): string;
3
+ export declare function encodeBase64Url(uint8: Uint8Array): string;
4
+ export declare function decodeBase64Url(input: string): Uint8Array;
@@ -0,0 +1,82 @@
1
+ const B64_ALPHABET = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_".split("");
2
+ function getBase64Index(char) {
3
+ if (char === "=") {
4
+ return 0;
5
+ }
6
+ const code = B64_ALPHABET.indexOf(char);
7
+ if (code === -1) {
8
+ throw new Error(`Invalid base64 character '${char}'`);
9
+ }
10
+ return code;
11
+ }
12
+ export function decodeBase64Int(str) {
13
+ let result = 0;
14
+ for (let i = str.length - 1; i >= 0; i--) {
15
+ const character = str.charAt(i);
16
+ const index = getBase64Index(character);
17
+ const factor = 64 ** (str.length - i - 1);
18
+ result += factor * index;
19
+ }
20
+ return result;
21
+ }
22
+ export function encodeBase64Int(value, length) {
23
+ if (length !== undefined && value >= 64 ** length) {
24
+ throw new Error(`value ${value} too big for base64 length ${length}`);
25
+ }
26
+ let remainder = value;
27
+ let result = "";
28
+ while (remainder !== 0) {
29
+ result = B64_ALPHABET[remainder % 64] + result;
30
+ remainder = Math.floor(remainder / 64);
31
+ }
32
+ return result.padStart(length ?? 1, "A");
33
+ }
34
+ export function encodeBase64Url(uint8) {
35
+ // CREDIT: https://github.com/denoland/std/blob/main/encoding/base64.ts
36
+ // CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727
37
+ let result = "";
38
+ let i;
39
+ const l = uint8.length;
40
+ for (i = 2; i < l; i += 3) {
41
+ result += B64_ALPHABET[uint8[i - 2] >> 2];
42
+ result += B64_ALPHABET[((uint8[i - 2] & 0x03) << 4) | (uint8[i - 1] >> 4)];
43
+ result += B64_ALPHABET[((uint8[i - 1] & 0x0f) << 2) | (uint8[i] >> 6)];
44
+ result += B64_ALPHABET[uint8[i] & 0x3f];
45
+ }
46
+ if (i === l + 1) {
47
+ // 1 octet yet to write
48
+ result += B64_ALPHABET[uint8[i - 2] >> 2];
49
+ result += B64_ALPHABET[(uint8[i - 2] & 0x03) << 4];
50
+ }
51
+ if (i === l) {
52
+ // 2 octets yet to write
53
+ result += B64_ALPHABET[uint8[i - 2] >> 2];
54
+ result += B64_ALPHABET[((uint8[i - 2] & 0x03) << 4) | (uint8[i - 1] >> 4)];
55
+ result += B64_ALPHABET[(uint8[i - 1] & 0x0f) << 2];
56
+ }
57
+ return result;
58
+ }
59
+ export function decodeBase64Url(input) {
60
+ if (typeof input !== "string") {
61
+ throw new Error(`input must be a string`);
62
+ }
63
+ if (input.length === 0) {
64
+ return new Uint8Array(0);
65
+ }
66
+ const remainder = input.length % 4;
67
+ const padSize = remainder > 0 ? 4 - remainder : remainder;
68
+ const str = input.padEnd(padSize + input.length, "=");
69
+ const result = new Uint8Array(3 * (str.length / 4));
70
+ for (let i = 0, j = 0; i < str.length; i += 4, j += 3) {
71
+ const sixtet0 = getBase64Index(str.charAt(i)) << 18;
72
+ const sixtet1 = getBase64Index(str.charAt(i + 1)) << 12;
73
+ const sixtet2 = getBase64Index(str.charAt(i + 2)) << 6;
74
+ const sixtet3 = getBase64Index(str.charAt(i + 3));
75
+ const chunk = sixtet0 | sixtet1 | sixtet2 | sixtet3;
76
+ result[j] = chunk >> 16;
77
+ result[j + 1] = (chunk >> 8) & 0xff;
78
+ result[j + 2] = chunk & 0xff;
79
+ }
80
+ return result.slice(0, result.length - padSize);
81
+ }
82
+ //# sourceMappingURL=base64.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base64.js","sourceRoot":"","sources":["../../src/encoding/base64.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function encodeUtf8(text: string): Uint8Array;
2
+ export declare function decodeUtf8(bytes: Uint8Array): string;
@@ -0,0 +1,9 @@
1
+ export function encodeUtf8(text) {
2
+ const encoder = new TextEncoder();
3
+ return encoder.encode(text);
4
+ }
5
+ export function decodeUtf8(bytes) {
6
+ const decoder = new TextDecoder();
7
+ return decoder.decode(bytes);
8
+ }
9
+ //# sourceMappingURL=utf8.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utf8.js","sourceRoot":"","sources":["../../src/encoding/utf8.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,UAAU,CAAC,IAAY;IACrC,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;IAClC,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;AAC9B,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,KAAiB;IAC1C,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;IAClC,OAAO,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;AAC/B,CAAC"}
package/dist/main.d.ts CHANGED
@@ -1,6 +1,3 @@
1
- export * from "./events/events.ts";
2
- export * from "./events/event-store.ts";
3
- export * from "./db/storage.ts";
4
- export * from "./keystore/keystore.ts";
5
- export * from "./keystore/encrypt.ts";
6
- export * from "./controller.ts";
1
+ export * from "./controller/controller.ts";
2
+ export * from "./core/main.ts";
3
+ export * from "./witness/main.ts";
package/dist/main.js CHANGED
@@ -1,7 +1,4 @@
1
- export * from "./events/events.js";
2
- export * from "./events/event-store.js";
3
- export * from "./db/storage.js";
4
- export * from "./keystore/keystore.js";
5
- export * from "./keystore/encrypt.js";
6
- export * from "./controller.js";
1
+ export * from "./controller/controller.js";
2
+ export * from "./core/main.js";
3
+ export * from "./witness/main.js";
7
4
  //# sourceMappingURL=main.js.map
package/dist/main.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AACxC,cAAc,iBAAiB,CAAC;AAChC,cAAc,wBAAwB,CAAC;AACvC,cAAc,uBAAuB,CAAC;AACtC,cAAc,iBAAiB,CAAC"}
1
+ {"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAC;AAC3C,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { RequestListener } from "node:http";
2
+ export interface ServerOptions {
3
+ logger?: (message: string, context?: unknown) => void;
4
+ }
5
+ export declare function createListener(handler: (request: Request) => Promise<Response>, logger?: (message: string, context?: unknown) => void): RequestListener;
@@ -0,0 +1,76 @@
1
+ import { Readable } from "node:stream";
2
+ import { format } from "node:util";
3
+ function toWebRequest(req, url) {
4
+ const headers = new Headers();
5
+ for (const [key, headerValue] of Object.entries(req.headers)) {
6
+ if (headerValue !== undefined) {
7
+ if (Array.isArray(headerValue)) {
8
+ for (const value of headerValue) {
9
+ headers.append(key, value);
10
+ }
11
+ }
12
+ else {
13
+ headers.set(key, headerValue);
14
+ }
15
+ }
16
+ }
17
+ let body = null;
18
+ if (!["GET", "HEAD"].includes(req.method ?? "")) {
19
+ body = Readable.toWeb(req);
20
+ }
21
+ const request = new Request(url, {
22
+ method: req.method,
23
+ headers: headers,
24
+ body,
25
+ duplex: "half",
26
+ // Cast required because DOM types omit `duplex`, but Node.js undici fetch requires it when body is a stream
27
+ });
28
+ return request;
29
+ }
30
+ async function handleRequest(req, res, handler) {
31
+ const host = req.headers.host ?? "0.0.0.0";
32
+ const protocol = req.headers["x-forwarded-proto"] ?? "http";
33
+ const url = new URL(req.url ?? "/", `${protocol}://${host}`);
34
+ const request = toWebRequest(req, url);
35
+ const response = await handler(request);
36
+ res.writeHead(response.status, Object.fromEntries(response.headers.entries()));
37
+ const reader = response.body?.getReader();
38
+ if (reader) {
39
+ while (true) {
40
+ const { done, value } = await reader.read();
41
+ if (done)
42
+ break;
43
+ res.write(value);
44
+ }
45
+ }
46
+ res.end();
47
+ }
48
+ export function createListener(handler, logger) {
49
+ return async (req, res) => {
50
+ const start = Date.now();
51
+ const url = req.url ?? "/";
52
+ const method = req.method ?? "GET";
53
+ res.on("finish", () => {
54
+ const ms = Date.now() - start;
55
+ logger?.(`${method} ${url} - ${res.statusCode} - ${ms}ms`, {
56
+ request: {
57
+ url,
58
+ method,
59
+ headers: req.headers,
60
+ },
61
+ response: {
62
+ status: res.statusCode,
63
+ },
64
+ });
65
+ });
66
+ try {
67
+ await handleRequest(req, res, handler);
68
+ }
69
+ catch (err) {
70
+ logger?.(`Error handling request\n${format(err)}\n`);
71
+ res.statusCode = 500;
72
+ res.end("Internal Server Error");
73
+ }
74
+ };
75
+ }
76
+ //# sourceMappingURL=serve.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"serve.js","sourceRoot":"","sources":["../../src/nodejs-utils/serve.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { CredentialBody, IssueEvent, Message, RegistryInceptEventBody, RevokeEvent } from "../core/main.ts";
2
+ export interface CredentialStorage {
3
+ getCredentialEvents(id: string): Generator<Message<IssueEvent | RevokeEvent>>;
4
+ getRegistry(id: string): Message<RegistryInceptEventBody> | null;
5
+ getRegistriesByOwner(owner: string): Generator<Message<RegistryInceptEventBody>>;
6
+ getCredential(id: string): CredentialBody | null;
7
+ getCredentialsByRegistry(registryId: string): CredentialBody[];
8
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=credential-storage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"credential-storage.js","sourceRoot":"","sources":["../../src/storage/credential-storage.ts"],"names":[],"mappings":""}
@@ -0,0 +1,10 @@
1
+ import type { KeyEvent, Message, ReplyEventBody } from "../core/main.ts";
2
+ export interface KeyEventStorage {
3
+ saveMessage(message: Message): void;
4
+ getKeyEvents(prefix: string): Generator<KeyEvent>;
5
+ getReplies(filter?: {
6
+ route?: string;
7
+ eid?: string;
8
+ cid?: string;
9
+ }): Generator<Message<ReplyEventBody>>;
10
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=key-event-storage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"key-event-storage.js","sourceRoot":"","sources":["../../src/storage/key-event-storage.ts"],"names":[],"mappings":""}
@@ -0,0 +1,4 @@
1
+ export interface MailboxStorage {
2
+ getMailboxOffset(prefix: string, topic: string): number;
3
+ saveMailboxOffset(prefix: string, topic: string, offset: number): void;
4
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=mailbox-storage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mailbox-storage.js","sourceRoot":"","sources":["../../src/storage/mailbox-storage.ts"],"names":[],"mappings":""}
@@ -0,0 +1,5 @@
1
+ export interface PrivateKeyStorage {
2
+ saveKey(publicKey: string, digest: string, encryptedPrivKey: string): void;
3
+ getEncryptedPrivateKey(publicKey: string): string;
4
+ getPublicKeyByDigest(digest: string): string;
5
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=private-key-storage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"private-key-storage.js","sourceRoot":"","sources":["../../src/storage/private-key-storage.ts"],"names":[],"mappings":""}
@@ -0,0 +1,12 @@
1
+ import type { DatabaseSync } from "node:sqlite";
2
+ import type { Database, Params, Row } from "./sqlite-database.ts";
3
+ /**
4
+ * Adapter that wraps the built-in `node:sqlite` `DatabaseSync` class so it satisfies the `Database` interface.
5
+ */
6
+ export declare class NodeSqliteDatabase implements Database {
7
+ #private;
8
+ constructor(db: DatabaseSync);
9
+ execute(sql: string, params?: Params): void;
10
+ queryOne(sql: string, params?: Params): Row | undefined;
11
+ iterate(sql: string, params?: Params): Iterable<Row>;
12
+ }