keri 0.0.0-dev.bf75350 → 0.0.0-dev.e00c3c1

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 +77 -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 +36 -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,153 @@
1
+ import { Message, parse } from "../cesr/__main__.js";
2
+ import { verifyOrThrow } from "./verify.js";
3
+ export class KeyEventLog {
4
+ #events;
5
+ #state;
6
+ constructor(events, state) {
7
+ this.#events = events;
8
+ this.#state = state;
9
+ }
10
+ static empty() {
11
+ return new KeyEventLog([], null);
12
+ }
13
+ static from(events) {
14
+ let log = KeyEventLog.empty();
15
+ for (const event of events) {
16
+ log = log.append(event);
17
+ }
18
+ return log;
19
+ }
20
+ static async parse(stream) {
21
+ let log = KeyEventLog.empty();
22
+ for await (const message of parse(stream)) {
23
+ // TODO: Verify that the message is a valid KeyEventBody before casting
24
+ if (message.body.t === "icp" || message.body.t === "ixn" || message.body.t === "rot") {
25
+ log = log.append(message);
26
+ }
27
+ }
28
+ return log;
29
+ }
30
+ get state() {
31
+ if (this.#state === null) {
32
+ throw new Error("No events in KEL");
33
+ }
34
+ return this.#state;
35
+ }
36
+ get events() {
37
+ return this.#events;
38
+ }
39
+ append(message) {
40
+ const sigs = message.attachments.ControllerIdxSigs ?? [];
41
+ const wigs = message.attachments.WitnessIdxSigs ?? [];
42
+ const body = message.body;
43
+ const bodyRaw = new Message(body).raw;
44
+ switch (body.t) {
45
+ case "icp": {
46
+ if (this.#state !== null) {
47
+ throw new Error("State already initialized");
48
+ }
49
+ const icp = body;
50
+ if (!icp.k || !Array.isArray(icp.k) || icp.k.length === 0) {
51
+ throw new Error("Inception event must have at least one key");
52
+ }
53
+ verifyOrThrow(bodyRaw, {
54
+ keys: icp.k,
55
+ threshold: icp.kt,
56
+ sigs,
57
+ });
58
+ if (icp.b && Array.isArray(icp.b) && icp.b.length > 0) {
59
+ verifyOrThrow(bodyRaw, {
60
+ keys: icp.b,
61
+ threshold: icp.bt,
62
+ sigs: wigs,
63
+ });
64
+ }
65
+ break;
66
+ }
67
+ case "ixn":
68
+ case "rot": {
69
+ if (this.#state === null) {
70
+ throw new Error("State must be initialized before applying interact or rotate events");
71
+ }
72
+ const state = this.#state;
73
+ verifyOrThrow(bodyRaw, {
74
+ keys: state.signingKeys,
75
+ threshold: state.signingThreshold,
76
+ sigs,
77
+ });
78
+ if (state.backers && state.backers.length > 0) {
79
+ verifyOrThrow(bodyRaw, {
80
+ keys: state.backers,
81
+ threshold: state.backerThreshold,
82
+ sigs: wigs,
83
+ });
84
+ }
85
+ break;
86
+ }
87
+ default:
88
+ throw new Error(`Unsupported event type: ${body.t}`);
89
+ }
90
+ const newState = reduceKeyState(this.#state, body);
91
+ return new KeyEventLog([...this.#events, message], newState);
92
+ }
93
+ }
94
+ function assertDefined(obj) {
95
+ if (obj === null) {
96
+ throw new Error("Object is null");
97
+ }
98
+ }
99
+ function merge(a, b) {
100
+ return {
101
+ identifier: b.identifier ?? a.identifier,
102
+ signingThreshold: b.signingThreshold ?? a.signingThreshold,
103
+ signingKeys: b.signingKeys ?? a.signingKeys,
104
+ nextThreshold: b.nextThreshold ?? a.nextThreshold,
105
+ nextKeyDigests: b.nextKeyDigests ?? a.nextKeyDigests,
106
+ backerThreshold: b.backerThreshold ?? a.backerThreshold,
107
+ backers: b.backers ?? a.backers,
108
+ configTraits: b.configTraits ?? a.configTraits,
109
+ lastEvent: b.lastEvent ?? a.lastEvent,
110
+ lastEstablishment: b.lastEstablishment ?? a.lastEstablishment,
111
+ };
112
+ }
113
+ function reduceKeyState(state, body) {
114
+ switch (body.t) {
115
+ case "icp": {
116
+ const icp = body;
117
+ return {
118
+ identifier: icp.i,
119
+ signingThreshold: icp.kt,
120
+ signingKeys: icp.k,
121
+ nextThreshold: icp.nt,
122
+ nextKeyDigests: icp.n,
123
+ backerThreshold: icp.bt,
124
+ backers: icp.b,
125
+ configTraits: icp.c,
126
+ lastEvent: { i: icp.i, s: icp.s, d: icp.d },
127
+ lastEstablishment: { i: icp.i, s: icp.s, d: icp.d },
128
+ };
129
+ }
130
+ case "ixn": {
131
+ assertDefined(state);
132
+ const ixn = body;
133
+ return merge(state, { lastEvent: { i: ixn.i, s: ixn.s, d: ixn.d } });
134
+ }
135
+ case "rot": {
136
+ assertDefined(state);
137
+ const rot = body;
138
+ return merge(state, {
139
+ backers: state.backers.filter((b) => !rot.br.includes(b)).concat(rot.ba),
140
+ backerThreshold: rot.bt,
141
+ signingKeys: rot.k,
142
+ signingThreshold: rot.kt,
143
+ nextKeyDigests: rot.n,
144
+ nextThreshold: rot.nt,
145
+ lastEvent: { i: rot.i, s: rot.s, d: rot.d },
146
+ lastEstablishment: { i: rot.i, s: rot.s, d: rot.d },
147
+ });
148
+ }
149
+ default:
150
+ throw new Error(`Unsupported event type: ${body.t}`);
151
+ }
152
+ }
153
+ //# sourceMappingURL=key-event-log.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"key-event-log.js","sourceRoot":"","sources":["../../src/core/key-event-log.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,94 @@
1
+ import { Message } from "../cesr/__main__.ts";
2
+ import type { Threshold } from "./threshold.ts";
3
+ export interface KeyState {
4
+ identifier: string;
5
+ signingThreshold: Threshold;
6
+ signingKeys: string[];
7
+ nextThreshold: Threshold;
8
+ nextKeyDigests: string[];
9
+ backerThreshold: string;
10
+ backers: string[];
11
+ configTraits: string[];
12
+ lastEvent: {
13
+ i: string;
14
+ s: string;
15
+ d: string;
16
+ };
17
+ lastEstablishment: {
18
+ i: string;
19
+ s: string;
20
+ d: string;
21
+ };
22
+ }
23
+ export interface InceptArgs {
24
+ signingKeys: string[];
25
+ signingThreshold?: Threshold;
26
+ nextKeys: string[];
27
+ nextThreshold?: Threshold;
28
+ wits?: string[];
29
+ toad?: number;
30
+ }
31
+ export interface InteractArgs {
32
+ data?: Record<string, unknown>;
33
+ }
34
+ export interface RotateArgs {
35
+ signingKeys: string[];
36
+ nextKeyDigests: string[];
37
+ data?: Record<string, unknown>;
38
+ br?: string[];
39
+ ba?: string[];
40
+ bt?: string;
41
+ }
42
+ export type InceptEventBody = {
43
+ v: string;
44
+ t: "icp";
45
+ d: string;
46
+ i: string;
47
+ s: string;
48
+ kt: Threshold;
49
+ k: string[];
50
+ nt: Threshold;
51
+ n: string[];
52
+ bt: string;
53
+ b: string[];
54
+ c: string[];
55
+ a: Record<string, unknown>[];
56
+ };
57
+ export type InteractEventBody = {
58
+ v: string;
59
+ t: "ixn";
60
+ d: string;
61
+ i: string;
62
+ s: string;
63
+ p: string;
64
+ a: Record<string, unknown>[];
65
+ };
66
+ export type RotateEventBody = {
67
+ v: string;
68
+ t: "rot";
69
+ d: string;
70
+ i: string;
71
+ s: string;
72
+ p: string;
73
+ kt: Threshold;
74
+ k: string[];
75
+ nt: Threshold;
76
+ n: string[];
77
+ bt: string;
78
+ br: string[];
79
+ ba: string[];
80
+ c: string[];
81
+ a: Record<string, unknown>[];
82
+ };
83
+ export type KeyEventBody = {
84
+ v: string;
85
+ t: string;
86
+ d: string;
87
+ i: string;
88
+ s: string;
89
+ [key: string]: unknown;
90
+ };
91
+ export type KeyEvent<T extends KeyEventBody = KeyEventBody> = Message<T>;
92
+ export declare function incept(args: InceptArgs): KeyEvent<InceptEventBody>;
93
+ export declare function interact(state: KeyState, args?: InteractArgs): KeyEvent<InteractEventBody>;
94
+ export declare function rotate(state: KeyState, args: RotateArgs): KeyEvent<RotateEventBody>;
@@ -0,0 +1,88 @@
1
+ import { Matter, Message } from "../cesr/__main__.js";
2
+ import { DUMMY_VERSION, encodeEvent } from "./events.js";
3
+ function isTransferable(key) {
4
+ const raw = Matter.parse(key);
5
+ switch (raw.code) {
6
+ case Matter.Code.ECDSA_256k1N:
7
+ case Matter.Code.Ed25519N:
8
+ case Matter.Code.Ed448N:
9
+ return false;
10
+ default:
11
+ return true;
12
+ }
13
+ }
14
+ export function incept(args) {
15
+ const keys = args.signingKeys;
16
+ if (keys.length === 0) {
17
+ throw new Error("No keys provided in inception event");
18
+ }
19
+ const wits = args.wits ?? [];
20
+ const transferable = keys.length > 1 || isTransferable(keys[0]);
21
+ const labels = transferable ? ["d", "i"] : ["d"];
22
+ let bt;
23
+ if (args.toad !== undefined) {
24
+ bt = args.toad.toString();
25
+ }
26
+ else if (wits.length === 0) {
27
+ bt = "0";
28
+ }
29
+ else if (wits.length === 1) {
30
+ bt = "1";
31
+ }
32
+ else {
33
+ bt = (wits.length - 1).toString();
34
+ }
35
+ const body = encodeEvent({
36
+ v: DUMMY_VERSION,
37
+ t: "icp",
38
+ d: "",
39
+ i: transferable ? "" : keys[0],
40
+ s: "0",
41
+ kt: keys.length.toString(),
42
+ k: keys,
43
+ nt: args.nextKeys.length.toString(),
44
+ n: args.nextKeys,
45
+ bt,
46
+ b: wits,
47
+ c: [],
48
+ a: [],
49
+ }, { labels, legacy: true });
50
+ return new Message(body);
51
+ }
52
+ export function interact(state, args = {}) {
53
+ const body = encodeEvent({
54
+ v: DUMMY_VERSION,
55
+ t: "ixn",
56
+ d: "",
57
+ i: state.identifier,
58
+ s: (parseInt(state.lastEvent.s, 16) + 1).toString(16),
59
+ p: state.lastEvent.d,
60
+ a: args.data ? [args.data] : [],
61
+ }, { labels: ["d"], legacy: true });
62
+ return new Message(body);
63
+ }
64
+ export function rotate(state, args) {
65
+ const keyDigest = state.nextKeyDigests[0];
66
+ if (!keyDigest) {
67
+ throw new Error(`State for id ${state.identifier} does not contain pre-committed next key digest`);
68
+ }
69
+ const body = encodeEvent({
70
+ v: DUMMY_VERSION,
71
+ t: "rot",
72
+ d: "",
73
+ i: state.identifier,
74
+ s: (parseInt(state.lastEvent.s, 16) + 1).toString(16),
75
+ p: state.lastEvent.d,
76
+ kt: "1",
77
+ k: args.signingKeys,
78
+ nt: "1",
79
+ n: args.nextKeyDigests,
80
+ bt: args.bt ?? "0",
81
+ br: args.br ?? [],
82
+ ba: args.ba ?? [],
83
+ c: [],
84
+ a: args.data ? [args.data] : [],
85
+ }, { labels: ["d"], legacy: true });
86
+ return new Message(body);
87
+ }
88
+ //# sourceMappingURL=key-event.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"key-event.js","sourceRoot":"","sources":["../../src/core/key-event.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AA2FzD,SAAS,cAAc,CAAC,GAAW;IACjC,MAAM,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC9B,QAAQ,GAAG,CAAC,IAAI,EAAE,CAAC;QACjB,KAAK,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC;QAC9B,KAAK,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC;QAC1B,KAAK,MAAM,CAAC,IAAI,CAAC,MAAM;YACrB,OAAO,KAAK,CAAC;QACf;YACE,OAAO,IAAI,CAAC;IAChB,CAAC;AACH,CAAC;AAaD,MAAM,UAAU,MAAM,CAAC,IAAgB;IACrC,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC;IAC9B,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACtB,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;IACzD,CAAC;IAED,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;IAC7B,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IAChE,MAAM,MAAM,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;IAEjD,IAAI,EAAU,CAAC;IACf,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC5B,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;SAAM,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC7B,EAAE,GAAG,GAAG,CAAC;IACX,CAAC;SAAM,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC7B,EAAE,GAAG,GAAG,CAAC;IACX,CAAC;SAAM,CAAC;QACN,EAAE,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;IAED,MAAM,IAAI,GAAG,WAAW,CACtB;QACE,CAAC,EAAE,aAAa;QAChB,CAAC,EAAE,KAAc;QACjB,CAAC,EAAE,EAAE;QACL,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QAC9B,CAAC,EAAE,GAAG;QACN,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAe;QACvC,CAAC,EAAE,IAAI;QACP,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAe;QAChD,CAAC,EAAE,IAAI,CAAC,QAAQ;QAChB,EAAE;QACF,CAAC,EAAE,IAAI;QACP,CAAC,EAAE,EAAc;QACjB,CAAC,EAAE,EAA+B;KACnC,EACD,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,CACzB,CAAC;IAEF,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;AAC3B,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,KAAe,EAAE,OAAqB,EAAE;IAC/D,MAAM,IAAI,GAAG,WAAW,CACtB;QACE,CAAC,EAAE,aAAa;QAChB,CAAC,EAAE,KAAc;QACjB,CAAC,EAAE,EAAE;QACL,CAAC,EAAE,KAAK,CAAC,UAAU;QACnB,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC;QACrD,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QACpB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAE,EAAgC;KAC/D,EACD,EAAE,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAChC,CAAC;IAEF,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;AAC3B,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,KAAe,EAAE,IAAgB;IACtD,MAAM,SAAS,GAAG,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;IAC1C,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CAAC,gBAAgB,KAAK,CAAC,UAAU,iDAAiD,CAAC,CAAC;IACrG,CAAC;IAED,MAAM,IAAI,GAAG,WAAW,CACtB;QACE,CAAC,EAAE,aAAa;QAChB,CAAC,EAAE,KAAc;QACjB,CAAC,EAAE,EAAE;QACL,CAAC,EAAE,KAAK,CAAC,UAAU;QACnB,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC;QACrD,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QACpB,EAAE,EAAE,GAAG;QACP,CAAC,EAAE,IAAI,CAAC,WAAW;QACnB,EAAE,EAAE,GAAG;QACP,CAAC,EAAE,IAAI,CAAC,cAAc;QACtB,EAAE,EAAE,IAAI,CAAC,EAAE,IAAI,GAAG;QAClB,EAAE,EAAE,IAAI,CAAC,EAAE,IAAK,EAAe;QAC/B,EAAE,EAAE,IAAI,CAAC,EAAE,IAAK,EAAe;QAC/B,CAAC,EAAE,EAAc;QACjB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAE,EAAgC;KAC/D,EACD,EAAE,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAChC,CAAC;IAEF,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;AAC3B,CAAC"}
@@ -0,0 +1,9 @@
1
+ export interface KeyPair {
2
+ privateKey: Uint8Array;
3
+ publicKey: string;
4
+ publicKeyDigest: string;
5
+ }
6
+ export interface GenerateKeyPairOptions {
7
+ nonTransferable?: boolean;
8
+ }
9
+ export declare function generateKeyPair(seed?: string, options?: GenerateKeyPairOptions): KeyPair;
@@ -0,0 +1,17 @@
1
+ import { ed25519 } from "@noble/curves/ed25519.js";
2
+ import { blake3 } from "@noble/hashes/blake3.js";
3
+ import { cesr } from "../cesr/__main__.js";
4
+ export function generateKeyPair(seed, options) {
5
+ const privateKey = seed
6
+ ? blake3(new TextEncoder().encode(seed), { dkLen: 32 })
7
+ : crypto.getRandomValues(new Uint8Array(32));
8
+ const rawPublicKey = ed25519.getPublicKey(privateKey);
9
+ const publicKey = options?.nonTransferable
10
+ ? cesr.crypto.ed25519N(rawPublicKey).text()
11
+ : cesr.crypto.ed25519(rawPublicKey).text();
12
+ const publicKeyDigest = cesr.crypto
13
+ .blake3_256(blake3.create({ dkLen: 32 }).update(new TextEncoder().encode(publicKey)).digest())
14
+ .text();
15
+ return { privateKey, publicKey, publicKeyDigest };
16
+ }
17
+ //# sourceMappingURL=keys.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"keys.js","sourceRoot":"","sources":["../../src/core/keys.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAY3C,MAAM,UAAU,eAAe,CAAC,IAAa,EAAE,OAAgC;IAC7E,MAAM,UAAU,GAAG,IAAI;QACrB,CAAC,CAAC,MAAM,CAAC,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;QACvD,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC;IAE/C,MAAM,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;IACtD,MAAM,SAAS,GAAG,OAAO,EAAE,eAAe;QACxC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,IAAI,EAAE;QAC3C,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,IAAI,EAAE,CAAC;IAE7C,MAAM,eAAe,GAAG,IAAI,CAAC,MAAM;SAChC,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;SAC7F,IAAI,EAAE,CAAC;IAEV,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,eAAe,EAAE,CAAC;AACpD,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { type Message } from "../cesr/__main__.ts";
2
+ export interface MailboxClientOptions {
3
+ /**
4
+ * The SAID of the mailbox controller.
5
+ */
6
+ id: string;
7
+ /**
8
+ * The URL of the mailbox server to send messages to.
9
+ */
10
+ url: string;
11
+ /**
12
+ * Optional fetch implementation to use for sending messages.
13
+ * Defaults to the global `fetch` function.
14
+ */
15
+ fetch?: typeof globalThis.fetch;
16
+ }
17
+ export declare class MailboxClient {
18
+ #private;
19
+ readonly url: string;
20
+ readonly id: string;
21
+ constructor(options: MailboxClientOptions);
22
+ sendMessage(message: Message, signal?: AbortSignal): Promise<Message[]>;
23
+ }
@@ -0,0 +1,59 @@
1
+ import { parse } from "../cesr/__main__.js";
2
+ export class MailboxClient {
3
+ url;
4
+ id;
5
+ #fetch;
6
+ constructor(options) {
7
+ this.url = options.url;
8
+ this.id = options.id;
9
+ this.#fetch = options.fetch ?? globalThis.fetch;
10
+ }
11
+ async sendMessage(message, signal) {
12
+ const url = new URL("/", this.url);
13
+ const body = JSON.stringify(message.body);
14
+ const headers = {
15
+ "Content-Type": "application/cesr+json",
16
+ "CESR-ATTACHMENT": message.attachments.text(),
17
+ "CESR-DESTINATION": this.id,
18
+ };
19
+ const response = await this.#fetch(url, {
20
+ method: "POST",
21
+ body,
22
+ headers,
23
+ signal,
24
+ });
25
+ if (!response.ok) {
26
+ throw new Error(`Failed to send event: ${response.status} ${response.statusText}`);
27
+ }
28
+ if (!response.body) {
29
+ return [];
30
+ }
31
+ const contentType = response.headers.get("Content-Type");
32
+ if (!contentType) {
33
+ return [];
34
+ }
35
+ if (contentType === "text/event-stream") {
36
+ const reader = response.body.getReader();
37
+ while (true) {
38
+ const { done, value } = await reader.read();
39
+ if (done) {
40
+ break;
41
+ }
42
+ const str = new TextDecoder().decode(value);
43
+ for (const line of str.split("\n")) {
44
+ if (line.startsWith("data: ")) {
45
+ const data = line.slice(6);
46
+ const message = await Array.fromAsync(parse(data));
47
+ reader.cancel("Got message, cancelling reader");
48
+ return message;
49
+ }
50
+ }
51
+ }
52
+ }
53
+ if (contentType?.startsWith("application/json")) {
54
+ return [];
55
+ }
56
+ return await Array.fromAsync(parse(response.body));
57
+ }
58
+ }
59
+ //# sourceMappingURL=mailbox-client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mailbox-client.js","sourceRoot":"","sources":["../../src/core/mailbox-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,KAAK,EAAE,MAAM,qBAAqB,CAAC;AAoB1D,MAAM,OAAO,aAAa;IACf,GAAG,CAAS;IACZ,EAAE,CAAS;IACX,MAAM,CAA0B;IAEzC,YAAY,OAA6B;QACvC,IAAI,CAAC,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;QACvB,IAAI,CAAC,EAAE,GAAG,OAAO,CAAC,EAAE,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,KAAK,IAAI,UAAU,CAAC,KAAK,CAAC;IAClD,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAgB,EAAE,MAAoB;QACtD,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QAEnC,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC1C,MAAM,OAAO,GAAG;YACd,cAAc,EAAE,uBAAuB;YACvC,iBAAiB,EAAE,OAAO,CAAC,WAAW,CAAC,IAAI,EAAE;YAC7C,kBAAkB,EAAE,IAAI,CAAC,EAAE;SAC5B,CAAC;QAEF,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;YACtC,MAAM,EAAE,MAAM;YACd,IAAI;YACJ,OAAO;YACP,MAAM;SACP,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,yBAAyB,QAAQ,CAAC,MAAM,IAAI,QAAQ,CAAC,UAAU,EAAE,CAAC,CAAC;QACrF,CAAC;QAED,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;YACnB,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,MAAM,WAAW,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QACzD,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,WAAW,KAAK,mBAAmB,EAAE,CAAC;YACxC,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACzC,OAAO,IAAI,EAAE,CAAC;gBACZ,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,MAAM,CAAC,IAAI,EAAE,CAAC;gBAE5C,IAAI,IAAI,EAAE,CAAC;oBACT,MAAM;gBACR,CAAC;gBAED,MAAM,GAAG,GAAG,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBAE5C,KAAK,MAAM,IAAI,IAAI,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;oBACnC,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;wBAC9B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;wBAC3B,MAAM,OAAO,GAAG,MAAM,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;wBACnD,MAAM,CAAC,MAAM,CAAC,gCAAgC,CAAC,CAAC;wBAChD,OAAO,OAAO,CAAC;oBACjB,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,WAAW,EAAE,UAAU,CAAC,kBAAkB,CAAC,EAAE,CAAC;YAChD,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,OAAO,MAAM,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;IACrD,CAAC;CACF"}
@@ -0,0 +1,51 @@
1
+ import { createCredential } from "./credential.ts";
2
+ import { issue, revoke } from "./credential-event.ts";
3
+ import { digest } from "./digest.ts";
4
+ import { formatDate } from "./events.ts";
5
+ import { incept, interact, rotate } from "./key-event.ts";
6
+ import { generateKeyPair } from "./keys.ts";
7
+ import { receipt } from "./receipt-event.ts";
8
+ import { incept as registry } from "./registry-event.ts";
9
+ import { exchange, query, reply } from "./routed-event.ts";
10
+ import { sign } from "./sign.ts";
11
+ import { verify } from "./verify.ts";
12
+ export { Attachments, type AttachmentsInit, type FirstSeenReplayCouple, type Frame, Message, type MessageBody, type NonTransReceiptCouple, type PathedMaterialCouple, type SealSourceCouple, type SealSourceTriple, type TransIdxSigGroup, type TransLastIdxSigGroup, VersionString, } from "../cesr/__main__.ts";
13
+ export type { Credential, CredentialBody, CredentialBodyInit, CredentialEdges, CredentialRules, CredentialSubject, } from "./credential.ts";
14
+ export { createCredential } from "./credential.ts";
15
+ export type { IssueEventBody as IssueEvent, IssueEventInit, RevokeEventBody as RevokeEvent, RevokeEventInit, } from "./credential-event.ts";
16
+ export type { Endpoint, EndRoleRecord, LocationRecord } from "./endpoint-discovery.ts";
17
+ export { resolveEndRole, resolveLocation } from "./endpoint-discovery.ts";
18
+ export type { WitnessEndpoint } from "./kawa.ts";
19
+ export { submitToWitnesses } from "./kawa.ts";
20
+ export type { InceptArgs, InceptEventBody, InteractArgs, InteractEventBody, KeyEvent, KeyEventBody, KeyState, RotateArgs, RotateEventBody, } from "./key-event.ts";
21
+ export { KeyEventLog } from "./key-event-log.ts";
22
+ export type { GenerateKeyPairOptions, KeyPair } from "./keys.ts";
23
+ export type { MailboxClientOptions } from "./mailbox-client.ts";
24
+ export { MailboxClient } from "./mailbox-client.ts";
25
+ export type { ReceiptEventBody, ReceiptEventInit } from "./receipt-event.ts";
26
+ export type { RegistryInceptEventBody, RegistryInceptEventInit } from "./registry-event.ts";
27
+ export type { ExchangeEventBody, ExchangeEventInit, QueryEventBody, QueryEventInit, ReplyEventBody, ReplyEventInit, } from "./routed-event.ts";
28
+ export type { SignOptions } from "./sign.ts";
29
+ export { sign } from "./sign.ts";
30
+ export type { Threshold } from "./threshold.ts";
31
+ export type { VerifyOptions, VerifyResult } from "./verify.ts";
32
+ export declare const keri: {
33
+ incept: typeof incept;
34
+ interact: typeof interact;
35
+ rotate: typeof rotate;
36
+ registry: typeof registry;
37
+ issue: typeof issue;
38
+ revoke: typeof revoke;
39
+ credential: typeof createCredential;
40
+ exchange: typeof exchange;
41
+ query: typeof query;
42
+ reply: typeof reply;
43
+ receipt: typeof receipt;
44
+ utils: {
45
+ sign: typeof sign;
46
+ verify: typeof verify;
47
+ formatDate: typeof formatDate;
48
+ generateKeyPair: typeof generateKeyPair;
49
+ digest: typeof digest;
50
+ };
51
+ };
@@ -0,0 +1,43 @@
1
+ import { createCredential } from "./credential.js";
2
+ import { issue, revoke } from "./credential-event.js";
3
+ import { digest } from "./digest.js";
4
+ import { formatDate } from "./events.js";
5
+ import { incept, interact, rotate } from "./key-event.js";
6
+ import { generateKeyPair } from "./keys.js";
7
+ import { receipt } from "./receipt-event.js";
8
+ import { incept as registry } from "./registry-event.js";
9
+ import { exchange, query, reply } from "./routed-event.js";
10
+ import { sign } from "./sign.js";
11
+ import { verify } from "./verify.js";
12
+ export { Attachments, Message, VersionString, } from "../cesr/__main__.js";
13
+ export { createCredential } from "./credential.js";
14
+ export { resolveEndRole, resolveLocation } from "./endpoint-discovery.js";
15
+ export { submitToWitnesses } from "./kawa.js";
16
+ export { KeyEventLog } from "./key-event-log.js";
17
+ export { MailboxClient } from "./mailbox-client.js";
18
+ export { sign } from "./sign.js";
19
+ export const keri = {
20
+ // Key events
21
+ incept,
22
+ interact,
23
+ rotate,
24
+ // Registry
25
+ registry,
26
+ issue,
27
+ revoke,
28
+ credential: createCredential,
29
+ // Routed
30
+ exchange,
31
+ query,
32
+ reply,
33
+ // Receipt
34
+ receipt,
35
+ utils: {
36
+ sign,
37
+ verify,
38
+ formatDate,
39
+ generateKeyPair,
40
+ digest,
41
+ },
42
+ };
43
+ //# sourceMappingURL=main.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"main.js","sourceRoot":"","sources":["../../src/core/main.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,MAAM,IAAI,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC3D,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErC,OAAO,EACL,WAAW,EAIX,OAAO,EAQP,aAAa,GACd,MAAM,qBAAqB,CAAC;AAS7B,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAQnD,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAE1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AAY9C,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAYpD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAIjC,MAAM,CAAC,MAAM,IAAI,GAAG;IAClB,aAAa;IACb,MAAM;IACN,QAAQ;IACR,MAAM;IACN,WAAW;IACX,QAAQ;IACR,KAAK;IACL,MAAM;IACN,UAAU,EAAE,gBAAgB;IAC5B,SAAS;IACT,QAAQ;IACR,KAAK;IACL,KAAK;IACL,UAAU;IACV,OAAO;IACP,KAAK,EAAE;QACL,IAAI;QACJ,MAAM;QACN,UAAU;QACV,eAAe;QACf,MAAM;KACP;CACF,CAAC"}
@@ -0,0 +1,15 @@
1
+ import { Message } from "../cesr/__main__.ts";
2
+ export interface ReceiptEventInit {
3
+ d: string;
4
+ i: string;
5
+ s: string;
6
+ }
7
+ export type ReceiptEventBody = {
8
+ v: string;
9
+ t: "rct";
10
+ d: string;
11
+ i: string;
12
+ s: string;
13
+ };
14
+ export type ReceiptEvent = Message<ReceiptEventBody>;
15
+ export declare function receipt(args: ReceiptEventInit): ReceiptEvent;
@@ -0,0 +1,13 @@
1
+ import { Message } from "../cesr/__main__.js";
2
+ import { DUMMY_VERSION, encodeEvent } from "./events.js";
3
+ export function receipt(args) {
4
+ const body = encodeEvent({
5
+ v: DUMMY_VERSION,
6
+ t: "rct",
7
+ d: args.d,
8
+ i: args.i,
9
+ s: args.s,
10
+ }, { labels: [] });
11
+ return new Message(body);
12
+ }
13
+ //# sourceMappingURL=receipt-event.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"receipt-event.js","sourceRoot":"","sources":["../../src/core/receipt-event.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAmBzD,MAAM,UAAU,OAAO,CAAC,IAAsB;IAC5C,MAAM,IAAI,GAAG,WAAW,CACtB;QACE,CAAC,EAAE,aAAa;QAChB,CAAC,EAAE,KAAK;QACR,CAAC,EAAE,IAAI,CAAC,CAAC;QACT,CAAC,EAAE,IAAI,CAAC,CAAC;QACT,CAAC,EAAE,IAAI,CAAC,CAAC;KACV,EACD,EAAE,MAAM,EAAE,EAAE,EAAE,CACf,CAAC;IAEF,OAAO,IAAI,OAAO,CAAmB,IAAI,CAAC,CAAC;AAC7C,CAAC"}
@@ -0,0 +1,26 @@
1
+ import { Message } from "../cesr/__main__.ts";
2
+ export interface RegistryInceptEventInit {
3
+ ii: string;
4
+ n?: string;
5
+ }
6
+ export type RegistryInceptEventBody = {
7
+ v: string;
8
+ t: "vcp";
9
+ d: string;
10
+ i: string;
11
+ ii: string;
12
+ s: string;
13
+ c: string[];
14
+ bt: string;
15
+ b: string[];
16
+ n: string;
17
+ };
18
+ export type RegistryEventBody = {
19
+ v: string;
20
+ t: string;
21
+ d: string;
22
+ i: string;
23
+ [key: string]: unknown;
24
+ };
25
+ export type RegistryEvent = Message<RegistryEventBody>;
26
+ export declare function incept(args: RegistryInceptEventInit): Message<RegistryInceptEventBody>;
@@ -0,0 +1,18 @@
1
+ import { Message } from "../cesr/__main__.js";
2
+ import { DUMMY_VERSION, encodeEvent, randomNonce } from "./events.js";
3
+ export function incept(args) {
4
+ const body = encodeEvent({
5
+ v: DUMMY_VERSION,
6
+ t: "vcp",
7
+ d: "",
8
+ i: "",
9
+ ii: args.ii,
10
+ s: "0",
11
+ c: ["NB"],
12
+ bt: "0",
13
+ b: [],
14
+ n: args.n ?? randomNonce(),
15
+ }, { labels: ["d", "i"], legacy: true });
16
+ return new Message(body);
17
+ }
18
+ //# sourceMappingURL=registry-event.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registry-event.js","sourceRoot":"","sources":["../../src/core/registry-event.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AA8BtE,MAAM,UAAU,MAAM,CAAC,IAA6B;IAClD,MAAM,IAAI,GAAG,WAAW,CACtB;QACE,CAAC,EAAE,aAAa;QAChB,CAAC,EAAE,KAAK;QACR,CAAC,EAAE,EAAE;QACL,CAAC,EAAE,EAAE;QACL,EAAE,EAAE,IAAI,CAAC,EAAE;QACX,CAAC,EAAE,GAAG;QACN,CAAC,EAAE,CAAC,IAAI,CAAC;QACT,EAAE,EAAE,GAAG;QACP,CAAC,EAAE,EAAE;QACL,CAAC,EAAE,IAAI,CAAC,CAAC,IAAI,WAAW,EAAE;KAC3B,EACD,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CACrC,CAAC;IAEF,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;AAC3B,CAAC"}