@powersync/service-core 0.0.0-dev-20240620165206

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 (454) hide show
  1. package/.probes/.gitkeep +0 -0
  2. package/CHANGELOG.md +82 -0
  3. package/LICENSE +67 -0
  4. package/README.md +3 -0
  5. package/dist/api/api-index.d.ts +2 -0
  6. package/dist/api/api-index.js +3 -0
  7. package/dist/api/api-index.js.map +1 -0
  8. package/dist/api/diagnostics.d.ts +21 -0
  9. package/dist/api/diagnostics.js +183 -0
  10. package/dist/api/diagnostics.js.map +1 -0
  11. package/dist/api/schema.d.ts +5 -0
  12. package/dist/api/schema.js +88 -0
  13. package/dist/api/schema.js.map +1 -0
  14. package/dist/auth/CachedKeyCollector.d.ts +46 -0
  15. package/dist/auth/CachedKeyCollector.js +116 -0
  16. package/dist/auth/CachedKeyCollector.js.map +1 -0
  17. package/dist/auth/CompoundKeyCollector.d.ts +8 -0
  18. package/dist/auth/CompoundKeyCollector.js +23 -0
  19. package/dist/auth/CompoundKeyCollector.js.map +1 -0
  20. package/dist/auth/JwtPayload.d.ts +10 -0
  21. package/dist/auth/JwtPayload.js +2 -0
  22. package/dist/auth/JwtPayload.js.map +1 -0
  23. package/dist/auth/KeyCollector.d.ts +24 -0
  24. package/dist/auth/KeyCollector.js +2 -0
  25. package/dist/auth/KeyCollector.js.map +1 -0
  26. package/dist/auth/KeySpec.d.ts +26 -0
  27. package/dist/auth/KeySpec.js +49 -0
  28. package/dist/auth/KeySpec.js.map +1 -0
  29. package/dist/auth/KeyStore.d.ts +39 -0
  30. package/dist/auth/KeyStore.js +131 -0
  31. package/dist/auth/KeyStore.js.map +1 -0
  32. package/dist/auth/LeakyBucket.d.ts +39 -0
  33. package/dist/auth/LeakyBucket.js +57 -0
  34. package/dist/auth/LeakyBucket.js.map +1 -0
  35. package/dist/auth/RemoteJWKSCollector.d.ts +24 -0
  36. package/dist/auth/RemoteJWKSCollector.js +106 -0
  37. package/dist/auth/RemoteJWKSCollector.js.map +1 -0
  38. package/dist/auth/StaticKeyCollector.d.ts +14 -0
  39. package/dist/auth/StaticKeyCollector.js +19 -0
  40. package/dist/auth/StaticKeyCollector.js.map +1 -0
  41. package/dist/auth/SupabaseKeyCollector.d.ts +22 -0
  42. package/dist/auth/SupabaseKeyCollector.js +61 -0
  43. package/dist/auth/SupabaseKeyCollector.js.map +1 -0
  44. package/dist/auth/auth-index.d.ts +10 -0
  45. package/dist/auth/auth-index.js +11 -0
  46. package/dist/auth/auth-index.js.map +1 -0
  47. package/dist/db/db-index.d.ts +1 -0
  48. package/dist/db/db-index.js +2 -0
  49. package/dist/db/db-index.js.map +1 -0
  50. package/dist/db/mongo.d.ts +29 -0
  51. package/dist/db/mongo.js +65 -0
  52. package/dist/db/mongo.js.map +1 -0
  53. package/dist/entry/cli-entry.d.ts +15 -0
  54. package/dist/entry/cli-entry.js +36 -0
  55. package/dist/entry/cli-entry.js.map +1 -0
  56. package/dist/entry/commands/config-command.d.ts +10 -0
  57. package/dist/entry/commands/config-command.js +21 -0
  58. package/dist/entry/commands/config-command.js.map +1 -0
  59. package/dist/entry/commands/migrate-action.d.ts +2 -0
  60. package/dist/entry/commands/migrate-action.js +18 -0
  61. package/dist/entry/commands/migrate-action.js.map +1 -0
  62. package/dist/entry/commands/start-action.d.ts +3 -0
  63. package/dist/entry/commands/start-action.js +15 -0
  64. package/dist/entry/commands/start-action.js.map +1 -0
  65. package/dist/entry/commands/teardown-action.d.ts +2 -0
  66. package/dist/entry/commands/teardown-action.js +17 -0
  67. package/dist/entry/commands/teardown-action.js.map +1 -0
  68. package/dist/entry/entry-index.d.ts +5 -0
  69. package/dist/entry/entry-index.js +6 -0
  70. package/dist/entry/entry-index.js.map +1 -0
  71. package/dist/index.d.ts +25 -0
  72. package/dist/index.js +28 -0
  73. package/dist/index.js.map +1 -0
  74. package/dist/locks/LockManager.d.ts +10 -0
  75. package/dist/locks/LockManager.js +7 -0
  76. package/dist/locks/LockManager.js.map +1 -0
  77. package/dist/locks/MongoLocks.d.ts +36 -0
  78. package/dist/locks/MongoLocks.js +81 -0
  79. package/dist/locks/MongoLocks.js.map +1 -0
  80. package/dist/locks/locks-index.d.ts +2 -0
  81. package/dist/locks/locks-index.js +3 -0
  82. package/dist/locks/locks-index.js.map +1 -0
  83. package/dist/metrics/Metrics.d.ts +30 -0
  84. package/dist/metrics/Metrics.js +176 -0
  85. package/dist/metrics/Metrics.js.map +1 -0
  86. package/dist/migrations/db/migrations/1684951997326-init.d.ts +3 -0
  87. package/dist/migrations/db/migrations/1684951997326-init.js +31 -0
  88. package/dist/migrations/db/migrations/1684951997326-init.js.map +1 -0
  89. package/dist/migrations/db/migrations/1688556755264-initial-sync-rules.d.ts +2 -0
  90. package/dist/migrations/db/migrations/1688556755264-initial-sync-rules.js +5 -0
  91. package/dist/migrations/db/migrations/1688556755264-initial-sync-rules.js.map +1 -0
  92. package/dist/migrations/db/migrations/1702295701188-sync-rule-state.d.ts +3 -0
  93. package/dist/migrations/db/migrations/1702295701188-sync-rule-state.js +54 -0
  94. package/dist/migrations/db/migrations/1702295701188-sync-rule-state.js.map +1 -0
  95. package/dist/migrations/db/migrations/1711543888062-write-checkpoint-index.d.ts +3 -0
  96. package/dist/migrations/db/migrations/1711543888062-write-checkpoint-index.js +27 -0
  97. package/dist/migrations/db/migrations/1711543888062-write-checkpoint-index.js.map +1 -0
  98. package/dist/migrations/definitions.d.ts +18 -0
  99. package/dist/migrations/definitions.js +6 -0
  100. package/dist/migrations/definitions.js.map +1 -0
  101. package/dist/migrations/executor.d.ts +16 -0
  102. package/dist/migrations/executor.js +64 -0
  103. package/dist/migrations/executor.js.map +1 -0
  104. package/dist/migrations/migrations-index.d.ts +3 -0
  105. package/dist/migrations/migrations-index.js +4 -0
  106. package/dist/migrations/migrations-index.js.map +1 -0
  107. package/dist/migrations/migrations.d.ts +10 -0
  108. package/dist/migrations/migrations.js +90 -0
  109. package/dist/migrations/migrations.js.map +1 -0
  110. package/dist/migrations/store/migration-store.d.ts +11 -0
  111. package/dist/migrations/store/migration-store.js +46 -0
  112. package/dist/migrations/store/migration-store.js.map +1 -0
  113. package/dist/replication/ErrorRateLimiter.d.ts +17 -0
  114. package/dist/replication/ErrorRateLimiter.js +43 -0
  115. package/dist/replication/ErrorRateLimiter.js.map +1 -0
  116. package/dist/replication/PgRelation.d.ts +16 -0
  117. package/dist/replication/PgRelation.js +26 -0
  118. package/dist/replication/PgRelation.js.map +1 -0
  119. package/dist/replication/WalConnection.d.ts +34 -0
  120. package/dist/replication/WalConnection.js +190 -0
  121. package/dist/replication/WalConnection.js.map +1 -0
  122. package/dist/replication/WalStream.d.ts +57 -0
  123. package/dist/replication/WalStream.js +515 -0
  124. package/dist/replication/WalStream.js.map +1 -0
  125. package/dist/replication/WalStreamManager.d.ts +30 -0
  126. package/dist/replication/WalStreamManager.js +198 -0
  127. package/dist/replication/WalStreamManager.js.map +1 -0
  128. package/dist/replication/WalStreamRunner.d.ts +38 -0
  129. package/dist/replication/WalStreamRunner.js +155 -0
  130. package/dist/replication/WalStreamRunner.js.map +1 -0
  131. package/dist/replication/replication-index.d.ts +7 -0
  132. package/dist/replication/replication-index.js +8 -0
  133. package/dist/replication/replication-index.js.map +1 -0
  134. package/dist/replication/util.d.ts +9 -0
  135. package/dist/replication/util.js +62 -0
  136. package/dist/replication/util.js.map +1 -0
  137. package/dist/routes/auth.d.ts +56 -0
  138. package/dist/routes/auth.js +182 -0
  139. package/dist/routes/auth.js.map +1 -0
  140. package/dist/routes/endpoints/admin.d.ts +1011 -0
  141. package/dist/routes/endpoints/admin.js +207 -0
  142. package/dist/routes/endpoints/admin.js.map +1 -0
  143. package/dist/routes/endpoints/checkpointing.d.ts +76 -0
  144. package/dist/routes/endpoints/checkpointing.js +36 -0
  145. package/dist/routes/endpoints/checkpointing.js.map +1 -0
  146. package/dist/routes/endpoints/dev.d.ts +312 -0
  147. package/dist/routes/endpoints/dev.js +172 -0
  148. package/dist/routes/endpoints/dev.js.map +1 -0
  149. package/dist/routes/endpoints/route-endpoints-index.d.ts +6 -0
  150. package/dist/routes/endpoints/route-endpoints-index.js +7 -0
  151. package/dist/routes/endpoints/route-endpoints-index.js.map +1 -0
  152. package/dist/routes/endpoints/socket-route.d.ts +2 -0
  153. package/dist/routes/endpoints/socket-route.js +119 -0
  154. package/dist/routes/endpoints/socket-route.js.map +1 -0
  155. package/dist/routes/endpoints/sync-rules.d.ts +174 -0
  156. package/dist/routes/endpoints/sync-rules.js +202 -0
  157. package/dist/routes/endpoints/sync-rules.js.map +1 -0
  158. package/dist/routes/endpoints/sync-stream.d.ts +132 -0
  159. package/dist/routes/endpoints/sync-stream.js +83 -0
  160. package/dist/routes/endpoints/sync-stream.js.map +1 -0
  161. package/dist/routes/hooks.d.ts +10 -0
  162. package/dist/routes/hooks.js +32 -0
  163. package/dist/routes/hooks.js.map +1 -0
  164. package/dist/routes/route-register.d.ts +10 -0
  165. package/dist/routes/route-register.js +87 -0
  166. package/dist/routes/route-register.js.map +1 -0
  167. package/dist/routes/router-socket.d.ts +10 -0
  168. package/dist/routes/router-socket.js +5 -0
  169. package/dist/routes/router-socket.js.map +1 -0
  170. package/dist/routes/router.d.ts +26 -0
  171. package/dist/routes/router.js +7 -0
  172. package/dist/routes/router.js.map +1 -0
  173. package/dist/routes/routes-index.d.ts +6 -0
  174. package/dist/routes/routes-index.js +7 -0
  175. package/dist/routes/routes-index.js.map +1 -0
  176. package/dist/runner/teardown.d.ts +2 -0
  177. package/dist/runner/teardown.js +94 -0
  178. package/dist/runner/teardown.js.map +1 -0
  179. package/dist/storage/BucketStorage.d.ts +307 -0
  180. package/dist/storage/BucketStorage.js +25 -0
  181. package/dist/storage/BucketStorage.js.map +1 -0
  182. package/dist/storage/ChecksumCache.d.ts +50 -0
  183. package/dist/storage/ChecksumCache.js +234 -0
  184. package/dist/storage/ChecksumCache.js.map +1 -0
  185. package/dist/storage/MongoBucketStorage.d.ts +52 -0
  186. package/dist/storage/MongoBucketStorage.js +409 -0
  187. package/dist/storage/MongoBucketStorage.js.map +1 -0
  188. package/dist/storage/SourceTable.d.ts +39 -0
  189. package/dist/storage/SourceTable.js +50 -0
  190. package/dist/storage/SourceTable.js.map +1 -0
  191. package/dist/storage/mongo/MongoBucketBatch.d.ts +48 -0
  192. package/dist/storage/mongo/MongoBucketBatch.js +581 -0
  193. package/dist/storage/mongo/MongoBucketBatch.js.map +1 -0
  194. package/dist/storage/mongo/MongoIdSequence.d.ts +12 -0
  195. package/dist/storage/mongo/MongoIdSequence.js +21 -0
  196. package/dist/storage/mongo/MongoIdSequence.js.map +1 -0
  197. package/dist/storage/mongo/MongoPersistedSyncRules.d.ts +9 -0
  198. package/dist/storage/mongo/MongoPersistedSyncRules.js +9 -0
  199. package/dist/storage/mongo/MongoPersistedSyncRules.js.map +1 -0
  200. package/dist/storage/mongo/MongoPersistedSyncRulesContent.d.ts +20 -0
  201. package/dist/storage/mongo/MongoPersistedSyncRulesContent.js +26 -0
  202. package/dist/storage/mongo/MongoPersistedSyncRulesContent.js.map +1 -0
  203. package/dist/storage/mongo/MongoSyncBucketStorage.d.ts +29 -0
  204. package/dist/storage/mongo/MongoSyncBucketStorage.js +391 -0
  205. package/dist/storage/mongo/MongoSyncBucketStorage.js.map +1 -0
  206. package/dist/storage/mongo/MongoSyncRulesLock.d.ts +16 -0
  207. package/dist/storage/mongo/MongoSyncRulesLock.js +65 -0
  208. package/dist/storage/mongo/MongoSyncRulesLock.js.map +1 -0
  209. package/dist/storage/mongo/OperationBatch.d.ts +26 -0
  210. package/dist/storage/mongo/OperationBatch.js +101 -0
  211. package/dist/storage/mongo/OperationBatch.js.map +1 -0
  212. package/dist/storage/mongo/PersistedBatch.d.ts +46 -0
  213. package/dist/storage/mongo/PersistedBatch.js +213 -0
  214. package/dist/storage/mongo/PersistedBatch.js.map +1 -0
  215. package/dist/storage/mongo/db.d.ts +26 -0
  216. package/dist/storage/mongo/db.js +35 -0
  217. package/dist/storage/mongo/db.js.map +1 -0
  218. package/dist/storage/mongo/models.d.ts +140 -0
  219. package/dist/storage/mongo/models.js +27 -0
  220. package/dist/storage/mongo/models.js.map +1 -0
  221. package/dist/storage/mongo/util.d.ts +26 -0
  222. package/dist/storage/mongo/util.js +81 -0
  223. package/dist/storage/mongo/util.js.map +1 -0
  224. package/dist/storage/storage-index.d.ts +14 -0
  225. package/dist/storage/storage-index.js +15 -0
  226. package/dist/storage/storage-index.js.map +1 -0
  227. package/dist/sync/BroadcastIterable.d.ts +38 -0
  228. package/dist/sync/BroadcastIterable.js +153 -0
  229. package/dist/sync/BroadcastIterable.js.map +1 -0
  230. package/dist/sync/LastValueSink.d.ts +25 -0
  231. package/dist/sync/LastValueSink.js +84 -0
  232. package/dist/sync/LastValueSink.js.map +1 -0
  233. package/dist/sync/merge.d.ts +39 -0
  234. package/dist/sync/merge.js +175 -0
  235. package/dist/sync/merge.js.map +1 -0
  236. package/dist/sync/safeRace.d.ts +1 -0
  237. package/dist/sync/safeRace.js +91 -0
  238. package/dist/sync/safeRace.js.map +1 -0
  239. package/dist/sync/sync-index.d.ts +6 -0
  240. package/dist/sync/sync-index.js +7 -0
  241. package/dist/sync/sync-index.js.map +1 -0
  242. package/dist/sync/sync.d.ts +18 -0
  243. package/dist/sync/sync.js +259 -0
  244. package/dist/sync/sync.js.map +1 -0
  245. package/dist/sync/util.d.ts +26 -0
  246. package/dist/sync/util.js +73 -0
  247. package/dist/sync/util.js.map +1 -0
  248. package/dist/system/CorePowerSyncSystem.d.ts +23 -0
  249. package/dist/system/CorePowerSyncSystem.js +52 -0
  250. package/dist/system/CorePowerSyncSystem.js.map +1 -0
  251. package/dist/system/system-index.d.ts +1 -0
  252. package/dist/system/system-index.js +2 -0
  253. package/dist/system/system-index.js.map +1 -0
  254. package/dist/util/Mutex.d.ts +47 -0
  255. package/dist/util/Mutex.js +132 -0
  256. package/dist/util/Mutex.js.map +1 -0
  257. package/dist/util/PgManager.d.ts +24 -0
  258. package/dist/util/PgManager.js +55 -0
  259. package/dist/util/PgManager.js.map +1 -0
  260. package/dist/util/alerting.d.ts +2 -0
  261. package/dist/util/alerting.js +8 -0
  262. package/dist/util/alerting.js.map +1 -0
  263. package/dist/util/config/collectors/config-collector.d.ts +29 -0
  264. package/dist/util/config/collectors/config-collector.js +116 -0
  265. package/dist/util/config/collectors/config-collector.js.map +1 -0
  266. package/dist/util/config/collectors/impl/base64-config-collector.d.ts +6 -0
  267. package/dist/util/config/collectors/impl/base64-config-collector.js +15 -0
  268. package/dist/util/config/collectors/impl/base64-config-collector.js.map +1 -0
  269. package/dist/util/config/collectors/impl/fallback-config-collector.d.ts +11 -0
  270. package/dist/util/config/collectors/impl/fallback-config-collector.js +19 -0
  271. package/dist/util/config/collectors/impl/fallback-config-collector.js.map +1 -0
  272. package/dist/util/config/collectors/impl/filesystem-config-collector.d.ts +6 -0
  273. package/dist/util/config/collectors/impl/filesystem-config-collector.js +37 -0
  274. package/dist/util/config/collectors/impl/filesystem-config-collector.js.map +1 -0
  275. package/dist/util/config/compound-config-collector.d.ts +32 -0
  276. package/dist/util/config/compound-config-collector.js +130 -0
  277. package/dist/util/config/compound-config-collector.js.map +1 -0
  278. package/dist/util/config/sync-rules/impl/base64-sync-rules-collector.d.ts +7 -0
  279. package/dist/util/config/sync-rules/impl/base64-sync-rules-collector.js +17 -0
  280. package/dist/util/config/sync-rules/impl/base64-sync-rules-collector.js.map +1 -0
  281. package/dist/util/config/sync-rules/impl/filesystem-sync-rules-collector.d.ts +7 -0
  282. package/dist/util/config/sync-rules/impl/filesystem-sync-rules-collector.js +21 -0
  283. package/dist/util/config/sync-rules/impl/filesystem-sync-rules-collector.js.map +1 -0
  284. package/dist/util/config/sync-rules/impl/inline-sync-rules-collector.d.ts +7 -0
  285. package/dist/util/config/sync-rules/impl/inline-sync-rules-collector.js +17 -0
  286. package/dist/util/config/sync-rules/impl/inline-sync-rules-collector.js.map +1 -0
  287. package/dist/util/config/sync-rules/sync-collector.d.ts +6 -0
  288. package/dist/util/config/sync-rules/sync-collector.js +3 -0
  289. package/dist/util/config/sync-rules/sync-collector.js.map +1 -0
  290. package/dist/util/config/types.d.ts +57 -0
  291. package/dist/util/config/types.js +7 -0
  292. package/dist/util/config/types.js.map +1 -0
  293. package/dist/util/config.d.ts +7 -0
  294. package/dist/util/config.js +35 -0
  295. package/dist/util/config.js.map +1 -0
  296. package/dist/util/env.d.ts +9 -0
  297. package/dist/util/env.js +26 -0
  298. package/dist/util/env.js.map +1 -0
  299. package/dist/util/memory-tracking.d.ts +7 -0
  300. package/dist/util/memory-tracking.js +58 -0
  301. package/dist/util/memory-tracking.js.map +1 -0
  302. package/dist/util/migration_lib.d.ts +11 -0
  303. package/dist/util/migration_lib.js +64 -0
  304. package/dist/util/migration_lib.js.map +1 -0
  305. package/dist/util/pgwire_utils.d.ts +24 -0
  306. package/dist/util/pgwire_utils.js +117 -0
  307. package/dist/util/pgwire_utils.js.map +1 -0
  308. package/dist/util/populate_test_data.d.ts +8 -0
  309. package/dist/util/populate_test_data.js +65 -0
  310. package/dist/util/populate_test_data.js.map +1 -0
  311. package/dist/util/protocol-types.d.ts +182 -0
  312. package/dist/util/protocol-types.js +42 -0
  313. package/dist/util/protocol-types.js.map +1 -0
  314. package/dist/util/secs.d.ts +2 -0
  315. package/dist/util/secs.js +49 -0
  316. package/dist/util/secs.js.map +1 -0
  317. package/dist/util/util-index.d.ts +22 -0
  318. package/dist/util/util-index.js +23 -0
  319. package/dist/util/util-index.js.map +1 -0
  320. package/dist/util/utils.d.ts +17 -0
  321. package/dist/util/utils.js +92 -0
  322. package/dist/util/utils.js.map +1 -0
  323. package/package.json +59 -0
  324. package/src/api/api-index.ts +2 -0
  325. package/src/api/diagnostics.ts +221 -0
  326. package/src/api/schema.ts +99 -0
  327. package/src/auth/CachedKeyCollector.ts +132 -0
  328. package/src/auth/CompoundKeyCollector.ts +33 -0
  329. package/src/auth/JwtPayload.ts +11 -0
  330. package/src/auth/KeyCollector.ts +27 -0
  331. package/src/auth/KeySpec.ts +67 -0
  332. package/src/auth/KeyStore.ts +156 -0
  333. package/src/auth/LeakyBucket.ts +66 -0
  334. package/src/auth/RemoteJWKSCollector.ts +130 -0
  335. package/src/auth/StaticKeyCollector.ts +21 -0
  336. package/src/auth/SupabaseKeyCollector.ts +67 -0
  337. package/src/auth/auth-index.ts +10 -0
  338. package/src/db/db-index.ts +1 -0
  339. package/src/db/mongo.ts +72 -0
  340. package/src/entry/cli-entry.ts +40 -0
  341. package/src/entry/commands/config-command.ts +36 -0
  342. package/src/entry/commands/migrate-action.ts +25 -0
  343. package/src/entry/commands/start-action.ts +24 -0
  344. package/src/entry/commands/teardown-action.ts +23 -0
  345. package/src/entry/entry-index.ts +5 -0
  346. package/src/index.ts +40 -0
  347. package/src/locks/LockManager.ts +16 -0
  348. package/src/locks/MongoLocks.ts +142 -0
  349. package/src/locks/locks-index.ts +2 -0
  350. package/src/metrics/Metrics.ts +265 -0
  351. package/src/migrations/db/migrations/1684951997326-init.ts +33 -0
  352. package/src/migrations/db/migrations/1688556755264-initial-sync-rules.ts +5 -0
  353. package/src/migrations/db/migrations/1702295701188-sync-rule-state.ts +99 -0
  354. package/src/migrations/db/migrations/1711543888062-write-checkpoint-index.ts +32 -0
  355. package/src/migrations/definitions.ts +21 -0
  356. package/src/migrations/executor.ts +87 -0
  357. package/src/migrations/migrations-index.ts +3 -0
  358. package/src/migrations/migrations.ts +118 -0
  359. package/src/migrations/store/migration-store.ts +63 -0
  360. package/src/replication/ErrorRateLimiter.ts +50 -0
  361. package/src/replication/PgRelation.ts +42 -0
  362. package/src/replication/WalConnection.ts +227 -0
  363. package/src/replication/WalStream.ts +624 -0
  364. package/src/replication/WalStreamManager.ts +213 -0
  365. package/src/replication/WalStreamRunner.ts +180 -0
  366. package/src/replication/replication-index.ts +7 -0
  367. package/src/replication/util.ts +76 -0
  368. package/src/routes/auth.ts +215 -0
  369. package/src/routes/endpoints/admin.ts +237 -0
  370. package/src/routes/endpoints/checkpointing.ts +41 -0
  371. package/src/routes/endpoints/dev.ts +199 -0
  372. package/src/routes/endpoints/route-endpoints-index.ts +6 -0
  373. package/src/routes/endpoints/socket-route.ts +135 -0
  374. package/src/routes/endpoints/sync-rules.ts +227 -0
  375. package/src/routes/endpoints/sync-stream.ts +101 -0
  376. package/src/routes/hooks.ts +46 -0
  377. package/src/routes/route-register.ts +104 -0
  378. package/src/routes/router-socket.ts +13 -0
  379. package/src/routes/router.ts +46 -0
  380. package/src/routes/routes-index.ts +6 -0
  381. package/src/runner/teardown.ts +108 -0
  382. package/src/storage/BucketStorage.ts +396 -0
  383. package/src/storage/ChecksumCache.ts +294 -0
  384. package/src/storage/MongoBucketStorage.ts +519 -0
  385. package/src/storage/SourceTable.ts +60 -0
  386. package/src/storage/mongo/MongoBucketBatch.ts +752 -0
  387. package/src/storage/mongo/MongoIdSequence.ts +24 -0
  388. package/src/storage/mongo/MongoPersistedSyncRules.ts +16 -0
  389. package/src/storage/mongo/MongoPersistedSyncRulesContent.ts +47 -0
  390. package/src/storage/mongo/MongoSyncBucketStorage.ts +533 -0
  391. package/src/storage/mongo/MongoSyncRulesLock.ts +81 -0
  392. package/src/storage/mongo/OperationBatch.ts +115 -0
  393. package/src/storage/mongo/PersistedBatch.ts +268 -0
  394. package/src/storage/mongo/db.ts +73 -0
  395. package/src/storage/mongo/models.ts +162 -0
  396. package/src/storage/mongo/util.ts +88 -0
  397. package/src/storage/storage-index.ts +15 -0
  398. package/src/sync/BroadcastIterable.ts +161 -0
  399. package/src/sync/LastValueSink.ts +100 -0
  400. package/src/sync/merge.ts +200 -0
  401. package/src/sync/safeRace.ts +99 -0
  402. package/src/sync/sync-index.ts +6 -0
  403. package/src/sync/sync.ts +319 -0
  404. package/src/sync/util.ts +98 -0
  405. package/src/system/CorePowerSyncSystem.ts +64 -0
  406. package/src/system/system-index.ts +1 -0
  407. package/src/util/Mutex.ts +159 -0
  408. package/src/util/PgManager.ts +64 -0
  409. package/src/util/alerting.ts +9 -0
  410. package/src/util/config/collectors/config-collector.ts +143 -0
  411. package/src/util/config/collectors/impl/base64-config-collector.ts +18 -0
  412. package/src/util/config/collectors/impl/fallback-config-collector.ts +22 -0
  413. package/src/util/config/collectors/impl/filesystem-config-collector.ts +43 -0
  414. package/src/util/config/compound-config-collector.ts +176 -0
  415. package/src/util/config/sync-rules/impl/base64-sync-rules-collector.ts +21 -0
  416. package/src/util/config/sync-rules/impl/filesystem-sync-rules-collector.ts +26 -0
  417. package/src/util/config/sync-rules/impl/inline-sync-rules-collector.ts +21 -0
  418. package/src/util/config/sync-rules/sync-collector.ts +8 -0
  419. package/src/util/config/types.ts +66 -0
  420. package/src/util/config.ts +39 -0
  421. package/src/util/env.ts +30 -0
  422. package/src/util/memory-tracking.ts +67 -0
  423. package/src/util/migration_lib.ts +79 -0
  424. package/src/util/pgwire_utils.ts +139 -0
  425. package/src/util/populate_test_data.ts +78 -0
  426. package/src/util/protocol-types.ts +228 -0
  427. package/src/util/secs.ts +54 -0
  428. package/src/util/util-index.ts +25 -0
  429. package/src/util/utils.ts +122 -0
  430. package/test/src/__snapshots__/pg_test.test.ts.snap +256 -0
  431. package/test/src/__snapshots__/sync.test.ts.snap +247 -0
  432. package/test/src/auth.test.ts +342 -0
  433. package/test/src/broadcast_iterable.test.ts +156 -0
  434. package/test/src/checksum_cache.test.ts +436 -0
  435. package/test/src/data_storage.test.ts +1176 -0
  436. package/test/src/env.ts +8 -0
  437. package/test/src/large_batch.test.ts +194 -0
  438. package/test/src/merge_iterable.test.ts +355 -0
  439. package/test/src/pg_test.test.ts +450 -0
  440. package/test/src/schema_changes.test.ts +545 -0
  441. package/test/src/setup.ts +7 -0
  442. package/test/src/slow_tests.test.ts +257 -0
  443. package/test/src/sql_functions.test.ts +254 -0
  444. package/test/src/sql_operators.test.ts +132 -0
  445. package/test/src/sync.test.ts +293 -0
  446. package/test/src/sync_rules.test.ts +1053 -0
  447. package/test/src/util.ts +76 -0
  448. package/test/src/validation.test.ts +63 -0
  449. package/test/src/wal_stream.test.ts +319 -0
  450. package/test/src/wal_stream_utils.ts +147 -0
  451. package/test/tsconfig.json +20 -0
  452. package/tsconfig.json +31 -0
  453. package/tsconfig.tsbuildinfo +1 -0
  454. package/vitest.config.ts +9 -0
