alepha 0.18.2 → 0.18.3

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 (397) hide show
  1. package/assets/devtools-ui/200.html +2 -2
  2. package/assets/devtools-ui/200.html.br +0 -0
  3. package/assets/devtools-ui/404.html +2 -2
  4. package/assets/devtools-ui/404.html.br +0 -0
  5. package/assets/devtools-ui/{asset.BfSBZ5Dd.css → asset.hG_f8HuK.css} +1 -1
  6. package/assets/devtools-ui/asset.hG_f8HuK.css.br +0 -0
  7. package/assets/devtools-ui/chunk.B3au4Lhg.js +1 -0
  8. package/assets/devtools-ui/chunk.B3au4Lhg.js.br +0 -0
  9. package/assets/devtools-ui/chunk.BLOrlnMB.js +1 -0
  10. package/assets/devtools-ui/chunk.BLOrlnMB.js.br +0 -0
  11. package/assets/devtools-ui/chunk.BLR01ljW.js +1 -0
  12. package/assets/devtools-ui/chunk.BLR01ljW.js.br +0 -0
  13. package/assets/devtools-ui/chunk.BTXaIUlA.js +1 -0
  14. package/assets/devtools-ui/chunk.BTXaIUlA.js.br +0 -0
  15. package/assets/devtools-ui/{chunk.lJL-lgnW.js → chunk.BhJaxmm8.js} +1 -1
  16. package/assets/devtools-ui/chunk.BhJaxmm8.js.br +0 -0
  17. package/assets/devtools-ui/chunk.BtoNxFuL.js +1 -0
  18. package/assets/devtools-ui/chunk.BtoNxFuL.js.br +0 -0
  19. package/assets/devtools-ui/chunk.C8YUV2Wd.js +1 -0
  20. package/assets/devtools-ui/chunk.C8YUV2Wd.js.br +0 -0
  21. package/assets/devtools-ui/{chunk.M6wyKO_3.js → chunk.CBbIgDzE.js} +2 -2
  22. package/assets/devtools-ui/chunk.CBbIgDzE.js.br +0 -0
  23. package/assets/devtools-ui/chunk.CFqIniwA.js +1 -0
  24. package/assets/devtools-ui/chunk.CFqIniwA.js.br +0 -0
  25. package/assets/devtools-ui/chunk.CLFF7f7-.js +1 -0
  26. package/assets/devtools-ui/chunk.CLFF7f7-.js.br +0 -0
  27. package/assets/devtools-ui/chunk.CRsBbA10.js +1 -0
  28. package/assets/devtools-ui/chunk.CRsBbA10.js.br +0 -0
  29. package/assets/devtools-ui/{chunk.DbEH1oOB.js → chunk.CZPo6v95.js} +1 -1
  30. package/assets/devtools-ui/chunk.CZPo6v95.js.br +0 -0
  31. package/assets/devtools-ui/chunk.D0fWgNos.js +1 -0
  32. package/assets/devtools-ui/chunk.D0fWgNos.js.br +1 -0
  33. package/assets/devtools-ui/chunk.D7-0ziQ6.js +1 -0
  34. package/assets/devtools-ui/chunk.D7-0ziQ6.js.br +0 -0
  35. package/assets/devtools-ui/chunk.DAewe0vm.js +1 -0
  36. package/assets/devtools-ui/chunk.DAewe0vm.js.br +0 -0
  37. package/assets/devtools-ui/chunk.DJRQEYqK.js +1 -0
  38. package/assets/devtools-ui/chunk.DJRQEYqK.js.br +0 -0
  39. package/assets/devtools-ui/{chunk.CZl6J9DF.js → chunk.DMAxv14p.js} +1 -1
  40. package/assets/devtools-ui/chunk.DMAxv14p.js.br +0 -0
  41. package/assets/devtools-ui/{chunk.BT2IiBkZ.js → chunk.DMImnNjU.js} +1 -1
  42. package/assets/devtools-ui/chunk.DMImnNjU.js.br +0 -0
  43. package/assets/devtools-ui/chunk.DeeQsidk.js +9 -0
  44. package/assets/devtools-ui/chunk.DeeQsidk.js.br +0 -0
  45. package/assets/devtools-ui/chunk.DqEwn9Vj.js +7 -0
  46. package/assets/devtools-ui/chunk.DqEwn9Vj.js.br +0 -0
  47. package/assets/devtools-ui/chunk.Dt8OsQey.js +1 -0
  48. package/assets/devtools-ui/chunk.Dt8OsQey.js.br +0 -0
  49. package/assets/devtools-ui/{chunk.B9pX3zit.js → chunk.Dtp8oa_f.js} +1 -1
  50. package/assets/devtools-ui/chunk.Dtp8oa_f.js.br +0 -0
  51. package/assets/devtools-ui/chunk.Dx3JzAYM.js +1 -0
  52. package/assets/devtools-ui/chunk.Dx3JzAYM.js.br +0 -0
  53. package/assets/devtools-ui/chunk.GCOj1-5E.js +1 -0
  54. package/assets/devtools-ui/chunk.GCOj1-5E.js.br +0 -0
  55. package/assets/devtools-ui/chunk.IC1LD8BH.js +1 -0
  56. package/assets/devtools-ui/chunk.IC1LD8BH.js.br +0 -0
  57. package/assets/devtools-ui/chunk.IwuB_TqW.js +1 -0
  58. package/assets/devtools-ui/chunk.IwuB_TqW.js.br +0 -0
  59. package/assets/devtools-ui/chunk.Qqapj2zq.js +1 -0
  60. package/assets/devtools-ui/chunk.Qqapj2zq.js.br +0 -0
  61. package/assets/devtools-ui/{chunk.C79YouPp.js → chunk.TKKKndOy.js} +1 -1
  62. package/assets/devtools-ui/chunk.TKKKndOy.js.br +0 -0
  63. package/assets/devtools-ui/chunk.YHTVhFQT.js +1 -0
  64. package/assets/devtools-ui/chunk.YHTVhFQT.js.br +0 -0
  65. package/assets/devtools-ui/chunk.fnod6uEi.js +1 -0
  66. package/assets/devtools-ui/chunk.fnod6uEi.js.br +0 -0
  67. package/assets/devtools-ui/chunk.mOCRmXjo.js +1 -0
  68. package/assets/devtools-ui/chunk.mOCRmXjo.js.br +0 -0
  69. package/assets/devtools-ui/chunk.qZTNEAK0.js +1 -0
  70. package/assets/devtools-ui/chunk.qZTNEAK0.js.br +0 -0
  71. package/assets/devtools-ui/chunk.rc9m0y4-.js +1 -0
  72. package/assets/devtools-ui/chunk.rc9m0y4-.js.br +0 -0
  73. package/assets/devtools-ui/entry.Cxc5QLCU.js +80 -0
  74. package/assets/devtools-ui/entry.Cxc5QLCU.js.br +0 -0
  75. package/assets/devtools-ui/index.html +2 -2
  76. package/assets/devtools-ui/index.html.br +0 -0
  77. package/assets/swagger-ui/swagger-ui-bundle.js +1 -1
  78. package/assets/swagger-ui/swagger-ui.css +1 -1
  79. package/dist/api/audits/index.d.ts +61 -5
  80. package/dist/api/audits/index.d.ts.map +1 -1
  81. package/dist/api/files/index.d.ts +61 -5
  82. package/dist/api/files/index.d.ts.map +1 -1
  83. package/dist/api/jobs/index.d.ts +61 -5
  84. package/dist/api/jobs/index.d.ts.map +1 -1
  85. package/dist/api/jobs/index.js +4 -2
  86. package/dist/api/jobs/index.js.map +1 -1
  87. package/dist/api/keys/index.d.ts +5 -5
  88. package/dist/api/notifications/index.browser.js +44 -1
  89. package/dist/api/notifications/index.browser.js.map +1 -1
  90. package/dist/api/notifications/index.d.ts +187 -2
  91. package/dist/api/notifications/index.d.ts.map +1 -1
  92. package/dist/api/notifications/index.js +143 -8
  93. package/dist/api/notifications/index.js.map +1 -1
  94. package/dist/api/parameters/index.d.ts +61 -5
  95. package/dist/api/parameters/index.d.ts.map +1 -1
  96. package/dist/api/users/index.d.ts +330 -93
  97. package/dist/api/users/index.d.ts.map +1 -1
  98. package/dist/api/users/index.js +27 -36
  99. package/dist/api/users/index.js.map +1 -1
  100. package/dist/cli/config/index.d.ts +46 -0
  101. package/dist/cli/config/index.d.ts.map +1 -0
  102. package/dist/cli/config/index.js +20 -0
  103. package/dist/cli/config/index.js.map +1 -0
  104. package/dist/cli/core/index.d.ts +69 -66
  105. package/dist/cli/core/index.d.ts.map +1 -1
  106. package/dist/cli/core/index.js +329 -196
  107. package/dist/cli/core/index.js.map +1 -1
  108. package/dist/cli/platform/index.d.ts +302 -63
  109. package/dist/cli/platform/index.d.ts.map +1 -1
  110. package/dist/cli/platform/index.js +455 -25
  111. package/dist/cli/platform/index.js.map +1 -1
  112. package/dist/core/index.browser.js +125 -87
  113. package/dist/core/index.browser.js.map +1 -1
  114. package/dist/core/index.d.ts +62 -53
  115. package/dist/core/index.d.ts.map +1 -1
  116. package/dist/core/index.js +125 -87
  117. package/dist/core/index.js.map +1 -1
  118. package/dist/core/index.native.js +125 -87
  119. package/dist/core/index.native.js.map +1 -1
  120. package/dist/core/index.workerd.js +125 -87
  121. package/dist/core/index.workerd.js.map +1 -1
  122. package/dist/crypto/index.d.ts +18 -1
  123. package/dist/crypto/index.d.ts.map +1 -1
  124. package/dist/crypto/index.js +29 -3
  125. package/dist/crypto/index.js.map +1 -1
  126. package/dist/devtools/index.js +3 -12
  127. package/dist/devtools/index.js.map +1 -1
  128. package/dist/logger/index.d.ts +10 -1
  129. package/dist/logger/index.d.ts.map +1 -1
  130. package/dist/logger/index.js +19 -9
  131. package/dist/logger/index.js.map +1 -1
  132. package/dist/orm/core/index.browser.js +57 -1
  133. package/dist/orm/core/index.browser.js.map +1 -1
  134. package/dist/orm/core/index.bun.js +378 -19
  135. package/dist/orm/core/index.bun.js.map +1 -1
  136. package/dist/orm/core/index.d.ts +328 -9
  137. package/dist/orm/core/index.d.ts.map +1 -1
  138. package/dist/orm/core/index.js +384 -21
  139. package/dist/orm/core/index.js.map +1 -1
  140. package/dist/orm/postgres/index.bun.js +49 -17
  141. package/dist/orm/postgres/index.bun.js.map +1 -1
  142. package/dist/orm/postgres/index.d.ts +47 -21
  143. package/dist/orm/postgres/index.d.ts.map +1 -1
  144. package/dist/orm/postgres/index.js +52 -17
  145. package/dist/orm/postgres/index.js.map +1 -1
  146. package/dist/react/core/index.d.ts +1 -1
  147. package/dist/react/core/index.d.ts.map +1 -1
  148. package/dist/react/core/index.js +6 -1
  149. package/dist/react/core/index.js.map +1 -1
  150. package/dist/react/form/index.d.ts +28 -18
  151. package/dist/react/form/index.d.ts.map +1 -1
  152. package/dist/react/form/index.js +92 -56
  153. package/dist/react/form/index.js.map +1 -1
  154. package/dist/react/router/index.browser.js +448 -116
  155. package/dist/react/router/index.browser.js.map +1 -1
  156. package/dist/react/router/index.d.ts +102 -40
  157. package/dist/react/router/index.d.ts.map +1 -1
  158. package/dist/react/router/index.js +453 -92
  159. package/dist/react/router/index.js.map +1 -1
  160. package/dist/security/index.d.ts +3 -11
  161. package/dist/security/index.d.ts.map +1 -1
  162. package/dist/security/index.js +6 -11
  163. package/dist/security/index.js.map +1 -1
  164. package/dist/server/auth/index.d.ts +22 -24
  165. package/dist/server/auth/index.d.ts.map +1 -1
  166. package/dist/server/auth/index.js +102 -82
  167. package/dist/server/auth/index.js.map +1 -1
  168. package/dist/server/cookies/index.d.ts +7 -4
  169. package/dist/server/cookies/index.d.ts.map +1 -1
  170. package/dist/server/cookies/index.js +13 -12
  171. package/dist/server/cookies/index.js.map +1 -1
  172. package/dist/server/core/index.d.ts +288 -4
  173. package/dist/server/core/index.d.ts.map +1 -1
  174. package/dist/server/core/index.js +375 -2
  175. package/dist/server/core/index.js.map +1 -1
  176. package/dist/server/links/index.browser.js +10 -71
  177. package/dist/server/links/index.browser.js.map +1 -1
  178. package/dist/server/links/index.d.ts +32 -49
  179. package/dist/server/links/index.d.ts.map +1 -1
  180. package/dist/server/links/index.js +73 -100
  181. package/dist/server/links/index.js.map +1 -1
  182. package/dist/system/index.browser.js +221 -2
  183. package/dist/system/index.browser.js.map +1 -1
  184. package/dist/system/index.d.ts +63 -1
  185. package/dist/system/index.d.ts.map +1 -1
  186. package/dist/system/index.js +221 -1
  187. package/dist/system/index.js.map +1 -1
  188. package/dist/system/index.workerd.js +224 -4
  189. package/dist/system/index.workerd.js.map +1 -1
  190. package/package.json +10 -5
  191. package/src/api/jobs/providers/JobProvider.ts +6 -3
  192. package/src/api/notifications/controllers/AdminNotificationController.ts +83 -0
  193. package/src/api/notifications/index.browser.ts +3 -0
  194. package/src/api/notifications/index.ts +14 -2
  195. package/src/api/notifications/jobs/NotificationJobs.ts +11 -2
  196. package/src/api/notifications/schemas/notificationDetailResourceSchema.ts +20 -0
  197. package/src/api/notifications/schemas/notificationQuerySchema.ts +19 -0
  198. package/src/api/notifications/schemas/notificationResourceSchema.ts +18 -0
  199. package/src/api/notifications/services/NotificationSenderService.ts +15 -2
  200. package/src/api/users/atoms/realmAuthSettingsAtom.ts +28 -32
  201. package/src/api/users/buckets/UserBuckets.ts +1 -1
  202. package/src/api/users/jobs/UserJobs.ts +1 -1
  203. package/src/api/users/primitives/$realm.ts +8 -49
  204. package/src/api/users/providers/RealmProvider.ts +2 -3
  205. package/src/api/users/services/RegistrationService.spec.ts +7 -7
  206. package/src/api/users/services/RegistrationService.ts +3 -3
  207. package/src/api/users/services/SessionService.spec.ts +4 -4
  208. package/src/api/users/services/SessionService.ts +3 -3
  209. package/src/cli/{core → config}/defineConfig.ts +14 -20
  210. package/src/cli/config/index.ts +1 -0
  211. package/src/cli/core/commands/db.ts +65 -1
  212. package/src/cli/core/commands/dev.ts +1 -0
  213. package/src/cli/core/commands/init.ts +2 -192
  214. package/src/cli/core/index.ts +34 -11
  215. package/src/cli/core/providers/ViteDevServerProvider.ts +52 -13
  216. package/src/cli/core/services/PackageManagerUtils.ts +43 -21
  217. package/src/cli/core/services/ProjectScaffolder.ts +214 -2
  218. package/src/cli/core/services/ViteUtils.ts +57 -0
  219. package/src/cli/core/tasks/BuildClientTask.ts +7 -2
  220. package/src/cli/core/tasks/BuildCloudflareTask.ts +4 -12
  221. package/src/cli/core/tasks/BuildServerTask.ts +2 -0
  222. package/src/cli/core/tasks/BuildVercelTask.ts +165 -168
  223. package/src/cli/core/templates/alephaConfigTs.ts +1 -1
  224. package/src/cli/core/templates/apiAppSecurityTs.ts +5 -8
  225. package/src/cli/core/templates/tsconfigJson.ts +6 -1
  226. package/src/cli/platform/adapters/CloudflareAdapter.spec.ts +1 -1
  227. package/src/cli/platform/adapters/CloudflareAdapter.ts +30 -29
  228. package/src/cli/platform/atoms/platformOptions.ts +21 -0
  229. package/src/cli/platform/commands/SecretsCommand.spec.ts +298 -0
  230. package/src/cli/platform/commands/SecretsCommand.ts +283 -0
  231. package/src/cli/platform/commands/platform.ts +12 -0
  232. package/src/cli/platform/index.ts +14 -28
  233. package/src/cli/platform/providers/GitHubSecretStore.spec.ts +153 -0
  234. package/src/cli/platform/providers/GitHubSecretStore.ts +112 -0
  235. package/src/cli/platform/providers/MemorySecretStore.ts +114 -0
  236. package/src/cli/platform/providers/SecretStoreProvider.ts +39 -0
  237. package/src/cli/platform/schemas/cloudflare.ts +2 -0
  238. package/src/cli/platform/services/CloudflareApi.ts +5 -2
  239. package/src/cli/platform/services/DockerComposeGenerator.spec.ts +115 -0
  240. package/src/cli/platform/services/DockerComposeGenerator.ts +46 -1
  241. package/src/cli/platform/services/SecretFilterService.spec.ts +111 -0
  242. package/src/cli/platform/services/SecretFilterService.ts +54 -0
  243. package/src/core/Alepha.ts +94 -25
  244. package/src/core/__tests__/Alepha-parseEnv.spec.ts +20 -0
  245. package/src/core/primitives/$memoize.ts +38 -26
  246. package/src/core/providers/AlsProvider.ts +2 -0
  247. package/src/core/providers/EventManager.ts +4 -0
  248. package/src/core/providers/KeylessJsonSchemaCodec.spec.ts +1 -4
  249. package/src/core/providers/KeylessJsonSchemaCodec.ts +19 -125
  250. package/src/core/providers/SchemaValidator.spec.ts +36 -0
  251. package/src/core/providers/SchemaValidator.ts +9 -0
  252. package/src/crypto/index.ts +6 -1
  253. package/src/crypto/providers/SecretProvider.ts +36 -0
  254. package/src/devtools/providers/DevToolsProvider.ts +3 -12
  255. package/src/logger/index.ts +33 -6
  256. package/src/logger/providers/PrettyFormatterProvider.ts +5 -3
  257. package/src/orm/__tests__/orm-next-tests.ts +492 -0
  258. package/src/orm/__tests__/orm-next.spec.ts +140 -0
  259. package/src/orm/core/constants/PG_SYMBOLS.ts +17 -0
  260. package/src/orm/core/index.bun.ts +3 -6
  261. package/src/orm/core/index.shared-server.ts +2 -0
  262. package/src/orm/core/index.shared.ts +2 -0
  263. package/src/orm/core/index.ts +5 -7
  264. package/src/orm/core/interfaces/AggregateQuery.ts +103 -0
  265. package/src/orm/core/interfaces/PgQueryWhere.ts +7 -0
  266. package/src/orm/core/primitives/$entity.ts +8 -0
  267. package/src/orm/core/primitives/$repository.ts +6 -3
  268. package/src/orm/core/primitives/$view.ts +88 -0
  269. package/src/orm/core/providers/DbCacheProvider.ts +66 -0
  270. package/src/orm/core/providers/DrizzleKitProvider.ts +42 -0
  271. package/src/orm/core/providers/drivers/BunSqliteProvider.ts +2 -3
  272. package/src/orm/core/providers/drivers/CloudflareD1Provider.ts +12 -0
  273. package/src/orm/core/providers/drivers/DatabaseProvider.ts +39 -0
  274. package/src/orm/core/providers/drivers/NodeSqliteProvider.ts +2 -3
  275. package/src/orm/core/schemas/databaseEnvSchema.ts +31 -0
  276. package/src/orm/core/schemas/insertSchema.ts +13 -3
  277. package/src/orm/core/schemas/updateSchema.ts +14 -3
  278. package/src/orm/core/services/ModelBuilder.ts +26 -14
  279. package/src/orm/core/services/QueryManager.ts +13 -0
  280. package/src/orm/core/services/Repository.ts +307 -5
  281. package/src/orm/core/services/SqliteModelBuilder.ts +38 -0
  282. package/src/orm/postgres/index.bun.ts +4 -7
  283. package/src/orm/postgres/index.ts +4 -7
  284. package/src/orm/postgres/providers/BunPostgresProvider.ts +12 -2
  285. package/src/orm/postgres/providers/NodePostgresProvider.ts +7 -0
  286. package/src/orm/postgres/providers/PglitePostgresProvider.ts +10 -17
  287. package/src/orm/postgres/providers/PostgresProvider.ts +7 -36
  288. package/src/orm/postgres/schemas/postgresEnvSchema.ts +32 -0
  289. package/src/orm/postgres/services/PostgresModelBuilder.ts +40 -0
  290. package/src/react/core/components/ErrorBoundary.tsx +5 -2
  291. package/src/react/form/hooks/useFieldValue.ts +34 -0
  292. package/src/react/form/hooks/useForm.browser.spec.tsx +94 -9
  293. package/src/react/form/hooks/useForm.ts +14 -2
  294. package/src/react/form/hooks/useFormState.ts +10 -10
  295. package/src/react/form/hooks/useFormValues.ts +29 -0
  296. package/src/react/form/index.ts +3 -1
  297. package/src/react/form/services/FormModel.ts +53 -122
  298. package/src/react/router/components/ErrorViewer.tsx +333 -34
  299. package/src/react/router/components/NestedView.tsx +10 -3
  300. package/src/react/router/primitives/$page.browser.spec.tsx +34 -0
  301. package/src/react/router/primitives/$page.spec.tsx +20 -0
  302. package/src/react/router/primitives/$page.ts +24 -0
  303. package/src/react/router/providers/ReactBrowserRouterProvider.ts +14 -2
  304. package/src/react/router/providers/ReactPageProvider.ts +156 -73
  305. package/src/react/router/providers/ReactServerProvider.ts +40 -2
  306. package/src/react/router/providers/ReactServerTemplateProvider.ts +13 -1
  307. package/src/security/providers/SecurityProvider.ts +5 -27
  308. package/src/server/auth/primitives/$auth.ts +52 -19
  309. package/src/server/auth/providers/ServerAuthProvider.ts +145 -139
  310. package/src/server/cookies/providers/ServerCookiesProvider.ts +12 -24
  311. package/src/server/core/index.ts +3 -1
  312. package/src/server/core/primitives/$sse.spec.ts +315 -0
  313. package/src/server/core/primitives/$sse.ts +715 -0
  314. package/src/server/links/index.browser.ts +1 -3
  315. package/src/server/links/index.ts +0 -3
  316. package/src/server/links/providers/LinkProvider.spec.ts +12 -21
  317. package/src/server/links/providers/LinkProvider.ts +20 -52
  318. package/src/server/links/providers/ServerLinksProvider.spec.ts +106 -0
  319. package/src/server/links/providers/ServerLinksProvider.ts +113 -73
  320. package/src/server/links/schemas/apiLinksResponseSchema.ts +4 -21
  321. package/src/server/links/services/BatchCollector.ts +5 -3
  322. package/src/system/index.browser.ts +1 -0
  323. package/src/system/index.ts +3 -0
  324. package/src/system/index.workerd.ts +39 -1
  325. package/src/system/providers/WorkerdFileSystemProvider.ts +365 -0
  326. package/assets/devtools-ui/asset.BfSBZ5Dd.css.br +0 -0
  327. package/assets/devtools-ui/chunk.2NYaoqWt.js +0 -1
  328. package/assets/devtools-ui/chunk.2NYaoqWt.js.br +0 -0
  329. package/assets/devtools-ui/chunk.B052Z_xQ.js +0 -1
  330. package/assets/devtools-ui/chunk.B052Z_xQ.js.br +0 -0
  331. package/assets/devtools-ui/chunk.B4kVY90C.js +0 -1
  332. package/assets/devtools-ui/chunk.B4kVY90C.js.br +0 -0
  333. package/assets/devtools-ui/chunk.B7QJXctB.js +0 -1
  334. package/assets/devtools-ui/chunk.B7QJXctB.js.br +0 -0
  335. package/assets/devtools-ui/chunk.B9pX3zit.js.br +0 -0
  336. package/assets/devtools-ui/chunk.BKF9JxIo.js +0 -1
  337. package/assets/devtools-ui/chunk.BKF9JxIo.js.br +0 -0
  338. package/assets/devtools-ui/chunk.BOHgdTP-.js +0 -1
  339. package/assets/devtools-ui/chunk.BOHgdTP-.js.br +0 -0
  340. package/assets/devtools-ui/chunk.BOVFxkYC.js +0 -1
  341. package/assets/devtools-ui/chunk.BOVFxkYC.js.br +0 -0
  342. package/assets/devtools-ui/chunk.BR842zj5.js +0 -1
  343. package/assets/devtools-ui/chunk.BR842zj5.js.br +0 -0
  344. package/assets/devtools-ui/chunk.BT2IiBkZ.js.br +0 -0
  345. package/assets/devtools-ui/chunk.C79YouPp.js.br +0 -0
  346. package/assets/devtools-ui/chunk.C8mlBrjW.js +0 -9
  347. package/assets/devtools-ui/chunk.C8mlBrjW.js.br +0 -0
  348. package/assets/devtools-ui/chunk.CK0ow3AZ.js +0 -1
  349. package/assets/devtools-ui/chunk.CK0ow3AZ.js.br +0 -0
  350. package/assets/devtools-ui/chunk.CZl6J9DF.js.br +0 -0
  351. package/assets/devtools-ui/chunk.CdNr0YzS.js +0 -1
  352. package/assets/devtools-ui/chunk.CdNr0YzS.js.br +0 -0
  353. package/assets/devtools-ui/chunk.Ce6_6iIF.js +0 -1
  354. package/assets/devtools-ui/chunk.Ce6_6iIF.js.br +0 -0
  355. package/assets/devtools-ui/chunk.CpyDMr6O.js +0 -1
  356. package/assets/devtools-ui/chunk.CpyDMr6O.js.br +0 -0
  357. package/assets/devtools-ui/chunk.CyPmvPnY.js +0 -1
  358. package/assets/devtools-ui/chunk.CyPmvPnY.js.br +0 -0
  359. package/assets/devtools-ui/chunk.DTI_geWu.js +0 -1
  360. package/assets/devtools-ui/chunk.DTI_geWu.js.br +0 -0
  361. package/assets/devtools-ui/chunk.DbEH1oOB.js.br +0 -0
  362. package/assets/devtools-ui/chunk.Ddeqj5gv.js +0 -1
  363. package/assets/devtools-ui/chunk.Ddeqj5gv.js.br +0 -0
  364. package/assets/devtools-ui/chunk.DpRnB4vJ.js +0 -1
  365. package/assets/devtools-ui/chunk.DpRnB4vJ.js.br +0 -0
  366. package/assets/devtools-ui/chunk.DxPGTlsg.js +0 -1
  367. package/assets/devtools-ui/chunk.DxPGTlsg.js.br +0 -0
  368. package/assets/devtools-ui/chunk.G7_MMBJS.js +0 -1
  369. package/assets/devtools-ui/chunk.G7_MMBJS.js.br +0 -0
  370. package/assets/devtools-ui/chunk.M6wyKO_3.js.br +0 -0
  371. package/assets/devtools-ui/chunk.OUxNGmQ6.js +0 -1
  372. package/assets/devtools-ui/chunk.OUxNGmQ6.js.br +0 -0
  373. package/assets/devtools-ui/chunk.T1kle-fF.js +0 -1
  374. package/assets/devtools-ui/chunk.T1kle-fF.js.br +0 -0
  375. package/assets/devtools-ui/chunk.WjpsbQAv.js +0 -1
  376. package/assets/devtools-ui/chunk.WjpsbQAv.js.br +0 -0
  377. package/assets/devtools-ui/chunk.c6YgVx86.js +0 -1
  378. package/assets/devtools-ui/chunk.c6YgVx86.js.br +0 -0
  379. package/assets/devtools-ui/chunk.dwU3E_MU.js +0 -1
  380. package/assets/devtools-ui/chunk.dwU3E_MU.js.br +0 -0
  381. package/assets/devtools-ui/chunk.lJL-lgnW.js.br +0 -0
  382. package/assets/devtools-ui/chunk.lPWRmvA-.js +0 -7
  383. package/assets/devtools-ui/chunk.lPWRmvA-.js.br +0 -0
  384. package/assets/devtools-ui/chunk.p3HJvugM.js +0 -1
  385. package/assets/devtools-ui/chunk.p3HJvugM.js.br +0 -0
  386. package/assets/devtools-ui/chunk.r_Xoa_CI.js +0 -1
  387. package/assets/devtools-ui/chunk.r_Xoa_CI.js.br +0 -0
  388. package/assets/devtools-ui/chunk.sRNuTYXb.js +0 -1
  389. package/assets/devtools-ui/chunk.sRNuTYXb.js.br +0 -0
  390. package/assets/devtools-ui/chunk.tUjcyX5C.js +0 -1
  391. package/assets/devtools-ui/chunk.tUjcyX5C.js.br +0 -0
  392. package/assets/devtools-ui/chunk.thjBxvCA.js +0 -1
  393. package/assets/devtools-ui/chunk.thjBxvCA.js.br +0 -0
  394. package/assets/devtools-ui/entry.GYhBVRpC.js +0 -78
  395. package/assets/devtools-ui/entry.GYhBVRpC.js.br +0 -0
  396. package/src/server/links/services/DefinitionsPool.spec.ts +0 -86
  397. package/src/server/links/services/DefinitionsPool.ts +0 -43
