@powerhousedao/reactor 6.0.0-dev.7 → 6.0.0-dev.77

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 (371) hide show
  1. package/dist/src/cache/collection-membership-cache.d.ts +13 -0
  2. package/dist/src/cache/collection-membership-cache.d.ts.map +1 -0
  3. package/dist/src/cache/document-meta-cache.d.ts.map +1 -1
  4. package/dist/src/cache/kysely-operation-index.d.ts +6 -1
  5. package/dist/src/cache/kysely-operation-index.d.ts.map +1 -1
  6. package/dist/src/cache/kysely-write-cache.d.ts +9 -2
  7. package/dist/src/cache/kysely-write-cache.d.ts.map +1 -1
  8. package/dist/src/cache/operation-index-types.d.ts +16 -2
  9. package/dist/src/cache/operation-index-types.d.ts.map +1 -1
  10. package/dist/src/cache/write/interfaces.d.ts +7 -2
  11. package/dist/src/cache/write/interfaces.d.ts.map +1 -1
  12. package/dist/src/client/reactor-client.d.ts +13 -10
  13. package/dist/src/client/reactor-client.d.ts.map +1 -1
  14. package/dist/src/client/types.d.ts +25 -6
  15. package/dist/src/client/types.d.ts.map +1 -1
  16. package/dist/src/core/reactor-builder.d.ts +23 -7
  17. package/dist/src/core/reactor-builder.d.ts.map +1 -1
  18. package/dist/src/core/reactor-client-builder.d.ts +5 -4
  19. package/dist/src/core/reactor-client-builder.d.ts.map +1 -1
  20. package/dist/src/core/reactor.d.ts +20 -80
  21. package/dist/src/core/reactor.d.ts.map +1 -1
  22. package/dist/src/core/types.d.ts +64 -28
  23. package/dist/src/core/types.d.ts.map +1 -1
  24. package/dist/src/core/utils.d.ts +39 -3
  25. package/dist/src/core/utils.d.ts.map +1 -1
  26. package/dist/src/events/types.d.ts +35 -10
  27. package/dist/src/events/types.d.ts.map +1 -1
  28. package/dist/src/executor/document-action-handler.d.ts +37 -0
  29. package/dist/src/executor/document-action-handler.d.ts.map +1 -0
  30. package/dist/src/executor/signature-verifier.d.ts +9 -0
  31. package/dist/src/executor/signature-verifier.d.ts.map +1 -0
  32. package/dist/src/executor/simple-job-executor-manager.d.ts +6 -1
  33. package/dist/src/executor/simple-job-executor-manager.d.ts.map +1 -1
  34. package/dist/src/executor/simple-job-executor.d.ts +6 -46
  35. package/dist/src/executor/simple-job-executor.d.ts.map +1 -1
  36. package/dist/src/executor/types.d.ts +1 -3
  37. package/dist/src/executor/types.d.ts.map +1 -1
  38. package/dist/src/executor/util.d.ts +12 -2
  39. package/dist/src/executor/util.d.ts.map +1 -1
  40. package/dist/src/index.d.ts +11 -9
  41. package/dist/src/index.d.ts.map +1 -1
  42. package/dist/src/index.js +19998 -61
  43. package/dist/src/job-tracker/in-memory-job-tracker.d.ts +4 -3
  44. package/dist/src/job-tracker/in-memory-job-tracker.d.ts.map +1 -1
  45. package/dist/src/job-tracker/interfaces.d.ts +3 -1
  46. package/dist/src/job-tracker/interfaces.d.ts.map +1 -1
  47. package/dist/src/logging/console.d.ts +1 -22
  48. package/dist/src/logging/console.d.ts.map +1 -1
  49. package/dist/src/logging/types.d.ts +1 -11
  50. package/dist/src/logging/types.d.ts.map +1 -1
  51. package/dist/src/processors/index.d.ts +1 -1
  52. package/dist/src/processors/index.d.ts.map +1 -1
  53. package/dist/src/processors/processor-manager.d.ts +2 -2
  54. package/dist/src/processors/processor-manager.d.ts.map +1 -1
  55. package/dist/src/processors/relational/types.d.ts +2 -0
  56. package/dist/src/processors/relational/types.d.ts.map +1 -0
  57. package/dist/src/processors/relational/utils.d.ts +2 -0
  58. package/dist/src/processors/relational/utils.d.ts.map +1 -0
  59. package/dist/src/processors/utils.d.ts +2 -2
  60. package/dist/src/processors/utils.d.ts.map +1 -1
  61. package/dist/src/queue/job-execution-handle.d.ts +3 -0
  62. package/dist/src/queue/job-execution-handle.d.ts.map +1 -1
  63. package/dist/src/queue/queue.d.ts +30 -1
  64. package/dist/src/queue/queue.d.ts.map +1 -1
  65. package/dist/src/queue/types.d.ts +4 -3
  66. package/dist/src/queue/types.d.ts.map +1 -1
  67. package/dist/src/read-models/base-read-model.d.ts +1 -1
  68. package/dist/src/read-models/base-read-model.d.ts.map +1 -1
  69. package/dist/src/read-models/coordinator.d.ts +2 -2
  70. package/dist/src/read-models/coordinator.d.ts.map +1 -1
  71. package/dist/src/read-models/document-view.d.ts +6 -3
  72. package/dist/src/read-models/document-view.d.ts.map +1 -1
  73. package/dist/src/read-models/interfaces.d.ts +1 -1
  74. package/dist/src/read-models/interfaces.d.ts.map +1 -1
  75. package/dist/src/registry/document-model-resolver.d.ts +29 -0
  76. package/dist/src/registry/document-model-resolver.d.ts.map +1 -0
  77. package/dist/src/registry/implementation.d.ts +4 -0
  78. package/dist/src/registry/implementation.d.ts.map +1 -1
  79. package/dist/src/registry/index.d.ts +3 -1
  80. package/dist/src/registry/index.d.ts.map +1 -1
  81. package/dist/src/registry/interfaces.d.ts +8 -0
  82. package/dist/src/registry/interfaces.d.ts.map +1 -1
  83. package/dist/src/shared/awaiter.d.ts +2 -2
  84. package/dist/src/shared/awaiter.d.ts.map +1 -1
  85. package/dist/src/shared/collect-all-pages.d.ts +7 -0
  86. package/dist/src/shared/collect-all-pages.d.ts.map +1 -0
  87. package/dist/src/shared/drive-url.d.ts +15 -0
  88. package/dist/src/shared/drive-url.d.ts.map +1 -0
  89. package/dist/src/shared/errors.d.ts +9 -0
  90. package/dist/src/shared/errors.d.ts.map +1 -1
  91. package/dist/src/shared/factories.d.ts +6 -2
  92. package/dist/src/shared/factories.d.ts.map +1 -1
  93. package/dist/src/shared/types.d.ts +32 -6
  94. package/dist/src/shared/types.d.ts.map +1 -1
  95. package/dist/src/signer/passthrough-signer.d.ts +1 -1
  96. package/dist/src/signer/passthrough-signer.d.ts.map +1 -1
  97. package/dist/src/storage/interfaces.d.ts +238 -124
  98. package/dist/src/storage/interfaces.d.ts.map +1 -1
  99. package/dist/src/storage/kysely/document-indexer.d.ts +8 -7
  100. package/dist/src/storage/kysely/document-indexer.d.ts.map +1 -1
  101. package/dist/src/storage/kysely/store.d.ts +5 -4
  102. package/dist/src/storage/kysely/store.d.ts.map +1 -1
  103. package/dist/src/storage/kysely/sync-cursor-storage.d.ts +1 -1
  104. package/dist/src/storage/kysely/sync-cursor-storage.d.ts.map +1 -1
  105. package/dist/src/storage/kysely/sync-dead-letter-storage.d.ts +17 -0
  106. package/dist/src/storage/kysely/sync-dead-letter-storage.d.ts.map +1 -0
  107. package/dist/src/storage/kysely/types.d.ts +22 -0
  108. package/dist/src/storage/kysely/types.d.ts.map +1 -1
  109. package/dist/src/storage/migrations/011_add_cursor_type_column.d.ts +3 -0
  110. package/dist/src/storage/migrations/011_add_cursor_type_column.d.ts.map +1 -0
  111. package/dist/src/storage/migrations/012_add_source_remote_column.d.ts +3 -0
  112. package/dist/src/storage/migrations/012_add_source_remote_column.d.ts.map +1 -0
  113. package/dist/src/storage/migrations/013_create_sync_dead_letters_table.d.ts +3 -0
  114. package/dist/src/storage/migrations/013_create_sync_dead_letters_table.d.ts.map +1 -0
  115. package/dist/src/storage/migrations/migrator.d.ts.map +1 -1
  116. package/dist/src/subs/default-error-handler.d.ts.map +1 -1
  117. package/dist/src/subs/subscription-notification-read-model.d.ts +3 -2
  118. package/dist/src/subs/subscription-notification-read-model.d.ts.map +1 -1
  119. package/dist/src/sync/batch-aggregator.d.ts +25 -0
  120. package/dist/src/sync/batch-aggregator.d.ts.map +1 -0
  121. package/dist/src/sync/buffered-mailbox.d.ts +36 -0
  122. package/dist/src/sync/buffered-mailbox.d.ts.map +1 -0
  123. package/dist/src/sync/channels/{gql-channel.d.ts → gql-req-channel.d.ts} +49 -42
  124. package/dist/src/sync/channels/gql-req-channel.d.ts.map +1 -0
  125. package/dist/src/sync/channels/gql-request-channel-factory.d.ts +32 -0
  126. package/dist/src/sync/channels/gql-request-channel-factory.d.ts.map +1 -0
  127. package/dist/src/sync/channels/gql-res-channel.d.ts +25 -0
  128. package/dist/src/sync/channels/gql-res-channel.d.ts.map +1 -0
  129. package/dist/src/sync/channels/gql-response-channel-factory.d.ts +13 -0
  130. package/dist/src/sync/channels/gql-response-channel-factory.d.ts.map +1 -0
  131. package/dist/src/sync/channels/index.d.ts +6 -4
  132. package/dist/src/sync/channels/index.d.ts.map +1 -1
  133. package/dist/src/sync/channels/interval-poll-timer.d.ts +40 -0
  134. package/dist/src/sync/channels/interval-poll-timer.d.ts.map +1 -0
  135. package/dist/src/sync/channels/poll-timer.d.ts +14 -0
  136. package/dist/src/sync/channels/poll-timer.d.ts.map +1 -0
  137. package/dist/src/sync/channels/utils.d.ts +15 -1
  138. package/dist/src/sync/channels/utils.d.ts.map +1 -1
  139. package/dist/src/sync/index.d.ts +10 -6
  140. package/dist/src/sync/index.d.ts.map +1 -1
  141. package/dist/src/sync/interfaces.d.ts +34 -21
  142. package/dist/src/sync/interfaces.d.ts.map +1 -1
  143. package/dist/src/sync/mailbox.d.ts +51 -12
  144. package/dist/src/sync/mailbox.d.ts.map +1 -1
  145. package/dist/src/sync/sync-awaiter.d.ts +34 -0
  146. package/dist/src/sync/sync-awaiter.d.ts.map +1 -0
  147. package/dist/src/sync/sync-builder.d.ts +5 -1
  148. package/dist/src/sync/sync-builder.d.ts.map +1 -1
  149. package/dist/src/sync/sync-manager.d.ts +21 -8
  150. package/dist/src/sync/sync-manager.d.ts.map +1 -1
  151. package/dist/src/sync/sync-operation.d.ts +4 -2
  152. package/dist/src/sync/sync-operation.d.ts.map +1 -1
  153. package/dist/src/sync/sync-status-tracker.d.ts +31 -0
  154. package/dist/src/sync/sync-status-tracker.d.ts.map +1 -0
  155. package/dist/src/sync/types.d.ts +90 -2
  156. package/dist/src/sync/types.d.ts.map +1 -1
  157. package/dist/src/sync/utils.d.ts +37 -2
  158. package/dist/src/sync/utils.d.ts.map +1 -1
  159. package/dist/src/utils/reshuffle.d.ts +22 -5
  160. package/dist/src/utils/reshuffle.d.ts.map +1 -1
  161. package/package.json +24 -20
  162. package/dist/src/actions/index.js +0 -76
  163. package/dist/src/actions/index.js.map +0 -1
  164. package/dist/src/cache/buffer/ring-buffer.js +0 -69
  165. package/dist/src/cache/buffer/ring-buffer.js.map +0 -1
  166. package/dist/src/cache/document-meta-cache-types.js +0 -2
  167. package/dist/src/cache/document-meta-cache-types.js.map +0 -1
  168. package/dist/src/cache/document-meta-cache.js +0 -128
  169. package/dist/src/cache/document-meta-cache.js.map +0 -1
  170. package/dist/src/cache/index.js +0 -2
  171. package/dist/src/cache/index.js.map +0 -1
  172. package/dist/src/cache/kysely-operation-index.js +0 -250
  173. package/dist/src/cache/kysely-operation-index.js.map +0 -1
  174. package/dist/src/cache/kysely-write-cache.js +0 -388
  175. package/dist/src/cache/kysely-write-cache.js.map +0 -1
  176. package/dist/src/cache/lru/lru-tracker.js +0 -96
  177. package/dist/src/cache/lru/lru-tracker.js.map +0 -1
  178. package/dist/src/cache/operation-index-types.js +0 -4
  179. package/dist/src/cache/operation-index-types.js.map +0 -1
  180. package/dist/src/cache/write/interfaces.js +0 -2
  181. package/dist/src/cache/write/interfaces.js.map +0 -1
  182. package/dist/src/cache/write-cache-types.js +0 -2
  183. package/dist/src/cache/write-cache-types.js.map +0 -1
  184. package/dist/src/client/reactor-client.js +0 -406
  185. package/dist/src/client/reactor-client.js.map +0 -1
  186. package/dist/src/client/types.js +0 -14
  187. package/dist/src/client/types.js.map +0 -1
  188. package/dist/src/core/reactor-builder.js +0 -231
  189. package/dist/src/core/reactor-builder.js.map +0 -1
  190. package/dist/src/core/reactor-client-builder.js +0 -123
  191. package/dist/src/core/reactor-client-builder.js.map +0 -1
  192. package/dist/src/core/reactor.js +0 -981
  193. package/dist/src/core/reactor.js.map +0 -1
  194. package/dist/src/core/types.js +0 -2
  195. package/dist/src/core/types.js.map +0 -1
  196. package/dist/src/core/utils.js +0 -171
  197. package/dist/src/core/utils.js.map +0 -1
  198. package/dist/src/events/event-bus.js +0 -53
  199. package/dist/src/events/event-bus.js.map +0 -1
  200. package/dist/src/events/interfaces.js +0 -2
  201. package/dist/src/events/interfaces.js.map +0 -1
  202. package/dist/src/events/types.js +0 -28
  203. package/dist/src/events/types.js.map +0 -1
  204. package/dist/src/executor/interfaces.js +0 -2
  205. package/dist/src/executor/interfaces.js.map +0 -1
  206. package/dist/src/executor/simple-job-executor-manager.js +0 -233
  207. package/dist/src/executor/simple-job-executor-manager.js.map +0 -1
  208. package/dist/src/executor/simple-job-executor.js +0 -898
  209. package/dist/src/executor/simple-job-executor.js.map +0 -1
  210. package/dist/src/executor/types.js +0 -11
  211. package/dist/src/executor/types.js.map +0 -1
  212. package/dist/src/executor/util.js +0 -184
  213. package/dist/src/executor/util.js.map +0 -1
  214. package/dist/src/index.js.map +0 -1
  215. package/dist/src/job-tracker/in-memory-job-tracker.js +0 -112
  216. package/dist/src/job-tracker/in-memory-job-tracker.js.map +0 -1
  217. package/dist/src/job-tracker/index.js +0 -2
  218. package/dist/src/job-tracker/index.js.map +0 -1
  219. package/dist/src/job-tracker/interfaces.js +0 -2
  220. package/dist/src/job-tracker/interfaces.js.map +0 -1
  221. package/dist/src/logging/console.js +0 -108
  222. package/dist/src/logging/console.js.map +0 -1
  223. package/dist/src/logging/types.js +0 -2
  224. package/dist/src/logging/types.js.map +0 -1
  225. package/dist/src/processors/index.js +0 -2
  226. package/dist/src/processors/index.js.map +0 -1
  227. package/dist/src/processors/processor-manager.js +0 -165
  228. package/dist/src/processors/processor-manager.js.map +0 -1
  229. package/dist/src/processors/types.d.ts +0 -63
  230. package/dist/src/processors/types.d.ts.map +0 -1
  231. package/dist/src/processors/types.js +0 -2
  232. package/dist/src/processors/types.js.map +0 -1
  233. package/dist/src/processors/utils.js +0 -58
  234. package/dist/src/processors/utils.js.map +0 -1
  235. package/dist/src/queue/interfaces.js +0 -2
  236. package/dist/src/queue/interfaces.js.map +0 -1
  237. package/dist/src/queue/job-execution-handle.js +0 -62
  238. package/dist/src/queue/job-execution-handle.js.map +0 -1
  239. package/dist/src/queue/queue.js +0 -384
  240. package/dist/src/queue/queue.js.map +0 -1
  241. package/dist/src/queue/types.js +0 -19
  242. package/dist/src/queue/types.js.map +0 -1
  243. package/dist/src/read-models/base-read-model.js +0 -143
  244. package/dist/src/read-models/base-read-model.js.map +0 -1
  245. package/dist/src/read-models/coordinator.js +0 -72
  246. package/dist/src/read-models/coordinator.js.map +0 -1
  247. package/dist/src/read-models/document-view.js +0 -375
  248. package/dist/src/read-models/document-view.js.map +0 -1
  249. package/dist/src/read-models/interfaces.js +0 -2
  250. package/dist/src/read-models/interfaces.js.map +0 -1
  251. package/dist/src/read-models/types.js +0 -2
  252. package/dist/src/read-models/types.js.map +0 -1
  253. package/dist/src/registry/implementation.js +0 -216
  254. package/dist/src/registry/implementation.js.map +0 -1
  255. package/dist/src/registry/index.js +0 -2
  256. package/dist/src/registry/index.js.map +0 -1
  257. package/dist/src/registry/interfaces.js +0 -2
  258. package/dist/src/registry/interfaces.js.map +0 -1
  259. package/dist/src/shared/awaiter.js +0 -123
  260. package/dist/src/shared/awaiter.js.map +0 -1
  261. package/dist/src/shared/consistency-tracker.js +0 -123
  262. package/dist/src/shared/consistency-tracker.js.map +0 -1
  263. package/dist/src/shared/errors.js +0 -75
  264. package/dist/src/shared/errors.js.map +0 -1
  265. package/dist/src/shared/factories.js +0 -33
  266. package/dist/src/shared/factories.js.map +0 -1
  267. package/dist/src/shared/types.js +0 -38
  268. package/dist/src/shared/types.js.map +0 -1
  269. package/dist/src/shared/utils.js +0 -8
  270. package/dist/src/shared/utils.js.map +0 -1
  271. package/dist/src/signer/passthrough-signer.js +0 -19
  272. package/dist/src/signer/passthrough-signer.js.map +0 -1
  273. package/dist/src/signer/types.js +0 -2
  274. package/dist/src/signer/types.js.map +0 -1
  275. package/dist/src/storage/consistency-aware-legacy-storage.d.ts +0 -33
  276. package/dist/src/storage/consistency-aware-legacy-storage.d.ts.map +0 -1
  277. package/dist/src/storage/consistency-aware-legacy-storage.js +0 -65
  278. package/dist/src/storage/consistency-aware-legacy-storage.js.map +0 -1
  279. package/dist/src/storage/index.js +0 -3
  280. package/dist/src/storage/index.js.map +0 -1
  281. package/dist/src/storage/interfaces.js +0 -19
  282. package/dist/src/storage/interfaces.js.map +0 -1
  283. package/dist/src/storage/kysely/document-indexer.js +0 -350
  284. package/dist/src/storage/kysely/document-indexer.js.map +0 -1
  285. package/dist/src/storage/kysely/keyframe-store.js +0 -64
  286. package/dist/src/storage/kysely/keyframe-store.js.map +0 -1
  287. package/dist/src/storage/kysely/store.js +0 -233
  288. package/dist/src/storage/kysely/store.js.map +0 -1
  289. package/dist/src/storage/kysely/sync-cursor-storage.js +0 -93
  290. package/dist/src/storage/kysely/sync-cursor-storage.js.map +0 -1
  291. package/dist/src/storage/kysely/sync-remote-storage.js +0 -133
  292. package/dist/src/storage/kysely/sync-remote-storage.js.map +0 -1
  293. package/dist/src/storage/kysely/types.js +0 -2
  294. package/dist/src/storage/kysely/types.js.map +0 -1
  295. package/dist/src/storage/migrations/001_create_operation_table.js +0 -41
  296. package/dist/src/storage/migrations/001_create_operation_table.js.map +0 -1
  297. package/dist/src/storage/migrations/002_create_keyframe_table.js +0 -27
  298. package/dist/src/storage/migrations/002_create_keyframe_table.js.map +0 -1
  299. package/dist/src/storage/migrations/003_create_document_table.js +0 -10
  300. package/dist/src/storage/migrations/003_create_document_table.js.map +0 -1
  301. package/dist/src/storage/migrations/004_create_document_relationship_table.js +0 -35
  302. package/dist/src/storage/migrations/004_create_document_relationship_table.js.map +0 -1
  303. package/dist/src/storage/migrations/005_create_indexer_state_table.js +0 -10
  304. package/dist/src/storage/migrations/005_create_indexer_state_table.js.map +0 -1
  305. package/dist/src/storage/migrations/006_create_document_snapshot_table.js +0 -49
  306. package/dist/src/storage/migrations/006_create_document_snapshot_table.js.map +0 -1
  307. package/dist/src/storage/migrations/007_create_slug_mapping_table.js +0 -24
  308. package/dist/src/storage/migrations/007_create_slug_mapping_table.js.map +0 -1
  309. package/dist/src/storage/migrations/008_create_view_state_table.js +0 -10
  310. package/dist/src/storage/migrations/008_create_view_state_table.js.map +0 -1
  311. package/dist/src/storage/migrations/009_create_operation_index_tables.js +0 -50
  312. package/dist/src/storage/migrations/009_create_operation_index_tables.js.map +0 -1
  313. package/dist/src/storage/migrations/010_create_sync_tables.js +0 -43
  314. package/dist/src/storage/migrations/010_create_sync_tables.js.map +0 -1
  315. package/dist/src/storage/migrations/index.js +0 -3
  316. package/dist/src/storage/migrations/index.js.map +0 -1
  317. package/dist/src/storage/migrations/migrator.js +0 -78
  318. package/dist/src/storage/migrations/migrator.js.map +0 -1
  319. package/dist/src/storage/migrations/run-migrations.js +0 -58
  320. package/dist/src/storage/migrations/run-migrations.js.map +0 -1
  321. package/dist/src/storage/migrations/types.js +0 -2
  322. package/dist/src/storage/migrations/types.js.map +0 -1
  323. package/dist/src/storage/txn.js +0 -42
  324. package/dist/src/storage/txn.js.map +0 -1
  325. package/dist/src/subs/default-error-handler.js +0 -27
  326. package/dist/src/subs/default-error-handler.js.map +0 -1
  327. package/dist/src/subs/react-subscription-manager.js +0 -185
  328. package/dist/src/subs/react-subscription-manager.js.map +0 -1
  329. package/dist/src/subs/subscription-notification-read-model.js +0 -62
  330. package/dist/src/subs/subscription-notification-read-model.js.map +0 -1
  331. package/dist/src/subs/types.js +0 -2
  332. package/dist/src/subs/types.js.map +0 -1
  333. package/dist/src/sync/channels/composite-channel-factory.d.ts +0 -30
  334. package/dist/src/sync/channels/composite-channel-factory.d.ts.map +0 -1
  335. package/dist/src/sync/channels/composite-channel-factory.js +0 -87
  336. package/dist/src/sync/channels/composite-channel-factory.js.map +0 -1
  337. package/dist/src/sync/channels/gql-channel-factory.d.ts +0 -25
  338. package/dist/src/sync/channels/gql-channel-factory.d.ts.map +0 -1
  339. package/dist/src/sync/channels/gql-channel-factory.js +0 -76
  340. package/dist/src/sync/channels/gql-channel-factory.js.map +0 -1
  341. package/dist/src/sync/channels/gql-channel.d.ts.map +0 -1
  342. package/dist/src/sync/channels/gql-channel.js +0 -423
  343. package/dist/src/sync/channels/gql-channel.js.map +0 -1
  344. package/dist/src/sync/channels/index.js +0 -6
  345. package/dist/src/sync/channels/index.js.map +0 -1
  346. package/dist/src/sync/channels/polling-channel.d.ts +0 -39
  347. package/dist/src/sync/channels/polling-channel.d.ts.map +0 -1
  348. package/dist/src/sync/channels/polling-channel.js +0 -72
  349. package/dist/src/sync/channels/polling-channel.js.map +0 -1
  350. package/dist/src/sync/channels/utils.js +0 -96
  351. package/dist/src/sync/channels/utils.js.map +0 -1
  352. package/dist/src/sync/errors.js +0 -17
  353. package/dist/src/sync/errors.js.map +0 -1
  354. package/dist/src/sync/index.js +0 -9
  355. package/dist/src/sync/index.js.map +0 -1
  356. package/dist/src/sync/interfaces.js +0 -2
  357. package/dist/src/sync/interfaces.js.map +0 -1
  358. package/dist/src/sync/mailbox.js +0 -59
  359. package/dist/src/sync/mailbox.js.map +0 -1
  360. package/dist/src/sync/sync-builder.js +0 -39
  361. package/dist/src/sync/sync-builder.js.map +0 -1
  362. package/dist/src/sync/sync-manager.js +0 -266
  363. package/dist/src/sync/sync-manager.js.map +0 -1
  364. package/dist/src/sync/sync-operation.js +0 -63
  365. package/dist/src/sync/sync-operation.js.map +0 -1
  366. package/dist/src/sync/types.js +0 -16
  367. package/dist/src/sync/types.js.map +0 -1
  368. package/dist/src/sync/utils.js +0 -78
  369. package/dist/src/sync/utils.js.map +0 -1
  370. package/dist/src/utils/reshuffle.js +0 -47
  371. package/dist/src/utils/reshuffle.js.map +0 -1
