cojson 0.10.8 → 0.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (180) hide show
  1. package/.turbo/turbo-build.log +1 -1
  2. package/CHANGELOG.md +20 -0
  3. package/dist/CoValuesStore.d.ts +12 -0
  4. package/dist/CoValuesStore.d.ts.map +1 -0
  5. package/dist/PeerKnownStates.d.ts +38 -0
  6. package/dist/PeerKnownStates.d.ts.map +1 -0
  7. package/dist/PeerState.d.ts +46 -0
  8. package/dist/PeerState.d.ts.map +1 -0
  9. package/dist/PriorityBasedMessageQueue.d.ts +18 -0
  10. package/dist/PriorityBasedMessageQueue.d.ts.map +1 -0
  11. package/dist/SyncStateManager.d.ts +20 -0
  12. package/dist/SyncStateManager.d.ts.map +1 -0
  13. package/dist/base64url.d.ts +3 -0
  14. package/dist/base64url.d.ts.map +1 -0
  15. package/dist/base64url.test.d.ts +2 -0
  16. package/dist/base64url.test.d.ts.map +1 -0
  17. package/dist/coValue.d.ts +52 -0
  18. package/dist/coValue.d.ts.map +1 -0
  19. package/dist/coValueCore.d.ts +143 -0
  20. package/dist/coValueCore.d.ts.map +1 -0
  21. package/dist/coValueCore.js +3 -9
  22. package/dist/coValueCore.js.map +1 -1
  23. package/dist/coValueState.d.ts +58 -0
  24. package/dist/coValueState.d.ts.map +1 -0
  25. package/dist/coValues/account.d.ts +69 -0
  26. package/dist/coValues/account.d.ts.map +1 -0
  27. package/dist/coValues/account.js +9 -10
  28. package/dist/coValues/account.js.map +1 -1
  29. package/dist/coValues/coList.d.ts +163 -0
  30. package/dist/coValues/coList.d.ts.map +1 -0
  31. package/dist/coValues/coMap.d.ts +142 -0
  32. package/dist/coValues/coMap.d.ts.map +1 -0
  33. package/dist/coValues/coPlainText.d.ts +33 -0
  34. package/dist/coValues/coPlainText.d.ts.map +1 -0
  35. package/dist/coValues/coStream.d.ts +109 -0
  36. package/dist/coValues/coStream.d.ts.map +1 -0
  37. package/dist/coValues/group.d.ts +143 -0
  38. package/dist/coValues/group.d.ts.map +1 -0
  39. package/dist/coValues/group.js +52 -6
  40. package/dist/coValues/group.js.map +1 -1
  41. package/dist/coreToCoValue.d.ts +15 -0
  42. package/dist/coreToCoValue.d.ts.map +1 -0
  43. package/dist/crypto/PureJSCrypto.d.ts +50 -0
  44. package/dist/crypto/PureJSCrypto.d.ts.map +1 -0
  45. package/dist/crypto/WasmCrypto.d.ts +49 -0
  46. package/dist/crypto/WasmCrypto.d.ts.map +1 -0
  47. package/dist/crypto/crypto.d.ts +142 -0
  48. package/dist/crypto/crypto.d.ts.map +1 -0
  49. package/dist/exports.d.ts +84 -0
  50. package/dist/exports.d.ts.map +1 -0
  51. package/dist/ids.d.ts +23 -0
  52. package/dist/ids.d.ts.map +1 -0
  53. package/dist/index.d.ts +2 -0
  54. package/dist/index.d.ts.map +1 -0
  55. package/dist/jsonStringify.d.ts +7 -0
  56. package/dist/jsonStringify.d.ts.map +1 -0
  57. package/dist/jsonValue.d.ts +45 -0
  58. package/dist/jsonValue.d.ts.map +1 -0
  59. package/dist/localNode.d.ts +111 -0
  60. package/dist/localNode.d.ts.map +1 -0
  61. package/dist/localNode.js +3 -5
  62. package/dist/localNode.js.map +1 -1
  63. package/dist/logger.d.ts +33 -0
  64. package/dist/logger.d.ts.map +1 -0
  65. package/dist/media.d.ts +8 -0
  66. package/dist/media.d.ts.map +1 -0
  67. package/dist/permissions.d.ts +24 -0
  68. package/dist/permissions.d.ts.map +1 -0
  69. package/dist/permissions.js +5 -9
  70. package/dist/permissions.js.map +1 -1
  71. package/dist/priority.d.ts +19 -0
  72. package/dist/priority.d.ts.map +1 -0
  73. package/dist/storage/FileSystem.d.ts +37 -0
  74. package/dist/storage/FileSystem.d.ts.map +1 -0
  75. package/dist/storage/chunksAndKnownStates.d.ts +7 -0
  76. package/dist/storage/chunksAndKnownStates.d.ts.map +1 -0
  77. package/dist/storage/index.d.ts +52 -0
  78. package/dist/storage/index.d.ts.map +1 -0
  79. package/dist/streamUtils.d.ts +13 -0
  80. package/dist/streamUtils.d.ts.map +1 -0
  81. package/dist/sync.d.ts +97 -0
  82. package/dist/sync.d.ts.map +1 -0
  83. package/dist/tests/PeerKnownStates.test.d.ts +2 -0
  84. package/dist/tests/PeerKnownStates.test.d.ts.map +1 -0
  85. package/dist/tests/PeerKnownStates.test.js +82 -0
  86. package/dist/tests/PeerKnownStates.test.js.map +1 -0
  87. package/dist/tests/PeerState.test.d.ts +2 -0
  88. package/dist/tests/PeerState.test.d.ts.map +1 -0
  89. package/dist/tests/PeerState.test.js +188 -0
  90. package/dist/tests/PeerState.test.js.map +1 -0
  91. package/dist/tests/PriorityBasedMessageQueue.test.d.ts +2 -0
  92. package/dist/tests/PriorityBasedMessageQueue.test.d.ts.map +1 -0
  93. package/dist/tests/PriorityBasedMessageQueue.test.js +120 -0
  94. package/dist/tests/PriorityBasedMessageQueue.test.js.map +1 -0
  95. package/dist/tests/SyncStateManager.test.d.ts +2 -0
  96. package/dist/tests/SyncStateManager.test.d.ts.map +1 -0
  97. package/dist/tests/SyncStateManager.test.js +127 -0
  98. package/dist/tests/SyncStateManager.test.js.map +1 -0
  99. package/dist/tests/account.test.d.ts +2 -0
  100. package/dist/tests/account.test.d.ts.map +1 -0
  101. package/dist/tests/account.test.js +66 -0
  102. package/dist/tests/account.test.js.map +1 -0
  103. package/dist/tests/coList.test.d.ts +2 -0
  104. package/dist/tests/coList.test.d.ts.map +1 -0
  105. package/dist/tests/coList.test.js +120 -0
  106. package/dist/tests/coList.test.js.map +1 -0
  107. package/dist/tests/coMap.test.d.ts +2 -0
  108. package/dist/tests/coMap.test.d.ts.map +1 -0
  109. package/dist/tests/coMap.test.js +164 -0
  110. package/dist/tests/coMap.test.js.map +1 -0
  111. package/dist/tests/coPlainText.test.d.ts +2 -0
  112. package/dist/tests/coPlainText.test.d.ts.map +1 -0
  113. package/dist/tests/coPlainText.test.js +99 -0
  114. package/dist/tests/coPlainText.test.js.map +1 -0
  115. package/dist/tests/coStream.test.d.ts +2 -0
  116. package/dist/tests/coStream.test.d.ts.map +1 -0
  117. package/dist/tests/coStream.test.js +206 -0
  118. package/dist/tests/coStream.test.js.map +1 -0
  119. package/dist/tests/coValueCore.test.d.ts +2 -0
  120. package/dist/tests/coValueCore.test.d.ts.map +1 -0
  121. package/dist/tests/coValueCore.test.js +164 -0
  122. package/dist/tests/coValueCore.test.js.map +1 -0
  123. package/dist/tests/coValueState.test.d.ts +2 -0
  124. package/dist/tests/coValueState.test.d.ts.map +1 -0
  125. package/dist/tests/coValueState.test.js +364 -0
  126. package/dist/tests/coValueState.test.js.map +1 -0
  127. package/dist/tests/crypto.test.d.ts +2 -0
  128. package/dist/tests/crypto.test.d.ts.map +1 -0
  129. package/dist/tests/crypto.test.js +144 -0
  130. package/dist/tests/crypto.test.js.map +1 -0
  131. package/dist/tests/cryptoImpl.test.d.ts +2 -0
  132. package/dist/tests/cryptoImpl.test.d.ts.map +1 -0
  133. package/dist/tests/cryptoImpl.test.js +144 -0
  134. package/dist/tests/cryptoImpl.test.js.map +1 -0
  135. package/dist/tests/group.test.d.ts +2 -0
  136. package/dist/tests/group.test.d.ts.map +1 -0
  137. package/dist/tests/group.test.js +576 -0
  138. package/dist/tests/group.test.js.map +1 -0
  139. package/dist/tests/logger.test.d.ts +2 -0
  140. package/dist/tests/logger.test.d.ts.map +1 -0
  141. package/dist/tests/logger.test.js +118 -0
  142. package/dist/tests/logger.test.js.map +1 -0
  143. package/dist/tests/permissions.test.d.ts +2 -0
  144. package/dist/tests/permissions.test.d.ts.map +1 -0
  145. package/dist/tests/permissions.test.js +2051 -0
  146. package/dist/tests/permissions.test.js.map +1 -0
  147. package/dist/tests/priority.test.d.ts +2 -0
  148. package/dist/tests/priority.test.d.ts.map +1 -0
  149. package/dist/tests/priority.test.js +61 -0
  150. package/dist/tests/priority.test.js.map +1 -0
  151. package/dist/tests/sync.test.d.ts +2 -0
  152. package/dist/tests/sync.test.d.ts.map +1 -0
  153. package/dist/tests/sync.test.js +1548 -0
  154. package/dist/tests/sync.test.js.map +1 -0
  155. package/dist/tests/testUtils.d.ts +142 -0
  156. package/dist/tests/testUtils.d.ts.map +1 -0
  157. package/dist/tests/testUtils.js +315 -0
  158. package/dist/tests/testUtils.js.map +1 -0
  159. package/dist/typeUtils/accountOrAgentIDfromSessionID.d.ts +4 -0
  160. package/dist/typeUtils/accountOrAgentIDfromSessionID.d.ts.map +1 -0
  161. package/dist/typeUtils/expectGroup.d.ts +4 -0
  162. package/dist/typeUtils/expectGroup.d.ts.map +1 -0
  163. package/dist/typeUtils/isAccountID.d.ts +4 -0
  164. package/dist/typeUtils/isAccountID.d.ts.map +1 -0
  165. package/dist/typeUtils/isCoValue.d.ts +4 -0
  166. package/dist/typeUtils/isCoValue.d.ts.map +1 -0
  167. package/dist/utils.d.ts +5 -0
  168. package/dist/utils.d.ts.map +1 -0
  169. package/package.json +6 -6
  170. package/src/coValueCore.ts +3 -9
  171. package/src/coValues/account.ts +15 -15
  172. package/src/coValues/group.ts +85 -12
  173. package/src/jsonValue.ts +9 -5
  174. package/src/localNode.ts +3 -5
  175. package/src/permissions.ts +5 -15
  176. package/src/tests/coValueCore.test.ts +2 -2
  177. package/src/tests/group.test.ts +187 -0
  178. package/src/tests/permissions.test.ts +330 -57
  179. package/src/tests/testUtils.ts +4 -1
  180. package/tsconfig.json +4 -2