@@ -1,13 +1,27 @@
1
1
  import { createRequire } from "node:module";
2
2
  import { $env, $hook, $inject, $module, $pipeline, AlephaError, t } from "alepha";
3
- import { AlephaOrm, DatabaseProvider, DbError, DbMigrationError, ModelBuilder, PG_CREATED_AT, PG_ENUM, PG_IDENTITY, PG_PRIMARY_KEY, PG_REF, PG_SERIAL, PG_UPDATED_AT, schema } from "alepha/orm";
3
+ import { AlephaOrm, DatabaseProvider, DbError, DbMigrationError, ModelBuilder, PG_CREATED_AT, PG_ENUM, PG_GENERATED, PG_IDENTITY, PG_PRIMARY_KEY, PG_REF, PG_SERIAL, PG_UPDATED_AT, databaseEnvSchema, schema } from "alepha/orm";
4
4
  import { sql } from "drizzle-orm";
5
5
  import { $lock } from "alepha/lock";
6
6
  import * as pg from "drizzle-orm/pg-core";
7
- import { check, customType, foreignKey, index, pgEnum, pgSchema, pgSequence, pgTable, unique, uniqueIndex } from "drizzle-orm/pg-core";
7
+ import { check, customType, foreignKey, index, pgEnum, pgMaterializedView, pgSchema, pgSequence, pgTable, pgView, unique, uniqueIndex } from "drizzle-orm/pg-core";
8
8
  import { mkdir } from "node:fs/promises";
