@pattern-stack/codegen 0.10.1 → 0.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (271) hide show
  1. package/CHANGELOG.md +62 -0
  2. package/README.md +5 -5
  3. package/consumer-skills/codegen/SKILL.md +2 -2
  4. package/consumer-skills/{sync → integration}/SKILL.md +29 -29
  5. package/consumer-skills/{sync → integration}/audit-and-detection.md +22 -22
  6. package/consumer-skills/{sync → integration}/change-sources-and-sinks.md +60 -60
  7. package/consumer-skills/subsystems/SKILL.md +8 -8
  8. package/consumer-skills/subsystems/wiring-and-order.md +7 -7
  9. package/dist/runtime/base-classes/index.d.ts +4 -4
  10. package/dist/runtime/base-classes/index.js +35 -35
  11. package/dist/runtime/base-classes/index.js.map +1 -1
  12. package/dist/runtime/base-classes/{synced-entity-repository.d.ts → integrated-entity-repository.d.ts} +15 -15
  13. package/dist/runtime/base-classes/{synced-entity-repository.js → integrated-entity-repository.js} +21 -21
  14. package/dist/runtime/base-classes/integrated-entity-repository.js.map +1 -0
  15. package/dist/runtime/base-classes/{synced-entity-service.d.ts → integrated-entity-service.d.ts} +6 -6
  16. package/dist/runtime/base-classes/{synced-entity-service.js → integrated-entity-service.js} +4 -4
  17. package/dist/runtime/base-classes/integrated-entity-service.js.map +1 -0
  18. package/dist/runtime/base-classes/{sync-upsert-config.d.ts → integration-upsert-config.d.ts} +13 -13
  19. package/dist/runtime/base-classes/integration-upsert-config.js +1 -0
  20. package/dist/runtime/base-classes/{junction-sync-repository.d.ts → junction-integration-repository.d.ts} +11 -11
  21. package/dist/runtime/base-classes/{junction-sync-repository.js → junction-integration-repository.js} +15 -15
  22. package/dist/runtime/base-classes/junction-integration-repository.js.map +1 -0
  23. package/dist/runtime/subsystems/auth/auth-oauth-state.schema.js.map +1 -1
  24. package/dist/runtime/subsystems/auth/auth.module.d.ts +4 -4
  25. package/dist/runtime/subsystems/auth/auth.module.js +3 -3
  26. package/dist/runtime/subsystems/auth/auth.module.js.map +1 -1
  27. package/dist/runtime/subsystems/auth/auth.tokens.d.ts +8 -8
  28. package/dist/runtime/subsystems/auth/auth.tokens.js +6 -6
  29. package/dist/runtime/subsystems/auth/auth.tokens.js.map +1 -1
  30. package/dist/runtime/subsystems/auth/backends/state-store.drizzle-backend.js.map +1 -1
  31. package/dist/runtime/subsystems/auth/controllers/auth.controller.d.ts +2 -2
  32. package/dist/runtime/subsystems/auth/controllers/auth.controller.js +3 -3
  33. package/dist/runtime/subsystems/auth/controllers/auth.controller.js.map +1 -1
  34. package/dist/runtime/subsystems/auth/index.d.ts +3 -3
  35. package/dist/runtime/subsystems/auth/index.js +40 -40
  36. package/dist/runtime/subsystems/auth/index.js.map +1 -1
  37. package/dist/runtime/subsystems/auth/middleware/requester-context.js.map +1 -1
  38. package/dist/runtime/subsystems/auth/protocols/auth-strategy.d.ts +3 -3
  39. package/dist/runtime/subsystems/auth/protocols/{integration-store.d.ts → connection-store.d.ts} +20 -20
  40. package/dist/runtime/subsystems/auth/protocols/connection-store.js +1 -0
  41. package/dist/runtime/subsystems/auth/protocols/provider-strategy.d.ts +3 -3
  42. package/dist/runtime/subsystems/auth/runtime/{integration-broken.error.d.ts → connection-broken.error.d.ts} +5 -5
  43. package/dist/runtime/subsystems/auth/runtime/connection-broken.error.js +19 -0
  44. package/dist/runtime/subsystems/auth/runtime/connection-broken.error.js.map +1 -0
  45. package/dist/runtime/subsystems/auth/runtime/oauth2-refresh.strategy.d.ts +10 -10
  46. package/dist/runtime/subsystems/auth/runtime/oauth2-refresh.strategy.js +28 -28
  47. package/dist/runtime/subsystems/auth/runtime/oauth2-refresh.strategy.js.map +1 -1
  48. package/dist/runtime/subsystems/auth/runtime/with-auth-retry.d.ts +1 -1
  49. package/dist/runtime/subsystems/auth/runtime/with-auth-retry.js +3 -3
  50. package/dist/runtime/subsystems/auth/runtime/with-auth-retry.js.map +1 -1
  51. package/dist/runtime/subsystems/index.d.ts +7 -7
  52. package/dist/runtime/subsystems/index.js +51 -51
  53. package/dist/runtime/subsystems/index.js.map +1 -1
  54. package/dist/runtime/subsystems/{sync → integration}/build-change-source.d.ts +3 -3
  55. package/dist/runtime/subsystems/{sync → integration}/build-change-source.js +3 -3
  56. package/dist/runtime/subsystems/integration/build-change-source.js.map +1 -0
  57. package/dist/runtime/subsystems/{sync → integration}/deep-equal.differ.d.ts +2 -2
  58. package/dist/runtime/subsystems/{sync → integration}/deep-equal.differ.js +1 -1
  59. package/dist/runtime/subsystems/integration/deep-equal.differ.js.map +1 -0
  60. package/dist/runtime/subsystems/{sync → integration}/detection-config.schema.d.ts +3 -3
  61. package/dist/runtime/subsystems/{sync → integration}/detection-config.schema.js +1 -1
  62. package/dist/runtime/subsystems/integration/detection-config.schema.js.map +1 -0
  63. package/dist/runtime/subsystems/{sync/execute-sync.use-case.d.ts → integration/execute-integration.use-case.d.ts} +13 -13
  64. package/dist/runtime/subsystems/{sync/execute-sync.use-case.js → integration/execute-integration.use-case.js} +30 -30
  65. package/dist/runtime/subsystems/integration/execute-integration.use-case.js.map +1 -0
  66. package/dist/runtime/subsystems/integration/index.d.ts +28 -0
  67. package/dist/runtime/subsystems/{sync → integration}/index.js +171 -171
  68. package/dist/runtime/subsystems/integration/index.js.map +1 -0
  69. package/dist/runtime/subsystems/{sync/sync-audit.schema.d.ts → integration/integration-audit.schema.d.ts} +64 -64
  70. package/dist/runtime/subsystems/{sync/sync-audit.schema.js → integration/integration-audit.schema.js} +47 -47
  71. package/dist/runtime/subsystems/integration/integration-audit.schema.js.map +1 -0
  72. package/dist/runtime/subsystems/{sync/sync-change-source.protocol.d.ts → integration/integration-change-source.protocol.d.ts} +10 -10
  73. package/dist/runtime/subsystems/integration/integration-change-source.protocol.js +1 -0
  74. package/dist/runtime/subsystems/{sync/sync-cursor-store.drizzle-backend.d.ts → integration/integration-cursor-store.drizzle-backend.d.ts} +1 -1
  75. package/dist/runtime/subsystems/{sync/sync-cursor-store.drizzle-backend.js → integration/integration-cursor-store.drizzle-backend.js} +65 -65
  76. package/dist/runtime/subsystems/integration/integration-cursor-store.drizzle-backend.js.map +1 -0
  77. package/dist/runtime/subsystems/{sync/sync-cursor-store.memory-backend.d.ts → integration/integration-cursor-store.memory-backend.d.ts} +6 -6
  78. package/dist/runtime/subsystems/{sync/sync-cursor-store.memory-backend.js → integration/integration-cursor-store.memory-backend.js} +5 -5
  79. package/dist/runtime/subsystems/integration/integration-cursor-store.memory-backend.js.map +1 -0
  80. package/dist/runtime/subsystems/{sync/sync-cursor-store.protocol.d.ts → integration/integration-cursor-store.protocol.d.ts} +13 -13
  81. package/dist/runtime/subsystems/integration/integration-cursor-store.protocol.js +1 -0
  82. package/dist/runtime/subsystems/{sync/sync-errors.d.ts → integration/integration-errors.d.ts} +2 -2
  83. package/dist/runtime/subsystems/{sync/sync-errors.js → integration/integration-errors.js} +3 -3
  84. package/dist/runtime/subsystems/integration/integration-errors.js.map +1 -0
  85. package/dist/runtime/subsystems/{sync/sync-field-diff.protocol.d.ts → integration/integration-field-diff.protocol.d.ts} +2 -2
  86. package/dist/runtime/subsystems/{sync/sync-field-diff.protocol.js → integration/integration-field-diff.protocol.js} +2 -2
  87. package/dist/runtime/subsystems/integration/integration-field-diff.protocol.js.map +1 -0
  88. package/dist/runtime/subsystems/{sync/sync-loopback.protocol.d.ts → integration/integration-loopback.protocol.d.ts} +2 -2
  89. package/dist/runtime/subsystems/integration/integration-loopback.protocol.js +1 -0
  90. package/dist/runtime/subsystems/{sync/sync-middleware.protocol.d.ts → integration/integration-middleware.protocol.d.ts} +5 -5
  91. package/dist/runtime/subsystems/integration/integration-middleware.protocol.js +1 -0
  92. package/dist/runtime/subsystems/{sync/sync-run-recorder.drizzle-backend.d.ts → integration/integration-run-recorder.drizzle-backend.d.ts} +5 -5
  93. package/dist/runtime/subsystems/{sync/sync-run-recorder.drizzle-backend.js → integration/integration-run-recorder.drizzle-backend.js} +73 -73
  94. package/dist/runtime/subsystems/integration/integration-run-recorder.drizzle-backend.js.map +1 -0
  95. package/dist/runtime/subsystems/{sync/sync-run-recorder.memory-backend.d.ts → integration/integration-run-recorder.memory-backend.d.ts} +15 -15
  96. package/dist/runtime/subsystems/{sync/sync-run-recorder.memory-backend.js → integration/integration-run-recorder.memory-backend.js} +11 -11
  97. package/dist/runtime/subsystems/integration/integration-run-recorder.memory-backend.js.map +1 -0
  98. package/dist/runtime/subsystems/{sync/sync-run-recorder.protocol.d.ts → integration/integration-run-recorder.protocol.d.ts} +25 -25
  99. package/dist/runtime/subsystems/integration/integration-run-recorder.protocol.js +1 -0
  100. package/dist/runtime/subsystems/{sync/sync-sink.protocol.d.ts → integration/integration-sink.protocol.d.ts} +5 -5
  101. package/dist/runtime/subsystems/integration/integration-sink.protocol.js +1 -0
  102. package/dist/runtime/subsystems/{sync/sync.module.d.ts → integration/integration.module.d.ts} +24 -24
  103. package/dist/runtime/subsystems/{sync/sync.module.js → integration/integration.module.js} +132 -132
  104. package/dist/runtime/subsystems/integration/integration.module.js.map +1 -0
  105. package/dist/runtime/subsystems/integration/integration.tokens.d.ts +47 -0
  106. package/dist/runtime/subsystems/integration/integration.tokens.js +18 -0
  107. package/dist/runtime/subsystems/integration/integration.tokens.js.map +1 -0
  108. package/dist/runtime/subsystems/{sync → integration}/loopback.middleware.d.ts +5 -5
  109. package/dist/runtime/subsystems/{sync → integration}/loopback.middleware.js +1 -1
  110. package/dist/runtime/subsystems/integration/loopback.middleware.js.map +1 -0
  111. package/dist/runtime/subsystems/{sync → integration}/poll-change-source.d.ts +5 -5
  112. package/dist/runtime/subsystems/{sync → integration}/poll-change-source.js +1 -1
  113. package/dist/runtime/subsystems/integration/poll-change-source.js.map +1 -0
  114. package/dist/runtime/subsystems/{sync → integration}/webhook-change-source.d.ts +5 -5
  115. package/dist/runtime/subsystems/{sync → integration}/webhook-change-source.js +1 -1
  116. package/dist/runtime/subsystems/integration/webhook-change-source.js.map +1 -0
  117. package/dist/runtime/subsystems/jobs/job-worker.module.d.ts +1 -1
  118. package/dist/runtime/subsystems/observability/index.d.ts +4 -4
  119. package/dist/runtime/subsystems/observability/index.js +11 -11
  120. package/dist/runtime/subsystems/observability/index.js.map +1 -1
  121. package/dist/runtime/subsystems/observability/observability.module.d.ts +2 -2
  122. package/dist/runtime/subsystems/observability/observability.module.js +11 -11
  123. package/dist/runtime/subsystems/observability/observability.module.js.map +1 -1
  124. package/dist/runtime/subsystems/observability/observability.protocol.d.ts +11 -11
  125. package/dist/runtime/subsystems/observability/observability.service.d.ts +6 -6
  126. package/dist/runtime/subsystems/observability/observability.service.js +11 -11
  127. package/dist/runtime/subsystems/observability/observability.service.js.map +1 -1
  128. package/dist/runtime/subsystems/observability/observability.tokens.d.ts +1 -1
  129. package/dist/runtime/subsystems/observability/observability.tokens.js.map +1 -1
  130. package/dist/runtime/subsystems/observability/reporters/bridge-metrics.reporter.d.ts +3 -3
  131. package/dist/runtime/subsystems/observability/reporters/bridge-metrics.reporter.js.map +1 -1
  132. package/dist/runtime/subsystems/observability/reporters/index.d.ts +3 -3
  133. package/dist/runtime/subsystems/observability/reporters/index.js.map +1 -1
  134. package/dist/src/cli/index.js +262 -269
  135. package/dist/src/cli/index.js.map +1 -1
  136. package/dist/src/index.d.ts +22 -22
  137. package/dist/src/index.js +191 -191
  138. package/dist/src/index.js.map +1 -1
  139. package/examples/auth-integrations/README.md +32 -32
  140. package/examples/auth-integrations/definitions/entities/{integration.yaml → connection.yaml} +10 -10
  141. package/examples/auth-integrations/runtime/{integrations/adapters/integration-grant-sink.adapter.ts → connections/adapters/connection-grant-sink.adapter.ts} +7 -7
  142. package/examples/auth-integrations/runtime/{integrations/adapters/integration-reader.adapter.ts → connections/adapters/connection-reader.adapter.ts} +10 -10
  143. package/examples/auth-integrations/runtime/{integrations/adapters/integration-token-writer.adapter.ts → connections/adapters/connection-token-writer.adapter.ts} +11 -11
  144. package/examples/auth-integrations/runtime/connections/connections-auth.module.ts +81 -0
  145. package/examples/auth-integrations/runtime/{integrations/facade/integrations.service.ts → connections/facade/connections.service.ts} +35 -35
  146. package/examples/auth-integrations/runtime/{integrations → connections}/oauth/use-cases/create-or-update-from-oauth-grant.use-case.ts +11 -11
  147. package/examples/auth-integrations/runtime/{integrations/oauth/use-cases/disconnect-integration.use-case.ts → connections/oauth/use-cases/disconnect-connection.use-case.ts} +6 -6
  148. package/examples/auth-integrations/runtime/connections/oauth/use-cases/list-user-connections.use-case.ts +21 -0
  149. package/examples/auth-integrations/runtime/connections/oauth/use-cases/mark-connection-requires-reauth.use-case.ts +21 -0
  150. package/package.json +1 -1
  151. package/runtime/base-classes/index.ts +8 -8
  152. package/runtime/base-classes/{synced-entity-repository.ts → integrated-entity-repository.ts} +36 -36
  153. package/runtime/base-classes/{synced-entity-service.ts → integrated-entity-service.ts} +6 -6
  154. package/runtime/base-classes/{sync-upsert-config.ts → integration-upsert-config.ts} +12 -12
  155. package/runtime/base-classes/{junction-sync-repository.ts → junction-integration-repository.ts} +28 -28
  156. package/runtime/subsystems/auth/auth-oauth-state.schema.ts +1 -1
  157. package/runtime/subsystems/auth/auth.module.ts +4 -4
  158. package/runtime/subsystems/auth/auth.tokens.ts +7 -7
  159. package/runtime/subsystems/auth/controllers/auth.controller.ts +7 -7
  160. package/runtime/subsystems/auth/index.ts +19 -19
  161. package/runtime/subsystems/auth/protocols/auth-strategy.ts +3 -3
  162. package/runtime/subsystems/auth/protocols/{integration-store.ts → connection-store.ts} +19 -19
  163. package/runtime/subsystems/auth/protocols/provider-strategy.ts +2 -2
  164. package/runtime/subsystems/auth/runtime/{integration-broken.error.ts → connection-broken.error.ts} +5 -5
  165. package/runtime/subsystems/auth/runtime/oauth2-refresh.strategy.ts +35 -35
  166. package/runtime/subsystems/auth/runtime/with-auth-retry.ts +3 -3
  167. package/runtime/subsystems/index.ts +11 -11
  168. package/runtime/subsystems/{sync → integration}/build-change-source.ts +3 -3
  169. package/runtime/subsystems/{sync → integration}/deep-equal.differ.ts +7 -7
  170. package/runtime/subsystems/{sync → integration}/detection-config.schema.ts +3 -3
  171. package/runtime/subsystems/{sync/execute-sync.use-case.ts → integration/execute-integration.use-case.ts} +40 -40
  172. package/runtime/subsystems/{sync → integration}/index.ts +47 -47
  173. package/runtime/subsystems/{sync/sync-audit.schema.ts → integration/integration-audit.schema.ts} +61 -61
  174. package/runtime/subsystems/{sync/sync-change-source.protocol.ts → integration/integration-change-source.protocol.ts} +9 -9
  175. package/runtime/subsystems/{sync/sync-cursor-store.drizzle-backend.ts → integration/integration-cursor-store.drizzle-backend.ts} +30 -30
  176. package/runtime/subsystems/{sync/sync-cursor-store.memory-backend.ts → integration/integration-cursor-store.memory-backend.ts} +9 -9
  177. package/runtime/subsystems/{sync/sync-cursor-store.protocol.ts → integration/integration-cursor-store.protocol.ts} +13 -13
  178. package/runtime/subsystems/{sync/sync-errors.ts → integration/integration-errors.ts} +3 -3
  179. package/runtime/subsystems/{sync/sync-field-diff.protocol.ts → integration/integration-field-diff.protocol.ts} +2 -2
  180. package/runtime/subsystems/{sync/sync-loopback.protocol.ts → integration/integration-loopback.protocol.ts} +2 -2
  181. package/runtime/subsystems/{sync/sync-middleware.protocol.ts → integration/integration-middleware.protocol.ts} +6 -6
  182. package/runtime/subsystems/{sync/sync-run-recorder.drizzle-backend.ts → integration/integration-run-recorder.drizzle-backend.ts} +39 -39
  183. package/runtime/subsystems/{sync/sync-run-recorder.memory-backend.ts → integration/integration-run-recorder.memory-backend.ts} +23 -23
  184. package/runtime/subsystems/{sync/sync-run-recorder.protocol.ts → integration/integration-run-recorder.protocol.ts} +25 -25
  185. package/runtime/subsystems/{sync/sync-sink.protocol.ts → integration/integration-sink.protocol.ts} +4 -4
  186. package/runtime/subsystems/{sync/sync.module.ts → integration/integration.module.ts} +48 -48
  187. package/runtime/subsystems/integration/integration.tokens.ts +49 -0
  188. package/runtime/subsystems/{sync → integration}/loopback.middleware.ts +5 -5
  189. package/runtime/subsystems/{sync → integration}/poll-change-source.ts +7 -7
  190. package/runtime/subsystems/{sync → integration}/webhook-change-source.ts +7 -7
  191. package/runtime/subsystems/observability/index.ts +1 -1
  192. package/runtime/subsystems/observability/observability.module.ts +2 -2
  193. package/runtime/subsystems/observability/observability.protocol.ts +11 -11
  194. package/runtime/subsystems/observability/observability.service.ts +13 -13
  195. package/runtime/subsystems/observability/observability.tokens.ts +1 -1
  196. package/src/patterns/library/index.ts +4 -4
  197. package/src/patterns/library/{synced.pattern.ts → integrated.pattern.ts} +12 -12
  198. package/src/patterns/library/junction.pattern.ts +1 -1
  199. package/src/patterns/pattern-definition.ts +3 -3
  200. package/templates/entity/new/backend/modules/core/{sync-source.ejs.t → integration-source.ejs.t} +6 -6
  201. package/templates/entity/new/backend/modules/core/{sync-source.providers.ejs.t → integration-source.providers.ejs.t} +2 -2
  202. package/templates/entity/new/clean-lite-ps/entity.ejs.t +1 -1
  203. package/templates/entity/new/clean-lite-ps/module.ejs.t +1 -1
  204. package/templates/entity/new/clean-lite-ps/prompt-extension.js +33 -33
  205. package/templates/entity/new/clean-lite-ps/repository.ejs.t +27 -27
  206. package/templates/entity/new/frontend/collections/collection.ejs.t +26 -1
  207. package/templates/entity/new/frontend/collections/collections-base.ejs.t +11 -0
  208. package/templates/entity/new/frontend/entity/combined.ejs.t +31 -1
  209. package/templates/entity/new/prompt.js +27 -15
  210. package/templates/junction/new/entity.ejs.t +1 -1
  211. package/templates/junction/new/prompt.js +24 -24
  212. package/templates/junction/new/repository.ejs.t +19 -19
  213. package/templates/subsystem/auth/auth-oauth-state.schema.ejs.t +2 -2
  214. package/templates/subsystem/auth-config/prompt.js +1 -1
  215. package/templates/subsystem/auth-integrations/app-module-hook.ejs.t +5 -5
  216. package/templates/subsystem/bridge/prompt.js +1 -1
  217. package/templates/subsystem/integration/integration-audit.schema.ejs.t +192 -0
  218. package/templates/subsystem/{sync → integration}/prompt.js +12 -12
  219. package/templates/subsystem/{sync-config/codegen-config-sync-block.ejs.t → integration-config/codegen-config-integration-block.ejs.t} +7 -7
  220. package/templates/subsystem/integration-config/prompt.js +22 -0
  221. package/templates/subsystem/jobs/worker.ejs.t +2 -2
  222. package/templates/subsystem/observability/main-hook.ejs.t +1 -1
  223. package/templates/subsystem/observability/prompt.js +1 -1
  224. package/templates/subsystem/openapi-config/prompt.js +1 -1
  225. package/dist/runtime/base-classes/junction-sync-repository.js.map +0 -1
  226. package/dist/runtime/base-classes/sync-upsert-config.js +0 -1
  227. package/dist/runtime/base-classes/synced-entity-repository.js.map +0 -1
  228. package/dist/runtime/base-classes/synced-entity-service.js.map +0 -1
  229. package/dist/runtime/subsystems/auth/protocols/integration-store.js +0 -1
  230. package/dist/runtime/subsystems/auth/runtime/integration-broken.error.js +0 -19
  231. package/dist/runtime/subsystems/auth/runtime/integration-broken.error.js.map +0 -1
  232. package/dist/runtime/subsystems/sync/build-change-source.js.map +0 -1
  233. package/dist/runtime/subsystems/sync/deep-equal.differ.js.map +0 -1
  234. package/dist/runtime/subsystems/sync/detection-config.schema.js.map +0 -1
  235. package/dist/runtime/subsystems/sync/execute-sync.use-case.js.map +0 -1
  236. package/dist/runtime/subsystems/sync/index.d.ts +0 -28
  237. package/dist/runtime/subsystems/sync/index.js.map +0 -1
  238. package/dist/runtime/subsystems/sync/loopback.middleware.js.map +0 -1
  239. package/dist/runtime/subsystems/sync/poll-change-source.js.map +0 -1
  240. package/dist/runtime/subsystems/sync/sync-audit.schema.js.map +0 -1
  241. package/dist/runtime/subsystems/sync/sync-change-source.protocol.js +0 -1
  242. package/dist/runtime/subsystems/sync/sync-cursor-store.drizzle-backend.js.map +0 -1
  243. package/dist/runtime/subsystems/sync/sync-cursor-store.memory-backend.js.map +0 -1
  244. package/dist/runtime/subsystems/sync/sync-cursor-store.protocol.js +0 -1
  245. package/dist/runtime/subsystems/sync/sync-errors.js.map +0 -1
  246. package/dist/runtime/subsystems/sync/sync-field-diff.protocol.js.map +0 -1
  247. package/dist/runtime/subsystems/sync/sync-loopback.protocol.js +0 -1
  248. package/dist/runtime/subsystems/sync/sync-middleware.protocol.js +0 -1
  249. package/dist/runtime/subsystems/sync/sync-run-recorder.drizzle-backend.js.map +0 -1
  250. package/dist/runtime/subsystems/sync/sync-run-recorder.memory-backend.js.map +0 -1
  251. package/dist/runtime/subsystems/sync/sync-run-recorder.protocol.js +0 -1
  252. package/dist/runtime/subsystems/sync/sync-sink.protocol.js +0 -1
  253. package/dist/runtime/subsystems/sync/sync.module.js.map +0 -1
  254. package/dist/runtime/subsystems/sync/sync.tokens.d.ts +0 -47
  255. package/dist/runtime/subsystems/sync/sync.tokens.js +0 -18
  256. package/dist/runtime/subsystems/sync/sync.tokens.js.map +0 -1
  257. package/dist/runtime/subsystems/sync/webhook-change-source.js.map +0 -1
  258. package/examples/auth-integrations/runtime/integrations/integrations-auth.module.ts +0 -81
  259. package/examples/auth-integrations/runtime/integrations/oauth/use-cases/list-user-integrations.use-case.ts +0 -21
  260. package/examples/auth-integrations/runtime/integrations/oauth/use-cases/mark-integration-requires-reauth.use-case.ts +0 -21
  261. package/runtime/subsystems/sync/sync.tokens.ts +0 -49
  262. package/templates/subsystem/sync/sync-audit.schema.ejs.t +0 -192
  263. package/templates/subsystem/sync-config/prompt.js +0 -22
  264. /package/dist/runtime/base-classes/{sync-upsert-config.js.map → integration-upsert-config.js.map} +0 -0
  265. /package/dist/runtime/subsystems/auth/protocols/{integration-store.js.map → connection-store.js.map} +0 -0
  266. /package/dist/runtime/subsystems/{sync/sync-change-source.protocol.js.map → integration/integration-change-source.protocol.js.map} +0 -0
  267. /package/dist/runtime/subsystems/{sync/sync-cursor-store.protocol.js.map → integration/integration-cursor-store.protocol.js.map} +0 -0
  268. /package/dist/runtime/subsystems/{sync/sync-loopback.protocol.js.map → integration/integration-loopback.protocol.js.map} +0 -0
  269. /package/dist/runtime/subsystems/{sync/sync-middleware.protocol.js.map → integration/integration-middleware.protocol.js.map} +0 -0
  270. /package/dist/runtime/subsystems/{sync/sync-run-recorder.protocol.js.map → integration/integration-run-recorder.protocol.js.map} +0 -0
  271. /package/dist/runtime/subsystems/{sync/sync-sink.protocol.js.map → integration/integration-sink.protocol.js.map} +0 -0