@@ -0,0 +1 @@
1
+ {"version":3,"file":"priority.d.ts","sourceRoot":"","sources":["../src/priority.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEtD;;;;;;;;;GASG;AACH,eAAO,MAAM,iBAAiB;;;;CAIpB,CAAC;AAEX,MAAM,MAAM,eAAe,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;AAE5D,wBAAgB,qBAAqB,CACnC,MAAM,EAAE,aAAa,GAAG,SAAS,GAAG,OAAO,GAC1C,eAAe,CAkBjB"}
@@ -0,0 +1,37 @@
1
+ import { CryptoProvider } from "../crypto/crypto.js";
2
+ import { RawCoID } from "../ids.js";
3
+ import { CoValueChunk } from "./index.js";
4
+ export type BlockFilename = `L${number}-${string}-${string}-H${number}.jsonl`;
5
+ export type BlockHeader = {
6
+ id: RawCoID;
7
+ start: number;
8
+ length: number;
9
+ }[];
10
+ export type WalEntry = {
11
+ id: RawCoID;
12
+ } & CoValueChunk;
13
+ export type WalFilename = `wal-${number}.jsonl`;
14
+ export interface FileSystem<WriteHandle, ReadHandle> {
15
+ crypto: CryptoProvider;
16
+ createFile(filename: string): Promise<WriteHandle>;
17
+ append(handle: WriteHandle, data: Uint8Array): Promise<void>;
18
+ close(handle: ReadHandle | WriteHandle): Promise<void>;
19
+ closeAndRename(handle: WriteHandle, filename: BlockFilename): Promise<void>;
20
+ openToRead(filename: string): Promise<{
21
+ handle: ReadHandle;
22
+ size: number;
23
+ }>;
24
+ read(handle: ReadHandle, offset: number, length: number): Promise<Uint8Array>;
25
+ listFiles(): Promise<string[]>;
26
+ removeFile(filename: BlockFilename | WalFilename): Promise<void>;
27
+ }
28
+ export declare const textEncoder: TextEncoder;
29
+ export declare const textDecoder: TextDecoder;
30
+ export declare function readChunk<RH, FS extends FileSystem<unknown, RH>>(handle: RH, header: {
31
+ start: number;
32
+ length: number;
33
+ }, fs: FS): Promise<CoValueChunk>;
34
+ export declare function readHeader<RH, FS extends FileSystem<unknown, RH>>(filename: string, handle: RH, size: number, fs: FS): Promise<BlockHeader>;
35
+ export declare function writeBlock<WH, RH, FS extends FileSystem<WH, RH>>(chunks: Map<RawCoID, CoValueChunk>, level: number, blockNumber: number, fs: FS): Promise<BlockFilename>;
36
+ export declare function writeToWal<WH, RH, FS extends FileSystem<WH, RH>>(handle: WH, fs: FS, id: RawCoID, chunk: CoValueChunk): Promise<void>;
37
+ //# sourceMappingURL=FileSystem.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FileSystem.d.ts","sourceRoot":"","sources":["../../src/storage/FileSystem.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAiB,MAAM,qBAAqB,CAAC;AACpE,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAE1C,MAAM,MAAM,aAAa,GAAG,IAAI,MAAM,IAAI,MAAM,IAAI,MAAM,KAAK,MAAM,QAAQ,CAAC;AAE9E,MAAM,MAAM,WAAW,GAAG;IAAE,EAAE,EAAE,OAAO,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,CAAC;AAE3E,MAAM,MAAM,QAAQ,GAAG;IAAE,EAAE,EAAE,OAAO,CAAA;CAAE,GAAG,YAAY,CAAC;AAEtD,MAAM,MAAM,WAAW,GAAG,OAAO,MAAM,QAAQ,CAAC;AAEhD,MAAM,WAAW,UAAU,CAAC,WAAW,EAAE,UAAU;IACjD,MAAM,EAAE,cAAc,CAAC;IACvB,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IACnD,MAAM,CAAC,MAAM,EAAE,WAAW,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7D,KAAK,CAAC,MAAM,EAAE,UAAU,GAAG,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACvD,cAAc,CAAC,MAAM,EAAE,WAAW,EAAE,QAAQ,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5E,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,MAAM,EAAE,UAAU,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC5E,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IAC9E,SAAS,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IAC/B,UAAU,CAAC,QAAQ,EAAE,aAAa,GAAG,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAClE;AAED,eAAO,MAAM,WAAW,aAAoB,CAAC;AAC7C,eAAO,MAAM,WAAW,aAAoB,CAAC;AAE7C,wBAAsB,SAAS,CAAC,EAAE,EAAE,EAAE,SAAS,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,EACpE,MAAM,EAAE,EAAE,EACV,MAAM,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EACzC,EAAE,EAAE,EAAE,GACL,OAAO,CAAC,YAAY,CAAC,CAKvB;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,EAAE,SAAS,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,EACrE,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,EAAE,EACV,IAAI,EAAE,MAAM,EACZ,EAAE,EAAE,EAAE,GACL,OAAO,CAAC,WAAW,CAAC,CAOtB;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,SAAS,UAAU,CAAC,EAAE,EAAE,EAAE,CAAC,EACpE,MAAM,EAAE,GAAG,CAAC,OAAO,EAAE,YAAY,CAAC,EAClC,KAAK,EAAE,MAAM,EACb,WAAW,EAAE,MAAM,EACnB,EAAE,EAAE,EAAE,GACL,OAAO,CAAC,aAAa,CAAC,CAyCxB;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,SAAS,UAAU,CAAC,EAAE,EAAE,EAAE,CAAC,EACpE,MAAM,EAAE,EAAE,EACV,EAAE,EAAE,EAAE,EACN,EAAE,EAAE,OAAO,EACX,KAAK,EAAE,YAAY,iBAQpB"}
@@ -0,0 +1,7 @@
1
+ import { RawCoID } from "../ids.js";
2
+ import { CoValueKnownState, NewContentMessage } from "../sync.js";
3
+ import { CoValueChunk } from "./index.js";
4
+ export declare function contentSinceChunk(id: RawCoID, chunk: CoValueChunk, known?: CoValueKnownState): NewContentMessage[];
5
+ export declare function chunkToKnownState(id: RawCoID, chunk: CoValueChunk): CoValueKnownState;
6
+ export declare function mergeChunks(chunkA: CoValueChunk, chunkB: CoValueChunk): "nonContigous" | CoValueChunk;
7
+ //# sourceMappingURL=chunksAndKnownStates.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunksAndKnownStates.d.ts","sourceRoot":"","sources":["../../src/storage/chunksAndKnownStates.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAa,MAAM,WAAW,CAAC;AAE/C,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAE1C,wBAAgB,iBAAiB,CAC/B,EAAE,EAAE,OAAO,EACX,KAAK,EAAE,YAAY,EACnB,KAAK,CAAC,EAAE,iBAAiB,GACxB,iBAAiB,EAAE,CA8CrB;AAED,wBAAgB,iBAAiB,CAAC,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,YAAY,qBAgBjE;AAED,wBAAgB,WAAW,CACzB,MAAM,EAAE,YAAY,EACpB,MAAM,EAAE,YAAY,GACnB,cAAc,GAAG,YAAY,CAyD/B"}
@@ -0,0 +1,52 @@
1
+ import { CoValueHeader, Transaction } from "../coValueCore.js";
2
+ import { Signature } from "../crypto/crypto.js";
3
+ import { RawCoID } from "../ids.js";
4
+ import { CoValueKnownState, IncomingSyncStream, NewContentMessage, OutgoingSyncQueue, Peer } from "../sync.js";
5
+ import { BlockFilename, FileSystem } from "./FileSystem.js";
6
+ export type { BlockFilename, WalFilename } from "./FileSystem.js";
7
+ export type CoValueChunk = {
8
+ header?: CoValueHeader;
9
+ sessionEntries: {
10
+ [sessionID: string]: {
11
+ after: number;
12
+ lastSignature: Signature;
13
+ transactions: Transaction[];
14
+ }[];
15
+ };
16
+ };
17
+ export declare class LSMStorage<WH, RH, FS extends FileSystem<WH, RH>> {
18
+ fs: FS;
19
+ fromLocalNode: IncomingSyncStream;
20
+ toLocalNode: OutgoingSyncQueue;
21
+ currentWal: WH | undefined;
22
+ coValues: {
23
+ [id: RawCoID]: CoValueChunk | undefined;
24
+ };
25
+ fileCache: string[] | undefined;
26
+ headerCache: Map<`L${number}-${string}-${string}-H${number}.jsonl`, {
27
+ [id: `co_z${string}`]: {
28
+ start: number;
29
+ length: number;
30
+ };
31
+ }>;
32
+ blockFileHandles: Map<`L${number}-${string}-${string}-H${number}.jsonl`, Promise<{
33
+ handle: RH;
34
+ size: number;
35
+ }>>;
36
+ constructor(fs: FS, fromLocalNode: IncomingSyncStream, toLocalNode: OutgoingSyncQueue);
37
+ sendNewContent(id: RawCoID, known: CoValueKnownState | undefined, asDependencyOf: RawCoID | undefined): Promise<void>;
38
+ withWAL(handler: (wal: WH) => Promise<void>): Promise<void>;
39
+ handleNewContent(newContent: NewContentMessage): Promise<void>;
40
+ getBlockHandle(blockFile: BlockFilename, fs: FS): Promise<{
41
+ handle: RH;
42
+ size: number;
43
+ }>;
44
+ loadCoValue(id: RawCoID, fs: FS): Promise<CoValueChunk | undefined>;
45
+ compact(): Promise<void>;
46
+ static asPeer<WH, RH, FS extends FileSystem<WH, RH>>({ fs, trace, localNodeName, }: {
47
+ fs: FS;
48
+ trace?: boolean;
49
+ localNodeName?: string;
50
+ }): Peer;
51
+ }
52
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/storage/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAGpC,OAAO,EACL,iBAAiB,EACjB,kBAAkB,EAClB,iBAAiB,EACjB,iBAAiB,EACjB,IAAI,EACL,MAAM,YAAY,CAAC;AACpB,OAAO,EACL,aAAa,EACb,UAAU,EAQX,MAAM,iBAAiB,CAAC;AAMzB,YAAY,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAIlE,MAAM,MAAM,YAAY,GAAG;IACzB,MAAM,CAAC,EAAE,aAAa,CAAC;IACvB,cAAc,EAAE;QACd,CAAC,SAAS,EAAE,MAAM,GAAG;YACnB,KAAK,EAAE,MAAM,CAAC;YACd,aAAa,EAAE,SAAS,CAAC;YACzB,YAAY,EAAE,WAAW,EAAE,CAAC;SAC7B,EAAE,CAAC;KACL,CAAC;CACH,CAAC;AAEF,qBAAa,UAAU,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,SAAS,UAAU,CAAC,EAAE,EAAE,EAAE,CAAC;IAgBlD,EAAE,EAAE,EAAE;IACN,aAAa,EAAE,kBAAkB;IACjC,WAAW,EAAE,iBAAiB;IAjBvC,UAAU,EAAE,EAAE,GAAG,SAAS,CAAC;IAC3B,QAAQ,EAAE;QACR,CAAC,EAAE,EAAE,OAAO,GAAG,YAAY,GAAG,SAAS,CAAC;KACzC,CAAC;IACF,SAAS,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;IAChC,WAAW;;mBAEiB,MAAM;oBAAU,MAAM;;OAC9C;IACJ,gBAAgB;gBAEI,EAAE;cAAQ,MAAM;QAChC;gBAGK,EAAE,EAAE,EAAE,EACN,aAAa,EAAE,kBAAkB,EACjC,WAAW,EAAE,iBAAiB;IAoDjC,cAAc,CAClB,EAAE,EAAE,OAAO,EACX,KAAK,EAAE,iBAAiB,GAAG,SAAS,EACpC,cAAc,EAAE,OAAO,GAAG,SAAS;IAqF/B,OAAO,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC;IAS3C,gBAAgB,CAAC,UAAU,EAAE,iBAAiB;IA6D9C,cAAc,CAClB,SAAS,EAAE,aAAa,EACxB,EAAE,EAAE,EAAE,GACL,OAAO,CAAC;QAAE,MAAM,EAAE,EAAE,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;IAQlC,WAAW,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,YAAY,GAAG,SAAS,CAAC;IAuDnE,OAAO;IA4Kb,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,SAAS,UAAU,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EACnD,EAAE,EACF,KAAK,EACL,aAAuB,GACxB,EAAE;QACD,EAAE,EAAE,EAAE,CAAC;QACP,KAAK,CAAC,EAAE,OAAO,CAAC;QAChB,aAAa,CAAC,EAAE,MAAM,CAAC;KACxB,GAAG,IAAI;CAiBT"}
@@ -0,0 +1,13 @@
1
+ import { Channel } from "queueueue";
2
+ import { Peer, PeerID, SyncMessage } from "./sync.js";
3
+ export { Channel } from "queueueue";
4
+ export declare function connectedPeers(peer1id: PeerID, peer2id: PeerID, { trace, peer1role, peer2role, crashOnClose, }?: {
5
+ trace?: boolean;
6
+ peer1role?: Peer["role"];
7
+ peer2role?: Peer["role"];
8
+ crashOnClose?: boolean;
9
+ }): [Peer, Peer];
10
+ export declare function newQueuePair(options?: {
11
+ traceAs?: string;
12
+ }): [AsyncIterable<SyncMessage>, Channel<SyncMessage>];
13
+ //# sourceMappingURL=streamUtils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"streamUtils.d.ts","sourceRoot":"","sources":["../src/streamUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,wBAAgB,cAAc,CAC5B,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,MAAM,EACf,EACE,KAAa,EACb,SAAkB,EAClB,SAAkB,EAClB,YAAoB,GACrB,GAAE;IACD,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,SAAS,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACzB,SAAS,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACzB,YAAY,CAAC,EAAE,OAAO,CAAC;CACnB,GACL,CAAC,IAAI,EAAE,IAAI,CAAC,CAyBd;AAED,wBAAgB,YAAY,CAC1B,OAAO,GAAE;IAAE,OAAO,CAAC,EAAE,MAAM,CAAA;CAAO,GACjC,CAAC,aAAa,CAAC,WAAW,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC,CA0BpD"}
package/dist/sync.d.ts ADDED
@@ -0,0 +1,97 @@
1
+ import { PeerState } from "./PeerState.js";
2
+ import { SyncStateManager } from "./SyncStateManager.js";
3
+ import { CoValueHeader, Transaction } from "./coValueCore.js";
4
+ import { CoValueCore } from "./coValueCore.js";
5
+ import { Signature } from "./crypto/crypto.js";
6
+ import { RawCoID, SessionID } from "./ids.js";
7
+ import { LocalNode } from "./localNode.js";
8
+ import { CoValuePriority } from "./priority.js";
9
+ export type CoValueKnownState = {
10
+ id: RawCoID;
11
+ header: boolean;
12
+ sessions: {
13
+ [sessionID: SessionID]: number;
14
+ };
15
+ };
16
+ export declare function emptyKnownState(id: RawCoID): CoValueKnownState;
17
+ export type SyncMessage = LoadMessage | KnownStateMessage | NewContentMessage | DoneMessage;
18
+ export type LoadMessage = {
19
+ action: "load";
20
+ } & CoValueKnownState;
21
+ export type KnownStateMessage = {
22
+ action: "known";
23
+ asDependencyOf?: RawCoID;
24
+ isCorrection?: boolean;
25
+ } & CoValueKnownState;
26
+ export type NewContentMessage = {
27
+ action: "content";
28
+ id: RawCoID;
29
+ header?: CoValueHeader;
30
+ priority: CoValuePriority;
31
+ new: {
32
+ [sessionID: SessionID]: SessionNewContent;
33
+ };
34
+ };
35
+ export type SessionNewContent = {
36
+ after: number;
37
+ newTransactions: Transaction[];
38
+ lastSignature: Signature;
39
+ };
40
+ export type DoneMessage = {
41
+ action: "done";
42
+ id: RawCoID;
43
+ };
44
+ export type PeerID = string;
45
+ export type DisconnectedError = "Disconnected";
46
+ export type PingTimeoutError = "PingTimeout";
47
+ export type IncomingSyncStream = AsyncIterable<SyncMessage | DisconnectedError | PingTimeoutError>;
48
+ export type OutgoingSyncQueue = {
49
+ push: (msg: SyncMessage) => Promise<unknown>;
50
+ close: () => void;
51
+ };
52
+ export interface Peer {
53
+ id: PeerID;
54
+ incoming: IncomingSyncStream;
55
+ outgoing: OutgoingSyncQueue;
56
+ role: "peer" | "server" | "client" | "storage";
57
+ priority?: number;
58
+ crashOnClose: boolean;
59
+ deletePeerStateOnClose?: boolean;
60
+ }
61
+ export declare function combinedKnownStates(stateA: CoValueKnownState, stateB: CoValueKnownState): CoValueKnownState;
62
+ export declare class SyncManager {
63
+ peers: {
64
+ [key: PeerID]: PeerState;
65
+ };
66
+ local: LocalNode;
67
+ requestedSyncs: {
68
+ [id: RawCoID]: {
69
+ done: Promise<void>;
70
+ nRequestsThisTick: number;
71
+ } | undefined;
72
+ };
73
+ peersCounter: import("@opentelemetry/api").UpDownCounter<import("@opentelemetry/api").Attributes>;
74
+ constructor(local: LocalNode);
75
+ syncState: SyncStateManager;
76
+ peersInPriorityOrder(): PeerState[];
77
+ getPeers(): PeerState[];
78
+ getServerAndStoragePeers(excludePeerId?: PeerID): PeerState[];
79
+ handleSyncMessage(msg: SyncMessage, peer: PeerState): Promise<void>;
80
+ subscribeToIncludingDependencies(id: RawCoID, peer: PeerState): Promise<void>;
81
+ tellUntoldKnownStateIncludingDependencies(id: RawCoID, peer: PeerState, asDependencyOf?: RawCoID): Promise<void>;
82
+ sendNewContentIncludingDependencies(id: RawCoID, peer: PeerState): Promise<void>;
83
+ addPeer(peer: Peer): void;
84
+ trySendToPeer(peer: PeerState, msg: SyncMessage): Promise<void>;
85
+ handleLoad(msg: LoadMessage, peer: PeerState): Promise<void>;
86
+ handleKnownState(msg: KnownStateMessage, peer: PeerState): Promise<void>;
87
+ handleNewContent(msg: NewContentMessage, peer: PeerState): Promise<void>;
88
+ handleCorrection(msg: KnownStateMessage, peer: PeerState): Promise<void>;
89
+ handleUnsubscribe(_msg: DoneMessage): void;
90
+ syncCoValue(coValue: CoValueCore): Promise<void>;
91
+ actuallySyncCoValue(coValue: CoValueCore): Promise<void>;
92
+ waitForSyncWithPeer(peerId: PeerID, id: RawCoID, timeout: number): Promise<unknown>;
93
+ waitForSync(id: RawCoID, timeout?: number): Promise<unknown[]>;
94
+ waitForAllCoValuesSync(timeout?: number): Promise<unknown[][]>;
95
+ gracefulShutdown(): void;
96
+ }
97
+ //# sourceMappingURL=sync.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../src/sync.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=PeerKnownStates.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PeerKnownStates.test.d.ts","sourceRoot":"","sources":["../../src/tests/PeerKnownStates.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,82 @@
1
+ import { describe, expect, test, vi } from "vitest";
2
+ import { PeerKnownStates } from "../PeerKnownStates.js";
3
+ import { emptyKnownState } from "../sync.js";
4
+ describe("PeerKnownStates", () => {
5
+ test("should set and get a known state", () => {
6
+ const peerKnownStates = new PeerKnownStates();
7
+ const id = "test-id";
8
+ const knownState = emptyKnownState(id);
9
+ peerKnownStates.dispatch({ type: "SET", id, value: knownState });
10
+ expect(peerKnownStates.get(id)).toEqual(knownState);
11
+ expect(peerKnownStates.has(id)).toBe(true);
12
+ });
13
+ test("should update header", () => {
14
+ const peerKnownStates = new PeerKnownStates();
15
+ const id = "test-id";
16
+ peerKnownStates.dispatch({ type: "UPDATE_HEADER", id, header: true });
17
+ const result = peerKnownStates.get(id);
18
+ expect(result?.header).toBe(true);
19
+ });
20
+ test("should update session counter", () => {
21
+ const peerKnownStates = new PeerKnownStates();
22
+ const id = "test-id";
23
+ const sessionId = "session-1";
24
+ peerKnownStates.dispatch({
25
+ type: "UPDATE_SESSION_COUNTER",
26
+ id,
27
+ sessionId,
28
+ value: 5,
29
+ });
30
+ const result = peerKnownStates.get(id);
31
+ expect(result?.sessions[sessionId]).toBe(5);
32
+ });
33
+ test("should combine with existing state", () => {
34
+ const peerKnownStates = new PeerKnownStates();
35
+ const id = "test-id";
36
+ const session1 = "session-1";
37
+ const session2 = "session-2";
38
+ const initialState = {
39
+ ...emptyKnownState(id),
40
+ sessions: { [session1]: 5 },
41
+ };
42
+ const combineState = {
43
+ ...emptyKnownState(id),
44
+ sessions: { [session2]: 10 },
45
+ };
46
+ peerKnownStates.dispatch({ type: "SET", id, value: initialState });
47
+ peerKnownStates.dispatch({ type: "COMBINE_WITH", id, value: combineState });
48
+ const result = peerKnownStates.get(id);
49
+ expect(result?.sessions).toEqual({ [session1]: 5, [session2]: 10 });
50
+ });
51
+ test("should set as empty", () => {
52
+ const peerKnownStates = new PeerKnownStates();
53
+ const id = "test-id";
54
+ const sessionId = "session-1";
55
+ const initialState = {
56
+ ...emptyKnownState(id),
57
+ sessions: { [sessionId]: 5 },
58
+ };
59
+ peerKnownStates.dispatch({ type: "SET", id, value: initialState });
60
+ peerKnownStates.dispatch({ type: "SET_AS_EMPTY", id });
61
+ const result = peerKnownStates.get(id);
62
+ expect(result).toEqual(emptyKnownState(id));
63
+ });
64
+ test("should trigger listeners on dispatch", () => {
65
+ const peerKnownStates = new PeerKnownStates();
66
+ const id = "test-id";
67
+ const listener = vi.fn();
68
+ peerKnownStates.subscribe(listener);
69
+ peerKnownStates.dispatch({ type: "SET_AS_EMPTY", id });
70
+ expect(listener).toHaveBeenCalledWith(id, emptyKnownState(id));
71
+ });
72
+ test("should unsubscribe listener", () => {
73
+ const peerKnownStates = new PeerKnownStates();
74
+ const id = "test-id";
75
+ const listener = vi.fn();
76
+ const unsubscribe = peerKnownStates.subscribe(listener);
77
+ unsubscribe();
78
+ peerKnownStates.dispatch({ type: "SET_AS_EMPTY", id });
79
+ expect(listener).not.toHaveBeenCalled();
80
+ });
81
+ });
82
+ //# sourceMappingURL=PeerKnownStates.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PeerKnownStates.test.js","sourceRoot":"","sources":["../../src/tests/PeerKnownStates.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=PeerState.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PeerState.test.d.ts","sourceRoot":"","sources":["../../src/tests/PeerState.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,188 @@
1
+ import { describe, expect, test, vi } from "vitest";
2
+ import { PeerState } from "../PeerState.js";
3
+ import { CO_VALUE_PRIORITY } from "../priority.js";
4
+ function setup() {
5
+ const mockPeer = {
6
+ id: "test-peer",
7
+ role: "peer",
8
+ priority: 1,
9
+ crashOnClose: false,
10
+ incoming: (async function* () { })(),
11
+ outgoing: {
12
+ push: vi.fn().mockResolvedValue(undefined),
13
+ close: vi.fn(),
14
+ },
15
+ };
16
+ const peerState = new PeerState(mockPeer, undefined);
17
+ return { mockPeer, peerState };
18
+ }
19
+ describe("PeerState", () => {
20
+ test("should push outgoing message to peer", async () => {
21
+ const { mockPeer, peerState } = setup();
22
+ const message = {
23
+ action: "load",
24
+ id: "co_ztest-id",
25
+ header: false,
26
+ sessions: {},
27
+ };
28
+ await peerState.pushOutgoingMessage(message);
29
+ expect(mockPeer.outgoing.push).toHaveBeenCalledWith(message);
30
+ });
31
+ test("should return peer's incoming when not closed", () => {
32
+ const { mockPeer, peerState } = setup();
33
+ expect(peerState.incoming).toBe(mockPeer.incoming);
34
+ });
35
+ test("should return Disconnected when closed", async () => {
36
+ const { peerState } = setup();
37
+ peerState.gracefulShutdown();
38
+ const incomingIterator = peerState.incoming[Symbol.asyncIterator]();
39
+ const { value, done } = await incomingIterator.next();
40
+ expect(value).toBe("Disconnected");
41
+ expect(done).toBe(false);
42
+ });
43
+ test("should perform graceful shutdown", () => {
44
+ const { mockPeer, peerState } = setup();
45
+ peerState.gracefulShutdown();
46
+ expect(mockPeer.outgoing.close).toHaveBeenCalled();
47
+ expect(peerState.closed).toBe(true);
48
+ });
49
+ test("should empty the queue when closing", async () => {
50
+ const { mockPeer, peerState } = setup();
51
+ mockPeer.outgoing.push = vi.fn().mockImplementation((message) => {
52
+ return new Promise((resolve) => {
53
+ setTimeout(resolve, 100);
54
+ });
55
+ });
56
+ const message1 = peerState.pushOutgoingMessage({
57
+ action: "content",
58
+ id: "co_z1",
59
+ new: {},
60
+ priority: CO_VALUE_PRIORITY.HIGH,
61
+ });
62
+ const message2 = peerState.pushOutgoingMessage({
63
+ action: "content",
64
+ id: "co_z1",
65
+ new: {},
66
+ priority: CO_VALUE_PRIORITY.HIGH,
67
+ });
68
+ peerState.gracefulShutdown();
69
+ await Promise.allSettled([message1, message2]);
70
+ await expect(message1).resolves.toBe(undefined);
71
+ await expect(message2).resolves.toBe(undefined);
72
+ });
73
+ test("should schedule outgoing messages based on their priority", async () => {
74
+ const { peerState } = setup();
75
+ const loadMessage = {
76
+ action: "load",
77
+ id: "co_zhigh",
78
+ header: false,
79
+ sessions: {},
80
+ };
81
+ const contentMessageHigh = {
82
+ action: "content",
83
+ id: "co_zhigh",
84
+ new: {},
85
+ priority: CO_VALUE_PRIORITY.HIGH,
86
+ };
87
+ const contentMessageMid = {
88
+ action: "content",
89
+ id: "co_zmid",
90
+ new: {},
91
+ priority: CO_VALUE_PRIORITY.MEDIUM,
92
+ };
93
+ const contentMessageLow = {
94
+ action: "content",
95
+ id: "co_zlow",
96
+ new: {},
97
+ priority: CO_VALUE_PRIORITY.LOW,
98
+ };
99
+ const promises = [
100
+ peerState.pushOutgoingMessage(contentMessageLow),
101
+ peerState.pushOutgoingMessage(contentMessageMid),
102
+ peerState.pushOutgoingMessage(contentMessageHigh),
103
+ peerState.pushOutgoingMessage(loadMessage),
104
+ ];
105
+ await Promise.all(promises);
106
+ // The first message is pushed directly, the other three are queued because are waiting
107
+ // for the first push to be completed.
108
+ expect(peerState["peer"].outgoing.push).toHaveBeenNthCalledWith(1, contentMessageLow);
109
+ // Load message are managed as high priority messages and having the same priority as the content message
110
+ // they follow the push order.
111
+ expect(peerState["peer"].outgoing.push).toHaveBeenNthCalledWith(2, contentMessageHigh);
112
+ expect(peerState["peer"].outgoing.push).toHaveBeenNthCalledWith(3, loadMessage);
113
+ expect(peerState["peer"].outgoing.push).toHaveBeenNthCalledWith(4, contentMessageMid);
114
+ });
115
+ test("should clone the knownStates into optimisticKnownStates and knownStates when passed as argument", () => {
116
+ const { peerState, mockPeer } = setup();
117
+ const action = {
118
+ type: "SET",
119
+ id: "co_z1",
120
+ value: {
121
+ id: "co_z1",
122
+ header: false,
123
+ sessions: {},
124
+ },
125
+ };
126
+ peerState.dispatchToKnownStates(action);
127
+ const newPeerState = new PeerState(mockPeer, peerState.knownStates);
128
+ expect(newPeerState.knownStates).toEqual(peerState.knownStates);
129
+ expect(newPeerState.optimisticKnownStates).toEqual(peerState.knownStates);
130
+ });
131
+ test("should dispatch to both states", () => {
132
+ const { peerState } = setup();
133
+ const knownStatesSpy = vi.spyOn(peerState.knownStates, "dispatch");
134
+ const optimisticKnownStatesSpy = vi.spyOn(peerState.optimisticKnownStates, "dispatch");
135
+ const action = {
136
+ type: "SET",
137
+ id: "co_z1",
138
+ value: {
139
+ id: "co_z1",
140
+ header: false,
141
+ sessions: {},
142
+ },
143
+ };
144
+ peerState.dispatchToKnownStates(action);
145
+ expect(knownStatesSpy).toHaveBeenCalledWith(action);
146
+ expect(optimisticKnownStatesSpy).toHaveBeenCalledWith(action);
147
+ });
148
+ test("should use same reference for knownStates and optimisticKnownStates for storage peers", () => {
149
+ const mockStoragePeer = {
150
+ id: "test-storage-peer",
151
+ role: "storage",
152
+ priority: 1,
153
+ crashOnClose: false,
154
+ incoming: (async function* () { })(),
155
+ outgoing: {
156
+ push: vi.fn().mockResolvedValue(undefined),
157
+ close: vi.fn(),
158
+ },
159
+ };
160
+ const peerState = new PeerState(mockStoragePeer, undefined);
161
+ // Verify they are the same reference
162
+ expect(peerState.knownStates).toBe(peerState.optimisticKnownStates);
163
+ // Verify that dispatching only updates one state
164
+ const knownStatesSpy = vi.spyOn(peerState.knownStates, "dispatch");
165
+ const optimisticKnownStatesSpy = vi.spyOn(peerState.optimisticKnownStates, "dispatch");
166
+ const action = {
167
+ type: "SET",
168
+ id: "co_z1",
169
+ value: {
170
+ id: "co_z1",
171
+ header: false,
172
+ sessions: {},
173
+ },
174
+ };
175
+ peerState.dispatchToKnownStates(action);
176
+ // Only one dispatch should happen since they're the same reference
177
+ expect(knownStatesSpy).toHaveBeenCalledTimes(1);
178
+ expect(knownStatesSpy).toHaveBeenCalledWith(action);
179
+ expect(optimisticKnownStatesSpy).toHaveBeenCalledTimes(1);
180
+ expect(optimisticKnownStatesSpy).toHaveBeenCalledWith(action);
181
+ });
182
+ test("should use separate references for knownStates and optimisticKnownStates for non-storage peers", () => {
183
+ const { peerState } = setup(); // Uses a regular peer
184
+ // Verify they are different references
185
+ expect(peerState.knownStates).not.toBe(peerState.optimisticKnownStates);
186
+ });
187
+ });
188
+ //# sourceMappingURL=PeerState.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PeerState.test.js","sourceRoot":"","sources":["../../src/tests/PeerState.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=PriorityBasedMessageQueue.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PriorityBasedMessageQueue.test.d.ts","sourceRoot":"","sources":["../../src/tests/PriorityBasedMessageQueue.test.ts"],"names":[],"mappings":""}