9
9
  import { migrate } from "drizzle-orm/pglite/migrator";
10
10
 
11
+ //#region ../../src/orm/postgres/schemas/postgresEnvSchema.ts
12
+ /**
13
+ * PostgreSQL-specific environment schema.
14
+ *
15
+ * Additional env vars for PostgreSQL providers on top of `databaseEnvSchema`.
16
+ */
17
+ const postgresEnvSchema = t.object({
18
+ POSTGRES_SCHEMA: t.optional(t.text()),
19
+ POOL_MAX: t.optional(t.integer()),
20
+ POOL_IDLE_TIMEOUT: t.optional(t.integer()),
21
+ POOL_CONNECT_TIMEOUT: t.optional(t.integer())
22
+ });
23
+
24
+ //#endregion
11
25
  //#region ../../src/orm/postgres/types/byte.ts
12
26
  /**
13
27
  * Postgres bytea type.
@@ -38,6 +52,19 @@ var PostgresModelBuilder = class extends ModelBuilder {
38
52
  const table = nsp.table(tableName, columns, configFn);
39
53
  options.tables.set(tableName, table);
40
54
  }
55
+ buildView(view, options) {
56
+ const viewName = view.name;
57
+ if (options.tables.has(viewName)) return;
58
+ const columns = this.schemaToPgColumns(viewName, view.schema, {
59
+ enum: pgEnum,
60
+ table: pgTable,
61
+ sequence: pgSequence
62
+ }, /* @__PURE__ */ new Map(), options.tables);
63
+ let drizzleView;
64
+ if (view.materialized) drizzleView = pgMaterializedView(viewName, columns).existing();
65
+ else drizzleView = pgView(viewName, columns).existing();
66
+ options.tables.set(viewName, drizzleView);
67
+ }
41
68
  buildSequence(sequence, options) {
42
69
  const sequenceName = sequence.name;
43
70
  if (options.sequences.has(sequenceName)) return;
@@ -76,6 +103,10 @@ var PostgresModelBuilder = class extends ModelBuilder {
76
103
  return target;
77
104
  }, config.actions);
78
105
  }
106
+ if (PG_GENERATED in value) {
107
+ const gen = value[PG_GENERATED];
108
+ col = col.generatedAlwaysAs(gen.expression);
109
+ }
79
110
  if (schema.required?.includes(key)) col = col.notNull();