@@ -1,12 +1,12 @@
1
1
  /**
2
- * ExecuteSyncUseCase — the generic sync orchestrator (SYNC-5).
2
+ * ExecuteIntegrationUseCase — the generic integration orchestrator (SYNC-5).
3
3
  *
4
4
  * One class. Reused across every `(provider, detection-mode, canonical-entity)`
5
5
  * tuple. Parameterized over `T` so canonical records stay typed end-to-end.
6
6
  *
7
7
  * Flow per run:
8
8
  *
9
- * 1. `recorder.startRun(...)` — opens a `sync_runs` row in 'running'.
9
+ * 1. `recorder.startRun(...)` — opens a `integration_runs` row in 'running'.
10
10
  * 2. for each change yielded by `source.listChanges(subscription, cursorBefore)`:
11
11
  * a. differ.diff(existing, incoming) → 'noop' short-circuits to
12
12
  * a noop audit row (no sink write).
@@ -33,7 +33,7 @@
33
33
  * ## Generics
34
34
  *
35
35
  * - `T` = canonical record shape from the adapter side. Same `T` flows
36
- * through `IChangeSource<T>`, `IFieldDiffer<T>`, `ISyncSink<T>`.
36
+ * through `IChangeSource<T>`, `IFieldDiffer<T>`, `IIntegrationSink<T>`.
37
37
  *
38
38
  * ## No CRM bleed
39
39
  *
@@ -41,30 +41,30 @@
41
41
  * is strictly provider-agnostic:
42
42
  * - `entityType` is `string` throughout; no `'opportunity' | 'account' | ...`
43
43
  * narrowing leaks into the use case
44
- * - the upstream consumer's `SyncRunRecorderService` class injection replaced with the
45
- * `ISyncRunRecorder` protocol (backend lands in SYNC-4)
44
+ * - the upstream consumer's `IntegrationRunRecorderService` class injection replaced with the
45
+ * `IIntegrationRunRecorder` protocol (backend lands in SYNC-4)
46
46
  */