@@ -1,165 +0,0 @@
1
- import { BaseReadModel } from "../read-models/base-read-model.js";
2
- import { createMinimalDriveHeader, extractDeletedDocumentId, extractDriveHeader, isDriveCreation, isDriveDeletion, matchesFilter, } from "./utils.js";
3
- /**
4
- * Manages processor lifecycle based on operations.
5
- * Extends BaseReadModel to receive operations from ReadModelCoordinator.
6
- *
7
- * Responsibilities:
8
- * 1. Detect drive creation from CREATE_DOCUMENT operations
9
- * 2. Create processors for each drive using registered factories
10
- * 3. Route operations to matching processors based on filters
11
- * 4. Clean up processors when drives are deleted or factories are unregistered
12
- */
13
- export class ProcessorManager extends BaseReadModel {
14
- factoryRegistry = new Map();
15
- processorsByDrive = new Map();
16
- factoryToProcessors = new Map();
17
- knownDriveIds = new Set();
18
- constructor(db, operationIndex, writeCache, consistencyTracker) {
19
- super(db, operationIndex, writeCache, consistencyTracker, "processor-manager");
20
- }
21
- async indexOperations(items) {
22
- if (items.length === 0)
23
- return;
24
- await this.detectAndRegisterNewDrives(items);
25
- await this.detectAndCleanupDeletedDrives(items);
26
- await this.routeOperationsToProcessors(items);
27
- await this.db.transaction().execute(async (trx) => {
28
- await this.saveState(trx, items);
29
- });
30
- this.updateConsistencyTracker(items);
31
- }
32
- async registerFactory(identifier, factory) {
33
- if (this.factoryRegistry.has(identifier)) {
34
- await this.unregisterFactory(identifier);
35
- }
36
- this.factoryRegistry.set(identifier, factory);
37
- this.factoryToProcessors.set(identifier, new Map());
38
- for (const driveId of this.knownDriveIds) {
39
- const driveHeader = createMinimalDriveHeader(driveId);
40
- await this.createProcessorsForDrive(driveId, identifier, factory, driveHeader);
41
- }
42
- }
43
- async unregisterFactory(identifier) {
44
- const factoryProcessors = this.factoryToProcessors.get(identifier);
45
- if (!factoryProcessors)
46
- return;
47
- for (const [driveId, records] of factoryProcessors) {
48
- for (const record of records) {
49
- await this.safeDisconnect(record.processor);
50
- }
51
- const driveProcessors = this.processorsByDrive.get(driveId);
52
- if (driveProcessors) {
53
- const remaining = driveProcessors.filter((p) => !records.includes(p));
54
- if (remaining.length > 0) {
55
- this.processorsByDrive.set(driveId, remaining);
56
- }
57
- else {
58
- this.processorsByDrive.delete(driveId);
59
- }
60
- }
61
- }
62
- this.factoryToProcessors.delete(identifier);
63
- this.factoryRegistry.delete(identifier);
64
- }
65
- getFactoryIdentifiers() {
66
- return Array.from(this.factoryRegistry.keys());
67
- }
68
- getProcessorsForDrive(driveId) {
69
- return this.processorsByDrive.get(driveId) ?? [];
70
- }
71
- async detectAndRegisterNewDrives(operations) {
72
- for (const op of operations) {
73
- if (!isDriveCreation(op))
74
- continue;
75
- const driveId = op.context.documentId;
76
- if (this.knownDriveIds.has(driveId))
77
- continue;
78
- this.knownDriveIds.add(driveId);
79
- const driveHeader = extractDriveHeader(op);
80
- if (!driveHeader)
81
- continue;
82
- for (const [identifier, factory] of this.factoryRegistry) {
83
- await this.createProcessorsForDrive(driveId, identifier, factory, driveHeader);
84
- }
85
- }
86
- }
87
- async detectAndCleanupDeletedDrives(operations) {
88
- for (const op of operations) {
89
- if (!isDriveDeletion(op))
90
- continue;
91
- const driveId = extractDeletedDocumentId(op);
92
- if (!driveId || !this.knownDriveIds.has(driveId))
93
- continue;
94
- if (!this.isDeletedDocumentADrive(driveId))
95
- continue;
96
- await this.cleanupDriveProcessors(driveId);
97
- this.knownDriveIds.delete(driveId);
98
- }
99
- }
100
- isDeletedDocumentADrive(documentId) {
101
- return this.knownDriveIds.has(documentId);
102
- }
103
- async createProcessorsForDrive(driveId, identifier, factory, driveHeader) {
104
- let records = [];
105
- try {
106
- records = await factory(driveHeader);
107
- }
108
- catch (error) {
109
- console.error(`ProcessorManager: Factory '${identifier}' failed for drive '${driveId}':`, error);
110
- return;
111
- }
112
- if (records.length === 0)
113
- return;
114
- const factoryProcessors = this.factoryToProcessors.get(identifier);
115
- if (factoryProcessors) {
116
- factoryProcessors.set(driveId, records);
117
- }
118
- const existingDriveProcessors = this.processorsByDrive.get(driveId) ?? [];
119
- this.processorsByDrive.set(driveId, [
120
- ...existingDriveProcessors,
121
- ...records,
122
- ]);
123
- }
124
- async cleanupDriveProcessors(driveId) {
125
- const processors = this.processorsByDrive.get(driveId);
126
- if (!processors)
127
- return;
128
- for (const record of processors) {
129
- await this.safeDisconnect(record.processor);
130
- }
131
- this.processorsByDrive.delete(driveId);
132
- for (const factoryProcessors of this.factoryToProcessors.values()) {
133
- factoryProcessors.delete(driveId);
134
- }
135
- }
136
- async safeDisconnect(processor) {
137
- try {
138
- await processor.onDisconnect();
139
- }
140
- catch (error) {
141
- console.error("ProcessorManager: Error disconnecting processor:", error);
142
- }
143
- }
144
- async routeOperationsToProcessors(operations) {
145
- const processorOperations = new Map();
146
- for (const [, records] of this.processorsByDrive) {
147
- for (const { processor, filter } of records) {
148
- const matching = operations.filter((op) => matchesFilter(op, filter));
149
- if (matching.length === 0)
150
- continue;
151
- const existing = processorOperations.get(processor) ?? [];
152
- processorOperations.set(processor, [...existing, ...matching]);
153
- }
154
- }
155
- await Promise.all(Array.from(processorOperations.entries()).map(async ([processor, ops]) => {
156
- try {
157
- await processor.onOperations(ops);
158
- }
159
- catch (error) {
160
- console.error("ProcessorManager: Error in processor.onOperations:", error);
161
- }
162
- }));
163
- }
164
- }
165
- //# sourceMappingURL=processor-manager.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"processor-manager.js","sourceRoot":"","sources":["../../../src/processors/processor-manager.ts"],"names":[],"mappings":"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"}
@@ -1,63 +0,0 @@
1
- import type { PHDocumentHeader } from "document-model";
2
- import type { OperationWithContext } from "../storage/interfaces.js";
3
- /**
4
- * Filter for matching operations to processors.
5
- * All fields are optional arrays - when provided, operations must match at least one value in each specified field.
6
- * When a field is undefined or empty, it matches all values for that field.
7
- */
8
- export type ProcessorFilter = {
9
- documentType?: string[];
10
- scope?: string[];
11
- branch?: string[];
12
- documentId?: string[];
13
- };
14
- /**
15
- * Describes an object that can process operations.
16
- */
17
- export interface IProcessor {
18
- /**
19
- * Processes a list of operations with context.
20
- * Called when operations match this processor's filter.
21
- */
22
- onOperations(operations: OperationWithContext[]): Promise<void>;
23
- /**
24
- * Called when the processor is disconnected.
25
- * Used to clean up any resources allocated during processor creation.
26
- */
27
- onDisconnect(): Promise<void>;
28
- }
29
- /**
30
- * Relates a processor to its filter configuration.
31
- */
32
- export type ProcessorRecord = {
33
- processor: IProcessor;
34
- filter: ProcessorFilter;
35
- };
36
- /**
37
- * A factory function that creates processor records for a given drive.
38
- * Called once per drive when the drive is first detected or when the factory is registered.
39
- */
40
- export type ProcessorFactory = (driveHeader: PHDocumentHeader) => ProcessorRecord[] | Promise<ProcessorRecord[]>;
41
- /**
42
- * Manages processor creation and destruction based on drive operations.
43
- */
44
- export interface IProcessorManager {
45
- /**
46
- * Registers a processor factory.
47
- * Immediately creates processors for all existing drives.
48
- */
49
- registerFactory(identifier: string, factory: ProcessorFactory): Promise<void>;
50
- /**
51
- * Unregisters a processor factory and disconnects all processors it created.
52
- */
53
- unregisterFactory(identifier: string): Promise<void>;
54
- /**
55
- * Gets all registered factory identifiers.
56
- */
57
- getFactoryIdentifiers(): string[];
58
- /**
59
- * Gets all processor records for a specific drive.
60
- */
61
- getProcessorsForDrive(driveId: string): ProcessorRecord[];
62
- }
63
- //# sourceMappingURL=types.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/processors/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAErE;;;;GAIG;AACH,MAAM,MAAM,eAAe,GAAG;IAC5B,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;CACvB,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB;;;OAGG;IACH,YAAY,CAAC,UAAU,EAAE,oBAAoB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEhE;;;OAGG;IACH,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CAC/B;AAED;;GAEG;AACH,MAAM,MAAM,eAAe,GAAG;IAC5B,SAAS,EAAE,UAAU,CAAC;IACtB,MAAM,EAAE,eAAe,CAAC;CACzB,CAAC;AAEF;;;GAGG;AACH,MAAM,MAAM,gBAAgB,GAAG,CAC7B,WAAW,EAAE,gBAAgB,KAC1B,eAAe,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC,CAAC;AAEpD;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC;;;OAGG;IACH,eAAe,CAAC,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE9E;;OAEG;IACH,iBAAiB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAErD;;OAEG;IACH,qBAAqB,IAAI,MAAM,EAAE,CAAC;IAElC;;OAEG;IACH,qBAAqB,CAAC,OAAO,EAAE,MAAM,GAAG,eAAe,EAAE,CAAC;CAC3D"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=types.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/processors/types.ts"],"names":[],"mappings":""}
@@ -1,58 +0,0 @@
1
- const DRIVE_DOCUMENT_TYPE = "powerhouse/document-drive";
2
- export function isDriveCreation(op) {
3
- return (op.operation.action.type === "CREATE_DOCUMENT" &&
4
- op.context.documentType === DRIVE_DOCUMENT_TYPE);
5
- }
6
- export function isDriveDeletion(op) {
7
- return op.operation.action.type === "DELETE_DOCUMENT";
8
- }
9
- export function extractDriveHeader(op) {
10
- if (!op.context.resultingState)
11
- return undefined;
12
- const state = JSON.parse(op.context.resultingState);
13
- return state.header;
14
- }
15
- export function extractDeletedDocumentId(op) {
16
- const input = op.operation.action.input;
17
- return input.documentId ?? op.context.documentId;
18
- }
19
- export function createMinimalDriveHeader(driveId) {
20
- return {
21
- id: driveId,
22
- documentType: DRIVE_DOCUMENT_TYPE,
23
- sig: {
24
- publicKey: {},
25
- nonce: "",
26
- },
27
- slug: "",
28
- name: "",
29
- branch: "main",
30
- revision: {},
31
- createdAtUtcIso: new Date().toISOString(),
32
- lastModifiedAtUtcIso: new Date().toISOString(),
33
- };
34
- }
35
- export function matchesFilter(op, filter) {
36
- if (filter.documentType && filter.documentType.length > 0) {
37
- if (!filter.documentType.includes(op.context.documentType)) {
38
- return false;
39
- }
40
- }
41
- if (filter.scope && filter.scope.length > 0) {
42
- if (!filter.scope.includes(op.context.scope)) {
43
- return false;
44
- }
45
- }
46
- if (filter.branch && filter.branch.length > 0) {
47
- if (!filter.branch.includes(op.context.branch)) {
48
- return false;
49
- }
50
- }
51
- if (filter.documentId && filter.documentId.length > 0) {
52
- if (!filter.documentId.includes(op.context.documentId)) {
53
- return false;
54
- }
55
- }
56
- return true;
57
- }
58
- //# sourceMappingURL=utils.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/processors/utils.ts"],"names":[],"mappings":"AAIA,MAAM,mBAAmB,GAAG,2BAA2B,CAAC;AAExD,MAAM,UAAU,eAAe,CAAC,EAAwB;IACtD,OAAO,CACL,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,KAAK,iBAAiB;QAC9C,EAAE,CAAC,OAAO,CAAC,YAAY,KAAK,mBAAmB,CAChD,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAAwB;IACtD,OAAO,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,KAAK,iBAAiB,CAAC;AACxD,CAAC;AAED,MAAM,UAAU,kBAAkB,CAChC,EAAwB;IAExB,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,cAAc;QAAE,OAAO,SAAS,CAAC;IAEjD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,cAAc,CAGjD,CAAC;IACF,OAAO,KAAK,CAAC,MAAsC,CAAC;AACtD,CAAC;AAED,MAAM,UAAU,wBAAwB,CACtC,EAAwB;IAExB,MAAM,KAAK,GAAG,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,KAAgC,CAAC;IACnE,OAAO,KAAK,CAAC,UAAU,IAAI,EAAE,CAAC,OAAO,CAAC,UAAU,CAAC;AACnD,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,OAAe;IACtD,OAAO;QACL,EAAE,EAAE,OAAO;QACX,YAAY,EAAE,mBAAmB;QACjC,GAAG,EAAE;YACH,SAAS,EAAE,EAAE;YACb,KAAK,EAAE,EAAE;SACV;QACD,IAAI,EAAE,EAAE;QACR,IAAI,EAAE,EAAE;QACR,MAAM,EAAE,MAAM;QACd,QAAQ,EAAE,EAAE;QACZ,eAAe,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACzC,oBAAoB,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;KAC/C,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,aAAa,CAC3B,EAAwB,EACxB,MAAuB;IAEvB,IAAI,MAAM,CAAC,YAAY,IAAI,MAAM,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC1D,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC;YAC3D,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC5C,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YAC7C,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED,IAAI,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC9C,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YAC/C,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED,IAAI,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACtD,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;YACvD,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=interfaces.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../../src/queue/interfaces.ts"],"names":[],"mappings":""}
@@ -1,62 +0,0 @@
1
- import { JobQueueState } from "./types.js";
2
- /**
3
- * Implementation of the IJobExecutionHandle interface
4
- */
5
- export class JobExecutionHandle {
6
- _state;
7
- _job;
8
- onStart;
9
- onComplete;
10
- onFail;
11
- getStateName(state) {
12
- switch (state) {
13
- case JobQueueState.PREPROCESSING:
14
- return "PREPROCESSING";
15
- case JobQueueState.PENDING:
16
- return "PENDING";
17
- case JobQueueState.READY:
18
- return "READY";
19
- case JobQueueState.RUNNING:
20
- return "RUNNING";
21
- case JobQueueState.RESOLVED:
22
- return "RESOLVED";
23
- default:
24
- return `UNKNOWN`;
25
- }
26
- }
27
- constructor(job, initialState, callbacks) {
28
- this._job = job;
29
- this._state = initialState;
30
- this.onStart = callbacks?.onStart;
31
- this.onComplete = callbacks?.onComplete;
32
- this.onFail = callbacks?.onFail;
33
- }
34
- get job() {
35
- return this._job;
36
- }
37
- get state() {
38
- return this._state;
39
- }
40
- start() {
41
- if (this._state !== JobQueueState.READY) {
42
- throw new Error(`Cannot start job in state ${this.getStateName(this._state)}`);
43
- }
44
- this._state = JobQueueState.RUNNING;
45
- this.onStart?.();
46
- }
47
- complete() {
48
- if (this._state !== JobQueueState.RUNNING) {
49
- throw new Error(`Cannot complete job in state ${this.getStateName(this._state)}`);
50
- }
51
- this._state = JobQueueState.RESOLVED;
52
- this.onComplete?.();
53
- }
54
- fail(error) {
55
- if (this._state !== JobQueueState.RUNNING) {
56
- throw new Error(`Cannot fail job in state ${this.getStateName(this._state)}`);
57
- }
58
- this._state = JobQueueState.RESOLVED;
59
- this.onFail?.(error);
60
- }
61
- }
62
- //# sourceMappingURL=job-execution-handle.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"job-execution-handle.js","sourceRoot":"","sources":["../../../src/queue/job-execution-handle.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE3C;;GAEG;AACH,MAAM,OAAO,kBAAkB;IACrB,MAAM,CAAgB;IACtB,IAAI,CAAM;IACV,OAAO,CAAc;IACrB,UAAU,CAAc;IACxB,MAAM,CAA8B;IAEpC,YAAY,CAAC,KAAoB;QACvC,QAAQ,KAAK,EAAE,CAAC;YACd,KAAK,aAAa,CAAC,aAAa;gBAC9B,OAAO,eAAe,CAAC;YACzB,KAAK,aAAa,CAAC,OAAO;gBACxB,OAAO,SAAS,CAAC;YACnB,KAAK,aAAa,CAAC,KAAK;gBACtB,OAAO,OAAO,CAAC;YACjB,KAAK,aAAa,CAAC,OAAO;gBACxB,OAAO,SAAS,CAAC;YACnB,KAAK,aAAa,CAAC,QAAQ;gBACzB,OAAO,UAAU,CAAC;YACpB;gBACE,OAAO,SAAS,CAAC;QACrB,CAAC;IACH,CAAC;IAED,YACE,GAAQ,EACR,YAA2B,EAC3B,SAIC;QAED,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC;QAChB,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,SAAS,EAAE,OAAO,CAAC;QAClC,IAAI,CAAC,UAAU,GAAG,SAAS,EAAE,UAAU,CAAC;QACxC,IAAI,CAAC,MAAM,GAAG,SAAS,EAAE,MAAM,CAAC;IAClC,CAAC;IAED,IAAI,GAAG;QACL,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,KAAK;QACH,IAAI,IAAI,CAAC,MAAM,KAAK,aAAa,CAAC,KAAK,EAAE,CAAC;YACxC,MAAM,IAAI,KAAK,CACb,6BAA6B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAC9D,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC;QACpC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;IACnB,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,MAAM,KAAK,aAAa,CAAC,OAAO,EAAE,CAAC;YAC1C,MAAM,IAAI,KAAK,CACb,gCAAgC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CACjE,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC,QAAQ,CAAC;QACrC,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;IACtB,CAAC;IAED,IAAI,CAAC,KAAgB;QACnB,IAAI,IAAI,CAAC,MAAM,KAAK,aAAa,CAAC,OAAO,EAAE,CAAC;YAC1C,MAAM,IAAI,KAAK,CACb,4BAA4B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAC7D,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC,QAAQ,CAAC;QACrC,IAAI,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;CACF"}