80
111
  return {
81
112
  ...columns,
@@ -176,10 +207,6 @@ var PostgresModelBuilder = class extends ModelBuilder {
176
207
 
177
208
  //#endregion
178
209
  //#region ../../src/orm/postgres/providers/PostgresProvider.ts
179
- const envSchema$1 = t.object({
180
- DATABASE_URL: t.optional(t.text()),
181
- POSTGRES_SCHEMA: t.optional(t.text())
182
- });
183
210
  /**
184
211
  * Abstract base class for PostgreSQL database providers.
185
212
  *
@@ -192,7 +219,8 @@ const envSchema$1 = t.object({
192
219
  * Subclasses must implement `connect()`, `close()`, and `executeMigrations()`.
193
220
  */
194
221
  var PostgresProvider = class extends DatabaseProvider {
195
- env = $env(envSchema$1);
222
+ env = $env(databaseEnvSchema);
223
+ pgEnv = $env(postgresEnvSchema);
196
224
  builder = $inject(PostgresModelBuilder);
197
225
  dialect = "postgresql";
198
226
  get name() {
@@ -221,7 +249,7 @@ var PostgresProvider = class extends DatabaseProvider {
221
249
  */
222
250
  get schema() {
223
251
  if (this.schemaForTesting) return this.schemaForTesting;
224
- if (this.env.POSTGRES_SCHEMA) return this.env.POSTGRES_SCHEMA;
252
+ if (this.pgEnv.POSTGRES_SCHEMA) return this.pgEnv.POSTGRES_SCHEMA;
225
253
  return "public";
226
254
  }
227
255
  onStart = $hook({
@@ -354,7 +382,11 @@ var BunPostgresProvider = class extends PostgresProvider {
354
382
  this.log.debug("Connect ..");
355
383
  if (typeof Bun === "undefined") throw new AlephaError("BunPostgresProvider requires the Bun runtime. Use NodePostgresProvider for Node.js.");
356
384
  const { drizzle } = await import("drizzle-orm/bun-sql");
357
- this.client = new Bun.SQL(this.url);
385
+ const bunOptions = { url: this.url };
386
+ if (this.pgEnv.POOL_MAX != null) bunOptions.max = this.pgEnv.POOL_MAX;
387
+ if (this.pgEnv.POOL_IDLE_TIMEOUT != null) bunOptions.idleTimeout = this.pgEnv.POOL_IDLE_TIMEOUT;
388
+ if (this.pgEnv.POOL_CONNECT_TIMEOUT != null) bunOptions.connectionTimeout = this.pgEnv.POOL_CONNECT_TIMEOUT;
389
+ this.client = new Bun.SQL(bunOptions);
358
390
  await this.client.unsafe("SELECT 1");
359
391
  this.bunDb = drizzle({
360
392
  client: this.client,
@@ -378,10 +410,6 @@ var BunPostgresProvider = class extends PostgresProvider {
378
410
 
379
411
  //#endregion
380
412
  //#region ../../src/orm/postgres/providers/PglitePostgresProvider.ts
381
- const envSchema = t.object({
382
- DATABASE_URL: t.optional(t.text()),
383
- POSTGRES_SCHEMA: t.optional(t.text())
384
- });
385
413
  var PglitePostgresProvider = class PglitePostgresProvider extends DatabaseProvider {
386
414
  static importPglite() {
387
415
  try {
@@ -389,9 +417,10 @@ var PglitePostgresProvider = class PglitePostgresProvider extends DatabaseProvid
389
417
  } catch {}
390
418
  }
391
419
  get schema() {
392
- return this.env.POSTGRES_SCHEMA ?? "public";
420
+ return this.pgEnv.POSTGRES_SCHEMA ?? "public";
393
421
  }
394
- env = $env(envSchema);
422
+ env = $env(databaseEnvSchema);
423
+ pgEnv = $env(postgresEnvSchema);
395
424
  builder = $inject(PostgresModelBuilder);
396
425
  client;
397
426
  pglite;
@@ -402,6 +431,9 @@ var PglitePostgresProvider = class PglitePostgresProvider extends DatabaseProvid
402
431
  return "pglite";
403
432
  }
404
433
  dialect = "postgresql";
434
+ get supportsTransactions() {
435
+ return false;
436
+ }
405
437
  get url() {
406
438
  let path = this.env.DATABASE_URL;
407
439
  if (!path) if (this.alepha.isTest()) path = ":memory:";
@@ -468,7 +500,7 @@ const AlephaOrmPostgres = $module({
468
500
  PostgresModelBuilder
469
501
  ],
470
502
  register: (alepha) => {
471
- const url = alepha.parseEnv(t.object({ DATABASE_URL: t.optional(t.text()) })).DATABASE_URL;
503
+ const url = alepha.parseEnv(databaseEnvSchema).DATABASE_URL;
472
504
  if (url?.startsWith("pglite:")) {
473
505
  alepha.with({
474
506
  optional: true,
@@ -490,5 +522,5 @@ const AlephaOrmPostgres = $module({
490
522
  });
491
523
 
492
524
  //#endregion
493
- export { AlephaOrmPostgres, BunPostgresProvider, PglitePostgresProvider, PostgresModelBuilder, PostgresProvider, byte };
525
+ export { AlephaOrmPostgres, BunPostgresProvider, PglitePostgresProvider, PostgresModelBuilder, PostgresProvider, byte, postgresEnvSchema };
494
526
  //# sourceMappingURL=index.bun.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.bun.js","names":["envSchema"],"sources":["../../../src/orm/postgres/types/byte.ts","../../../src/orm/postgres/services/PostgresModelBuilder.ts","../../../src/orm/postgres/providers/PostgresProvider.ts","../../../src/orm/postgres/providers/BunPostgresProvider.ts","../../../src/orm/postgres/providers/PglitePostgresProvider.ts","../../../src/orm/postgres/index.bun.ts"],"sourcesContent":["import { customType } from \"drizzle-orm/pg-core\";\n\n/**\n * Postgres bytea type.\n */\nexport const byte = customType<{\n data: Buffer;\n}>({\n dataType: () => \"bytea\",\n});\n","import { AlephaError, type TObject, type TSchema, t } from \"alepha\";\nimport {\n type EntityPrimitive,\n type FromSchema,\n ModelBuilder,\n PG_CREATED_AT,\n PG_ENUM,\n PG_IDENTITY,\n PG_PRIMARY_KEY,\n PG_REF,\n PG_SERIAL,\n PG_UPDATED_AT,\n type PgEnumOptions,\n type PgIdentityOptions,\n type PgRefOptions,\n type SequencePrimitive,\n schema,\n} from \"alepha/orm\";\nimport type { BuildExtraConfigColumns } from \"drizzle-orm\";\nimport * as pg from \"drizzle-orm/pg-core\";\nimport {\n check,\n foreignKey,\n index,\n type PgEnum,\n type PgSchema,\n type PgTableExtraConfigValue,\n type PgTableWithColumns,\n pgEnum,\n pgSchema,\n pgSequence,\n pgTable,\n unique,\n uniqueIndex,\n} from \"drizzle-orm/pg-core\";\nimport { byte } from \"../types/byte.ts\";\n\nexport class PostgresModelBuilder extends ModelBuilder {\n protected schemas = new Map<string, PgSchema>();\n\n protected getPgSchema(name: string) {\n if (!this.schemas.has(name) && name !== \"public\") {\n this.schemas.set(name, pgSchema(name));\n }\n\n const nsp =\n name !== \"public\"\n ? this.schemas.get(name)\n : ({\n enum: pgEnum,\n table: pgTable,\n sequence: pgSequence,\n } as any);\n\n if (!nsp) {\n throw new AlephaError(`Postgres schema ${name} not found`);\n }\n\n return nsp;\n }\n\n public buildTable(\n entity: EntityPrimitive<any>,\n options: {\n tables: Map<string, unknown>;\n enums: Map<string, unknown>;\n schemas: Map<string, unknown>;\n schema: string;\n },\n ) {\n const tableName = entity.name;\n if (options.tables.has(tableName)) {\n return;\n }\n\n const nsp = this.getPgSchema(options.schema);\n\n // Register PgSchema so drizzle-kit knows the schema is declared in code.\n // Without this, pushSchema diffs \"schema exists in DB but not in code\" → DROP.\n if (options.schema !== \"public\" && !options.schemas.has(options.schema)) {\n options.schemas.set(options.schema, nsp);\n }\n\n const columns = this.schemaToPgColumns(\n tableName,\n entity.schema,\n nsp,\n options.enums,\n options.tables,\n );\n\n // Build the config function that includes indexes, foreign keys, constraints, and custom config\n const configFn = this.getTableConfig(entity, options.tables);\n\n const table = nsp.table(tableName, columns, configFn);\n\n options.tables.set(tableName, table);\n }\n\n public buildSequence(\n sequence: SequencePrimitive,\n options: {\n sequences: Map<string, unknown>;\n schema: string;\n },\n ) {\n const sequenceName = sequence.name;\n if (options.sequences.has(sequenceName)) {\n return;\n }\n\n const nsp = this.getPgSchema(options.schema);\n\n options.sequences.set(\n sequenceName,\n nsp.sequence(sequenceName, sequence.options),\n );\n }\n\n // -------------------------------------------------------------------------------------------------------------------\n\n /**\n * Get PostgreSQL-specific config builder for the table.\n */\n protected getTableConfig(\n entity: EntityPrimitive,\n tables: Map<string, unknown>,\n ):\n | ((\n self: BuildExtraConfigColumns<string, any, \"pg\">,\n ) => PgTableExtraConfigValue[])\n | undefined {\n // PostgreSQL-specific builders\n const pgBuilders = {\n index,\n uniqueIndex,\n unique,\n check,\n foreignKey,\n };\n\n // Table resolver function\n const tableResolver = (entityName: string) => {\n return tables.get(entityName) as any;\n };\n\n return this.buildTableConfig<\n PgTableExtraConfigValue,\n BuildExtraConfigColumns<string, any, \"pg\">\n >(entity, pgBuilders as any, tableResolver);\n }\n\n schemaToPgColumns = <T extends TObject>(\n tableName: string,\n schema: T,\n nsp: PgSchema,\n enums: Map<string, unknown>,\n tables: Map<string, unknown>,\n ): FromSchema<T> => {\n return Object.entries(schema.properties).reduce<Partial<FromSchema<T>>>(\n (columns, [key, value]) => {\n let col = this.mapFieldToColumn(tableName, key, value, nsp, enums);\n\n if (\"default\" in value && value.default != null) {\n col = col.default(value.default as any);\n }\n\n if (PG_PRIMARY_KEY in value) {\n col = col.primaryKey();\n }\n\n if (PG_REF in value) {\n const config = value[PG_REF] as PgRefOptions;\n col = col.references(() => {\n const ref = config.ref();\n const table = tables.get(\n ref.entity.name,\n ) as PgTableWithColumns<any>;\n\n if (!table) {\n throw new AlephaError(\n `Referenced table ${ref.entity.name} not found for ${tableName}.${key}`,\n );\n }\n\n const target = table[ref.name];\n if (!target) {\n throw new AlephaError(\n `Referenced column ${ref.name} not found in table ${ref.entity.name} for ${tableName}.${key}`,\n );\n }\n\n return target;\n }, config.actions);\n }\n\n if (schema.required?.includes(key)) {\n col = col.notNull();\n }\n\n return {\n ...columns,\n [key]: col,\n };\n },\n {},\n ) as FromSchema<T>;\n };\n\n mapFieldToColumn = (\n tableName: string,\n fieldName: string,\n value: TSchema,\n nsp: PgSchema,\n enums: Map<string, any>,\n ) => {\n const key = this.toColumnName(fieldName);\n\n if (\n // is nullish ?\n \"anyOf\" in value &&\n Array.isArray(value.anyOf) &&\n value.anyOf.length === 2 &&\n value.anyOf.some((it: TSchema) => t.schema.isNull(it))\n ) {\n // then, remove nullish\n value = value.anyOf.find((it: TSchema) => !t.schema.isNull(it))!;\n }\n\n if (t.schema.isInteger(value)) {\n if (PG_SERIAL in value) {\n return pg.serial(key);\n }\n\n if (PG_IDENTITY in value) {\n const options = value[PG_IDENTITY] as PgIdentityOptions;\n if (options.mode === \"byDefault\") {\n return pg.integer().generatedByDefaultAsIdentity(options);\n }\n return pg.integer().generatedAlwaysAsIdentity(options);\n }\n\n return pg.integer(key);\n }\n\n if (t.schema.isBigInt(value)) {\n if (PG_IDENTITY in value) {\n const options = value[PG_IDENTITY] as PgIdentityOptions;\n if (options.mode === \"byDefault\") {\n return pg\n .bigint({ mode: \"bigint\" })\n .generatedByDefaultAsIdentity(options);\n }\n return pg.bigint({ mode: \"bigint\" }).generatedAlwaysAsIdentity(options);\n }\n }\n\n if (t.schema.isNumber(value)) {\n if (PG_IDENTITY in value) {\n const options = value[PG_IDENTITY] as PgIdentityOptions;\n if (options.mode === \"byDefault\") {\n return pg\n .bigint({ mode: \"number\" })\n .generatedByDefaultAsIdentity(options);\n }\n return pg.bigint({ mode: \"number\" }).generatedAlwaysAsIdentity(options);\n }\n\n if (value.format === \"int64\") {\n return pg.bigint(key, { mode: \"number\" });\n }\n\n return pg.numeric(key);\n }\n\n if (t.schema.isString(value)) {\n return this.mapStringToColumn(key, value);\n }\n\n if (t.schema.isBoolean(value)) {\n return pg.boolean(key);\n }\n\n if (t.schema.isObject(value)) {\n return schema(key, value);\n }\n\n if (t.schema.isRecord(value)) {\n return schema(key, value);\n }\n\n const isTypeEnum = (value: any): value is { enum: any[] } =>\n t.schema.isUnsafe(value) &&\n \"type\" in value &&\n value.type === \"string\" &&\n \"enum\" in value &&\n Array.isArray(value.enum);\n\n if (t.schema.isArray(value)) {\n if (t.schema.isObject(value.items)) {\n return schema(key, value);\n }\n if (t.schema.isRecord(value.items)) {\n return schema(key, value);\n }\n if (t.schema.isString(value.items)) {\n return pg.text(key).array();\n }\n if (t.schema.isInteger(value.items)) {\n return pg.integer(key).array();\n }\n if (t.schema.isNumber(value.items)) {\n return pg.numeric(key).array();\n }\n if (t.schema.isBoolean(value.items)) {\n return pg.boolean(key).array();\n }\n if (isTypeEnum(value.items)) {\n return pg.text(key).array();\n }\n }\n\n // Enum handling\n if (isTypeEnum(value)) {\n if (!value.enum.every((it) => typeof it === \"string\")) {\n throw new AlephaError(\n `Enum for ${fieldName} must be an array of strings, got ${JSON.stringify(\n value.enum,\n )}`,\n );\n }\n\n // SQL Enum\n if (PG_ENUM in value && value[PG_ENUM]) {\n const options = value[PG_ENUM] as PgEnumOptions;\n const enumName = options.name ?? `${tableName}_${key}_enum`;\n\n if (enums.has(enumName)) {\n const values = (\n enums.get(enumName) as PgEnum<[string]>\n ).enumValues.join(\",\");\n const newValues = value.enum.join(\",\");\n if (values !== newValues) {\n throw new AlephaError(\n `Enum name conflict for ${enumName}: [${values}] vs [${newValues}]`,\n );\n }\n }\n\n enums.set(enumName, nsp.enum(enumName, value.enum as [string]));\n\n return enums.get(enumName)(key);\n }\n\n // else, map to TEXT\n return this.mapStringToColumn(key, value);\n }\n\n throw new AlephaError(\n `Unsupported schema type for ${fieldName} as ${JSON.stringify(value)}`,\n );\n };\n\n /**\n * Map a string to a PG column.\n *\n * @param key The key of the field.\n * @param value The value of the field.\n */\n mapStringToColumn = (key: string, value: TSchema) => {\n if (\"format\" in value) {\n if (value.format === \"uuid\") {\n if (PG_PRIMARY_KEY in value) {\n return pg.uuid(key).defaultRandom();\n }\n\n return pg.uuid(key);\n }\n\n if (value.format === \"byte\") {\n return byte(key);\n }\n\n if (value.format === \"date-time\") {\n if (PG_CREATED_AT in value) {\n return pg\n .timestamp(key, { mode: \"string\", withTimezone: true })\n .defaultNow();\n }\n if (PG_UPDATED_AT in value) {\n return pg\n .timestamp(key, { mode: \"string\", withTimezone: true })\n .defaultNow();\n }\n return pg.timestamp(key, { mode: \"string\", withTimezone: true });\n }\n\n if (value.format === \"date\") {\n return pg.date(key, { mode: \"string\" });\n }\n }\n\n return pg.text(key);\n };\n}\n","import {\n $env,\n $hook,\n $inject,\n $pipeline,\n AlephaError,\n type Static,\n t,\n} from \"alepha\";\nimport { $lock } from \"alepha/lock\";\nimport {\n DatabaseProvider,\n DbError,\n DbMigrationError,\n type SQLLike,\n} from \"alepha/orm\";\nimport { sql } from \"drizzle-orm\";\nimport type { PgDatabase } from \"drizzle-orm/pg-core\";\nimport { PostgresModelBuilder } from \"../services/PostgresModelBuilder.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nconst envSchema = t.object({\n /**\n * Main configuration for database connection.\n * Accept a string in the format of a Postgres connection URL.\n * Example: postgres://user:password@localhost:5432/database\n * or\n * Example: postgres://user:password@localhost:5432/database?sslmode=require\n */\n DATABASE_URL: t.optional(t.text()),\n\n /**\n * In addition to the DATABASE_URL, you can specify the postgres schema name.\n *\n * It will monkey patch drizzle tables.\n */\n POSTGRES_SCHEMA: t.optional(t.text()),\n});\n\ndeclare module \"alepha\" {\n interface Env extends Partial<Static<typeof envSchema>> {}\n}\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * Abstract base class for PostgreSQL database providers.\n *\n * Provides shared logic for Node.js and Bun PostgreSQL providers:\n * - Environment variable handling (DATABASE_URL, POSTGRES_SCHEMA)\n * - Schema name resolution (with test schema generation)\n * - SQL execution with error wrapping\n * - Lifecycle hooks (start with migration lock, stop with test cleanup)\n *\n * Subclasses must implement `connect()`, `close()`, and `executeMigrations()`.\n */\nexport abstract class PostgresProvider extends DatabaseProvider {\n protected readonly env = $env(envSchema);\n protected readonly builder = $inject(PostgresModelBuilder);\n\n public override readonly dialect = \"postgresql\";\n\n public get name() {\n return \"postgres\";\n }\n\n /**\n * In testing mode, the schema name will be generated and deleted after the test.\n */\n protected schemaForTesting = this.alepha.isTest()\n ? this.generateTestSchemaName()\n : undefined;\n\n public override get url() {\n if (!this.env.DATABASE_URL) {\n throw new AlephaError(\"DATABASE_URL is not defined in the environment\");\n }\n\n return this.env.DATABASE_URL;\n }\n\n /**\n * Execute a SQL statement.\n */\n public override execute(\n statement: SQLLike,\n ): Promise<Array<Record<string, unknown>>> {\n try {\n return this.db.execute(statement);\n } catch (error) {\n throw new DbError(\"Error executing statement\", error);\n }\n }\n\n /**\n * Get Postgres schema used by this provider.\n */\n public override get schema(): string {\n if (this.schemaForTesting) {\n return this.schemaForTesting;\n }\n\n if (this.env.POSTGRES_SCHEMA) {\n return this.env.POSTGRES_SCHEMA;\n }\n\n return \"public\";\n }\n\n public abstract override get db(): PgDatabase<any>;\n\n /**\n * Establish the database connection.\n */\n public abstract connect(): Promise<void>;\n\n /**\n * Close the database connection.\n */\n public abstract close(): Promise<void>;\n\n // -------------------------------------------------------------------------------------------------------------------\n\n protected readonly onStart = $hook({\n on: \"start\",\n handler: async () => {\n await this.connect();\n await this.generateTestSchema();\n\n // never migrate in serverless mode (vercel, netlify, ...)\n if (!this.alepha.isServerless()) {\n try {\n await this.migrateLock.run();\n } catch (error) {\n throw new DbMigrationError(error);\n }\n }\n },\n });\n\n protected readonly onStop = $hook({\n on: \"stop\",\n handler: async () => {\n await this.dropTestSchema();\n await this.close();\n },\n });\n\n protected migrateLock = $pipeline({\n use: [$lock({ name: \"postgres:migrate\" })],\n handler: async () => {\n await this.migrate();\n },\n });\n\n // -------------------------------------------------------------------------------------------------------------------\n // Create unique schema for tests and clean up after. Format: test_alepha_{epoch_seconds}_{random8}\n // -------------------------------------------------------------------------------------------------------------------\n\n protected async generateTestSchema() {\n if (\n this.alepha.isTest() &&\n this.schemaForTesting?.startsWith(\"test_alepha_\")\n ) {\n // Self-healing: drop stale schemas left behind by crashed/failed test runs\n await this.cleanupStaleTestSchemas();\n\n await this.execute(\n sql`CREATE SCHEMA IF NOT EXISTS ${sql.raw(this.schemaForTesting)}`,\n );\n }\n }\n\n /**\n * Drop the current test schema if applicable.\n */\n protected async dropTestSchema(): Promise<void> {\n if (\n this.alepha.isTest() &&\n this.schemaForTesting?.startsWith(\"test_alepha_\")\n ) {\n this.log.info(`Deleting test schema '${this.schemaForTesting}' ...`);\n await this.execute(\n sql`DROP SCHEMA IF EXISTS ${sql.raw(this.schemaForTesting)} CASCADE`,\n );\n this.log.info(`Test schema '${this.schemaForTesting}' deleted`);\n }\n }\n\n /**\n * Remove stale test schemas older than 1 hour.\n *\n * Parses the embedded epoch from schema names (format: test_alepha_{epoch}_{random8})\n * and drops any that exceed the TTL. This handles schemas left behind by crashed tests,\n * killed processes, or failed startups where stop() never fired.\n *\n * Uses a PG advisory lock so only one concurrent test process performs the cleanup.\n */\n protected async cleanupStaleTestSchemas(): Promise<void> {\n try {\n // Non-blocking advisory lock — first process in cleans, others skip\n const [lock] = await this.execute(\n sql`SELECT pg_try_advisory_lock(hashtext('alepha:test:schema:cleanup')) AS acquired`,\n );\n\n if (!lock?.acquired) {\n return;\n }\n\n try {\n const result = await this.execute(\n sql`SELECT schema_name FROM information_schema.schemata WHERE schema_name LIKE 'test_alepha_%'`,\n );\n\n const now = Date.now();\n const maxAge = 60 * 60 * 1000; // 1 hour\n\n for (const row of result) {\n const name = row.schema_name as string;\n\n // Skip our own schema (it was just created or is about to be)\n if (name === this.schemaForTesting) {\n continue;\n }\n\n const age = this.parseTestSchemaAge(name, now);\n if (age !== undefined && age > maxAge) {\n this.log.warn(\n `Dropping stale test schema '${name}' (age: ${Math.round(age / 60_000)}min) ...`,\n );\n await this.execute(\n sql`DROP SCHEMA IF EXISTS ${sql.raw(name)} CASCADE`,\n );\n }\n }\n } finally {\n await this.execute(\n sql`SELECT pg_advisory_unlock(hashtext('alepha:test:schema:cleanup'))`,\n );\n }\n } catch (error) {\n // Don't fail test setup if stale cleanup fails\n this.log.warn(\"Failed to clean up stale test schemas\", { error });\n }\n }\n\n /**\n * Parse the age in milliseconds from a test schema name.\n * Format: test_alepha_{epoch_seconds}_{random8}\n * Returns undefined if the name doesn't match the expected format.\n */\n protected parseTestSchemaAge(name: string, now: number): number | undefined {\n const parts = name.split(\"_\");\n // test_alepha_{epoch}_{random} → [\"test\", \"alepha\", epoch, random]\n if (parts.length !== 4 || parts[0] !== \"test\" || parts[1] !== \"alepha\") {\n return undefined;\n }\n\n const epoch = Number(parts[2]);\n if (!Number.isFinite(epoch) || epoch <= 0) {\n return undefined;\n }\n\n return now - epoch * 1000;\n }\n}\n","import { AlephaError } from \"alepha\";\nimport { sql } from \"drizzle-orm\";\nimport type { BunSQLDatabase } from \"drizzle-orm/bun-sql\";\nimport type { PgDatabase } from \"drizzle-orm/pg-core\";\nimport { PostgresProvider } from \"./PostgresProvider.ts\";\n\n/**\n * Bun PostgreSQL provider using Drizzle ORM with Bun's native SQL client.\n *\n * This provider uses Bun's built-in SQL class for PostgreSQL connections,\n * which provides excellent performance on the Bun runtime.\n *\n * @example\n * ```ts\n * // Set DATABASE_URL environment variable\n * // DATABASE_URL=postgres://user:password@localhost:5432/database\n *\n * // Or configure programmatically\n * alepha.with({\n * provide: DatabaseProvider,\n * use: BunPostgresProvider,\n * });\n * ```\n */\nexport class BunPostgresProvider extends PostgresProvider {\n protected client?: Bun.SQL;\n protected bunDb?: BunSQLDatabase;\n\n /**\n * Get the Drizzle Postgres database instance.\n */\n public override get db(): PgDatabase<any> {\n if (!this.bunDb) {\n throw new AlephaError(\"Database not initialized\");\n }\n\n return this.bunDb as unknown as PgDatabase<any>;\n }\n\n protected override async executeMigrations(\n migrationsFolder: string,\n ): Promise<void> {\n if (this.schema !== \"public\") {\n await this.db.execute(\n sql.raw(`SET search_path TO ${this.schema}, public`),\n );\n }\n const { migrate } = await import(\"drizzle-orm/bun-sql/migrator\");\n await migrate(this.bunDb!, {\n migrationsFolder,\n migrationsTable: this.migrationsTable,\n });\n }\n\n // -------------------------------------------------------------------------------------------------------------------\n\n public async connect(): Promise<void> {\n this.log.debug(\"Connect ..\");\n\n // Check if we're running in Bun\n if (typeof Bun === \"undefined\") {\n throw new AlephaError(\n \"BunPostgresProvider requires the Bun runtime. Use NodePostgresProvider for Node.js.\",\n );\n }\n\n const { drizzle } = await import(\"drizzle-orm/bun-sql\");\n\n // Create Bun SQL client\n this.client = new Bun.SQL(this.url);\n\n // Test connection\n await this.client.unsafe(\"SELECT 1\");\n\n this.bunDb = drizzle({\n client: this.client,\n logger: {\n logQuery: (query: string, params: unknown[]) => {\n this.log.trace(query, { params });\n },\n },\n });\n\n // Set search_path so schema-free migration SQL resolves to the correct schema.\n if (this.schema !== \"public\") {\n await this.client.unsafe(`SET search_path TO ${this.schema}, public`);\n }\n\n this.log.info(\"Connection OK\");\n }\n\n public async close(): Promise<void> {\n if (this.client) {\n this.log.debug(\"Close...\");\n\n await this.client.close();\n\n this.client = undefined;\n this.bunDb = undefined;\n\n this.log.info(\"Connection closed\");\n }\n }\n}\n","import { mkdir } from \"node:fs/promises\";\nimport { createRequire } from \"node:module\";\nimport type { PGlite } from \"@electric-sql/pglite\";\nimport { $env, $hook, $inject, AlephaError, t } from \"alepha\";\nimport { DatabaseProvider, type SQLLike } from \"alepha/orm\";\nimport { sql } from \"drizzle-orm\";\nimport type { PgliteDatabase } from \"drizzle-orm/pglite\";\nimport { migrate } from \"drizzle-orm/pglite/migrator\";\nimport { PostgresModelBuilder } from \"../services/PostgresModelBuilder.ts\";\n\nconst envSchema = t.object({\n /**\n * Same as NodePostgresProvider connection string.\n * But, will accept only `file:` protocol for the database path.\n *\n * DATABASE_URL=memory://\n * DATABASE_URL=./db\n * DATABASE_URL=file://absolute/path/to/db\n */\n DATABASE_URL: t.optional(t.text()),\n POSTGRES_SCHEMA: t.optional(t.text()),\n});\n\nexport interface PgLiteModule {\n PGlite: typeof PGlite;\n}\n\nexport class PglitePostgresProvider extends DatabaseProvider {\n public static importPglite(): PgLiteModule | undefined {\n try {\n return createRequire(import.meta.url)(\"@electric-sql/pglite\");\n } catch {\n // ignored\n }\n }\n\n public override get schema(): string {\n return this.env.POSTGRES_SCHEMA ?? \"public\";\n }\n\n protected readonly env = $env(envSchema);\n protected readonly builder = $inject(PostgresModelBuilder);\n\n protected client?: PGlite;\n protected pglite?: PgliteDatabase;\n\n public get name() {\n return \"postgres\";\n }\n\n public get driver() {\n return \"pglite\";\n }\n\n public override readonly dialect = \"postgresql\";\n\n public override get url(): string {\n let path = this.env.DATABASE_URL;\n\n if (!path) {\n if (this.alepha.isTest()) {\n path = \":memory:\"; // use in-memory database for tests by default\n } else {\n path = \"node_modules/.alepha/pglite\"; // default path for dev\n }\n } else {\n if (path.includes(\":memory:\")) {\n // like postgres://:memory: or pglite://:memory:\n path = \":memory:\";\n } else if (path.startsWith(\"file://\")) {\n path = path.replace(\"file://\", \"\");\n }\n }\n\n return path;\n }\n\n public override get db(): PgliteDatabase {\n if (!this.pglite) {\n throw new AlephaError(\"Database not initialized\");\n }\n\n return this.pglite;\n }\n\n public override async execute(\n statement: SQLLike,\n ): Promise<Array<Record<string, unknown>>> {\n const { rows } = await this.db.execute(statement);\n return rows;\n }\n\n protected readonly onStart = $hook({\n on: \"start\",\n handler: async () => {\n if (Object.keys(this.kit.getModels(this)).length === 0) {\n return;\n }\n\n const module = PglitePostgresProvider.importPglite();\n if (!module) {\n throw new AlephaError(\n \"@electric-sql/pglite is not installed. Please install it to use the pglite driver.\",\n );\n }\n\n const { drizzle } = createRequire(import.meta.url)(\"drizzle-orm/pglite\");\n const path = this.url;\n\n if (path !== \":memory:\") {\n await mkdir(path, { recursive: true }).catch(() => null);\n this.client = new module.PGlite(path);\n } else {\n this.client = new module.PGlite();\n }\n\n this.pglite = drizzle({\n client: this.client,\n });\n\n await this.migrate();\n\n this.log.info(`Using PGlite database at ${path}`);\n },\n });\n\n protected readonly onStop = $hook({\n on: \"stop\",\n handler: async () => {\n if (this.client) {\n this.log.debug(\"Closing PGlite connection...\");\n await this.client.close();\n this.client = undefined;\n this.pglite = undefined;\n this.log.info(\"PGlite connection closed\");\n }\n },\n });\n\n protected async executeMigrations(migrationsFolder: string): Promise<void> {\n // Set search_path so schema-free migration SQL resolves to the correct schema.\n // PGlite uses a single connection, so SET persists through the migration.\n if (this.schema !== \"public\") {\n await this.db.execute(\n sql.raw(`SET search_path TO ${this.schema}, public`),\n );\n }\n await migrate(this.db, {\n migrationsFolder,\n migrationsTable: this.migrationsTable,\n });\n }\n}\n","import { $module, type Alepha, t } from \"alepha\";\nimport { AlephaOrm, DatabaseProvider } from \"alepha/orm\";\nimport { BunPostgresProvider } from \"./providers/BunPostgresProvider.ts\";\nimport { PglitePostgresProvider } from \"./providers/PglitePostgresProvider.ts\";\nimport { PostgresProvider } from \"./providers/PostgresProvider.ts\";\nimport { PostgresModelBuilder } from \"./services/PostgresModelBuilder.ts\";\n\nexport * from \"./providers/BunPostgresProvider.ts\";\nexport * from \"./providers/PglitePostgresProvider.ts\";\nexport * from \"./providers/PostgresProvider.ts\";\nexport * from \"./services/PostgresModelBuilder.ts\";\nexport * from \"./types/byte.ts\";\n\nexport const AlephaOrmPostgres = $module({\n name: \"alepha.orm.postgres\",\n primitives: [],\n services: [\n PostgresProvider,\n BunPostgresProvider,\n PglitePostgresProvider,\n PostgresModelBuilder,\n ],\n register: (alepha: Alepha) => {\n const env = alepha.parseEnv(\n t.object({\n DATABASE_URL: t.optional(t.text()),\n }),\n );\n\n const url = env.DATABASE_URL;\n\n if (url?.startsWith(\"pglite:\")) {\n alepha.with({\n optional: true,\n provide: DatabaseProvider,\n use: PglitePostgresProvider,\n });\n return;\n }\n\n if (url?.startsWith(\"postgres:\")) {\n alepha.with({\n optional: true,\n provide: DatabaseProvider,\n use: BunPostgresProvider,\n });\n return;\n }\n\n alepha.with(AlephaOrm);\n },\n});\n"],"mappings":"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"}
1
+ {"version":3,"file":"index.bun.js","names":[],"sources":["../../../src/orm/postgres/schemas/postgresEnvSchema.ts","../../../src/orm/postgres/types/byte.ts","../../../src/orm/postgres/services/PostgresModelBuilder.ts","../../../src/orm/postgres/providers/PostgresProvider.ts","../../../src/orm/postgres/providers/BunPostgresProvider.ts","../../../src/orm/postgres/providers/PglitePostgresProvider.ts","../../../src/orm/postgres/index.bun.ts"],"sourcesContent":["import { type Static, t } from \"alepha\";\n\n/**\n * PostgreSQL-specific environment schema.\n *\n * Additional env vars for PostgreSQL providers on top of `databaseEnvSchema`.\n */\nexport const postgresEnvSchema = t.object({\n /**\n * PostgreSQL schema name (defaults to `\"public\"` when unset).\n */\n POSTGRES_SCHEMA: t.optional(t.text()),\n\n /**\n * Maximum number of connections in the pool.\n */\n POOL_MAX: t.optional(t.integer()),\n\n /**\n * Seconds a connection can be idle before being closed.\n */\n POOL_IDLE_TIMEOUT: t.optional(t.integer()),\n\n /**\n * Seconds to wait when establishing a new connection.\n */\n POOL_CONNECT_TIMEOUT: t.optional(t.integer()),\n});\n\ndeclare module \"alepha\" {\n interface Env extends Partial<Static<typeof postgresEnvSchema>> {}\n}\n","import { customType } from \"drizzle-orm/pg-core\";\n\n/**\n * Postgres bytea type.\n */\nexport const byte = customType<{\n data: Buffer;\n}>({\n dataType: () => \"bytea\",\n});\n","import { AlephaError, type TObject, type TSchema, t } from \"alepha\";\nimport {\n type EntityPrimitive,\n type FromSchema,\n ModelBuilder,\n PG_CREATED_AT,\n PG_ENUM,\n PG_GENERATED,\n PG_IDENTITY,\n PG_PRIMARY_KEY,\n PG_REF,\n PG_SERIAL,\n PG_UPDATED_AT,\n type PgEnumOptions,\n type PgGeneratedOptions,\n type PgIdentityOptions,\n type PgRefOptions,\n type SequencePrimitive,\n schema,\n type ViewPrimitive,\n} from \"alepha/orm\";\nimport type { BuildExtraConfigColumns } from \"drizzle-orm\";\nimport * as pg from \"drizzle-orm/pg-core\";\nimport {\n check,\n foreignKey,\n index,\n type PgEnum,\n type PgSchema,\n type PgTableExtraConfigValue,\n type PgTableWithColumns,\n pgEnum,\n pgMaterializedView,\n pgSchema,\n pgSequence,\n pgTable,\n pgView,\n unique,\n uniqueIndex,\n} from \"drizzle-orm/pg-core\";\nimport { byte } from \"../types/byte.ts\";\n\nexport class PostgresModelBuilder extends ModelBuilder {\n protected schemas = new Map<string, PgSchema>();\n\n protected getPgSchema(name: string) {\n if (!this.schemas.has(name) && name !== \"public\") {\n this.schemas.set(name, pgSchema(name));\n }\n\n const nsp =\n name !== \"public\"\n ? this.schemas.get(name)\n : ({\n enum: pgEnum,\n table: pgTable,\n sequence: pgSequence,\n } as any);\n\n if (!nsp) {\n throw new AlephaError(`Postgres schema ${name} not found`);\n }\n\n return nsp;\n }\n\n public buildTable(\n entity: EntityPrimitive<any>,\n options: {\n tables: Map<string, unknown>;\n enums: Map<string, unknown>;\n schemas: Map<string, unknown>;\n schema: string;\n },\n ) {\n const tableName = entity.name;\n if (options.tables.has(tableName)) {\n return;\n }\n\n const nsp = this.getPgSchema(options.schema);\n\n // Register PgSchema so drizzle-kit knows the schema is declared in code.\n // Without this, pushSchema diffs \"schema exists in DB but not in code\" → DROP.\n if (options.schema !== \"public\" && !options.schemas.has(options.schema)) {\n options.schemas.set(options.schema, nsp);\n }\n\n const columns = this.schemaToPgColumns(\n tableName,\n entity.schema,\n nsp,\n options.enums,\n options.tables,\n );\n\n // Build the config function that includes indexes, foreign keys, constraints, and custom config\n const configFn = this.getTableConfig(entity, options.tables);\n\n const table = nsp.table(tableName, columns, configFn);\n\n options.tables.set(tableName, table);\n }\n\n public buildView(\n view: ViewPrimitive,\n options: {\n tables: Map<string, unknown>;\n schema: string;\n },\n ) {\n const viewName = view.name;\n if (options.tables.has(viewName)) {\n return;\n }\n\n const columns = this.schemaToPgColumns(\n viewName,\n view.schema,\n { enum: pgEnum, table: pgTable, sequence: pgSequence } as any,\n new Map(),\n options.tables,\n );\n\n let drizzleView: unknown;\n if (view.materialized) {\n drizzleView = pgMaterializedView(viewName, columns).existing();\n } else {\n drizzleView = pgView(viewName, columns).existing();\n }\n\n options.tables.set(viewName, drizzleView);\n }\n\n public buildSequence(\n sequence: SequencePrimitive,\n options: {\n sequences: Map<string, unknown>;\n schema: string;\n },\n ) {\n const sequenceName = sequence.name;\n if (options.sequences.has(sequenceName)) {\n return;\n }\n\n const nsp = this.getPgSchema(options.schema);\n\n options.sequences.set(\n sequenceName,\n nsp.sequence(sequenceName, sequence.options),\n );\n }\n\n // -------------------------------------------------------------------------------------------------------------------\n\n /**\n * Get PostgreSQL-specific config builder for the table.\n */\n protected getTableConfig(\n entity: EntityPrimitive,\n tables: Map<string, unknown>,\n ):\n | ((\n self: BuildExtraConfigColumns<string, any, \"pg\">,\n ) => PgTableExtraConfigValue[])\n | undefined {\n // PostgreSQL-specific builders\n const pgBuilders = {\n index,\n uniqueIndex,\n unique,\n check,\n foreignKey,\n };\n\n // Table resolver function\n const tableResolver = (entityName: string) => {\n return tables.get(entityName) as any;\n };\n\n return this.buildTableConfig<\n PgTableExtraConfigValue,\n BuildExtraConfigColumns<string, any, \"pg\">\n >(entity, pgBuilders as any, tableResolver);\n }\n\n schemaToPgColumns = <T extends TObject>(\n tableName: string,\n schema: T,\n nsp: PgSchema,\n enums: Map<string, unknown>,\n tables: Map<string, unknown>,\n ): FromSchema<T> => {\n return Object.entries(schema.properties).reduce<Partial<FromSchema<T>>>(\n (columns, [key, value]) => {\n let col = this.mapFieldToColumn(tableName, key, value, nsp, enums);\n\n if (\"default\" in value && value.default != null) {\n col = col.default(value.default as any);\n }\n\n if (PG_PRIMARY_KEY in value) {\n col = col.primaryKey();\n }\n\n if (PG_REF in value) {\n const config = value[PG_REF] as PgRefOptions;\n col = col.references(() => {\n const ref = config.ref();\n const table = tables.get(\n ref.entity.name,\n ) as PgTableWithColumns<any>;\n\n if (!table) {\n throw new AlephaError(\n `Referenced table ${ref.entity.name} not found for ${tableName}.${key}`,\n );\n }\n\n const target = table[ref.name];\n if (!target) {\n throw new AlephaError(\n `Referenced column ${ref.name} not found in table ${ref.entity.name} for ${tableName}.${key}`,\n );\n }\n\n return target;\n }, config.actions);\n }\n\n if (PG_GENERATED in value) {\n const gen = value[PG_GENERATED] as PgGeneratedOptions;\n col = col.generatedAlwaysAs(gen.expression);\n }\n\n if (schema.required?.includes(key)) {\n col = col.notNull();\n }\n\n return {\n ...columns,\n [key]: col,\n };\n },\n {},\n ) as FromSchema<T>;\n };\n\n mapFieldToColumn = (\n tableName: string,\n fieldName: string,\n value: TSchema,\n nsp: PgSchema,\n enums: Map<string, any>,\n ) => {\n const key = this.toColumnName(fieldName);\n\n if (\n // is nullish ?\n \"anyOf\" in value &&\n Array.isArray(value.anyOf) &&\n value.anyOf.length === 2 &&\n value.anyOf.some((it: TSchema) => t.schema.isNull(it))\n ) {\n // then, remove nullish\n value = value.anyOf.find((it: TSchema) => !t.schema.isNull(it))!;\n }\n\n if (t.schema.isInteger(value)) {\n if (PG_SERIAL in value) {\n return pg.serial(key);\n }\n\n if (PG_IDENTITY in value) {\n const options = value[PG_IDENTITY] as PgIdentityOptions;\n if (options.mode === \"byDefault\") {\n return pg.integer().generatedByDefaultAsIdentity(options);\n }\n return pg.integer().generatedAlwaysAsIdentity(options);\n }\n\n return pg.integer(key);\n }\n\n if (t.schema.isBigInt(value)) {\n if (PG_IDENTITY in value) {\n const options = value[PG_IDENTITY] as PgIdentityOptions;\n if (options.mode === \"byDefault\") {\n return pg\n .bigint({ mode: \"bigint\" })\n .generatedByDefaultAsIdentity(options);\n }\n return pg.bigint({ mode: \"bigint\" }).generatedAlwaysAsIdentity(options);\n }\n }\n\n if (t.schema.isNumber(value)) {\n if (PG_IDENTITY in value) {\n const options = value[PG_IDENTITY] as PgIdentityOptions;\n if (options.mode === \"byDefault\") {\n return pg\n .bigint({ mode: \"number\" })\n .generatedByDefaultAsIdentity(options);\n }\n return pg.bigint({ mode: \"number\" }).generatedAlwaysAsIdentity(options);\n }\n\n if (value.format === \"int64\") {\n return pg.bigint(key, { mode: \"number\" });\n }\n\n return pg.numeric(key);\n }\n\n if (t.schema.isString(value)) {\n return this.mapStringToColumn(key, value);\n }\n\n if (t.schema.isBoolean(value)) {\n return pg.boolean(key);\n }\n\n if (t.schema.isObject(value)) {\n return schema(key, value);\n }\n\n if (t.schema.isRecord(value)) {\n return schema(key, value);\n }\n\n const isTypeEnum = (value: any): value is { enum: any[] } =>\n t.schema.isUnsafe(value) &&\n \"type\" in value &&\n value.type === \"string\" &&\n \"enum\" in value &&\n Array.isArray(value.enum);\n\n if (t.schema.isArray(value)) {\n if (t.schema.isObject(value.items)) {\n return schema(key, value);\n }\n if (t.schema.isRecord(value.items)) {\n return schema(key, value);\n }\n if (t.schema.isString(value.items)) {\n return pg.text(key).array();\n }\n if (t.schema.isInteger(value.items)) {\n return pg.integer(key).array();\n }\n if (t.schema.isNumber(value.items)) {\n return pg.numeric(key).array();\n }\n if (t.schema.isBoolean(value.items)) {\n return pg.boolean(key).array();\n }\n if (isTypeEnum(value.items)) {\n return pg.text(key).array();\n }\n }\n\n // Enum handling\n if (isTypeEnum(value)) {\n if (!value.enum.every((it) => typeof it === \"string\")) {\n throw new AlephaError(\n `Enum for ${fieldName} must be an array of strings, got ${JSON.stringify(\n value.enum,\n )}`,\n );\n }\n\n // SQL Enum\n if (PG_ENUM in value && value[PG_ENUM]) {\n const options = value[PG_ENUM] as PgEnumOptions;\n const enumName = options.name ?? `${tableName}_${key}_enum`;\n\n if (enums.has(enumName)) {\n const values = (\n enums.get(enumName) as PgEnum<[string]>\n ).enumValues.join(\",\");\n const newValues = value.enum.join(\",\");\n if (values !== newValues) {\n throw new AlephaError(\n `Enum name conflict for ${enumName}: [${values}] vs [${newValues}]`,\n );\n }\n }\n\n enums.set(enumName, nsp.enum(enumName, value.enum as [string]));\n\n return enums.get(enumName)(key);\n }\n\n // else, map to TEXT\n return this.mapStringToColumn(key, value);\n }\n\n throw new AlephaError(\n `Unsupported schema type for ${fieldName} as ${JSON.stringify(value)}`,\n );\n };\n\n /**\n * Map a string to a PG column.\n *\n * @param key The key of the field.\n * @param value The value of the field.\n */\n mapStringToColumn = (key: string, value: TSchema) => {\n if (\"format\" in value) {\n if (value.format === \"uuid\") {\n if (PG_PRIMARY_KEY in value) {\n return pg.uuid(key).defaultRandom();\n }\n\n return pg.uuid(key);\n }\n\n if (value.format === \"byte\") {\n return byte(key);\n }\n\n if (value.format === \"date-time\") {\n if (PG_CREATED_AT in value) {\n return pg\n .timestamp(key, { mode: \"string\", withTimezone: true })\n .defaultNow();\n }\n if (PG_UPDATED_AT in value) {\n return pg\n .timestamp(key, { mode: \"string\", withTimezone: true })\n .defaultNow();\n }\n return pg.timestamp(key, { mode: \"string\", withTimezone: true });\n }\n\n if (value.format === \"date\") {\n return pg.date(key, { mode: \"string\" });\n }\n }\n\n return pg.text(key);\n };\n}\n","import { $env, $hook, $inject, $pipeline, AlephaError } from \"alepha\";\nimport { $lock } from \"alepha/lock\";\nimport {\n DatabaseProvider,\n DbError,\n DbMigrationError,\n databaseEnvSchema,\n type SQLLike,\n} from \"alepha/orm\";\nimport { sql } from \"drizzle-orm\";\nimport type { PgDatabase } from \"drizzle-orm/pg-core\";\nimport { postgresEnvSchema } from \"../schemas/postgresEnvSchema.ts\";\nimport { PostgresModelBuilder } from \"../services/PostgresModelBuilder.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * Abstract base class for PostgreSQL database providers.\n *\n * Provides shared logic for Node.js and Bun PostgreSQL providers:\n * - Environment variable handling (DATABASE_URL, POSTGRES_SCHEMA)\n * - Schema name resolution (with test schema generation)\n * - SQL execution with error wrapping\n * - Lifecycle hooks (start with migration lock, stop with test cleanup)\n *\n * Subclasses must implement `connect()`, `close()`, and `executeMigrations()`.\n */\nexport abstract class PostgresProvider extends DatabaseProvider {\n protected readonly env = $env(databaseEnvSchema);\n protected readonly pgEnv = $env(postgresEnvSchema);\n protected readonly builder = $inject(PostgresModelBuilder);\n\n public override readonly dialect = \"postgresql\";\n\n public get name() {\n return \"postgres\";\n }\n\n /**\n * In testing mode, the schema name will be generated and deleted after the test.\n */\n protected schemaForTesting = this.alepha.isTest()\n ? this.generateTestSchemaName()\n : undefined;\n\n public override get url() {\n if (!this.env.DATABASE_URL) {\n throw new AlephaError(\"DATABASE_URL is not defined in the environment\");\n }\n\n return this.env.DATABASE_URL;\n }\n\n /**\n * Execute a SQL statement.\n */\n public override execute(\n statement: SQLLike,\n ): Promise<Array<Record<string, unknown>>> {\n try {\n return this.db.execute(statement);\n } catch (error) {\n throw new DbError(\"Error executing statement\", error);\n }\n }\n\n /**\n * Get Postgres schema used by this provider.\n */\n public override get schema(): string {\n if (this.schemaForTesting) {\n return this.schemaForTesting;\n }\n\n if (this.pgEnv.POSTGRES_SCHEMA) {\n return this.pgEnv.POSTGRES_SCHEMA;\n }\n\n return \"public\";\n }\n\n public abstract override get db(): PgDatabase<any>;\n\n /**\n * Establish the database connection.\n */\n public abstract connect(): Promise<void>;\n\n /**\n * Close the database connection.\n */\n public abstract close(): Promise<void>;\n\n // -------------------------------------------------------------------------------------------------------------------\n\n protected readonly onStart = $hook({\n on: \"start\",\n handler: async () => {\n await this.connect();\n await this.generateTestSchema();\n\n // never migrate in serverless mode (vercel, netlify, ...)\n if (!this.alepha.isServerless()) {\n try {\n await this.migrateLock.run();\n } catch (error) {\n throw new DbMigrationError(error);\n }\n }\n },\n });\n\n protected readonly onStop = $hook({\n on: \"stop\",\n handler: async () => {\n await this.dropTestSchema();\n await this.close();\n },\n });\n\n protected migrateLock = $pipeline({\n use: [$lock({ name: \"postgres:migrate\" })],\n handler: async () => {\n await this.migrate();\n },\n });\n\n // -------------------------------------------------------------------------------------------------------------------\n // Create unique schema for tests and clean up after. Format: test_alepha_{epoch_seconds}_{random8}\n // -------------------------------------------------------------------------------------------------------------------\n\n protected async generateTestSchema() {\n if (\n this.alepha.isTest() &&\n this.schemaForTesting?.startsWith(\"test_alepha_\")\n ) {\n // Self-healing: drop stale schemas left behind by crashed/failed test runs\n await this.cleanupStaleTestSchemas();\n\n await this.execute(\n sql`CREATE SCHEMA IF NOT EXISTS ${sql.raw(this.schemaForTesting)}`,\n );\n }\n }\n\n /**\n * Drop the current test schema if applicable.\n */\n protected async dropTestSchema(): Promise<void> {\n if (\n this.alepha.isTest() &&\n this.schemaForTesting?.startsWith(\"test_alepha_\")\n ) {\n this.log.info(`Deleting test schema '${this.schemaForTesting}' ...`);\n await this.execute(\n sql`DROP SCHEMA IF EXISTS ${sql.raw(this.schemaForTesting)} CASCADE`,\n );\n this.log.info(`Test schema '${this.schemaForTesting}' deleted`);\n }\n }\n\n /**\n * Remove stale test schemas older than 1 hour.\n *\n * Parses the embedded epoch from schema names (format: test_alepha_{epoch}_{random8})\n * and drops any that exceed the TTL. This handles schemas left behind by crashed tests,\n * killed processes, or failed startups where stop() never fired.\n *\n * Uses a PG advisory lock so only one concurrent test process performs the cleanup.\n */\n protected async cleanupStaleTestSchemas(): Promise<void> {\n try {\n // Non-blocking advisory lock — first process in cleans, others skip\n const [lock] = await this.execute(\n sql`SELECT pg_try_advisory_lock(hashtext('alepha:test:schema:cleanup')) AS acquired`,\n );\n\n if (!lock?.acquired) {\n return;\n }\n\n try {\n const result = await this.execute(\n sql`SELECT schema_name FROM information_schema.schemata WHERE schema_name LIKE 'test_alepha_%'`,\n );\n\n const now = Date.now();\n const maxAge = 60 * 60 * 1000; // 1 hour\n\n for (const row of result) {\n const name = row.schema_name as string;\n\n // Skip our own schema (it was just created or is about to be)\n if (name === this.schemaForTesting) {\n continue;\n }\n\n const age = this.parseTestSchemaAge(name, now);\n if (age !== undefined && age > maxAge) {\n this.log.warn(\n `Dropping stale test schema '${name}' (age: ${Math.round(age / 60_000)}min) ...`,\n );\n await this.execute(\n sql`DROP SCHEMA IF EXISTS ${sql.raw(name)} CASCADE`,\n );\n }\n }\n } finally {\n await this.execute(\n sql`SELECT pg_advisory_unlock(hashtext('alepha:test:schema:cleanup'))`,\n );\n }\n } catch (error) {\n // Don't fail test setup if stale cleanup fails\n this.log.warn(\"Failed to clean up stale test schemas\", { error });\n }\n }\n\n /**\n * Parse the age in milliseconds from a test schema name.\n * Format: test_alepha_{epoch_seconds}_{random8}\n * Returns undefined if the name doesn't match the expected format.\n */\n protected parseTestSchemaAge(name: string, now: number): number | undefined {\n const parts = name.split(\"_\");\n // test_alepha_{epoch}_{random} → [\"test\", \"alepha\", epoch, random]\n if (parts.length !== 4 || parts[0] !== \"test\" || parts[1] !== \"alepha\") {\n return undefined;\n }\n\n const epoch = Number(parts[2]);\n if (!Number.isFinite(epoch) || epoch <= 0) {\n return undefined;\n }\n\n return now - epoch * 1000;\n }\n}\n","import { AlephaError } from \"alepha\";\nimport { sql } from \"drizzle-orm\";\nimport type { BunSQLDatabase } from \"drizzle-orm/bun-sql\";\nimport type { PgDatabase } from \"drizzle-orm/pg-core\";\nimport { PostgresProvider } from \"./PostgresProvider.ts\";\n\n/**\n * Bun PostgreSQL provider using Drizzle ORM with Bun's native SQL client.\n *\n * This provider uses Bun's built-in SQL class for PostgreSQL connections,\n * which provides excellent performance on the Bun runtime.\n *\n * @example\n * ```ts\n * // Set DATABASE_URL environment variable\n * // DATABASE_URL=postgres://user:password@localhost:5432/database\n *\n * // Or configure programmatically\n * alepha.with({\n * provide: DatabaseProvider,\n * use: BunPostgresProvider,\n * });\n * ```\n */\nexport class BunPostgresProvider extends PostgresProvider {\n protected client?: Bun.SQL;\n protected bunDb?: BunSQLDatabase;\n\n /**\n * Get the Drizzle Postgres database instance.\n */\n public override get db(): PgDatabase<any> {\n if (!this.bunDb) {\n throw new AlephaError(\"Database not initialized\");\n }\n\n return this.bunDb as unknown as PgDatabase<any>;\n }\n\n protected override async executeMigrations(\n migrationsFolder: string,\n ): Promise<void> {\n if (this.schema !== \"public\") {\n await this.db.execute(\n sql.raw(`SET search_path TO ${this.schema}, public`),\n );\n }\n const { migrate } = await import(\"drizzle-orm/bun-sql/migrator\");\n await migrate(this.bunDb!, {\n migrationsFolder,\n migrationsTable: this.migrationsTable,\n });\n }\n\n // -------------------------------------------------------------------------------------------------------------------\n\n public async connect(): Promise<void> {\n this.log.debug(\"Connect ..\");\n\n // Check if we're running in Bun\n if (typeof Bun === \"undefined\") {\n throw new AlephaError(\n \"BunPostgresProvider requires the Bun runtime. Use NodePostgresProvider for Node.js.\",\n );\n }\n\n const { drizzle } = await import(\"drizzle-orm/bun-sql\");\n\n // Create Bun SQL client with pool options\n const bunOptions: Record<string, any> = { url: this.url };\n if (this.pgEnv.POOL_MAX != null) {\n bunOptions.max = this.pgEnv.POOL_MAX;\n }\n if (this.pgEnv.POOL_IDLE_TIMEOUT != null) {\n bunOptions.idleTimeout = this.pgEnv.POOL_IDLE_TIMEOUT;\n }\n if (this.pgEnv.POOL_CONNECT_TIMEOUT != null) {\n bunOptions.connectionTimeout = this.pgEnv.POOL_CONNECT_TIMEOUT;\n }\n this.client = new Bun.SQL(bunOptions);\n\n // Test connection\n await this.client.unsafe(\"SELECT 1\");\n\n this.bunDb = drizzle({\n client: this.client,\n logger: {\n logQuery: (query: string, params: unknown[]) => {\n this.log.trace(query, { params });\n },\n },\n });\n\n // Set search_path so schema-free migration SQL resolves to the correct schema.\n if (this.schema !== \"public\") {\n await this.client.unsafe(`SET search_path TO ${this.schema}, public`);\n }\n\n this.log.info(\"Connection OK\");\n }\n\n public async close(): Promise<void> {\n if (this.client) {\n this.log.debug(\"Close...\");\n\n await this.client.close();\n\n this.client = undefined;\n this.bunDb = undefined;\n\n this.log.info(\"Connection closed\");\n }\n }\n}\n","import { mkdir } from \"node:fs/promises\";\nimport { createRequire } from \"node:module\";\nimport type { PGlite } from \"@electric-sql/pglite\";\nimport { $env, $hook, $inject, AlephaError } from \"alepha\";\nimport { DatabaseProvider, databaseEnvSchema, type SQLLike } from \"alepha/orm\";\nimport { sql } from \"drizzle-orm\";\nimport type { PgliteDatabase } from \"drizzle-orm/pglite\";\nimport { migrate } from \"drizzle-orm/pglite/migrator\";\nimport { postgresEnvSchema } from \"../schemas/postgresEnvSchema.ts\";\nimport { PostgresModelBuilder } from \"../services/PostgresModelBuilder.ts\";\n\nexport interface PgLiteModule {\n PGlite: typeof PGlite;\n}\n\nexport class PglitePostgresProvider extends DatabaseProvider {\n public static importPglite(): PgLiteModule | undefined {\n try {\n return createRequire(import.meta.url)(\"@electric-sql/pglite\");\n } catch {\n // ignored\n }\n }\n\n public override get schema(): string {\n return this.pgEnv.POSTGRES_SCHEMA ?? \"public\";\n }\n\n protected readonly env = $env(databaseEnvSchema);\n protected readonly pgEnv = $env(postgresEnvSchema);\n protected readonly builder = $inject(PostgresModelBuilder);\n\n protected client?: PGlite;\n protected pglite?: PgliteDatabase;\n\n public get name() {\n return \"postgres\";\n }\n\n public get driver() {\n return \"pglite\";\n }\n\n public override readonly dialect = \"postgresql\";\n\n public override get supportsTransactions(): boolean {\n return false;\n }\n\n public override get url(): string {\n let path = this.env.DATABASE_URL;\n\n if (!path) {\n if (this.alepha.isTest()) {\n path = \":memory:\"; // use in-memory database for tests by default\n } else {\n path = \"node_modules/.alepha/pglite\"; // default path for dev\n }\n } else {\n if (path.includes(\":memory:\")) {\n // like postgres://:memory: or pglite://:memory:\n path = \":memory:\";\n } else if (path.startsWith(\"file://\")) {\n path = path.replace(\"file://\", \"\");\n }\n }\n\n return path;\n }\n\n public override get db(): PgliteDatabase {\n if (!this.pglite) {\n throw new AlephaError(\"Database not initialized\");\n }\n\n return this.pglite;\n }\n\n public override async execute(\n statement: SQLLike,\n ): Promise<Array<Record<string, unknown>>> {\n const { rows } = await this.db.execute(statement);\n return rows;\n }\n\n protected readonly onStart = $hook({\n on: \"start\",\n handler: async () => {\n if (Object.keys(this.kit.getModels(this)).length === 0) {\n return;\n }\n\n const module = PglitePostgresProvider.importPglite();\n if (!module) {\n throw new AlephaError(\n \"@electric-sql/pglite is not installed. Please install it to use the pglite driver.\",\n );\n }\n\n const { drizzle } = createRequire(import.meta.url)(\"drizzle-orm/pglite\");\n const path = this.url;\n\n if (path !== \":memory:\") {\n await mkdir(path, { recursive: true }).catch(() => null);\n this.client = new module.PGlite(path);\n } else {\n this.client = new module.PGlite();\n }\n\n this.pglite = drizzle({\n client: this.client,\n });\n\n await this.migrate();\n\n this.log.info(`Using PGlite database at ${path}`);\n },\n });\n\n protected readonly onStop = $hook({\n on: \"stop\",\n handler: async () => {\n if (this.client) {\n this.log.debug(\"Closing PGlite connection...\");\n await this.client.close();\n this.client = undefined;\n this.pglite = undefined;\n this.log.info(\"PGlite connection closed\");\n }\n },\n });\n\n protected async executeMigrations(migrationsFolder: string): Promise<void> {\n // Set search_path so schema-free migration SQL resolves to the correct schema.\n // PGlite uses a single connection, so SET persists through the migration.\n if (this.schema !== \"public\") {\n await this.db.execute(\n sql.raw(`SET search_path TO ${this.schema}, public`),\n );\n }\n await migrate(this.db, {\n migrationsFolder,\n migrationsTable: this.migrationsTable,\n });\n }\n}\n","import { $module, type Alepha } from \"alepha\";\nimport { AlephaOrm, DatabaseProvider, databaseEnvSchema } from \"alepha/orm\";\nimport { BunPostgresProvider } from \"./providers/BunPostgresProvider.ts\";\nimport { PglitePostgresProvider } from \"./providers/PglitePostgresProvider.ts\";\nimport { PostgresProvider } from \"./providers/PostgresProvider.ts\";\nimport { PostgresModelBuilder } from \"./services/PostgresModelBuilder.ts\";\n\nexport * from \"./providers/BunPostgresProvider.ts\";\nexport * from \"./providers/PglitePostgresProvider.ts\";\nexport * from \"./providers/PostgresProvider.ts\";\nexport * from \"./schemas/postgresEnvSchema.ts\";\nexport * from \"./services/PostgresModelBuilder.ts\";\nexport * from \"./types/byte.ts\";\n\nexport const AlephaOrmPostgres = $module({\n name: \"alepha.orm.postgres\",\n primitives: [],\n services: [\n PostgresProvider,\n BunPostgresProvider,\n PglitePostgresProvider,\n PostgresModelBuilder,\n ],\n register: (alepha: Alepha) => {\n const env = alepha.parseEnv(databaseEnvSchema);\n\n const url = env.DATABASE_URL;\n\n if (url?.startsWith(\"pglite:\")) {\n alepha.with({\n optional: true,\n provide: DatabaseProvider,\n use: PglitePostgresProvider,\n });\n return;\n }\n\n if (url?.startsWith(\"postgres:\")) {\n alepha.with({\n optional: true,\n provide: DatabaseProvider,\n use: BunPostgresProvider,\n });\n return;\n }\n\n alepha.with(AlephaOrm);\n },\n});\n"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import * as alepha from "alepha";
2
2
  import { Static, TObject, TSchema } from "alepha";
3
- import { DatabaseProvider, EntityPrimitive, FromSchema, ModelBuilder, SQLLike, SequencePrimitive } from "alepha/orm";
3
+ import { DatabaseProvider, EntityPrimitive, FromSchema, ModelBuilder, SQLLike, SequencePrimitive, ViewPrimitive } from "alepha/orm";
4
4
  import { BuildExtraConfigColumns } from "drizzle-orm";
5
5
  import * as pg from "drizzle-orm/pg-core";
6
6
  import { PgDatabase, PgSchema, PgTableExtraConfigValue } from "drizzle-orm/pg-core";
@@ -19,6 +19,10 @@ declare class PostgresModelBuilder extends ModelBuilder {
19
19
  schemas: Map<string, unknown>;
20
20
  schema: string;
21
21
  }): void;
22
+ buildView(view: ViewPrimitive, options: {
23
+ tables: Map<string, unknown>;
24
+ schema: string;
25
+ }): void;
22
26
  buildSequence(sequence: SequencePrimitive, options: {
23
27
  sequences: Map<string, unknown>;
24
28
  schema: string;
@@ -46,25 +50,6 @@ declare class PostgresModelBuilder extends ModelBuilder {
46
50
  }
47
51
  //#endregion
48
52
  //#region ../../src/orm/postgres/providers/PostgresProvider.d.ts
49
- declare const envSchema: alepha.TObject<{
50
- /**
51
- * Main configuration for database connection.
52
- * Accept a string in the format of a Postgres connection URL.
53
- * Example: postgres://user:password@localhost:5432/database
54
- * or
55
- * Example: postgres://user:password@localhost:5432/database?sslmode=require
56
- */
57
- DATABASE_URL: alepha.TOptional<alepha.TString>;
58
- /**
59
- * In addition to the DATABASE_URL, you can specify the postgres schema name.
60
- *
61
- * It will monkey patch drizzle tables.
62
- */
63
- POSTGRES_SCHEMA: alepha.TOptional<alepha.TString>;
64
- }>;
65
- declare module "alepha" {
66
- interface Env extends Partial<Static<typeof envSchema>> {}
67
- }
68
53
  /**
69
54
  * Abstract base class for PostgreSQL database providers.
70
55
  *
@@ -79,7 +64,13 @@ declare module "alepha" {
79
64
  declare abstract class PostgresProvider extends DatabaseProvider {
80
65
  protected readonly env: {
81
66
  DATABASE_URL?: string | undefined;
67
+ DATABASE_SYNC?: boolean | undefined;
68
+ };
69
+ protected readonly pgEnv: {
82
70
  POSTGRES_SCHEMA?: string | undefined;
71
+ POOL_MAX?: number | undefined;
72
+ POOL_IDLE_TIMEOUT?: number | undefined;
73
+ POOL_CONNECT_TIMEOUT?: number | undefined;
83
74
  };
84
75
  protected readonly builder: PostgresModelBuilder;
85
76
  readonly dialect = "postgresql";
@@ -771,7 +762,13 @@ declare class PglitePostgresProvider extends DatabaseProvider {
771
762
  get schema(): string;
772
763
  protected readonly env: {
773
764
  DATABASE_URL?: string | undefined;
765
+ DATABASE_SYNC?: boolean | undefined;
766
+ };
767
+ protected readonly pgEnv: {
774
768
  POSTGRES_SCHEMA?: string | undefined;
769
+ POOL_MAX?: number | undefined;
770
+ POOL_IDLE_TIMEOUT?: number | undefined;
771
+ POOL_CONNECT_TIMEOUT?: number | undefined;
775
772
  };
776
773
  protected readonly builder: PostgresModelBuilder;
777
774
  protected client?: PGlite;
@@ -779,6 +776,7 @@ declare class PglitePostgresProvider extends DatabaseProvider {
779
776
  get name(): string;
780
777
  get driver(): string;
781
778
  readonly dialect = "postgresql";
779
+ get supportsTransactions(): boolean;
782
780
  get url(): string;
783
781
  get db(): PgliteDatabase;
784
782
  execute(statement: SQLLike): Promise<Array<Record<string, unknown>>>;
@@ -787,6 +785,34 @@ declare class PglitePostgresProvider extends DatabaseProvider {
787
785
  protected executeMigrations(migrationsFolder: string): Promise<void>;
788
786
  }
789
787
  //#endregion
788
+ //#region ../../src/orm/postgres/schemas/postgresEnvSchema.d.ts
789
+ /**
790
+ * PostgreSQL-specific environment schema.
791
+ *
792
+ * Additional env vars for PostgreSQL providers on top of `databaseEnvSchema`.
793
+ */
794
+ declare const postgresEnvSchema: alepha.TObject<{
795
+ /**
796
+ * PostgreSQL schema name (defaults to `"public"` when unset).
797
+ */
798
+ POSTGRES_SCHEMA: alepha.TOptional<alepha.TString>;
799
+ /**
800
+ * Maximum number of connections in the pool.
801
+ */
802
+ POOL_MAX: alepha.TOptional<alepha.TInteger>;
803
+ /**
804
+ * Seconds a connection can be idle before being closed.
805
+ */
806
+ POOL_IDLE_TIMEOUT: alepha.TOptional<alepha.TInteger>;
807
+ /**
808
+ * Seconds to wait when establishing a new connection.
809
+ */
810
+ POOL_CONNECT_TIMEOUT: alepha.TOptional<alepha.TInteger>;
811
+ }>;
812
+ declare module "alepha" {
813
+ interface Env extends Partial<Static<typeof postgresEnvSchema>> {}
814
+ } //# sourceMappingURL=postgresEnvSchema.d.ts.map
815
+ //#endregion
790
816
  //#region ../../src/orm/postgres/types/byte.d.ts
791
817
  /**
792
818
  * Postgres bytea type.
@@ -821,5 +847,5 @@ declare const byte: {
821
847
  //#region ../../src/orm/postgres/index.d.ts
822
848
  declare const AlephaOrmPostgres: alepha.Service<alepha.Module>;
823
849
  //#endregion
824
- export { AlephaOrmPostgres, BunPostgresProvider, CloudflareHyperdriveProvider, NodePostgresProvider, PgLiteModule, PglitePostgresProvider, PostgresModelBuilder, PostgresProvider, byte };
850
+ export { AlephaOrmPostgres, BunPostgresProvider, CloudflareHyperdriveProvider, NodePostgresProvider, PgLiteModule, PglitePostgresProvider, PostgresModelBuilder, PostgresProvider, byte, postgresEnvSchema };
825
851
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","names":["Modes","text","binary","Mode","BufferParameter","ArrayBuffer","ArrayBufferView","MessageName","BackendMessage","name","length","parseComplete","bindComplete","closeComplete","noData","portalSuspended","replicationStart","emptyQuery","copyDone","AuthenticationOk","constructor","AuthenticationCleartextPassword","AuthenticationMD5Password","Uint8Array","salt","AuthenticationSASL","mechanisms","AuthenticationSASLContinue","data","AuthenticationSASLFinal","AuthenticationMessage","NoticeOrError","message","severity","code","detail","hint","position","internalPosition","internalQuery","where","schema","table","column","dataType","constraint","file","line","routine","DatabaseError","Error","CopyDataMessage","chunk","CopyResponse","columnTypes","columnCount","Field","tableID","columnID","dataTypeID","dataTypeSize","dataTypeModifier","format","RowDescriptionMessage","fieldCount","fields","ParameterDescriptionMessage","parameterCount","dataTypeIDs","ParameterStatusMessage","parameterName","parameterValue","BackendKeyDataMessage","processID","secretKey","NotificationResponseMessage","processId","channel","payload","ReadyForQueryMessage","status","CommandCompleteMessage","DataRowMessage","NoticeMessage","messages_AuthenticationCleartextPassword","messages_AuthenticationMD5Password","messages_AuthenticationMessage","messages_AuthenticationOk","messages_AuthenticationSASL","messages_AuthenticationSASLContinue","messages_AuthenticationSASLFinal","messages_BackendKeyDataMessage","messages_BackendMessage","messages_CommandCompleteMessage","messages_CopyDataMessage","messages_CopyResponse","messages_DataRowMessage","messages_DatabaseError","messages_Field","messages_MessageName","messages_NoticeMessage","messages_NotificationResponseMessage","messages_ParameterDescriptionMessage","messages_ParameterStatusMessage","messages_ReadyForQueryMessage","messages_RowDescriptionMessage","messages_bindComplete","messages_closeComplete","messages_copyDone","messages_emptyQuery","messages_noData","messages_parseComplete","messages_portalSuspended","messages_replicationStart","messages","IDBFS","Emscripten","FileSystemType","IDBDatabase","Record","quit","dbs","FS","filesystems","MEMFS","NODEFS","PostgresMod","EmscriptenModule","Array","Blob","Promise","Omit","preInit","mod","preRun","postRun","FD_BUFFER_MAX","WASM_PREFIX","INITIAL_MEMORY","pg_extensions","_pgl_initdb","_pgl_backend","_pgl_shutdown","_interactive_write","msgLength","_interactive_one","peek","_set_read_write_cbs","read_cb","write_cb","addFunction","ptr","cb","signature","removeFunction","f","PostgresFactory","T","Partial","moduleOverrides","_default","postgresMod_FS","postgresMod_PostgresMod","postgresMod","default","DumpTarCompressionOptions","PGDATA","FsType","Filesystem","PGlite","File","init","pg","emscriptenOptions","emscriptenOpts","syncToFs","relaxedDurability","initialSyncFs","dumpTar","dbname","compression","closeFs","EmscriptenBuiltinFilesystem","dataDir","_relaxedDurability","BaseFilesystem","debug","FsStats","chmod","path","mode","close","fd","fstat","lstat","mkdir","recursive","options","open","flags","readdir","read","buffer","offset","rename","oldPath","newPath","rmdir","truncate","len","unlink","utimes","atime","mtime","writeFile","encoding","flag","write","dev","ino","nlink","uid","gid","rdev","size","blksize","blocks","ctime","ERRNO_CODES","EBADF","EBADFD","EEXIST","EINVAL","EISDIR","ENODEV","ENOENT","ENOTDIR","ENOTEMPTY","FilesystemType","DebugLevel","RowMode","ParserOptions","pgType","value","SerializerOptions","QueryOptions","rowMode","parsers","serializers","blob","onNotice","notice","paramTypes","ExecProtocolOptions","throwOnError","ExtensionSetupResult","TNamespace","URL","namespaceObj","bundlePath","ExtensionSetup","PGliteInterface","clientOnly","Extension","setup","ExtensionNamespace","Extensions","namespace","InitializedExtensions","TExtensions","K","ExecProtocolResult","DumpDataDirResult","tarball","extension","filename","PGliteOptions","WebAssembly","Module","username","database","fs","extensions","loadDataDir","initialMemory","wasmModule","fsBundle","Results","TemplateStringsArray","DescribeQueryResult","Transaction","waitReady","ready","closed","query","params","sql","sqlStrings","exec","describeQuery","transaction","tx","callback","execProtocolRaw","execProtocol","runExclusive","fn","listen","unlisten","onNotification","offNotification","dumpDataDir","refreshArrayTypes","PGliteInterfaceExtensions","E","ReturnType","Awaited","N","Row","key","rows","affectedRows","rollback","Serializer","Parser","queryParams","serializer","resultFields","parser","BOOL","BYTEA","CHAR","INT8","INT2","INT4","REGPROC","TEXT","OID","TID","XID","CID","JSON","XML","PG_NODE_TREE","SMGR","PATH","POLYGON","CIDR","FLOAT4","FLOAT8","ABSTIME","RELTIME","TINTERVAL","CIRCLE","MACADDR8","MONEY","MACADDR","INET","ACLITEM","BPCHAR","VARCHAR","DATE","TIME","TIMESTAMP","TIMESTAMPTZ","INTERVAL","TIMETZ","BIT","VARBIT","NUMERIC","REFCURSOR","REGPROCEDURE","REGOPER","REGOPERATOR","REGCLASS","REGTYPE","UUID","TXID_SNAPSHOT","PG_LSN","PG_NDISTINCT","PG_DEPENDENCIES","TSVECTOR","TSQUERY","GTSVECTOR","REGCONFIG","REGDICTIONARY","JSONB","REGNAMESPACE","REGROLE","types","Date","string","to","from","serialize","x","parse","number","bigint","json","boolean","date","bytea","typeId","TypeHandler","TypeHandlers","parseType","type","arraySerializer","xs","typarray","arrayParser","types$1_ABSTIME","types$1_ACLITEM","types$1_BIT","types$1_BOOL","types$1_BPCHAR","types$1_BYTEA","types$1_CHAR","types$1_CID","types$1_CIDR","types$1_CIRCLE","types$1_DATE","types$1_FLOAT4","types$1_FLOAT8","types$1_GTSVECTOR","types$1_INET","types$1_INT2","types$1_INT4","types$1_INT8","types$1_INTERVAL","types$1_JSON","types$1_JSONB","types$1_MACADDR","types$1_MACADDR8","types$1_MONEY","types$1_NUMERIC","types$1_OID","types$1_PATH","types$1_PG_DEPENDENCIES","types$1_PG_LSN","types$1_PG_NDISTINCT","types$1_PG_NODE_TREE","types$1_POLYGON","types$1_Parser","types$1_REFCURSOR","types$1_REGCLASS","types$1_REGCONFIG","types$1_REGDICTIONARY","types$1_REGNAMESPACE","types$1_REGOPER","types$1_REGOPERATOR","types$1_REGPROC","types$1_REGPROCEDURE","types$1_REGROLE","types$1_REGTYPE","types$1_RELTIME","types$1_SMGR","types$1_Serializer","types$1_TEXT","types$1_TID","types$1_TIME","types$1_TIMESTAMP","types$1_TIMESTAMPTZ","types$1_TIMETZ","types$1_TINTERVAL","types$1_TSQUERY","types$1_TSVECTOR","types$1_TXID_SNAPSHOT","types$1_TypeHandler","types$1_TypeHandlers","types$1_UUID","types$1_VARBIT","types$1_VARCHAR","types$1_XID","types$1_XML","types$1_arrayParser","types$1_arraySerializer","types$1_parseType","types$1_parsers","types$1_serializers","types$1_types","types$1","BasePGlite","force","Pick","private","execProtocolStream","_handleBlob","_getWrittenBlob","_cleanupBlob","_checkReady","_runExclusiveQuery","_runExclusiveTransaction","_initArrayTypes","O","Symbol","asyncDispose","AsyncDisposable","DEFAULT_RECV_BUF_SIZE","MAX_BUFFER_SIZE","create","execProtocolRawSync","isInTransaction","clone","_runExclusiveListen","A","B","C","D","F","G","I","M","P","Q","R","S","W","a","b","c","d","e","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","y","z"],"sources":["../../../src/orm/postgres/services/PostgresModelBuilder.ts","../../../src/orm/postgres/providers/PostgresProvider.ts","../../../src/orm/postgres/providers/BunPostgresProvider.ts","../../../src/orm/postgres/providers/CloudflareHyperdriveProvider.ts","../../../src/orm/postgres/providers/NodePostgresProvider.ts","../../../../../node_modules/@electric-sql/pglite/dist/pglite-CntadC_p.d.ts","../../../src/orm/postgres/providers/PglitePostgresProvider.ts","../../../src/orm/postgres/types/byte.ts","../../../src/orm/postgres/index.ts"],"x_google_ignoreList":[5],"mappings":"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"}
1
+ {"version":3,"file":"index.d.ts","names":["Modes","text","binary","Mode","BufferParameter","ArrayBuffer","ArrayBufferView","MessageName","BackendMessage","name","length","parseComplete","bindComplete","closeComplete","noData","portalSuspended","replicationStart","emptyQuery","copyDone","AuthenticationOk","constructor","AuthenticationCleartextPassword","AuthenticationMD5Password","Uint8Array","salt","AuthenticationSASL","mechanisms","AuthenticationSASLContinue","data","AuthenticationSASLFinal","AuthenticationMessage","NoticeOrError","message","severity","code","detail","hint","position","internalPosition","internalQuery","where","schema","table","column","dataType","constraint","file","line","routine","DatabaseError","Error","CopyDataMessage","chunk","CopyResponse","columnTypes","columnCount","Field","tableID","columnID","dataTypeID","dataTypeSize","dataTypeModifier","format","RowDescriptionMessage","fieldCount","fields","ParameterDescriptionMessage","parameterCount","dataTypeIDs","ParameterStatusMessage","parameterName","parameterValue","BackendKeyDataMessage","processID","secretKey","NotificationResponseMessage","processId","channel","payload","ReadyForQueryMessage","status","CommandCompleteMessage","DataRowMessage","NoticeMessage","messages_AuthenticationCleartextPassword","messages_AuthenticationMD5Password","messages_AuthenticationMessage","messages_AuthenticationOk","messages_AuthenticationSASL","messages_AuthenticationSASLContinue","messages_AuthenticationSASLFinal","messages_BackendKeyDataMessage","messages_BackendMessage","messages_CommandCompleteMessage","messages_CopyDataMessage","messages_CopyResponse","messages_DataRowMessage","messages_DatabaseError","messages_Field","messages_MessageName","messages_NoticeMessage","messages_NotificationResponseMessage","messages_ParameterDescriptionMessage","messages_ParameterStatusMessage","messages_ReadyForQueryMessage","messages_RowDescriptionMessage","messages_bindComplete","messages_closeComplete","messages_copyDone","messages_emptyQuery","messages_noData","messages_parseComplete","messages_portalSuspended","messages_replicationStart","messages","IDBFS","Emscripten","FileSystemType","IDBDatabase","Record","quit","dbs","FS","filesystems","MEMFS","NODEFS","PostgresMod","EmscriptenModule","Array","Blob","Promise","Omit","preInit","mod","preRun","postRun","FD_BUFFER_MAX","WASM_PREFIX","INITIAL_MEMORY","pg_extensions","_pgl_initdb","_pgl_backend","_pgl_shutdown","_interactive_write","msgLength","_interactive_one","peek","_set_read_write_cbs","read_cb","write_cb","addFunction","ptr","cb","signature","removeFunction","f","PostgresFactory","T","Partial","moduleOverrides","_default","postgresMod_FS","postgresMod_PostgresMod","postgresMod","default","DumpTarCompressionOptions","PGDATA","FsType","Filesystem","PGlite","File","init","pg","emscriptenOptions","emscriptenOpts","syncToFs","relaxedDurability","initialSyncFs","dumpTar","dbname","compression","closeFs","EmscriptenBuiltinFilesystem","dataDir","_relaxedDurability","BaseFilesystem","debug","FsStats","chmod","path","mode","close","fd","fstat","lstat","mkdir","recursive","options","open","flags","readdir","read","buffer","offset","rename","oldPath","newPath","rmdir","truncate","len","unlink","utimes","atime","mtime","writeFile","encoding","flag","write","dev","ino","nlink","uid","gid","rdev","size","blksize","blocks","ctime","ERRNO_CODES","EBADF","EBADFD","EEXIST","EINVAL","EISDIR","ENODEV","ENOENT","ENOTDIR","ENOTEMPTY","FilesystemType","DebugLevel","RowMode","ParserOptions","pgType","value","SerializerOptions","QueryOptions","rowMode","parsers","serializers","blob","onNotice","notice","paramTypes","ExecProtocolOptions","throwOnError","ExtensionSetupResult","TNamespace","URL","namespaceObj","bundlePath","ExtensionSetup","PGliteInterface","clientOnly","Extension","setup","ExtensionNamespace","Extensions","namespace","InitializedExtensions","TExtensions","K","ExecProtocolResult","DumpDataDirResult","tarball","extension","filename","PGliteOptions","WebAssembly","Module","username","database","fs","extensions","loadDataDir","initialMemory","wasmModule","fsBundle","Results","TemplateStringsArray","DescribeQueryResult","Transaction","waitReady","ready","closed","query","params","sql","sqlStrings","exec","describeQuery","transaction","tx","callback","execProtocolRaw","execProtocol","runExclusive","fn","listen","unlisten","onNotification","offNotification","dumpDataDir","refreshArrayTypes","PGliteInterfaceExtensions","E","ReturnType","Awaited","N","Row","key","rows","affectedRows","rollback","Serializer","Parser","queryParams","serializer","resultFields","parser","BOOL","BYTEA","CHAR","INT8","INT2","INT4","REGPROC","TEXT","OID","TID","XID","CID","JSON","XML","PG_NODE_TREE","SMGR","PATH","POLYGON","CIDR","FLOAT4","FLOAT8","ABSTIME","RELTIME","TINTERVAL","CIRCLE","MACADDR8","MONEY","MACADDR","INET","ACLITEM","BPCHAR","VARCHAR","DATE","TIME","TIMESTAMP","TIMESTAMPTZ","INTERVAL","TIMETZ","BIT","VARBIT","NUMERIC","REFCURSOR","REGPROCEDURE","REGOPER","REGOPERATOR","REGCLASS","REGTYPE","UUID","TXID_SNAPSHOT","PG_LSN","PG_NDISTINCT","PG_DEPENDENCIES","TSVECTOR","TSQUERY","GTSVECTOR","REGCONFIG","REGDICTIONARY","JSONB","REGNAMESPACE","REGROLE","types","Date","string","to","from","serialize","x","parse","number","bigint","json","boolean","date","bytea","typeId","TypeHandler","TypeHandlers","parseType","type","arraySerializer","xs","typarray","arrayParser","types$1_ABSTIME","types$1_ACLITEM","types$1_BIT","types$1_BOOL","types$1_BPCHAR","types$1_BYTEA","types$1_CHAR","types$1_CID","types$1_CIDR","types$1_CIRCLE","types$1_DATE","types$1_FLOAT4","types$1_FLOAT8","types$1_GTSVECTOR","types$1_INET","types$1_INT2","types$1_INT4","types$1_INT8","types$1_INTERVAL","types$1_JSON","types$1_JSONB","types$1_MACADDR","types$1_MACADDR8","types$1_MONEY","types$1_NUMERIC","types$1_OID","types$1_PATH","types$1_PG_DEPENDENCIES","types$1_PG_LSN","types$1_PG_NDISTINCT","types$1_PG_NODE_TREE","types$1_POLYGON","types$1_Parser","types$1_REFCURSOR","types$1_REGCLASS","types$1_REGCONFIG","types$1_REGDICTIONARY","types$1_REGNAMESPACE","types$1_REGOPER","types$1_REGOPERATOR","types$1_REGPROC","types$1_REGPROCEDURE","types$1_REGROLE","types$1_REGTYPE","types$1_RELTIME","types$1_SMGR","types$1_Serializer","types$1_TEXT","types$1_TID","types$1_TIME","types$1_TIMESTAMP","types$1_TIMESTAMPTZ","types$1_TIMETZ","types$1_TINTERVAL","types$1_TSQUERY","types$1_TSVECTOR","types$1_TXID_SNAPSHOT","types$1_TypeHandler","types$1_TypeHandlers","types$1_UUID","types$1_VARBIT","types$1_VARCHAR","types$1_XID","types$1_XML","types$1_arrayParser","types$1_arraySerializer","types$1_parseType","types$1_parsers","types$1_serializers","types$1_types","types$1","BasePGlite","force","Pick","private","execProtocolStream","_handleBlob","_getWrittenBlob","_cleanupBlob","_checkReady","_runExclusiveQuery","_runExclusiveTransaction","_initArrayTypes","O","Symbol","asyncDispose","AsyncDisposable","DEFAULT_RECV_BUF_SIZE","MAX_BUFFER_SIZE","create","execProtocolRawSync","isInTransaction","clone","_runExclusiveListen","A","B","C","D","F","G","I","M","P","Q","R","S","W","a","b","c","d","e","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","y","z"],"sources":["../../../src/orm/postgres/services/PostgresModelBuilder.ts","../../../src/orm/postgres/providers/PostgresProvider.ts","../../../src/orm/postgres/providers/BunPostgresProvider.ts","../../../src/orm/postgres/providers/CloudflareHyperdriveProvider.ts","../../../src/orm/postgres/providers/NodePostgresProvider.ts","../../../../../node_modules/@electric-sql/pglite/dist/pglite-CntadC_p.d.ts","../../../src/orm/postgres/providers/PglitePostgresProvider.ts","../../../src/orm/postgres/schemas/postgresEnvSchema.ts","../../../src/orm/postgres/types/byte.ts","../../../src/orm/postgres/index.ts"],"x_google_ignoreList":[5],"mappings":"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"}