47
47
  import { Inject, Injectable, Logger, Optional } from '@nestjs/common';
48
- import type { IChangeSource, Change } from './sync-change-source.protocol';
49
- import type { ICursorStore } from './sync-cursor-store.protocol';
50
- import type { IFieldDiffer, FieldDiff } from './sync-field-diff.protocol';
51
- import type { ISyncSink } from './sync-sink.protocol';
52
- import type { ISyncRunRecorder } from './sync-run-recorder.protocol';
53
- import { assertTenantId } from './sync-errors';
48
+ import type { IChangeSource, Change } from './integration-change-source.protocol';
49
+ import type { ICursorStore } from './integration-cursor-store.protocol';
50
+ import type { IFieldDiffer, FieldDiff } from './integration-field-diff.protocol';
51
+ import type { IIntegrationSink } from './integration-sink.protocol';
52
+ import type { IIntegrationRunRecorder } from './integration-run-recorder.protocol';
53
+ import { assertTenantId } from './integration-errors';
54
54
  import {
55
- SYNC_CHANGE_SOURCE,
56
- SYNC_CURSOR_STORE,
57
- SYNC_FIELD_DIFFER,
58
- SYNC_MULTI_TENANT,
59
- SYNC_RUN_RECORDER,
60
- SYNC_SINK,
61
- } from './sync.tokens';
55
+ INTEGRATION_CHANGE_SOURCE,
56
+ INTEGRATION_CURSOR_STORE,
57
+ INTEGRATION_FIELD_DIFFER,
58
+ INTEGRATION_MULTI_TENANT,
59
+ INTEGRATION_RUN_RECORDER,
60
+ INTEGRATION_SINK,
61
+ } from './integration.tokens';
62
62
 
