@powerhousedao/reactor 5.1.0-staging.0 → 5.2.0-dev.1

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 (215) hide show
  1. package/dist/src/actions/index.d.ts +24 -0
  2. package/dist/src/actions/index.d.ts.map +1 -0
  3. package/dist/src/actions/index.js +76 -0
  4. package/dist/src/actions/index.js.map +1 -0
  5. package/dist/src/cache/document-meta-cache-types.d.ts +114 -0
  6. package/dist/src/cache/document-meta-cache-types.d.ts.map +1 -0
  7. package/dist/src/cache/document-meta-cache-types.js +2 -0
  8. package/dist/src/cache/document-meta-cache-types.js.map +1 -0
  9. package/dist/src/cache/document-meta-cache.d.ts +30 -0
  10. package/dist/src/cache/document-meta-cache.d.ts.map +1 -0
  11. package/dist/src/cache/document-meta-cache.js +128 -0
  12. package/dist/src/cache/document-meta-cache.js.map +1 -0
  13. package/dist/src/cache/kysely-operation-index.d.ts +4 -2
  14. package/dist/src/cache/kysely-operation-index.d.ts.map +1 -1
  15. package/dist/src/cache/kysely-operation-index.js +67 -24
  16. package/dist/src/cache/kysely-operation-index.js.map +1 -1
  17. package/dist/src/cache/kysely-write-cache.d.ts.map +1 -1
  18. package/dist/src/cache/kysely-write-cache.js +3 -2
  19. package/dist/src/cache/kysely-write-cache.js.map +1 -1
  20. package/dist/src/cache/operation-index-types.d.ts +4 -3
  21. package/dist/src/cache/operation-index-types.d.ts.map +1 -1
  22. package/dist/src/cache/operation-index-types.js.map +1 -1
  23. package/dist/src/client/reactor-client.d.ts +16 -4
  24. package/dist/src/client/reactor-client.d.ts.map +1 -1
  25. package/dist/src/client/reactor-client.js +122 -5
  26. package/dist/src/client/reactor-client.js.map +1 -1
  27. package/dist/src/client/types.d.ts +22 -3
  28. package/dist/src/client/types.d.ts.map +1 -1
  29. package/dist/src/core/reactor-builder.d.ts +10 -9
  30. package/dist/src/core/reactor-builder.d.ts.map +1 -1
  31. package/dist/src/core/reactor-builder.js +73 -17
  32. package/dist/src/core/reactor-builder.js.map +1 -1
  33. package/dist/src/core/reactor-client-builder.d.ts +10 -1
  34. package/dist/src/core/reactor-client-builder.d.ts.map +1 -1
  35. package/dist/src/core/reactor-client-builder.js +16 -1
  36. package/dist/src/core/reactor-client-builder.js.map +1 -1
  37. package/dist/src/core/reactor.d.ts +11 -10
  38. package/dist/src/core/reactor.d.ts.map +1 -1
  39. package/dist/src/core/reactor.js +78 -91
  40. package/dist/src/core/reactor.js.map +1 -1
  41. package/dist/src/core/types.d.ts +22 -7
  42. package/dist/src/core/types.d.ts.map +1 -1
  43. package/dist/src/core/utils.d.ts +1 -2
  44. package/dist/src/core/utils.d.ts.map +1 -1
  45. package/dist/src/core/utils.js +2 -2
  46. package/dist/src/core/utils.js.map +1 -1
  47. package/dist/src/events/types.d.ts +1 -0
  48. package/dist/src/events/types.d.ts.map +1 -1
  49. package/dist/src/executor/simple-job-executor-manager.d.ts +3 -1
  50. package/dist/src/executor/simple-job-executor-manager.d.ts.map +1 -1
  51. package/dist/src/executor/simple-job-executor-manager.js +10 -7
  52. package/dist/src/executor/simple-job-executor-manager.js.map +1 -1
  53. package/dist/src/executor/simple-job-executor.d.ts +17 -3
  54. package/dist/src/executor/simple-job-executor.d.ts.map +1 -1
  55. package/dist/src/executor/simple-job-executor.js +329 -221
  56. package/dist/src/executor/simple-job-executor.js.map +1 -1
  57. package/dist/src/executor/types.d.ts +2 -0
  58. package/dist/src/executor/types.d.ts.map +1 -1
  59. package/dist/src/executor/types.js.map +1 -1
  60. package/dist/src/executor/util.d.ts +14 -5
  61. package/dist/src/executor/util.d.ts.map +1 -1
  62. package/dist/src/executor/util.js +36 -9
  63. package/dist/src/executor/util.js.map +1 -1
  64. package/dist/src/index.d.ts +12 -5
  65. package/dist/src/index.d.ts.map +1 -1
  66. package/dist/src/index.js +10 -2
  67. package/dist/src/index.js.map +1 -1
  68. package/dist/src/logging/console.d.ts +11 -1
  69. package/dist/src/logging/console.d.ts.map +1 -1
  70. package/dist/src/logging/console.js +45 -14
  71. package/dist/src/logging/console.js.map +1 -1
  72. package/dist/src/logging/types.d.ts +1 -0
  73. package/dist/src/logging/types.d.ts.map +1 -1
  74. package/dist/src/processors/index.d.ts +3 -0
  75. package/dist/src/processors/index.d.ts.map +1 -0
  76. package/dist/src/processors/index.js +2 -0
  77. package/dist/src/processors/index.js.map +1 -0
  78. package/dist/src/processors/processor-manager.d.ts +38 -0
  79. package/dist/src/processors/processor-manager.d.ts.map +1 -0
  80. package/dist/src/processors/processor-manager.js +165 -0
  81. package/dist/src/processors/processor-manager.js.map +1 -0
  82. package/dist/src/processors/types.d.ts +63 -0
  83. package/dist/src/processors/types.d.ts.map +1 -0
  84. package/dist/src/processors/types.js +2 -0
  85. package/dist/src/processors/types.js.map +1 -0
  86. package/dist/src/processors/utils.d.ts +10 -0
  87. package/dist/src/processors/utils.d.ts.map +1 -0
  88. package/dist/src/processors/utils.js +58 -0
  89. package/dist/src/processors/utils.js.map +1 -0
  90. package/dist/src/queue/types.d.ts +2 -0
  91. package/dist/src/queue/types.d.ts.map +1 -1
  92. package/dist/src/queue/types.js.map +1 -1
  93. package/dist/src/read-models/base-read-model.d.ts +60 -0
  94. package/dist/src/read-models/base-read-model.d.ts.map +1 -0
  95. package/dist/src/read-models/base-read-model.js +143 -0
  96. package/dist/src/read-models/base-read-model.js.map +1 -0
  97. package/dist/src/read-models/coordinator.d.ts +3 -2
  98. package/dist/src/read-models/coordinator.d.ts.map +1 -1
  99. package/dist/src/read-models/coordinator.js +12 -13
  100. package/dist/src/read-models/coordinator.js.map +1 -1
  101. package/dist/src/read-models/document-view.d.ts +6 -7
  102. package/dist/src/read-models/document-view.d.ts.map +1 -1
  103. package/dist/src/read-models/document-view.js +18 -81
  104. package/dist/src/read-models/document-view.js.map +1 -1
  105. package/dist/src/read-models/types.d.ts +2 -1
  106. package/dist/src/read-models/types.d.ts.map +1 -1
  107. package/dist/src/registry/implementation.d.ts +42 -34
  108. package/dist/src/registry/implementation.d.ts.map +1 -1
  109. package/dist/src/registry/implementation.js +168 -48
  110. package/dist/src/registry/implementation.js.map +1 -1
  111. package/dist/src/registry/interfaces.d.ts +69 -8
  112. package/dist/src/registry/interfaces.d.ts.map +1 -1
  113. package/dist/src/shared/errors.d.ts +16 -0
  114. package/dist/src/shared/errors.d.ts.map +1 -1
  115. package/dist/src/shared/errors.js +28 -0
  116. package/dist/src/shared/errors.js.map +1 -1
  117. package/dist/src/shared/types.d.ts +4 -0
  118. package/dist/src/shared/types.d.ts.map +1 -1
  119. package/dist/src/shared/types.js.map +1 -1
  120. package/dist/src/signer/passthrough-signer.d.ts +9 -3
  121. package/dist/src/signer/passthrough-signer.d.ts.map +1 -1
  122. package/dist/src/signer/passthrough-signer.js +13 -0
  123. package/dist/src/signer/passthrough-signer.js.map +1 -1
  124. package/dist/src/signer/types.d.ts +2 -22
  125. package/dist/src/signer/types.d.ts.map +1 -1
  126. package/dist/src/storage/consistency-aware-legacy-storage.d.ts +33 -0
  127. package/dist/src/storage/consistency-aware-legacy-storage.d.ts.map +1 -0
  128. package/dist/src/storage/consistency-aware-legacy-storage.js +65 -0
  129. package/dist/src/storage/consistency-aware-legacy-storage.js.map +1 -0
  130. package/dist/src/storage/interfaces.d.ts +94 -1
  131. package/dist/src/storage/interfaces.d.ts.map +1 -1
  132. package/dist/src/storage/interfaces.js +2 -2
  133. package/dist/src/storage/interfaces.js.map +1 -1
  134. package/dist/src/storage/kysely/store.d.ts +1 -0
  135. package/dist/src/storage/kysely/store.d.ts.map +1 -1
  136. package/dist/src/storage/kysely/store.js +41 -4
  137. package/dist/src/storage/kysely/store.js.map +1 -1
  138. package/dist/src/storage/kysely/sync-cursor-storage.js +2 -2
  139. package/dist/src/storage/kysely/sync-cursor-storage.js.map +1 -1
  140. package/dist/src/storage/kysely/sync-remote-storage.js +8 -8
  141. package/dist/src/storage/kysely/sync-remote-storage.js.map +1 -1
  142. package/dist/src/storage/kysely/types.d.ts +6 -6
  143. package/dist/src/storage/migrations/001_create_operation_table.d.ts.map +1 -1
  144. package/dist/src/storage/migrations/001_create_operation_table.js +2 -1
  145. package/dist/src/storage/migrations/001_create_operation_table.js.map +1 -1
  146. package/dist/src/storage/migrations/008_create_view_state_table.d.ts +1 -1
  147. package/dist/src/storage/migrations/008_create_view_state_table.d.ts.map +1 -1
  148. package/dist/src/storage/migrations/008_create_view_state_table.js +2 -1
  149. package/dist/src/storage/migrations/008_create_view_state_table.js.map +1 -1
  150. package/dist/src/storage/migrations/009_create_operation_index_tables.js +1 -1
  151. package/dist/src/storage/migrations/009_create_operation_index_tables.js.map +1 -1
  152. package/dist/src/storage/migrations/010_create_sync_tables.js +5 -5
  153. package/dist/src/storage/migrations/010_create_sync_tables.js.map +1 -1
  154. package/dist/src/storage/migrations/migrator.d.ts +3 -2
  155. package/dist/src/storage/migrations/migrator.d.ts.map +1 -1
  156. package/dist/src/storage/migrations/migrator.js +29 -6
  157. package/dist/src/storage/migrations/migrator.js.map +1 -1
  158. package/dist/src/storage/txn.d.ts.map +1 -1
  159. package/dist/src/storage/txn.js +2 -3
  160. package/dist/src/storage/txn.js.map +1 -1
  161. package/dist/src/subs/subscription-notification-read-model.d.ts +17 -0
  162. package/dist/src/subs/subscription-notification-read-model.d.ts.map +1 -0
  163. package/dist/src/subs/subscription-notification-read-model.js +62 -0
  164. package/dist/src/subs/subscription-notification-read-model.js.map +1 -0
  165. package/dist/src/sync/channels/composite-channel-factory.d.ts +30 -0
  166. package/dist/src/sync/channels/composite-channel-factory.d.ts.map +1 -0
  167. package/dist/src/sync/channels/composite-channel-factory.js +87 -0
  168. package/dist/src/sync/channels/composite-channel-factory.js.map +1 -0
  169. package/dist/src/sync/channels/gql-channel-factory.d.ts +5 -2
  170. package/dist/src/sync/channels/gql-channel-factory.d.ts.map +1 -1
  171. package/dist/src/sync/channels/gql-channel-factory.js +8 -2
  172. package/dist/src/sync/channels/gql-channel-factory.js.map +1 -1
  173. package/dist/src/sync/channels/gql-channel.d.ts +28 -1
  174. package/dist/src/sync/channels/gql-channel.d.ts.map +1 -1
  175. package/dist/src/sync/channels/gql-channel.js +150 -22
  176. package/dist/src/sync/channels/gql-channel.js.map +1 -1
  177. package/dist/src/sync/channels/index.d.ts +2 -1
  178. package/dist/src/sync/channels/index.d.ts.map +1 -1
  179. package/dist/src/sync/channels/index.js +2 -1
  180. package/dist/src/sync/channels/index.js.map +1 -1
  181. package/dist/src/sync/channels/polling-channel.d.ts +39 -0
  182. package/dist/src/sync/channels/polling-channel.d.ts.map +1 -0
  183. package/dist/src/sync/channels/polling-channel.js +72 -0
  184. package/dist/src/sync/channels/polling-channel.js.map +1 -0
  185. package/dist/src/sync/channels/utils.d.ts +17 -2
  186. package/dist/src/sync/channels/utils.d.ts.map +1 -1
  187. package/dist/src/sync/channels/utils.js +76 -6
  188. package/dist/src/sync/channels/utils.js.map +1 -1
  189. package/dist/src/sync/errors.d.ts +1 -1
  190. package/dist/src/sync/errors.d.ts.map +1 -1
  191. package/dist/src/sync/errors.js +2 -2
  192. package/dist/src/sync/errors.js.map +1 -1
  193. package/dist/src/sync/index.d.ts +2 -2
  194. package/dist/src/sync/index.d.ts.map +1 -1
  195. package/dist/src/sync/index.js +2 -2
  196. package/dist/src/sync/index.js.map +1 -1
  197. package/dist/src/sync/interfaces.d.ts +16 -1
  198. package/dist/src/sync/interfaces.d.ts.map +1 -1
  199. package/dist/src/sync/sync-builder.d.ts +3 -2
  200. package/dist/src/sync/sync-builder.d.ts.map +1 -1
  201. package/dist/src/sync/sync-builder.js +4 -4
  202. package/dist/src/sync/sync-builder.js.map +1 -1
  203. package/dist/src/sync/sync-manager.d.ts +4 -1
  204. package/dist/src/sync/sync-manager.d.ts.map +1 -1
  205. package/dist/src/sync/sync-manager.js +65 -8
  206. package/dist/src/sync/sync-manager.js.map +1 -1
  207. package/dist/src/sync/utils.d.ts +19 -0
  208. package/dist/src/sync/utils.d.ts.map +1 -1
  209. package/dist/src/sync/utils.js +44 -0
  210. package/dist/src/sync/utils.js.map +1 -1
  211. package/package.json +3 -3
  212. package/dist/src/sync/channels/internal-channel.d.ts +0 -57
  213. package/dist/src/sync/channels/internal-channel.d.ts.map +0 -1
  214. package/dist/src/sync/channels/internal-channel.js +0 -106
  215. package/dist/src/sync/channels/internal-channel.js.map +0 -1