@@ -0,0 +1,122 @@
1
+ import crypto from 'crypto';
2
+ import * as pgwire from '@powersync/service-jpgwire';
3
+ import { pgwireRows } from '@powersync/service-jpgwire';
4
+
5
+ import * as storage from '../storage/storage-index.js';
6
+ import { BucketChecksum, OpId } from './protocol-types.js';
7
+ import { retriedQuery } from './pgwire_utils.js';
8
+ import { logger } from '@powersync/lib-services-framework';
9
+
10
+ export type ChecksumMap = Map<string, BucketChecksum>;
11
+
12
+ export function hashData(type: string, id: string, data: string): number {
13
+ const hash = crypto.createHash('sha256');
14
+ hash.update(`put.${type}.${id}.${data}`);
15
+ const buffer = hash.digest();
16
+ return buffer.readUInt32LE(0);
17
+ }
18
+
19
+ export function hashDelete(sourceKey: string) {
20
+ const hash = crypto.createHash('sha256');
21
+ hash.update(`delete.${sourceKey}`);
22
+ const buffer = hash.digest();
23
+ return buffer.readUInt32LE(0);
24
+ }
25
+
26
+ export function timestampToOpId(ts: bigint): OpId {
27
+ // Dynamic values are passed in in some cases, so we make extra sure that the
28
+ // number is a bigint and not number or Long.
29
+ if (typeof ts != 'bigint') {
30
+ throw new Error(`bigint expected, got: ${ts} (${typeof ts})`);
31
+ }
32
+ return ts.toString(10);
33
+ }
34
+
35
+ export function checksumsDiff(previous: ChecksumMap, current: ChecksumMap) {
36
+ // All changed ones
37
+ const updatedBuckets = new Map<string, BucketChecksum>();
38
+
39
+ const toRemove = new Set<string>(previous.keys());
40
+
41
+ for (let checksum of current.values()) {
42
+ const p = previous.get(checksum.bucket);
43
+ if (p == null) {
44
+ // Added
45
+ updatedBuckets.set(checksum.bucket, checksum);
46
+ } else {
47
+ toRemove.delete(checksum.bucket);
48
+ if (checksum.checksum != p.checksum || checksum.count != p.count) {
49
+ // Updated
50
+ updatedBuckets.set(checksum.bucket, checksum);
51
+ } else {
52
+ // No change
53
+ }
54
+ }
55
+ }
56
+
57
+ return {
58
+ updatedBuckets: [...updatedBuckets.values()],
59
+ removedBuckets: [...toRemove]
60
+ };
61
+ }
62
+
63
+ export function addChecksums(a: number, b: number) {
64
+ return (a + b) & 0xffffffff;
65
+ }
66
+
67
+ export function addBucketChecksums(a: BucketChecksum, b: BucketChecksum | null): BucketChecksum {
68
+ if (b == null) {
69
+ return a;
70
+ } else {
71
+ return {
72
+ bucket: a.bucket,
73
+ count: a.count + b.count,
74
+ checksum: addChecksums(a.checksum, b.checksum)
75
+ };
76
+ }
77
+ }
78
+
79
+ export async function getClientCheckpoint(
80
+ db: pgwire.PgClient,
81
+ bucketStorage: storage.BucketStorageFactory,
82
+ options?: { timeout?: number }
83
+ ): Promise<OpId> {
84
+ const start = Date.now();
85
+
86
+ const [{ lsn }] = pgwireRows(await db.query(`SELECT pg_logical_emit_message(false, 'powersync', 'ping') as lsn`));
87
+
88
+ // This old API needs a persisted checkpoint id.
89
+ // Since we don't use LSNs anymore, the only way to get that is to wait.
90
+
91
+ const timeout = options?.timeout ?? 50_000;
92
+
93
+ logger.info(`Waiting for LSN checkpoint: ${lsn}`);
94
+ while (Date.now() - start < timeout) {
95
+ const cp = await bucketStorage.getActiveCheckpoint();
96
+ if (!cp.hasSyncRules()) {
97
+ throw new Error('No sync rules available');
98
+ }
99
+ if (cp.lsn >= lsn) {
100
+ logger.info(`Got write checkpoint: ${lsn} : ${cp.checkpoint}`);
101
+ return cp.checkpoint;
102
+ }
103
+
104
+ await new Promise((resolve) => setTimeout(resolve, 30));
105
+ }
106
+
107
+ throw new Error('Timeout while waiting for checkpoint');
108
+ }
109
+
110
+ export async function createWriteCheckpoint(
111
+ db: pgwire.PgClient,
112
+ bucketStorage: storage.BucketStorageFactory,
113
+ user_id: string
114
+ ): Promise<bigint> {
115
+ const [{ lsn }] = pgwireRows(
116
+ await retriedQuery(db, `SELECT pg_logical_emit_message(false, 'powersync', 'ping') as lsn`)
117
+ );
118
+
119
+ const id = await bucketStorage.createWriteCheckpoint(user_id, { '1': lsn });
120
+ logger.info(`Write checkpoint 2: ${JSON.stringify({ lsn, id: String(id) })}`);
121
+ return id;
122
+ }
@@ -0,0 +1,256 @@
1
+ // Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
2
+
3
+ exports[`pg data types > schema 1`] = `
4
+ [
5
+ {
6
+ "name": "public",
7
+ "tables": [
8
+ {
9
+ "columns": [
10
+ {
11
+ "name": "id",
12
+ "pg_type": "int4",
13
+ "type": "integer",
14
+ },
15
+ {
16
+ "name": "text",
17
+ "pg_type": "text",
18
+ "type": "text",
19
+ },
20
+ {
21
+ "name": "uuid",
22
+ "pg_type": "uuid",
23
+ "type": "uuid",
24
+ },
25
+ {
26
+ "name": "varchar",
27
+ "pg_type": "varchar",
28
+ "type": "character varying(255)",
29
+ },
30
+ {
31
+ "name": "bool",
32
+ "pg_type": "bool",
33
+ "type": "boolean",
34
+ },
35
+ {
36
+ "name": "bytea",
37
+ "pg_type": "bytea",
38
+ "type": "bytea",
39
+ },
40
+ {
41
+ "name": "int2",
42
+ "pg_type": "int2",
43
+ "type": "smallint",
44
+ },
45
+ {
46
+ "name": "int4",
47
+ "pg_type": "int4",
48
+ "type": "integer",
49
+ },
50
+ {
51
+ "name": "int8",
52
+ "pg_type": "int8",
53
+ "type": "bigint",
54
+ },
55
+ {
56
+ "name": "float4",
57
+ "pg_type": "float4",
58
+ "type": "real",
59
+ },
60
+ {
61
+ "name": "float8",
62
+ "pg_type": "float8",
63
+ "type": "double precision",
64
+ },
65
+ {
66
+ "name": "numeric",
67
+ "pg_type": "numeric",
68
+ "type": "numeric",
69
+ },
70
+ {
71
+ "name": "json",
72
+ "pg_type": "json",
73
+ "type": "json",
74
+ },
75
+ {
76
+ "name": "jsonb",
77
+ "pg_type": "jsonb",
78
+ "type": "jsonb",
79
+ },
80
+ {
81
+ "name": "pg_lsn",
82
+ "pg_type": "pg_lsn",
83
+ "type": "pg_lsn",
84
+ },
85
+ {
86
+ "name": "date",
87
+ "pg_type": "date",
88
+ "type": "date",
89
+ },
90
+ {
91
+ "name": "time",
92
+ "pg_type": "time",
93
+ "type": "time without time zone",
94
+ },
95
+ {
96
+ "name": "timestamp",
97
+ "pg_type": "timestamp",
98
+ "type": "timestamp without time zone",
99
+ },
100
+ {
101
+ "name": "timestamptz",
102
+ "pg_type": "timestamptz",
103
+ "type": "timestamp with time zone",
104
+ },
105
+ {
106
+ "name": "interval",
107
+ "pg_type": "interval",
108
+ "type": "interval",
109
+ },
110
+ {
111
+ "name": "macaddr",
112
+ "pg_type": "macaddr",
113
+ "type": "macaddr",
114
+ },
115
+ {
116
+ "name": "inet",
117
+ "pg_type": "inet",
118
+ "type": "inet",
119
+ },
120
+ {
121
+ "name": "oid",
122
+ "pg_type": "oid",
123
+ "type": "oid",
124
+ },
125
+ ],
126
+ "name": "test_data",
127
+ },
128
+ {
129
+ "columns": [
130
+ {
131
+ "name": "id",
132
+ "pg_type": "int4",
133
+ "type": "integer",
134
+ },
135
+ {
136
+ "name": "text",
137
+ "pg_type": "text[]",
138
+ "type": "text[]",
139
+ },
140
+ {
141
+ "name": "uuid",
142
+ "pg_type": "uuid[]",
143
+ "type": "uuid[]",
144
+ },
145
+ {
146
+ "name": "varchar",
147
+ "pg_type": "varchar[]",
148
+ "type": "character varying(255)[]",
149
+ },
150
+ {
151
+ "name": "bool",
152
+ "pg_type": "bool[]",
153
+ "type": "boolean[]",
154
+ },
155
+ {
156
+ "name": "bytea",
157
+ "pg_type": "bytea[]",
158
+ "type": "bytea[]",
159
+ },
160
+ {
161
+ "name": "int2",
162
+ "pg_type": "int2[]",
163
+ "type": "smallint[]",
164
+ },
165
+ {
166
+ "name": "int4",
167
+ "pg_type": "int4[]",
168
+ "type": "integer[]",
169
+ },
170
+ {
171
+ "name": "int8",
172
+ "pg_type": "int8[]",
173
+ "type": "bigint[]",
174
+ },
175
+ {
176
+ "name": "float4",
177
+ "pg_type": "float4[]",
178
+ "type": "real[]",
179
+ },
180
+ {
181
+ "name": "float8",
182
+ "pg_type": "float8[]",
183
+ "type": "double precision[]",
184
+ },
185
+ {
186
+ "name": "numeric",
187
+ "pg_type": "numeric[]",
188
+ "type": "numeric[]",
189
+ },
190
+ {
191
+ "name": "json",
192
+ "pg_type": "json[]",
193
+ "type": "json[]",
194
+ },
195
+ {
196
+ "name": "jsonb",
197
+ "pg_type": "jsonb[]",
198
+ "type": "jsonb[]",
199
+ },
200
+ {
201
+ "name": "pg_lsn",
202
+ "pg_type": "pg_lsn[]",
203
+ "type": "pg_lsn[]",
204
+ },
205
+ {
206
+ "name": "date",
207
+ "pg_type": "date[]",
208
+ "type": "date[]",
209
+ },
210
+ {
211
+ "name": "time",
212
+ "pg_type": "time[]",
213
+ "type": "time without time zone[]",
214
+ },
215
+ {
216
+ "name": "timestamp",
217
+ "pg_type": "timestamp[]",
218
+ "type": "timestamp without time zone[]",
219
+ },
220
+ {
221
+ "name": "timestamptz",
222
+ "pg_type": "timestamptz[]",
223
+ "type": "timestamp with time zone[]",
224
+ },
225
+ {
226
+ "name": "interval",
227
+ "pg_type": "interval[]",
228
+ "type": "interval[]",
229
+ },
230
+ {
231
+ "name": "macaddr",
232
+ "pg_type": "macaddr[]",
233
+ "type": "macaddr[]",
234
+ },
235
+ {
236
+ "name": "inet",
237
+ "pg_type": "inet[]",
238
+ "type": "inet[]",
239
+ },
240
+ {
241
+ "name": "oid",
242
+ "pg_type": "oid[]",
243
+ "type": "oid[]",
244
+ },
245
+ {
246
+ "name": "multidimensional",
247
+ "pg_type": "text[]",
248
+ "type": "text[]",
249
+ },
250
+ ],
251
+ "name": "test_data_arrays",
252
+ },
253
+ ],
254
+ },
255
+ ]
256
+ `;
@@ -0,0 +1,247 @@
1
+ // Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
2
+
3
+ exports[`sync - mongodb > expired token 1`] = `
4
+ [
5
+ {
6
+ "token_expires_in": 0,
7
+ },
8
+ ]
9
+ `;
10
+
11
+ exports[`sync - mongodb > expiring token 1`] = `
12
+ [
13
+ {
14
+ "checkpoint": {
15
+ "buckets": [
16
+ {
17
+ "bucket": "mybucket[]",
18
+ "checksum": 0,
19
+ "count": 0,
20
+ },
21
+ ],
22
+ "last_op_id": "0",
23
+ "write_checkpoint": undefined,
24
+ },
25
+ },
26
+ {
27
+ "checkpoint_complete": {
28
+ "last_op_id": "0",
29
+ },
30
+ },
31
+ ]
32
+ `;
33
+
34
+ exports[`sync - mongodb > expiring token 2`] = `
35
+ [
36
+ {
37
+ "token_expires_in": 0,
38
+ },
39
+ ]
40
+ `;
41
+
42
+ exports[`sync - mongodb > sync global data 1`] = `
43
+ [
44
+ {
45
+ "checkpoint": {
46
+ "buckets": [
47
+ {
48
+ "bucket": "mybucket[]",
49
+ "checksum": -93886621,
50
+ "count": 2,
51
+ },
52
+ ],
53
+ "last_op_id": "2",
54
+ "write_checkpoint": undefined,
55
+ },
56
+ },
57
+ {
58
+ "data": {
59
+ "after": "0",
60
+ "bucket": "mybucket[]",
61
+ "data": [
62
+ {
63
+ "checksum": 920318466n,
64
+ "data": "{\\"id\\":\\"t1\\",\\"description\\":\\"Test 1\\"}",
65
+ "object_id": "t1",
66
+ "object_type": "test",
67
+ "op": "PUT",
68
+ "op_id": "1",
69
+ "subkey": "6544e3899293153fa7b38331/117ab485-4b42-58a2-ab32-0053a22c3423",
70
+ },
71
+ {
72
+ "checksum": 3280762209n,
73
+ "data": "{\\"id\\":\\"t2\\",\\"description\\":\\"Test 2\\"}",
74
+ "object_id": "t2",
75
+ "object_type": "test",
76
+ "op": "PUT",
77
+ "op_id": "2",
78
+ "subkey": "6544e3899293153fa7b38331/ec27c691-b47a-5d92-927a-9944feb89eee",
79
+ },
80
+ ],
81
+ "has_more": false,
82
+ "next_after": "2",
83
+ },
84
+ },
85
+ {
86
+ "checkpoint_complete": {
87
+ "last_op_id": "2",
88
+ },
89
+ },
90
+ ]
91
+ `;
92
+
93
+ exports[`sync - mongodb > sync legacy non-raw data 1`] = `
94
+ [
95
+ {
96
+ "checkpoint": {
97
+ "buckets": [
98
+ {
99
+ "bucket": "mybucket[]",
100
+ "checksum": -852817836,
101
+ "count": 1,
102
+ },
103
+ ],
104
+ "last_op_id": "1",
105
+ "write_checkpoint": undefined,
106
+ },
107
+ },
108
+ {
109
+ "data": {
110
+ "after": "0",
111
+ "bucket": "mybucket[]",
112
+ "data": [
113
+ {
114
+ "checksum": 3442149460n,
115
+ "data": {
116
+ "description": "Test
117
+ \\"string\\"",
118
+ "id": "t1",
119
+ "large_num": 12345678901234567890n,
120
+ },
121
+ "object_id": "t1",
122
+ "object_type": "test",
123
+ "op": "PUT",
124
+ "op_id": "1",
125
+ "subkey": "6544e3899293153fa7b38331/117ab485-4b42-58a2-ab32-0053a22c3423",
126
+ },
127
+ ],
128
+ "has_more": false,
129
+ "next_after": "1",
130
+ },
131
+ },
132
+ {
133
+ "checkpoint_complete": {
134
+ "last_op_id": "1",
135
+ },
136
+ },
137
+ ]
138
+ `;
139
+
140
+ exports[`sync - mongodb > sync updates to global data 1`] = `
141
+ [
142
+ {
143
+ "checkpoint": {
144
+ "buckets": [
145
+ {
146
+ "bucket": "mybucket[]",
147
+ "checksum": 0,
148
+ "count": 0,
149
+ },
150
+ ],
151
+ "last_op_id": "0",
152
+ "write_checkpoint": undefined,
153
+ },
154
+ },
155
+ {
156
+ "checkpoint_complete": {
157
+ "last_op_id": "0",
158
+ },
159
+ },
160
+ ]
161
+ `;
162
+
163
+ exports[`sync - mongodb > sync updates to global data 2`] = `
164
+ [
165
+ {
166
+ "checkpoint_diff": {
167
+ "last_op_id": "1",
168
+ "removed_buckets": [],
169
+ "updated_buckets": [
170
+ {
171
+ "bucket": "mybucket[]",
172
+ "checksum": 920318466,
173
+ "count": 1,
174
+ },
175
+ ],
176
+ "write_checkpoint": undefined,
177
+ },
178
+ },
179
+ {
180
+ "data": {
181
+ "after": "0",
182
+ "bucket": "mybucket[]",
183
+ "data": [
184
+ {
185
+ "checksum": 920318466n,
186
+ "data": "{\\"id\\":\\"t1\\",\\"description\\":\\"Test 1\\"}",
187
+ "object_id": "t1",
188
+ "object_type": "test",
189
+ "op": "PUT",
190
+ "op_id": "1",
191
+ "subkey": "6544e3899293153fa7b38331/117ab485-4b42-58a2-ab32-0053a22c3423",
192
+ },
193
+ ],
194
+ "has_more": false,
195
+ "next_after": "1",
196
+ },
197
+ },
198
+ {
199
+ "checkpoint_complete": {
200
+ "last_op_id": "1",
201
+ },
202
+ },
203
+ ]
204
+ `;
205
+
206
+ exports[`sync - mongodb > sync updates to global data 3`] = `
207
+ [
208
+ {
209
+ "checkpoint_diff": {
210
+ "last_op_id": "2",
211
+ "removed_buckets": [],
212
+ "updated_buckets": [
213
+ {
214
+ "bucket": "mybucket[]",
215
+ "checksum": -93886621,
216
+ "count": 2,
217
+ },
218
+ ],
219
+ "write_checkpoint": undefined,
220
+ },
221
+ },
222
+ {
223
+ "data": {
224
+ "after": "1",
225
+ "bucket": "mybucket[]",
226
+ "data": [
227
+ {
228
+ "checksum": 3280762209n,
229
+ "data": "{\\"id\\":\\"t2\\",\\"description\\":\\"Test 2\\"}",
230
+ "object_id": "t2",
231
+ "object_type": "test",
232
+ "op": "PUT",
233
+ "op_id": "2",
234
+ "subkey": "6544e3899293153fa7b38331/ec27c691-b47a-5d92-927a-9944feb89eee",
235
+ },
236
+ ],
237
+ "has_more": false,
238
+ "next_after": "2",
239
+ },
240
+ },
241
+ {
242
+ "checkpoint_complete": {
243
+ "last_op_id": "2",
244
+ },
245
+ },
246
+ ]
247
+ `;