63
63
  // ============================================================================
64
64
  // Inputs + result
65
65
  // ============================================================================
66
66
 
67
- export interface ExecuteSyncInput<T> {
67
+ export interface ExecuteIntegrationInput<T> {
68
68
  /** The subscription whose cursor/identity frames this run. */
69
69
  readonly subscription: {
70
70
  readonly id: string;
@@ -77,19 +77,19 @@ export interface ExecuteSyncInput<T> {
77
77
  readonly provider: string;
78
78
  /** Run direction — almost always `'inbound'`. Reserved for writeback. */
79
79
  readonly direction: 'inbound' | 'outbound';
80
- /** Detection mode — maps 1:1 to `sync_runs.action`. */
80
+ /** Detection mode — maps 1:1 to `integration_runs.action`. */
81
81
  readonly action: 'poll' | 'cdc' | 'webhook' | 'manual' | 'writeback';
82
82
  /** Multi-tenant deployments pass the tenant id through. */
83
83
  readonly tenantId?: string | null;
84
84
  /**
85
85
  * Optional override — inject a specific change source for this run when
86
86
  * the DI-bound source is not the one to use (e.g. manual backfill with
87
- * a custom cursor). Defaults to the DI-resolved `SYNC_CHANGE_SOURCE`.
87
+ * a custom cursor). Defaults to the DI-resolved `INTEGRATION_CHANGE_SOURCE`.
88
88
  */
89
89
  readonly sourceOverride?: IChangeSource<T>;
90
90
  }
91
91
 
92
- export interface ExecuteSyncResult {
92
+ export interface ExecuteIntegrationResult {
93
93
  readonly runId: string;
94
94
  readonly status: 'success' | 'no_changes' | 'failed';
95
95
  readonly recordsFound: number;
@@ -102,25 +102,25 @@ export interface ExecuteSyncResult {
102
102
  }
103
103
 
104
104
  // ============================================================================
105
- // ExecuteSyncUseCase
105
+ // ExecuteIntegrationUseCase
106
106
  // ============================================================================
107
107
 
108
108
  @Injectable()
109
- export class ExecuteSyncUseCase<T extends Record<string, unknown>> {
110
- private readonly logger = new Logger(ExecuteSyncUseCase.name);
109
+ export class ExecuteIntegrationUseCase<T extends Record<string, unknown>> {
110
+ private readonly logger = new Logger(ExecuteIntegrationUseCase.name);
111
111
 
112
112
  constructor(
113
- @Inject(SYNC_CHANGE_SOURCE) private readonly source: IChangeSource<T>,
114
- @Inject(SYNC_CURSOR_STORE) private readonly cursors: ICursorStore,
115
- @Inject(SYNC_FIELD_DIFFER) private readonly differ: IFieldDiffer<T>,
116
- @Inject(SYNC_SINK) private readonly sink: ISyncSink<T>,
117
- @Inject(SYNC_RUN_RECORDER) private readonly recorder: ISyncRunRecorder,
113
+ @Inject(INTEGRATION_CHANGE_SOURCE) private readonly source: IChangeSource<T>,
114
+ @Inject(INTEGRATION_CURSOR_STORE) private readonly cursors: ICursorStore,
115
+ @Inject(INTEGRATION_FIELD_DIFFER) private readonly differ: IFieldDiffer<T>,
116
+ @Inject(INTEGRATION_SINK) private readonly sink: IIntegrationSink<T>,
117
+ @Inject(INTEGRATION_RUN_RECORDER) private readonly recorder: IIntegrationRunRecorder,
118
118
  @Optional()
119
- @Inject(SYNC_MULTI_TENANT)
119
+ @Inject(INTEGRATION_MULTI_TENANT)
120
120
  private readonly multiTenant: boolean = false,
121
121
  ) {}
122
122
 
123
- async execute(input: ExecuteSyncInput<T>): Promise<ExecuteSyncResult> {
123
+ async execute(input: ExecuteIntegrationInput<T>): Promise<ExecuteIntegrationResult> {
124
124
  // Defense-in-depth tenancy guard — fire BEFORE startRun so a rejected
125
125
  // input never leaves a dangling `status=running` row. Backends also
126
126
  // enforce (SYNC-4), but failing fast at the orchestrator boundary is
@@ -163,10 +163,10 @@ export class ExecuteSyncUseCase<T extends Record<string, unknown>> {
163
163
  recordsFailed++;
164
164
  const message = err instanceof Error ? err.message : String(err);
165
165
  this.logger.warn(
166
- `sync item failed: subscription=${input.subscription.id} externalId=${change.externalId}: ${message}`,
166
+ `integration item failed: subscription=${input.subscription.id} externalId=${change.externalId}: ${message}`,
167
167
  );
168
168
  await this.recorder.recordItem({
169
- syncRunId: runId,
169
+ integrationRunId: runId,
170
170
  entityType: input.subscription.domain,
171
171
  externalId: change.externalId,
172
172
  operation: change.operation === 'deleted' ? 'deleted' : 'updated',
@@ -197,7 +197,7 @@ export class ExecuteSyncUseCase<T extends Record<string, unknown>> {
197
197
  status = 'failed';
198
198
  runError = err instanceof Error ? err.message : String(err);
199
199
  this.logger.error(
200
- `sync source failed: subscription=${input.subscription.id}: ${runError}`,
200
+ `integration source failed: subscription=${input.subscription.id}: ${runError}`,
201
201
  );
202
202
  }
203
203
 
@@ -244,7 +244,7 @@ export class ExecuteSyncUseCase<T extends Record<string, unknown>> {
244
244
 
245
245
  private async processChange(
246
246
  runId: string,
247
- input: ExecuteSyncInput<T>,
247
+ input: ExecuteIntegrationInput<T>,
248
248
  change: Change<T>,
249
249
  ): Promise<void> {
250
250
  // Deletion branch — no diff, no upsert; soft-delete via sink.
@@ -254,7 +254,7 @@ export class ExecuteSyncUseCase<T extends Record<string, unknown>> {
254
254
  change.externalId,
255
255
  );
256
256
  await this.recorder.recordItem({
257
- syncRunId: runId,
257
+ integrationRunId: runId,
258
258
  entityType: input.subscription.domain,
259
259
  externalId: change.externalId,
260
260
  localId: result?.id ?? null,
@@ -285,7 +285,7 @@ export class ExecuteSyncUseCase<T extends Record<string, unknown>> {
285
285
  // returned by the upsert. Sinks without the flag keep today's behavior.
286
286
  if (!this.sink.reprojectsOnNoop) {
287
287
  await this.recorder.recordItem({
288
- syncRunId: runId,
288
+ integrationRunId: runId,
289
289
  entityType: input.subscription.domain,
290
290
  externalId: change.externalId,
291
291
  localId: null,
@@ -303,7 +303,7 @@ export class ExecuteSyncUseCase<T extends Record<string, unknown>> {
303
303
  input.provider,
304
304
  );
305
305
  await this.recorder.recordItem({
306
- syncRunId: runId,
306
+ integrationRunId: runId,
307
307
  entityType: input.subscription.domain,
308
308
  externalId: change.externalId,
309
309
  localId: noopLocalId,
@@ -322,7 +322,7 @@ export class ExecuteSyncUseCase<T extends Record<string, unknown>> {
322
322
  );
323
323
 
324
324
  await this.recorder.recordItem({
325
- syncRunId: runId,
325
+ integrationRunId: runId,
326
326
  entityType: input.subscription.domain,
327
327
  externalId: change.externalId,
328
328
  localId,
@@ -1,13 +1,13 @@
1
1
  /**
2
- * Sync subsystem — public API
2
+ * Integration subsystem — public API
3
3
  *
4
4
  * Slices landed so far:
5
5
  * - SYNC-2 — protocols + DI tokens (#134)
6
6
  * - SYNC-1 — Drizzle audit-table schemas (#148)
7
7
  * - SYNC-3 — MemoryCursorStore (#149)
8
- * - SYNC-5 — ExecuteSyncUseCase + DeepEqualDiffer + recorder/loopback protocols (#150)
8
+ * - SYNC-5 — ExecuteIntegrationUseCase + DeepEqualDiffer + recorder/loopback protocols (#150)
9
9
  * - SYNC-4 — Drizzle backends (#151)
10
- * - SYNC-6 — SyncModule + MemoryRunRecorder + multi-tenancy opt-in (this slice)
10
+ * - SYNC-6 — IntegrationModule + MemoryRunRecorder + multi-tenancy opt-in (this slice)
11
11
  *
12
12
  * Scaffold templates (SYNC-7) and docs/skills (SYNC-8) land in their own
13
13
  * PRs. See epic #60.
@@ -18,31 +18,31 @@ export type {
18
18
  Change,
19
19
  ChangeSource,
20
20
  IChangeSource,
21
- SyncSubscriptionView,
22
- } from './sync-change-source.protocol';
21
+ IntegrationSubscriptionView,
22
+ } from './integration-change-source.protocol';
23
23
  export type {
24
24
  CursorSnapshot,
25
25
  ICursorStore,
26
- } from './sync-cursor-store.protocol';
26
+ } from './integration-cursor-store.protocol';
27
27
  export type {
28
28
  DiffResult,
29
29
  FieldDiff,
30
30
  FieldDiffValue,
31
31
  IFieldDiffer,
32
- } from './sync-field-diff.protocol';
32
+ } from './integration-field-diff.protocol';
33
33
  export {
34
34
  FieldDiffSchema,
35
35
  FieldDiffValueSchema,
36
- } from './sync-field-diff.protocol';
37
- export type { ISyncSink } from './sync-sink.protocol';
36
+ } from './integration-field-diff.protocol';
37
+ export type { IIntegrationSink } from './integration-sink.protocol';
38
38
  export type {
39
39
  CompleteRunInput,
40
- ISyncRunRecorder,
40
+ IIntegrationRunRecorder,
41
41
  RecordItemInput,
42
42
  StartRunInput,
43
- SyncRunSummary,
44
- } from './sync-run-recorder.protocol';
45
- export type { ILoopbackFingerprintStore } from './sync-loopback.protocol';
43
+ IntegrationRunSummary,
44
+ } from './integration-run-recorder.protocol';
45
+ export type { ILoopbackFingerprintStore } from './integration-loopback.protocol';
46
46
 
47
47
  // DetectionConfig (#226-1) — Zod schema + inferred types; canonical source
48
48
  // of filter/mapping shape consumed by primitives + codegen YAML validator
@@ -68,10 +68,10 @@ export type {
68
68
  ChangeIterator,
69
69
  ChangeMiddleware,
70
70
  ComposeChangeMiddleware,
71
- } from './sync-middleware.protocol';
71
+ } from './integration-middleware.protocol';
72
72
 
73
73
  // Loopback middleware factory (#226-5) — replaces the orchestrator's prior
74
- // `@Optional() SYNC_LOOPBACK_FINGERPRINT_STORE` branch. Consumers compose
74
+ // `@Optional() INTEGRATION_LOOPBACK_FINGERPRINT_STORE` branch. Consumers compose
75
75
  // `createLoopbackMiddleware(store)` into their primitive's middleware chain.
76
76
  export { createLoopbackMiddleware } from './loopback.middleware';
77
77
 
@@ -100,42 +100,42 @@ export { buildChangeSource } from './build-change-source';
100
100
 
101
101
  // Tokens
102
102
  export {
103
- SYNC_CHANGE_SOURCE,
104
- SYNC_CURSOR_STORE,
105
- SYNC_FIELD_DIFFER,
106
- SYNC_MODULE_OPTIONS,
107
- SYNC_MULTI_TENANT,
108
- SYNC_RUN_RECORDER,
109
- SYNC_SINK,
110
- } from './sync.tokens';
103
+ INTEGRATION_CHANGE_SOURCE,
104
+ INTEGRATION_CURSOR_STORE,
105
+ INTEGRATION_FIELD_DIFFER,
106
+ INTEGRATION_MODULE_OPTIONS,
107
+ INTEGRATION_MULTI_TENANT,
108
+ INTEGRATION_RUN_RECORDER,
109
+ INTEGRATION_SINK,
110
+ } from './integration.tokens';
111
111
 
112
112
  // Errors + shared guards
113
- export { MissingTenantIdError, assertTenantId } from './sync-errors';
113
+ export { MissingTenantIdError, assertTenantId } from './integration-errors';
114
114
 
115
115
  // Audit schemas (SYNC-1) — Drizzle pgTable declarations + row types + enums
116
116
  export {
117
- syncSubscriptions,
118
- syncRuns,
119
- syncRunItems,
120
- syncRunDirectionEnum,
121
- syncRunActionEnum,
122
- syncRunStatusEnum,
123
- syncRunItemOperationEnum,
124
- syncRunItemStatusEnum,
125
- } from './sync-audit.schema';
117
+ integrationSubscriptions,
118
+ integrationRuns,
119
+ integrationRunItems,
120
+ integrationRunDirectionEnum,
121
+ integrationRunActionEnum,
122
+ integrationRunStatusEnum,
123
+ integrationRunItemOperationEnum,
124
+ integrationRunItemStatusEnum,
125
+ } from './integration-audit.schema';
126
126
  export type {
127
- SyncSubscriptionRow,
128
- SyncRunRow,
129
- SyncRunItemRow,
130
- } from './sync-audit.schema';
127
+ IntegrationSubscriptionRow,
128
+ IntegrationRunRow,
129
+ IntegrationRunItemRow,
130
+ } from './integration-audit.schema';
131
131
 
132
132
  // Memory backends (SYNC-3, SYNC-6) — test doubles
133
- export { MemoryCursorStore } from './sync-cursor-store.memory-backend';
133
+ export { MemoryCursorStore } from './integration-cursor-store.memory-backend';
134
134
  export {
135
135
  MemoryRunRecorder,
136
136
  type MemoryRunRecord,
137
- type MemorySyncSubscription,
138
- } from './sync-run-recorder.memory-backend';
137
+ type MemoryIntegrationSubscription,
138
+ } from './integration-run-recorder.memory-backend';
139
139
 
140
140
  // Runtime (SYNC-5) — orchestrator + default differ
141
141
  export {
@@ -143,14 +143,14 @@ export {
143
143
  type DeepEqualDifferOptions,
144
144
  } from './deep-equal.differ';
145
145
  export {
146
- ExecuteSyncUseCase,
147
- type ExecuteSyncInput,
148
- type ExecuteSyncResult,
149
- } from './execute-sync.use-case';
146
+ ExecuteIntegrationUseCase,
147
+ type ExecuteIntegrationInput,
148
+ type ExecuteIntegrationResult,
149
+ } from './execute-integration.use-case';
150
150
 
151
151
  // Drizzle backends (SYNC-4)
152
- export { PostgresCursorStore } from './sync-cursor-store.drizzle-backend';
153
- export { DrizzleSyncRunRecorder } from './sync-run-recorder.drizzle-backend';
152
+ export { PostgresCursorStore } from './integration-cursor-store.drizzle-backend';
153
+ export { DrizzleIntegrationRunRecorder } from './integration-run-recorder.drizzle-backend';
154
154
 
155
155
  // Module (SYNC-6)
156
- export { SyncModule, type SyncModuleOptions } from './sync.module';
156
+ export { IntegrationModule, type IntegrationModuleOptions } from './integration.module';
@@ -1,23 +1,23 @@
1
1
  /**
2
- * Drizzle schema for the sync subsystem audit/observability tables (SYNC-1).
2
+ * Drizzle schema for the integration subsystem audit/observability tables (SYNC-1).
3
3
  *
4
- * Three tables model end-to-end sync observability, keyed by the single port
5
- * every sync adapter implements (`IChangeSource<T>` from SYNC-2):
4
+ * Three tables model end-to-end integration observability, keyed by the single port
5
+ * every integration adapter implements (`IChangeSource<T>` from SYNC-2):
6
6
  *
7
- * - `sync_subscriptions` — owns the cursor per
8
- * `(integration_id, adapter, domain, external_ref)` tuple. Addressed
7
+ * - `integration_subscriptions` — owns the cursor per
8
+ * `(connection_id, adapter, domain, external_ref)` tuple. Addressed
9
9
  * by id by `ICursorStore` (SYNC-3/SYNC-4).
10
- * - `sync_runs` — per-run audit log: start/complete, status,
10
+ * - `integration_runs` — per-run audit log: start/complete, status,
11
11
  * cursor before/after, counts, direction (inbound|outbound),
12
12
  * action (poll|cdc|webhook|manual|writeback).
13
- * - `sync_run_items` — per-record change log with structured
13
+ * - `integration_run_items` — per-record change log with structured
14
14
  * `changed_fields` jsonb enforced by the Zod `FieldDiffSchema`
15
15
  * contract (ADR-0003; protocol lives in SYNC-2's
16
- * sync-field-diff.protocol.ts).
16
+ * integration-field-diff.protocol.ts).
17
17
  *
18
18
  * Design calls (vs. issue #126 open questions):
19
19
  *
20
- * - `sync_subscriptions` ships in the subsystem (not consumer-owned).
20
+ * - `integration_subscriptions` ships in the subsystem (not consumer-owned).
21
21
  * Rationale: SYNC-4's `PostgresCursorStore` needs to read/write this
22
22
  * table directly; making it consumer-owned would require consumers to
23
23
  * hand-wire a shape the backend already knows. The row is addressable
@@ -26,13 +26,13 @@
26
26
  * owned while remaining consumer-queryable.
27
27
  *
28
28
  * - `tenant_id` is always emitted on the three tables as nullable text.
29
- * The `SYNC_MULTI_TENANT` DI flag (SYNC-6) is what enforces the
29
+ * The `INTEGRATION_MULTI_TENANT` DI flag (SYNC-6) is what enforces the
30
30
  * non-null + cross-tenant-isolation contract at the service/orchestrator
31
31
  * boundary. This mirrors JOB-1/JOB-8's final shape — runtime guard, not
32
32
  * a scaffold-time conditional column. Keeps the schema file uniform
33
33
  * across single-tenant and multi-tenant deployments.
34
34
  *
35
- * - `changed_fields` on `sync_run_items` is typed via the Zod-inferred
35
+ * - `changed_fields` on `integration_run_items` is typed via the Zod-inferred
36
36
  * `FieldDiff` shape from SYNC-2 (`{ [fieldName]: { from, to } }`). The
37
37
  * recorder service (SYNC-5) validates every write against
38
38
  * `FieldDiffSchema.parse` so consumers can rely on the shape.
@@ -51,28 +51,28 @@ import {
51
51
  } from 'drizzle-orm/pg-core';
52
52
  import type { InferSelectModel } from 'drizzle-orm';
53
53
 
54
- import type { FieldDiff } from './sync-field-diff.protocol';
54
+ import type { FieldDiff } from './integration-field-diff.protocol';
55
55
 
56
56
  // ─── Enums ──────────────────────────────────────────────────────────────────
57
57
 
58
58
  /**
59
- * Direction of a sync run relative to local state.
59
+ * Direction of a integration run relative to local state.
60
60
  *
61
61
  * - `inbound` — external → local (the common case: SFDC poll → local DB).
62
62
  * - `outbound` — local → external (writeback; deferred per epic but the
63
63
  * column shape is reserved so future writeback runs share the audit log).
64
64
  */
65
- export const syncRunDirectionEnum = pgEnum('sync_run_direction', [
65
+ export const integrationRunDirectionEnum = pgEnum('integration_run_direction', [
66
66
  'inbound',
67
67
  'outbound',
68
68
  ]);
69
69
 
70
70
  /**
71
71
  * How the run detected upstream changes. Maps 1:1 to the `Change.source`
72
- * provenance on inbound runs; `manual` captures operator-triggered re-syncs
72
+ * provenance on inbound runs; `manual` captures operator-triggered re-integrations
73
73
  * and `writeback` captures outbound runs.
74
74
  */
75
- export const syncRunActionEnum = pgEnum('sync_run_action', [
75
+ export const integrationRunActionEnum = pgEnum('integration_run_action', [
76
76
  'poll',
77
77
  'cdc',
78
78
  'webhook',
@@ -81,7 +81,7 @@ export const syncRunActionEnum = pgEnum('sync_run_action', [
81
81
  ]);
82
82
 
83
83
  /**
84
- * Lifecycle status of a sync run.
84
+ * Lifecycle status of a integration run.
85
85
  *
86
86
  * - `running` — in-flight; recorder has started but not completed.
87
87
  * - `success` — completed with at least one change processed.
@@ -89,7 +89,7 @@ export const syncRunActionEnum = pgEnum('sync_run_action', [
89
89
  * - `failed` — errored before completion; `error` column carries the
90
90
  * message. `records_processed` may be non-zero (partial progress).
91
91
  */
92
- export const syncRunStatusEnum = pgEnum('sync_run_status', [
92
+ export const integrationRunStatusEnum = pgEnum('integration_run_status', [
93
93
  'running',
94
94
  'success',
95
95
  'no_changes',
@@ -100,7 +100,7 @@ export const syncRunStatusEnum = pgEnum('sync_run_status', [
100
100
  * Operation applied per record. Mirrors `Change<T>.operation` from SYNC-2,
101
101
  * plus the recorder's own `'noop'` for changes that matched existing state.
102
102
  */
103
- export const syncRunItemOperationEnum = pgEnum('sync_run_item_operation', [
103
+ export const integrationRunItemOperationEnum = pgEnum('integration_run_item_operation', [
104
104
  'created',
105
105
  'updated',
106
106
  'deleted',
@@ -113,18 +113,18 @@ export const syncRunItemOperationEnum = pgEnum('sync_run_item_operation', [
113
113
  * epic), which record the external_id but intentionally do not touch local
114
114
  * state.
115
115
  */
116
- export const syncRunItemStatusEnum = pgEnum('sync_run_item_status', [
116
+ export const integrationRunItemStatusEnum = pgEnum('integration_run_item_status', [
117
117
  'success',
118
118
  'failed',
119
119
  'skipped',
120
120
  ]);
121
121
 
122
- // ─── sync_subscriptions ─────────────────────────────────────────────────────
122
+ // ─── integration_subscriptions ─────────────────────────────────────────────────────
123
123
 
124
124
  /**
125
125
  * One cursor owner per (integration, adapter, domain, external_ref).
126
126
  *
127
- * - `integration_id` — opaque id of the connected account/instance. E.g.
127
+ * - `connection_id` — opaque id of the connected account/instance. E.g.
128
128
  * the SFDC org id for polling strategies, the GitHub installation id
129
129
  * for webhook strategies.
130
130
  * - `adapter` — short adapter label, e.g. `'salesforce'`, `'hubspot'`.
@@ -138,11 +138,11 @@ export const syncRunItemStatusEnum = pgEnum('sync_run_item_status', [
138
138
  * `{ systemModstamp }`, cdc: `{ replayId }`, webhook: `{ ts }`). Overwritten
139
139
  * by `ICursorStore.put(id, cursor)`.
140
140
  */
141
- export const syncSubscriptions = pgTable(
142
- 'sync_subscriptions',
141
+ export const integrationSubscriptions = pgTable(
142
+ 'integration_subscriptions',
143
143
  {
144
144
  id: uuid('id').primaryKey().defaultRandom(),
145
- integrationId: text('integration_id').notNull(),
145
+ connectionId: text('connection_id').notNull(),
146
146
  adapter: text('adapter').notNull(),
147
147
  domain: text('domain').notNull(),
148
148
  externalRef: text('external_ref'),
@@ -157,8 +157,8 @@ export const syncSubscriptions = pgTable(
157
157
  * successful run advances it.
158
158
  */
159
159
  cursor: jsonb('cursor').$type<unknown>(),
160
- lastSyncAt: timestamp('last_sync_at', { withTimezone: true }),
161
- /** Runtime-enforced when `SYNC_MULTI_TENANT` is true; see SYNC-6. */
160
+ lastIntegrationAt: timestamp('last_integration_at', { withTimezone: true }),
161
+ /** Runtime-enforced when `INTEGRATION_MULTI_TENANT` is true; see SYNC-6. */
162
162
  tenantId: text('tenant_id'),
163
163
  createdAt: timestamp('created_at', { withTimezone: true }).notNull().defaultNow(),
164
164
  updatedAt: timestamp('updated_at', { withTimezone: true }).notNull().defaultNow(),
@@ -167,30 +167,30 @@ export const syncSubscriptions = pgTable(
167
167
  /**
168
168
  * Composite uniqueness per the epic shape. `external_ref` is nullable;
169
169
  * Postgres treats NULLs as distinct in a UNIQUE constraint, which means
170
- * two rows with the same `(integration_id, adapter, domain)` and NULL
170
+ * two rows with the same `(connection_id, adapter, domain)` and NULL
171
171
  * external_ref are allowed. That's intentional — a subscription with
172
172
  * NULL external_ref covers the full domain, and duplicates there would
173
173
  * be a consumer-layer modeling issue, not a schema concern.
174
174
  */
175
- uqSyncSubscriptionTuple: uniqueIndex('uq_sync_subscriptions_tuple').on(
176
- t.integrationId,
175
+ uqIntegrationSubscriptionTuple: uniqueIndex('uq_integration_subscriptions_tuple').on(
176
+ t.connectionId,
177
177
  t.adapter,
178
178
  t.domain,
179
179
  t.externalRef,
180
180
  ),
181
181
  /** Scheduling query: list enabled subscriptions ordered by staleness. */
182
- idxSyncSubscriptionsEnabledLastSync: index(
183
- 'idx_sync_subscriptions_enabled_last_sync',
184
- ).on(t.enabled, t.lastSyncAt),
182
+ idxIntegrationSubscriptionsEnabledLastIntegration: index(
183
+ 'idx_integration_subscriptions_enabled_last_integration',
184
+ ).on(t.enabled, t.lastIntegrationAt),
185
185
  }),
186
186
  );
187
187
 
188
- export type SyncSubscriptionRow = InferSelectModel<typeof syncSubscriptions>;
188
+ export type IntegrationSubscriptionRow = InferSelectModel<typeof integrationSubscriptions>;
189
189
 
190
- // ─── sync_runs ──────────────────────────────────────────────────────────────
190
+ // ─── integration_runs ──────────────────────────────────────────────────────────────
191
191
 
192
192
  /**
193
- * One row per invocation of `ExecuteSyncUseCase`. `started_at` is set when
193
+ * One row per invocation of `ExecuteIntegrationUseCase`. `started_at` is set when
194
194
  * the recorder opens the run; `completed_at`, `status`, `records_*`,
195
195
  * `cursor_after`, and `duration_ms` are filled on completion.
196
196
  *
@@ -199,16 +199,16 @@ export type SyncSubscriptionRow = InferSelectModel<typeof syncSubscriptions>;
199
199
  * about exactly what window was scanned without cross-referencing another
200
200
  * table.
201
201
  */
202
- export const syncRuns = pgTable(
203
- 'sync_runs',
202
+ export const integrationRuns = pgTable(
203
+ 'integration_runs',
204
204
  {
205
205
  id: uuid('id').primaryKey().defaultRandom(),
206
206
  subscriptionId: uuid('subscription_id')
207
207
  .notNull()
208
- .references(() => syncSubscriptions.id, { onDelete: 'cascade' }),
209
- direction: syncRunDirectionEnum('direction').notNull(),
210
- action: syncRunActionEnum('action').notNull(),
211
- status: syncRunStatusEnum('status').notNull().default('running'),
208
+ .references(() => integrationSubscriptions.id, { onDelete: 'cascade' }),
209
+ direction: integrationRunDirectionEnum('direction').notNull(),
210
+ action: integrationRunActionEnum('action').notNull(),
211
+ status: integrationRunStatusEnum('status').notNull().default('running'),
212
212
  recordsFound: integer('records_found').notNull().default(0),
213
213
  recordsProcessed: integer('records_processed').notNull().default(0),
214
214
  cursorBefore: jsonb('cursor_before').$type<unknown>(),
@@ -219,25 +219,25 @@ export const syncRuns = pgTable(
219
219
  .notNull()
220
220
  .defaultNow(),
221
221
  completedAt: timestamp('completed_at', { withTimezone: true }),
222
- /** Runtime-enforced when `SYNC_MULTI_TENANT` is true; see SYNC-6. */
222
+ /** Runtime-enforced when `INTEGRATION_MULTI_TENANT` is true; see SYNC-6. */
223
223
  tenantId: text('tenant_id'),
224
224
  },
225
225
  (t) => ({
226
226
  /** Timeline read: "most recent runs for this subscription". */
227
- idxSyncRunsSubscriptionStartedAt: index(
228
- 'idx_sync_runs_subscription_started_at',
227
+ idxIntegrationRunsSubscriptionStartedAt: index(
228
+ 'idx_integration_runs_subscription_started_at',
229
229
  ).on(t.subscriptionId, t.startedAt),
230
230
  /** Stale-run sweeper: "runs that started > N minutes ago and are still running". */
231
- idxSyncRunsStatusStartedAt: index('idx_sync_runs_status_started_at').on(
231
+ idxIntegrationRunsStatusStartedAt: index('idx_integration_runs_status_started_at').on(
232
232
  t.status,
233
233
  t.startedAt,
234
234
  ),
235
235
  }),
236
236
  );
237
237
 
238
- export type SyncRunRow = InferSelectModel<typeof syncRuns>;
238
+ export type IntegrationRunRow = InferSelectModel<typeof integrationRuns>;
239
239
 
240
- // ─── sync_run_items ─────────────────────────────────────────────────────────
240
+ // ─── integration_run_items ─────────────────────────────────────────────────────────
241
241
 
242
242
  /**
243
243
  * One row per upstream change processed within a run. Captures the canonical
@@ -254,18 +254,18 @@ export type SyncRunRow = InferSelectModel<typeof syncRuns>;
254
254
  * `"Pinnacle opportunity"`) so run-log UIs don't need to re-hydrate the
255
255
  * canonical record.
256
256
  */
257
- export const syncRunItems = pgTable(
258
- 'sync_run_items',
257
+ export const integrationRunItems = pgTable(
258
+ 'integration_run_items',
259
259
  {
260
260
  id: uuid('id').primaryKey().defaultRandom(),
261
- syncRunId: uuid('sync_run_id')
261
+ integrationRunId: uuid('integration_run_id')
262
262
  .notNull()
263
- .references(() => syncRuns.id, { onDelete: 'cascade' }),
263
+ .references(() => integrationRuns.id, { onDelete: 'cascade' }),
264
264
  entityType: text('entity_type').notNull(),
265
265
  externalId: text('external_id').notNull(),
266
266
  localId: text('local_id'),
267
- operation: syncRunItemOperationEnum('operation').notNull(),
268
- status: syncRunItemStatusEnum('status').notNull(),
267
+ operation: integrationRunItemOperationEnum('operation').notNull(),
268
+ status: integrationRunItemStatusEnum('status').notNull(),
269
269
  /**
270
270
  * Structured per-field diff — ADR-0003 shape enforced by
271
271
  * `FieldDiffSchema.parse` at the recorder service layer.
@@ -281,20 +281,20 @@ export const syncRunItems = pgTable(
281
281
  createdAt: timestamp('created_at', { withTimezone: true })
282
282
  .notNull()
283
283
  .defaultNow(),
284
- /** Runtime-enforced when `SYNC_MULTI_TENANT` is true; see SYNC-6. */
284
+ /** Runtime-enforced when `INTEGRATION_MULTI_TENANT` is true; see SYNC-6. */
285
285
  tenantId: text('tenant_id'),
286
286
  },
287
287
  (t) => ({
288
288
  /** Ordered timeline within a run. */
289
- idxSyncRunItemsRunCreatedAt: index('idx_sync_run_items_run_created_at').on(
290
- t.syncRunId,
289
+ idxIntegrationRunItemsRunCreatedAt: index('idx_integration_run_items_run_created_at').on(
290
+ t.integrationRunId,
291
291
  t.createdAt,
292
292
  ),
293
- /** Per-record history: "every sync that touched opportunity/$extId". */
294
- idxSyncRunItemsEntityExternal: index(
295
- 'idx_sync_run_items_entity_external',
293
+ /** Per-record history: "every integration that touched opportunity/$extId". */
294
+ idxIntegrationRunItemsEntityExternal: index(
295
+ 'idx_integration_run_items_entity_external',
296
296
  ).on(t.entityType, t.externalId),
297
297
  }),
298
298
  );
299
299
 
300
- export type SyncRunItemRow = InferSelectModel<typeof syncRunItems>;
300
+ export type IntegrationRunItemRow = InferSelectModel<typeof integrationRunItems>;