@@ -1,106 +0,0 @@
1
- import { ChannelError, InternalChannelError } from "../errors.js";
2
- import { Mailbox } from "../mailbox.js";
3
- import { ChannelErrorSource } from "../types.js";
4
- import { envelopeToSyncOperation } from "./utils.js";
5
- /**
6
- * In-memory synchronization channel for testing purposes only.
7
- *
8
- * InternalChannel enables direct bidirectional communication between two reactor
9
- * instances without network transport. Channels are wired together by passing
10
- * a send function that delivers envelopes to the peer's inbox.
11
- */
12
- export class InternalChannel {
13
- inbox;
14
- outbox;
15
- deadLetter;
16
- channelId;
17
- remoteName;
18
- cursorStorage;
19
- send;
20
- isShutdown;
21
- constructor(channelId, remoteName, cursorStorage, send) {
22
- this.channelId = channelId;
23
- this.remoteName = remoteName;
24
- this.cursorStorage = cursorStorage;
25
- this.send = send;
26
- this.isShutdown = false;
27
- this.inbox = new Mailbox();
28
- this.outbox = new Mailbox();
29
- this.deadLetter = new Mailbox();
30
- this.outbox.onAdded((syncOp) => {
31
- this.handleOutboxAdded(syncOp);
32
- });
33
- }
34
- /**
35
- * Shuts down the channel and prevents further operations.
36
- */
37
- shutdown() {
38
- this.isShutdown = true;
39
- }
40
- /**
41
- * Receives a sync envelope from a peer channel.
42
- *
43
- * This method is called by the peer's send function to deliver an envelope
44
- * to this channel's inbox.
45
- *
46
- * @param envelope - The sync envelope to receive
47
- * @throws {InternalChannelError} If channel is shutdown
48
- */
49
- receive(envelope) {
50
- if (this.isShutdown) {
51
- throw new InternalChannelError(`Channel ${this.channelId} is shutdown and cannot receive envelopes`);
52
- }
53
- if (envelope.type === "operations" && envelope.operations) {
54
- const syncOp = envelopeToSyncOperation(envelope, this.remoteName);
55
- syncOp.transported();
56
- this.inbox.add(syncOp);
57
- }
58
- }
59
- /**
60
- * Updates the synchronization cursor for this channel's remote.
61
- *
62
- * Cursors track progress through the operation stream and enable resuming
63
- * synchronization after restarts. The cursor is exclusive - the next sync
64
- * will start at cursorOrdinal + 1.
65
- *
66
- * @param cursorOrdinal - The last processed ordinal (exclusive)
67
- */
68
- async updateCursor(cursorOrdinal) {
69
- const cursor = {
70
- remoteName: this.remoteName,
71
- cursorOrdinal,
72
- lastSyncedAtUtcMs: Date.now(),
73
- };
74
- await this.cursorStorage.upsert(cursor);
75
- }
76
- /**
77
- * Handles sync operations added to the outbox by sending them to the peer.
78
- *
79
- * This method is called automatically via the outbox.onAdded callback.
80
- * It converts the sync operation to a SyncEnvelope and sends it via the send function.
81
- *
82
- * @param syncOp - The sync operation to transport
83
- */
84
- handleOutboxAdded(syncOp) {
85
- if (this.isShutdown) {
86
- return;
87
- }
88
- try {
89
- syncOp.started();
90
- const envelope = {
91
- type: "operations",
92
- channelMeta: { id: this.channelId },
93
- operations: syncOp.operations,
94
- };
95
- this.send(envelope);
96
- }
97
- catch (error) {
98
- const err = error instanceof Error ? error : new Error(String(error));
99
- const channelError = new ChannelError(ChannelErrorSource.Outbox, err);
100
- syncOp.failed(channelError);
101
- this.deadLetter.add(syncOp);
102
- this.outbox.remove(syncOp);
103
- }
104
- }
105
- }
106
- //# sourceMappingURL=internal-channel.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"internal-channel.js","sourceRoot":"","sources":["../../../../src/sync/channels/internal-channel.ts"],"names":[],"mappings":"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"}