@warlock.js/cascade 4.0.156 → 4.0.158

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 (689) hide show
  1. package/package.json +4 -4
  2. package/cjs/context/database-data-source-context.d.ts +0 -29
  3. package/cjs/context/database-data-source-context.d.ts.map +0 -1
  4. package/cjs/context/database-data-source-context.js +0 -28
  5. package/cjs/context/database-data-source-context.js.map +0 -1
  6. package/cjs/context/database-transaction-context.d.ts +0 -35
  7. package/cjs/context/database-transaction-context.d.ts.map +0 -1
  8. package/cjs/context/database-transaction-context.js +0 -40
  9. package/cjs/context/database-transaction-context.js.map +0 -1
  10. package/cjs/contracts/database-driver.contract.d.ts +0 -450
  11. package/cjs/contracts/database-driver.contract.d.ts.map +0 -1
  12. package/cjs/contracts/database-id-generator.contract.d.ts +0 -109
  13. package/cjs/contracts/database-id-generator.contract.d.ts.map +0 -1
  14. package/cjs/contracts/database-remover.contract.d.ts +0 -104
  15. package/cjs/contracts/database-remover.contract.d.ts.map +0 -1
  16. package/cjs/contracts/database-restorer.contract.d.ts +0 -143
  17. package/cjs/contracts/database-restorer.contract.d.ts.map +0 -1
  18. package/cjs/contracts/database-writer.contract.d.ts +0 -119
  19. package/cjs/contracts/database-writer.contract.d.ts.map +0 -1
  20. package/cjs/contracts/driver-blueprint.contract.d.ts +0 -49
  21. package/cjs/contracts/driver-blueprint.contract.d.ts.map +0 -1
  22. package/cjs/contracts/index.d.ts +0 -10
  23. package/cjs/contracts/index.d.ts.map +0 -1
  24. package/cjs/contracts/migration-driver.contract.d.ts +0 -522
  25. package/cjs/contracts/migration-driver.contract.d.ts.map +0 -1
  26. package/cjs/contracts/query-builder.contract.d.ts +0 -1609
  27. package/cjs/contracts/query-builder.contract.d.ts.map +0 -1
  28. package/cjs/contracts/sync-adapter.contract.d.ts +0 -58
  29. package/cjs/contracts/sync-adapter.contract.d.ts.map +0 -1
  30. package/cjs/data-source/data-source-registry.d.ts +0 -108
  31. package/cjs/data-source/data-source-registry.d.ts.map +0 -1
  32. package/cjs/data-source/data-source-registry.js +0 -145
  33. package/cjs/data-source/data-source-registry.js.map +0 -1
  34. package/cjs/data-source/data-source.d.ts +0 -147
  35. package/cjs/data-source/data-source.d.ts.map +0 -1
  36. package/cjs/data-source/data-source.js +0 -83
  37. package/cjs/data-source/data-source.js.map +0 -1
  38. package/cjs/database-dirty-tracker.d.ts +0 -252
  39. package/cjs/database-dirty-tracker.d.ts.map +0 -1
  40. package/cjs/database-dirty-tracker.js +0 -386
  41. package/cjs/database-dirty-tracker.js.map +0 -1
  42. package/cjs/drivers/mongodb/mongodb-blueprint.d.ts +0 -30
  43. package/cjs/drivers/mongodb/mongodb-blueprint.d.ts.map +0 -1
  44. package/cjs/drivers/mongodb/mongodb-blueprint.js +0 -51
  45. package/cjs/drivers/mongodb/mongodb-blueprint.js.map +0 -1
  46. package/cjs/drivers/mongodb/mongodb-driver.d.ts +0 -324
  47. package/cjs/drivers/mongodb/mongodb-driver.d.ts.map +0 -1
  48. package/cjs/drivers/mongodb/mongodb-driver.js +0 -799
  49. package/cjs/drivers/mongodb/mongodb-driver.js.map +0 -1
  50. package/cjs/drivers/mongodb/mongodb-id-generator.d.ts +0 -116
  51. package/cjs/drivers/mongodb/mongodb-id-generator.d.ts.map +0 -1
  52. package/cjs/drivers/mongodb/mongodb-id-generator.js +0 -149
  53. package/cjs/drivers/mongodb/mongodb-id-generator.js.map +0 -1
  54. package/cjs/drivers/mongodb/mongodb-migration-driver.d.ts +0 -317
  55. package/cjs/drivers/mongodb/mongodb-migration-driver.d.ts.map +0 -1
  56. package/cjs/drivers/mongodb/mongodb-migration-driver.js +0 -666
  57. package/cjs/drivers/mongodb/mongodb-migration-driver.js.map +0 -1
  58. package/cjs/drivers/mongodb/mongodb-query-builder.d.ts +0 -1122
  59. package/cjs/drivers/mongodb/mongodb-query-builder.d.ts.map +0 -1
  60. package/cjs/drivers/mongodb/mongodb-query-builder.js +0 -1988
  61. package/cjs/drivers/mongodb/mongodb-query-builder.js.map +0 -1
  62. package/cjs/drivers/mongodb/mongodb-query-operations.d.ts +0 -226
  63. package/cjs/drivers/mongodb/mongodb-query-operations.d.ts.map +0 -1
  64. package/cjs/drivers/mongodb/mongodb-query-operations.js +0 -270
  65. package/cjs/drivers/mongodb/mongodb-query-operations.js.map +0 -1
  66. package/cjs/drivers/mongodb/mongodb-query-parser.d.ts +0 -262
  67. package/cjs/drivers/mongodb/mongodb-query-parser.d.ts.map +0 -1
  68. package/cjs/drivers/mongodb/mongodb-query-parser.js +0 -1351
  69. package/cjs/drivers/mongodb/mongodb-query-parser.js.map +0 -1
  70. package/cjs/drivers/mongodb/mongodb-sync-adapter.d.ts +0 -79
  71. package/cjs/drivers/mongodb/mongodb-sync-adapter.d.ts.map +0 -1
  72. package/cjs/drivers/mongodb/mongodb-sync-adapter.js +0 -146
  73. package/cjs/drivers/mongodb/mongodb-sync-adapter.js.map +0 -1
  74. package/cjs/drivers/mongodb/types.d.ts +0 -43
  75. package/cjs/drivers/mongodb/types.d.ts.map +0 -1
  76. package/cjs/drivers/postgres/index.d.ts +0 -16
  77. package/cjs/drivers/postgres/index.d.ts.map +0 -1
  78. package/cjs/drivers/postgres/postgres-blueprint.d.ts +0 -64
  79. package/cjs/drivers/postgres/postgres-blueprint.d.ts.map +0 -1
  80. package/cjs/drivers/postgres/postgres-blueprint.js +0 -121
  81. package/cjs/drivers/postgres/postgres-blueprint.js.map +0 -1
  82. package/cjs/drivers/postgres/postgres-dialect.d.ts +0 -136
  83. package/cjs/drivers/postgres/postgres-dialect.d.ts.map +0 -1
  84. package/cjs/drivers/postgres/postgres-dialect.js +0 -268
  85. package/cjs/drivers/postgres/postgres-dialect.js.map +0 -1
  86. package/cjs/drivers/postgres/postgres-driver.d.ts +0 -432
  87. package/cjs/drivers/postgres/postgres-driver.d.ts.map +0 -1
  88. package/cjs/drivers/postgres/postgres-driver.js +0 -965
  89. package/cjs/drivers/postgres/postgres-driver.js.map +0 -1
  90. package/cjs/drivers/postgres/postgres-migration-driver.d.ts +0 -397
  91. package/cjs/drivers/postgres/postgres-migration-driver.d.ts.map +0 -1
  92. package/cjs/drivers/postgres/postgres-migration-driver.js +0 -900
  93. package/cjs/drivers/postgres/postgres-migration-driver.js.map +0 -1
  94. package/cjs/drivers/postgres/postgres-query-builder.d.ts +0 -254
  95. package/cjs/drivers/postgres/postgres-query-builder.d.ts.map +0 -1
  96. package/cjs/drivers/postgres/postgres-query-builder.js +0 -933
  97. package/cjs/drivers/postgres/postgres-query-builder.js.map +0 -1
  98. package/cjs/drivers/postgres/postgres-query-parser.d.ts +0 -328
  99. package/cjs/drivers/postgres/postgres-query-parser.d.ts.map +0 -1
  100. package/cjs/drivers/postgres/postgres-query-parser.js +0 -864
  101. package/cjs/drivers/postgres/postgres-query-parser.js.map +0 -1
  102. package/cjs/drivers/postgres/postgres-sql-serializer.d.ts +0 -37
  103. package/cjs/drivers/postgres/postgres-sql-serializer.d.ts.map +0 -1
  104. package/cjs/drivers/postgres/postgres-sql-serializer.js +0 -400
  105. package/cjs/drivers/postgres/postgres-sql-serializer.js.map +0 -1
  106. package/cjs/drivers/postgres/postgres-sync-adapter.d.ts +0 -83
  107. package/cjs/drivers/postgres/postgres-sync-adapter.d.ts.map +0 -1
  108. package/cjs/drivers/postgres/postgres-sync-adapter.js +0 -197
  109. package/cjs/drivers/postgres/postgres-sync-adapter.js.map +0 -1
  110. package/cjs/drivers/postgres/types.d.ts +0 -142
  111. package/cjs/drivers/postgres/types.d.ts.map +0 -1
  112. package/cjs/drivers/sql/index.d.ts +0 -10
  113. package/cjs/drivers/sql/index.d.ts.map +0 -1
  114. package/cjs/drivers/sql/sql-dialect.contract.d.ts +0 -204
  115. package/cjs/drivers/sql/sql-dialect.contract.d.ts.map +0 -1
  116. package/cjs/drivers/sql/sql-types.d.ts +0 -202
  117. package/cjs/drivers/sql/sql-types.d.ts.map +0 -1
  118. package/cjs/errors/missing-data-source.error.d.ts +0 -22
  119. package/cjs/errors/missing-data-source.error.d.ts.map +0 -1
  120. package/cjs/errors/missing-data-source.error.js +0 -29
  121. package/cjs/errors/missing-data-source.error.js.map +0 -1
  122. package/cjs/errors/transaction-rollback.error.d.ts +0 -20
  123. package/cjs/errors/transaction-rollback.error.d.ts.map +0 -1
  124. package/cjs/errors/transaction-rollback.error.js +0 -27
  125. package/cjs/errors/transaction-rollback.error.js.map +0 -1
  126. package/cjs/events/model-events.d.ts +0 -231
  127. package/cjs/events/model-events.d.ts.map +0 -1
  128. package/cjs/events/model-events.js +0 -259
  129. package/cjs/events/model-events.js.map +0 -1
  130. package/cjs/expressions/aggregate-expressions.d.ts +0 -215
  131. package/cjs/expressions/aggregate-expressions.d.ts.map +0 -1
  132. package/cjs/expressions/aggregate-expressions.js +0 -221
  133. package/cjs/expressions/aggregate-expressions.js.map +0 -1
  134. package/cjs/expressions/index.d.ts +0 -2
  135. package/cjs/expressions/index.d.ts.map +0 -1
  136. package/cjs/index.d.ts +0 -45
  137. package/cjs/index.d.ts.map +0 -1
  138. package/cjs/index.js +0 -1
  139. package/cjs/index.js.map +0 -1
  140. package/cjs/migration/column-builder.d.ts +0 -417
  141. package/cjs/migration/column-builder.d.ts.map +0 -1
  142. package/cjs/migration/column-builder.js +0 -586
  143. package/cjs/migration/column-builder.js.map +0 -1
  144. package/cjs/migration/column-helpers.d.ts +0 -275
  145. package/cjs/migration/column-helpers.d.ts.map +0 -1
  146. package/cjs/migration/column-helpers.js +0 -389
  147. package/cjs/migration/column-helpers.js.map +0 -1
  148. package/cjs/migration/foreign-key-builder.d.ts +0 -103
  149. package/cjs/migration/foreign-key-builder.d.ts.map +0 -1
  150. package/cjs/migration/foreign-key-builder.js +0 -121
  151. package/cjs/migration/foreign-key-builder.js.map +0 -1
  152. package/cjs/migration/index.d.ts +0 -7
  153. package/cjs/migration/index.d.ts.map +0 -1
  154. package/cjs/migration/migration-runner.d.ts +0 -278
  155. package/cjs/migration/migration-runner.d.ts.map +0 -1
  156. package/cjs/migration/migration-runner.js +0 -815
  157. package/cjs/migration/migration-runner.js.map +0 -1
  158. package/cjs/migration/migration.d.ts +0 -1992
  159. package/cjs/migration/migration.d.ts.map +0 -1
  160. package/cjs/migration/migration.js +0 -2162
  161. package/cjs/migration/migration.js.map +0 -1
  162. package/cjs/migration/sql-grammar.d.ts +0 -61
  163. package/cjs/migration/sql-grammar.d.ts.map +0 -1
  164. package/cjs/migration/sql-grammar.js +0 -164
  165. package/cjs/migration/sql-grammar.js.map +0 -1
  166. package/cjs/migration/sql-serializer.d.ts +0 -22
  167. package/cjs/migration/sql-serializer.d.ts.map +0 -1
  168. package/cjs/migration/sql-serializer.js +0 -26
  169. package/cjs/migration/sql-serializer.js.map +0 -1
  170. package/cjs/migration/types.d.ts +0 -155
  171. package/cjs/migration/types.d.ts.map +0 -1
  172. package/cjs/model/methods/accessor-methods.d.ts +0 -13
  173. package/cjs/model/methods/accessor-methods.d.ts.map +0 -1
  174. package/cjs/model/methods/accessor-methods.js +0 -51
  175. package/cjs/model/methods/accessor-methods.js.map +0 -1
  176. package/cjs/model/methods/delete-methods.d.ts +0 -10
  177. package/cjs/model/methods/delete-methods.d.ts.map +0 -1
  178. package/cjs/model/methods/delete-methods.js +0 -10
  179. package/cjs/model/methods/delete-methods.js.map +0 -1
  180. package/cjs/model/methods/dirty-methods.d.ts +0 -10
  181. package/cjs/model/methods/dirty-methods.d.ts.map +0 -1
  182. package/cjs/model/methods/dirty-methods.js +0 -15
  183. package/cjs/model/methods/dirty-methods.js.map +0 -1
  184. package/cjs/model/methods/hydration-methods.d.ts +0 -10
  185. package/cjs/model/methods/hydration-methods.d.ts.map +0 -1
  186. package/cjs/model/methods/hydration-methods.js +0 -57
  187. package/cjs/model/methods/hydration-methods.js.map +0 -1
  188. package/cjs/model/methods/instance-event-methods.d.ts +0 -7
  189. package/cjs/model/methods/instance-event-methods.d.ts.map +0 -1
  190. package/cjs/model/methods/instance-event-methods.js +0 -15
  191. package/cjs/model/methods/instance-event-methods.js.map +0 -1
  192. package/cjs/model/methods/meta-methods.d.ts +0 -7
  193. package/cjs/model/methods/meta-methods.d.ts.map +0 -1
  194. package/cjs/model/methods/meta-methods.js +0 -78
  195. package/cjs/model/methods/meta-methods.js.map +0 -1
  196. package/cjs/model/methods/query-methods.d.ts +0 -24
  197. package/cjs/model/methods/query-methods.d.ts.map +0 -1
  198. package/cjs/model/methods/query-methods.js +0 -161
  199. package/cjs/model/methods/query-methods.js.map +0 -1
  200. package/cjs/model/methods/restore-methods.d.ts +0 -10
  201. package/cjs/model/methods/restore-methods.d.ts.map +0 -1
  202. package/cjs/model/methods/restore-methods.js +0 -13
  203. package/cjs/model/methods/restore-methods.js.map +0 -1
  204. package/cjs/model/methods/scope-methods.d.ts +0 -7
  205. package/cjs/model/methods/scope-methods.d.ts.map +0 -1
  206. package/cjs/model/methods/scope-methods.js +0 -15
  207. package/cjs/model/methods/scope-methods.js.map +0 -1
  208. package/cjs/model/methods/serialization-methods.d.ts +0 -3
  209. package/cjs/model/methods/serialization-methods.d.ts.map +0 -1
  210. package/cjs/model/methods/serialization-methods.js +0 -27
  211. package/cjs/model/methods/serialization-methods.js.map +0 -1
  212. package/cjs/model/methods/static-event-methods.d.ts +0 -9
  213. package/cjs/model/methods/static-event-methods.d.ts.map +0 -1
  214. package/cjs/model/methods/static-event-methods.js +0 -29
  215. package/cjs/model/methods/static-event-methods.js.map +0 -1
  216. package/cjs/model/methods/write-methods.d.ts +0 -10
  217. package/cjs/model/methods/write-methods.d.ts.map +0 -1
  218. package/cjs/model/methods/write-methods.js +0 -52
  219. package/cjs/model/methods/write-methods.js.map +0 -1
  220. package/cjs/model/model.d.ts +0 -1650
  221. package/cjs/model/model.d.ts.map +0 -1
  222. package/cjs/model/model.js +0 -1657
  223. package/cjs/model/model.js.map +0 -1
  224. package/cjs/model/model.types.d.ts +0 -44
  225. package/cjs/model/model.types.d.ts.map +0 -1
  226. package/cjs/model/register-model.d.ts +0 -81
  227. package/cjs/model/register-model.d.ts.map +0 -1
  228. package/cjs/model/register-model.js +0 -94
  229. package/cjs/model/register-model.js.map +0 -1
  230. package/cjs/query-builder/query-builder.d.ts +0 -556
  231. package/cjs/query-builder/query-builder.d.ts.map +0 -1
  232. package/cjs/query-builder/query-builder.js +0 -1070
  233. package/cjs/query-builder/query-builder.js.map +0 -1
  234. package/cjs/relations/helpers.d.ts +0 -156
  235. package/cjs/relations/helpers.d.ts.map +0 -1
  236. package/cjs/relations/helpers.js +0 -201
  237. package/cjs/relations/helpers.js.map +0 -1
  238. package/cjs/relations/index.d.ts +0 -35
  239. package/cjs/relations/index.d.ts.map +0 -1
  240. package/cjs/relations/pivot-operations.d.ts +0 -160
  241. package/cjs/relations/pivot-operations.d.ts.map +0 -1
  242. package/cjs/relations/pivot-operations.js +0 -293
  243. package/cjs/relations/pivot-operations.js.map +0 -1
  244. package/cjs/relations/relation-hydrator.d.ts +0 -68
  245. package/cjs/relations/relation-hydrator.d.ts.map +0 -1
  246. package/cjs/relations/relation-hydrator.js +0 -81
  247. package/cjs/relations/relation-hydrator.js.map +0 -1
  248. package/cjs/relations/relation-loader.d.ts +0 -194
  249. package/cjs/relations/relation-loader.d.ts.map +0 -1
  250. package/cjs/relations/relation-loader.js +0 -466
  251. package/cjs/relations/relation-loader.js.map +0 -1
  252. package/cjs/relations/types.d.ts +0 -306
  253. package/cjs/relations/types.d.ts.map +0 -1
  254. package/cjs/remover/database-remover.d.ts +0 -100
  255. package/cjs/remover/database-remover.d.ts.map +0 -1
  256. package/cjs/remover/database-remover.js +0 -214
  257. package/cjs/remover/database-remover.js.map +0 -1
  258. package/cjs/restorer/database-restorer.d.ts +0 -131
  259. package/cjs/restorer/database-restorer.d.ts.map +0 -1
  260. package/cjs/restorer/database-restorer.js +0 -434
  261. package/cjs/restorer/database-restorer.js.map +0 -1
  262. package/cjs/sql-database-dirty-tracker.d.ts +0 -13
  263. package/cjs/sql-database-dirty-tracker.d.ts.map +0 -1
  264. package/cjs/sql-database-dirty-tracker.js +0 -14
  265. package/cjs/sql-database-dirty-tracker.js.map +0 -1
  266. package/cjs/sync/index.d.ts +0 -12
  267. package/cjs/sync/index.d.ts.map +0 -1
  268. package/cjs/sync/model-events.d.ts +0 -62
  269. package/cjs/sync/model-events.d.ts.map +0 -1
  270. package/cjs/sync/model-events.js +0 -49
  271. package/cjs/sync/model-events.js.map +0 -1
  272. package/cjs/sync/model-sync-operation.d.ts +0 -163
  273. package/cjs/sync/model-sync-operation.d.ts.map +0 -1
  274. package/cjs/sync/model-sync-operation.js +0 -292
  275. package/cjs/sync/model-sync-operation.js.map +0 -1
  276. package/cjs/sync/model-sync.d.ts +0 -130
  277. package/cjs/sync/model-sync.d.ts.map +0 -1
  278. package/cjs/sync/model-sync.js +0 -178
  279. package/cjs/sync/model-sync.js.map +0 -1
  280. package/cjs/sync/sync-context.d.ts +0 -70
  281. package/cjs/sync/sync-context.d.ts.map +0 -1
  282. package/cjs/sync/sync-context.js +0 -101
  283. package/cjs/sync/sync-context.js.map +0 -1
  284. package/cjs/sync/sync-manager.d.ts +0 -213
  285. package/cjs/sync/sync-manager.d.ts.map +0 -1
  286. package/cjs/sync/sync-manager.js +0 -689
  287. package/cjs/sync/sync-manager.js.map +0 -1
  288. package/cjs/sync/types.d.ts +0 -289
  289. package/cjs/sync/types.d.ts.map +0 -1
  290. package/cjs/test-migrations/test-enhanced-features.migration.d.ts +0 -15
  291. package/cjs/test-migrations/test-enhanced-features.migration.d.ts.map +0 -1
  292. package/cjs/types.d.ts +0 -371
  293. package/cjs/types.d.ts.map +0 -1
  294. package/cjs/utils/connect-to-database.d.ts +0 -300
  295. package/cjs/utils/connect-to-database.d.ts.map +0 -1
  296. package/cjs/utils/connect-to-database.js +0 -128
  297. package/cjs/utils/connect-to-database.js.map +0 -1
  298. package/cjs/utils/database-writer.utils.d.ts +0 -15
  299. package/cjs/utils/database-writer.utils.d.ts.map +0 -1
  300. package/cjs/utils/database-writer.utils.js +0 -14
  301. package/cjs/utils/database-writer.utils.js.map +0 -1
  302. package/cjs/utils/define-model.js +0 -100
  303. package/cjs/utils/define-model.js.map +0 -1
  304. package/cjs/utils/is-valid-date-value.d.ts +0 -5
  305. package/cjs/utils/is-valid-date-value.d.ts.map +0 -1
  306. package/cjs/utils/is-valid-date-value.js +0 -25
  307. package/cjs/utils/is-valid-date-value.js.map +0 -1
  308. package/cjs/utils/once-connected.d.ts +0 -146
  309. package/cjs/utils/once-connected.d.ts.map +0 -1
  310. package/cjs/utils/once-connected.js +0 -251
  311. package/cjs/utils/once-connected.js.map +0 -1
  312. package/cjs/validation/database-seal-plugins.d.ts +0 -12
  313. package/cjs/validation/database-seal-plugins.d.ts.map +0 -1
  314. package/cjs/validation/database-seal-plugins.js +0 -1
  315. package/cjs/validation/database-seal-plugins.js.map +0 -1
  316. package/cjs/validation/database-writer-validation-error.d.ts +0 -97
  317. package/cjs/validation/database-writer-validation-error.d.ts.map +0 -1
  318. package/cjs/validation/database-writer-validation-error.js +0 -160
  319. package/cjs/validation/database-writer-validation-error.js.map +0 -1
  320. package/cjs/validation/index.d.ts +0 -3
  321. package/cjs/validation/index.d.ts.map +0 -1
  322. package/cjs/validation/mutators/embed-mutator.d.ts +0 -9
  323. package/cjs/validation/mutators/embed-mutator.d.ts.map +0 -1
  324. package/cjs/validation/mutators/embed-mutator.js +0 -33
  325. package/cjs/validation/mutators/embed-mutator.js.map +0 -1
  326. package/cjs/validation/plugins/embed-validator-plugin.d.ts +0 -24
  327. package/cjs/validation/plugins/embed-validator-plugin.d.ts.map +0 -1
  328. package/cjs/validation/plugins/embed-validator-plugin.js +0 -18
  329. package/cjs/validation/plugins/embed-validator-plugin.js.map +0 -1
  330. package/cjs/validation/rules/database-model-rule.d.ts +0 -7
  331. package/cjs/validation/rules/database-model-rule.d.ts.map +0 -1
  332. package/cjs/validation/rules/database-model-rule.js +0 -27
  333. package/cjs/validation/rules/database-model-rule.js.map +0 -1
  334. package/cjs/validation/transformers/embed-model-transformer.d.ts +0 -3
  335. package/cjs/validation/transformers/embed-model-transformer.d.ts.map +0 -1
  336. package/cjs/validation/transformers/embed-model-transformer.js +0 -18
  337. package/cjs/validation/transformers/embed-model-transformer.js.map +0 -1
  338. package/cjs/validation/validators/embed-validator.d.ts +0 -21
  339. package/cjs/validation/validators/embed-validator.d.ts.map +0 -1
  340. package/cjs/validation/validators/embed-validator.js +0 -43
  341. package/cjs/validation/validators/embed-validator.js.map +0 -1
  342. package/cjs/writer/database-writer.d.ts +0 -181
  343. package/cjs/writer/database-writer.d.ts.map +0 -1
  344. package/cjs/writer/database-writer.js +0 -407
  345. package/cjs/writer/database-writer.js.map +0 -1
  346. package/esm/context/database-data-source-context.d.ts +0 -29
  347. package/esm/context/database-data-source-context.d.ts.map +0 -1
  348. package/esm/context/database-data-source-context.js +0 -28
  349. package/esm/context/database-data-source-context.js.map +0 -1
  350. package/esm/context/database-transaction-context.d.ts +0 -35
  351. package/esm/context/database-transaction-context.d.ts.map +0 -1
  352. package/esm/context/database-transaction-context.js +0 -40
  353. package/esm/context/database-transaction-context.js.map +0 -1
  354. package/esm/contracts/database-driver.contract.d.ts +0 -450
  355. package/esm/contracts/database-driver.contract.d.ts.map +0 -1
  356. package/esm/contracts/database-id-generator.contract.d.ts +0 -109
  357. package/esm/contracts/database-id-generator.contract.d.ts.map +0 -1
  358. package/esm/contracts/database-remover.contract.d.ts +0 -104
  359. package/esm/contracts/database-remover.contract.d.ts.map +0 -1
  360. package/esm/contracts/database-restorer.contract.d.ts +0 -143
  361. package/esm/contracts/database-restorer.contract.d.ts.map +0 -1
  362. package/esm/contracts/database-writer.contract.d.ts +0 -119
  363. package/esm/contracts/database-writer.contract.d.ts.map +0 -1
  364. package/esm/contracts/driver-blueprint.contract.d.ts +0 -49
  365. package/esm/contracts/driver-blueprint.contract.d.ts.map +0 -1
  366. package/esm/contracts/index.d.ts +0 -10
  367. package/esm/contracts/index.d.ts.map +0 -1
  368. package/esm/contracts/migration-driver.contract.d.ts +0 -522
  369. package/esm/contracts/migration-driver.contract.d.ts.map +0 -1
  370. package/esm/contracts/query-builder.contract.d.ts +0 -1609
  371. package/esm/contracts/query-builder.contract.d.ts.map +0 -1
  372. package/esm/contracts/sync-adapter.contract.d.ts +0 -58
  373. package/esm/contracts/sync-adapter.contract.d.ts.map +0 -1
  374. package/esm/data-source/data-source-registry.d.ts +0 -108
  375. package/esm/data-source/data-source-registry.d.ts.map +0 -1
  376. package/esm/data-source/data-source-registry.js +0 -145
  377. package/esm/data-source/data-source-registry.js.map +0 -1
  378. package/esm/data-source/data-source.d.ts +0 -147
  379. package/esm/data-source/data-source.d.ts.map +0 -1
  380. package/esm/data-source/data-source.js +0 -83
  381. package/esm/data-source/data-source.js.map +0 -1
  382. package/esm/database-dirty-tracker.d.ts +0 -252
  383. package/esm/database-dirty-tracker.d.ts.map +0 -1
  384. package/esm/database-dirty-tracker.js +0 -386
  385. package/esm/database-dirty-tracker.js.map +0 -1
  386. package/esm/drivers/mongodb/mongodb-blueprint.d.ts +0 -30
  387. package/esm/drivers/mongodb/mongodb-blueprint.d.ts.map +0 -1
  388. package/esm/drivers/mongodb/mongodb-blueprint.js +0 -51
  389. package/esm/drivers/mongodb/mongodb-blueprint.js.map +0 -1
  390. package/esm/drivers/mongodb/mongodb-driver.d.ts +0 -324
  391. package/esm/drivers/mongodb/mongodb-driver.d.ts.map +0 -1
  392. package/esm/drivers/mongodb/mongodb-driver.js +0 -799
  393. package/esm/drivers/mongodb/mongodb-driver.js.map +0 -1
  394. package/esm/drivers/mongodb/mongodb-id-generator.d.ts +0 -116
  395. package/esm/drivers/mongodb/mongodb-id-generator.d.ts.map +0 -1
  396. package/esm/drivers/mongodb/mongodb-id-generator.js +0 -149
  397. package/esm/drivers/mongodb/mongodb-id-generator.js.map +0 -1
  398. package/esm/drivers/mongodb/mongodb-migration-driver.d.ts +0 -317
  399. package/esm/drivers/mongodb/mongodb-migration-driver.d.ts.map +0 -1
  400. package/esm/drivers/mongodb/mongodb-migration-driver.js +0 -666
  401. package/esm/drivers/mongodb/mongodb-migration-driver.js.map +0 -1
  402. package/esm/drivers/mongodb/mongodb-query-builder.d.ts +0 -1122
  403. package/esm/drivers/mongodb/mongodb-query-builder.d.ts.map +0 -1
  404. package/esm/drivers/mongodb/mongodb-query-builder.js +0 -1988
  405. package/esm/drivers/mongodb/mongodb-query-builder.js.map +0 -1
  406. package/esm/drivers/mongodb/mongodb-query-operations.d.ts +0 -226
  407. package/esm/drivers/mongodb/mongodb-query-operations.d.ts.map +0 -1
  408. package/esm/drivers/mongodb/mongodb-query-operations.js +0 -270
  409. package/esm/drivers/mongodb/mongodb-query-operations.js.map +0 -1
  410. package/esm/drivers/mongodb/mongodb-query-parser.d.ts +0 -262
  411. package/esm/drivers/mongodb/mongodb-query-parser.d.ts.map +0 -1
  412. package/esm/drivers/mongodb/mongodb-query-parser.js +0 -1351
  413. package/esm/drivers/mongodb/mongodb-query-parser.js.map +0 -1
  414. package/esm/drivers/mongodb/mongodb-sync-adapter.d.ts +0 -79
  415. package/esm/drivers/mongodb/mongodb-sync-adapter.d.ts.map +0 -1
  416. package/esm/drivers/mongodb/mongodb-sync-adapter.js +0 -146
  417. package/esm/drivers/mongodb/mongodb-sync-adapter.js.map +0 -1
  418. package/esm/drivers/mongodb/types.d.ts +0 -43
  419. package/esm/drivers/mongodb/types.d.ts.map +0 -1
  420. package/esm/drivers/postgres/index.d.ts +0 -16
  421. package/esm/drivers/postgres/index.d.ts.map +0 -1
  422. package/esm/drivers/postgres/postgres-blueprint.d.ts +0 -64
  423. package/esm/drivers/postgres/postgres-blueprint.d.ts.map +0 -1
  424. package/esm/drivers/postgres/postgres-blueprint.js +0 -121
  425. package/esm/drivers/postgres/postgres-blueprint.js.map +0 -1
  426. package/esm/drivers/postgres/postgres-dialect.d.ts +0 -136
  427. package/esm/drivers/postgres/postgres-dialect.d.ts.map +0 -1
  428. package/esm/drivers/postgres/postgres-dialect.js +0 -268
  429. package/esm/drivers/postgres/postgres-dialect.js.map +0 -1
  430. package/esm/drivers/postgres/postgres-driver.d.ts +0 -432
  431. package/esm/drivers/postgres/postgres-driver.d.ts.map +0 -1
  432. package/esm/drivers/postgres/postgres-driver.js +0 -965
  433. package/esm/drivers/postgres/postgres-driver.js.map +0 -1
  434. package/esm/drivers/postgres/postgres-migration-driver.d.ts +0 -397
  435. package/esm/drivers/postgres/postgres-migration-driver.d.ts.map +0 -1
  436. package/esm/drivers/postgres/postgres-migration-driver.js +0 -900
  437. package/esm/drivers/postgres/postgres-migration-driver.js.map +0 -1
  438. package/esm/drivers/postgres/postgres-query-builder.d.ts +0 -254
  439. package/esm/drivers/postgres/postgres-query-builder.d.ts.map +0 -1
  440. package/esm/drivers/postgres/postgres-query-builder.js +0 -933
  441. package/esm/drivers/postgres/postgres-query-builder.js.map +0 -1
  442. package/esm/drivers/postgres/postgres-query-parser.d.ts +0 -328
  443. package/esm/drivers/postgres/postgres-query-parser.d.ts.map +0 -1
  444. package/esm/drivers/postgres/postgres-query-parser.js +0 -864
  445. package/esm/drivers/postgres/postgres-query-parser.js.map +0 -1
  446. package/esm/drivers/postgres/postgres-sql-serializer.d.ts +0 -37
  447. package/esm/drivers/postgres/postgres-sql-serializer.d.ts.map +0 -1
  448. package/esm/drivers/postgres/postgres-sql-serializer.js +0 -400
  449. package/esm/drivers/postgres/postgres-sql-serializer.js.map +0 -1
  450. package/esm/drivers/postgres/postgres-sync-adapter.d.ts +0 -83
  451. package/esm/drivers/postgres/postgres-sync-adapter.d.ts.map +0 -1
  452. package/esm/drivers/postgres/postgres-sync-adapter.js +0 -197
  453. package/esm/drivers/postgres/postgres-sync-adapter.js.map +0 -1
  454. package/esm/drivers/postgres/types.d.ts +0 -142
  455. package/esm/drivers/postgres/types.d.ts.map +0 -1
  456. package/esm/drivers/sql/index.d.ts +0 -10
  457. package/esm/drivers/sql/index.d.ts.map +0 -1
  458. package/esm/drivers/sql/sql-dialect.contract.d.ts +0 -204
  459. package/esm/drivers/sql/sql-dialect.contract.d.ts.map +0 -1
  460. package/esm/drivers/sql/sql-types.d.ts +0 -202
  461. package/esm/drivers/sql/sql-types.d.ts.map +0 -1
  462. package/esm/errors/missing-data-source.error.d.ts +0 -22
  463. package/esm/errors/missing-data-source.error.d.ts.map +0 -1
  464. package/esm/errors/missing-data-source.error.js +0 -29
  465. package/esm/errors/missing-data-source.error.js.map +0 -1
  466. package/esm/errors/transaction-rollback.error.d.ts +0 -20
  467. package/esm/errors/transaction-rollback.error.d.ts.map +0 -1
  468. package/esm/errors/transaction-rollback.error.js +0 -27
  469. package/esm/errors/transaction-rollback.error.js.map +0 -1
  470. package/esm/events/model-events.d.ts +0 -231
  471. package/esm/events/model-events.d.ts.map +0 -1
  472. package/esm/events/model-events.js +0 -259
  473. package/esm/events/model-events.js.map +0 -1
  474. package/esm/expressions/aggregate-expressions.d.ts +0 -215
  475. package/esm/expressions/aggregate-expressions.d.ts.map +0 -1
  476. package/esm/expressions/aggregate-expressions.js +0 -221
  477. package/esm/expressions/aggregate-expressions.js.map +0 -1
  478. package/esm/expressions/index.d.ts +0 -2
  479. package/esm/expressions/index.d.ts.map +0 -1
  480. package/esm/index.d.ts +0 -45
  481. package/esm/index.d.ts.map +0 -1
  482. package/esm/index.js +0 -1
  483. package/esm/index.js.map +0 -1
  484. package/esm/migration/column-builder.d.ts +0 -417
  485. package/esm/migration/column-builder.d.ts.map +0 -1
  486. package/esm/migration/column-builder.js +0 -586
  487. package/esm/migration/column-builder.js.map +0 -1
  488. package/esm/migration/column-helpers.d.ts +0 -275
  489. package/esm/migration/column-helpers.d.ts.map +0 -1
  490. package/esm/migration/column-helpers.js +0 -389
  491. package/esm/migration/column-helpers.js.map +0 -1
  492. package/esm/migration/foreign-key-builder.d.ts +0 -103
  493. package/esm/migration/foreign-key-builder.d.ts.map +0 -1
  494. package/esm/migration/foreign-key-builder.js +0 -121
  495. package/esm/migration/foreign-key-builder.js.map +0 -1
  496. package/esm/migration/index.d.ts +0 -7
  497. package/esm/migration/index.d.ts.map +0 -1
  498. package/esm/migration/migration-runner.d.ts +0 -278
  499. package/esm/migration/migration-runner.d.ts.map +0 -1
  500. package/esm/migration/migration-runner.js +0 -815
  501. package/esm/migration/migration-runner.js.map +0 -1
  502. package/esm/migration/migration.d.ts +0 -1992
  503. package/esm/migration/migration.d.ts.map +0 -1
  504. package/esm/migration/migration.js +0 -2162
  505. package/esm/migration/migration.js.map +0 -1
  506. package/esm/migration/sql-grammar.d.ts +0 -61
  507. package/esm/migration/sql-grammar.d.ts.map +0 -1
  508. package/esm/migration/sql-grammar.js +0 -164
  509. package/esm/migration/sql-grammar.js.map +0 -1
  510. package/esm/migration/sql-serializer.d.ts +0 -22
  511. package/esm/migration/sql-serializer.d.ts.map +0 -1
  512. package/esm/migration/sql-serializer.js +0 -26
  513. package/esm/migration/sql-serializer.js.map +0 -1
  514. package/esm/migration/types.d.ts +0 -155
  515. package/esm/migration/types.d.ts.map +0 -1
  516. package/esm/model/methods/accessor-methods.d.ts +0 -13
  517. package/esm/model/methods/accessor-methods.d.ts.map +0 -1
  518. package/esm/model/methods/accessor-methods.js +0 -51
  519. package/esm/model/methods/accessor-methods.js.map +0 -1
  520. package/esm/model/methods/delete-methods.d.ts +0 -10
  521. package/esm/model/methods/delete-methods.d.ts.map +0 -1
  522. package/esm/model/methods/delete-methods.js +0 -10
  523. package/esm/model/methods/delete-methods.js.map +0 -1
  524. package/esm/model/methods/dirty-methods.d.ts +0 -10
  525. package/esm/model/methods/dirty-methods.d.ts.map +0 -1
  526. package/esm/model/methods/dirty-methods.js +0 -15
  527. package/esm/model/methods/dirty-methods.js.map +0 -1
  528. package/esm/model/methods/hydration-methods.d.ts +0 -10
  529. package/esm/model/methods/hydration-methods.d.ts.map +0 -1
  530. package/esm/model/methods/hydration-methods.js +0 -57
  531. package/esm/model/methods/hydration-methods.js.map +0 -1
  532. package/esm/model/methods/instance-event-methods.d.ts +0 -7
  533. package/esm/model/methods/instance-event-methods.d.ts.map +0 -1
  534. package/esm/model/methods/instance-event-methods.js +0 -15
  535. package/esm/model/methods/instance-event-methods.js.map +0 -1
  536. package/esm/model/methods/meta-methods.d.ts +0 -7
  537. package/esm/model/methods/meta-methods.d.ts.map +0 -1
  538. package/esm/model/methods/meta-methods.js +0 -78
  539. package/esm/model/methods/meta-methods.js.map +0 -1
  540. package/esm/model/methods/query-methods.d.ts +0 -24
  541. package/esm/model/methods/query-methods.d.ts.map +0 -1
  542. package/esm/model/methods/query-methods.js +0 -161
  543. package/esm/model/methods/query-methods.js.map +0 -1
  544. package/esm/model/methods/restore-methods.d.ts +0 -10
  545. package/esm/model/methods/restore-methods.d.ts.map +0 -1
  546. package/esm/model/methods/restore-methods.js +0 -13
  547. package/esm/model/methods/restore-methods.js.map +0 -1
  548. package/esm/model/methods/scope-methods.d.ts +0 -7
  549. package/esm/model/methods/scope-methods.d.ts.map +0 -1
  550. package/esm/model/methods/scope-methods.js +0 -15
  551. package/esm/model/methods/scope-methods.js.map +0 -1
  552. package/esm/model/methods/serialization-methods.d.ts +0 -3
  553. package/esm/model/methods/serialization-methods.d.ts.map +0 -1
  554. package/esm/model/methods/serialization-methods.js +0 -27
  555. package/esm/model/methods/serialization-methods.js.map +0 -1
  556. package/esm/model/methods/static-event-methods.d.ts +0 -9
  557. package/esm/model/methods/static-event-methods.d.ts.map +0 -1
  558. package/esm/model/methods/static-event-methods.js +0 -29
  559. package/esm/model/methods/static-event-methods.js.map +0 -1
  560. package/esm/model/methods/write-methods.d.ts +0 -10
  561. package/esm/model/methods/write-methods.d.ts.map +0 -1
  562. package/esm/model/methods/write-methods.js +0 -52
  563. package/esm/model/methods/write-methods.js.map +0 -1
  564. package/esm/model/model.d.ts +0 -1650
  565. package/esm/model/model.d.ts.map +0 -1
  566. package/esm/model/model.js +0 -1657
  567. package/esm/model/model.js.map +0 -1
  568. package/esm/model/model.types.d.ts +0 -44
  569. package/esm/model/model.types.d.ts.map +0 -1
  570. package/esm/model/register-model.d.ts +0 -81
  571. package/esm/model/register-model.d.ts.map +0 -1
  572. package/esm/model/register-model.js +0 -94
  573. package/esm/model/register-model.js.map +0 -1
  574. package/esm/query-builder/query-builder.d.ts +0 -556
  575. package/esm/query-builder/query-builder.d.ts.map +0 -1
  576. package/esm/query-builder/query-builder.js +0 -1070
  577. package/esm/query-builder/query-builder.js.map +0 -1
  578. package/esm/relations/helpers.d.ts +0 -156
  579. package/esm/relations/helpers.d.ts.map +0 -1
  580. package/esm/relations/helpers.js +0 -201
  581. package/esm/relations/helpers.js.map +0 -1
  582. package/esm/relations/index.d.ts +0 -35
  583. package/esm/relations/index.d.ts.map +0 -1
  584. package/esm/relations/pivot-operations.d.ts +0 -160
  585. package/esm/relations/pivot-operations.d.ts.map +0 -1
  586. package/esm/relations/pivot-operations.js +0 -293
  587. package/esm/relations/pivot-operations.js.map +0 -1
  588. package/esm/relations/relation-hydrator.d.ts +0 -68
  589. package/esm/relations/relation-hydrator.d.ts.map +0 -1
  590. package/esm/relations/relation-hydrator.js +0 -81
  591. package/esm/relations/relation-hydrator.js.map +0 -1
  592. package/esm/relations/relation-loader.d.ts +0 -194
  593. package/esm/relations/relation-loader.d.ts.map +0 -1
  594. package/esm/relations/relation-loader.js +0 -466
  595. package/esm/relations/relation-loader.js.map +0 -1
  596. package/esm/relations/types.d.ts +0 -306
  597. package/esm/relations/types.d.ts.map +0 -1
  598. package/esm/remover/database-remover.d.ts +0 -100
  599. package/esm/remover/database-remover.d.ts.map +0 -1
  600. package/esm/remover/database-remover.js +0 -214
  601. package/esm/remover/database-remover.js.map +0 -1
  602. package/esm/restorer/database-restorer.d.ts +0 -131
  603. package/esm/restorer/database-restorer.d.ts.map +0 -1
  604. package/esm/restorer/database-restorer.js +0 -434
  605. package/esm/restorer/database-restorer.js.map +0 -1
  606. package/esm/sql-database-dirty-tracker.d.ts +0 -13
  607. package/esm/sql-database-dirty-tracker.d.ts.map +0 -1
  608. package/esm/sql-database-dirty-tracker.js +0 -14
  609. package/esm/sql-database-dirty-tracker.js.map +0 -1
  610. package/esm/sync/index.d.ts +0 -12
  611. package/esm/sync/index.d.ts.map +0 -1
  612. package/esm/sync/model-events.d.ts +0 -62
  613. package/esm/sync/model-events.d.ts.map +0 -1
  614. package/esm/sync/model-events.js +0 -49
  615. package/esm/sync/model-events.js.map +0 -1
  616. package/esm/sync/model-sync-operation.d.ts +0 -163
  617. package/esm/sync/model-sync-operation.d.ts.map +0 -1
  618. package/esm/sync/model-sync-operation.js +0 -292
  619. package/esm/sync/model-sync-operation.js.map +0 -1
  620. package/esm/sync/model-sync.d.ts +0 -130
  621. package/esm/sync/model-sync.d.ts.map +0 -1
  622. package/esm/sync/model-sync.js +0 -178
  623. package/esm/sync/model-sync.js.map +0 -1
  624. package/esm/sync/sync-context.d.ts +0 -70
  625. package/esm/sync/sync-context.d.ts.map +0 -1
  626. package/esm/sync/sync-context.js +0 -101
  627. package/esm/sync/sync-context.js.map +0 -1
  628. package/esm/sync/sync-manager.d.ts +0 -213
  629. package/esm/sync/sync-manager.d.ts.map +0 -1
  630. package/esm/sync/sync-manager.js +0 -689
  631. package/esm/sync/sync-manager.js.map +0 -1
  632. package/esm/sync/types.d.ts +0 -289
  633. package/esm/sync/types.d.ts.map +0 -1
  634. package/esm/test-migrations/test-enhanced-features.migration.d.ts +0 -15
  635. package/esm/test-migrations/test-enhanced-features.migration.d.ts.map +0 -1
  636. package/esm/types.d.ts +0 -371
  637. package/esm/types.d.ts.map +0 -1
  638. package/esm/utils/connect-to-database.d.ts +0 -300
  639. package/esm/utils/connect-to-database.d.ts.map +0 -1
  640. package/esm/utils/connect-to-database.js +0 -128
  641. package/esm/utils/connect-to-database.js.map +0 -1
  642. package/esm/utils/database-writer.utils.d.ts +0 -15
  643. package/esm/utils/database-writer.utils.d.ts.map +0 -1
  644. package/esm/utils/database-writer.utils.js +0 -14
  645. package/esm/utils/database-writer.utils.js.map +0 -1
  646. package/esm/utils/define-model.js +0 -100
  647. package/esm/utils/define-model.js.map +0 -1
  648. package/esm/utils/is-valid-date-value.d.ts +0 -5
  649. package/esm/utils/is-valid-date-value.d.ts.map +0 -1
  650. package/esm/utils/is-valid-date-value.js +0 -25
  651. package/esm/utils/is-valid-date-value.js.map +0 -1
  652. package/esm/utils/once-connected.d.ts +0 -146
  653. package/esm/utils/once-connected.d.ts.map +0 -1
  654. package/esm/utils/once-connected.js +0 -251
  655. package/esm/utils/once-connected.js.map +0 -1
  656. package/esm/validation/database-seal-plugins.d.ts +0 -12
  657. package/esm/validation/database-seal-plugins.d.ts.map +0 -1
  658. package/esm/validation/database-seal-plugins.js +0 -1
  659. package/esm/validation/database-seal-plugins.js.map +0 -1
  660. package/esm/validation/database-writer-validation-error.d.ts +0 -97
  661. package/esm/validation/database-writer-validation-error.d.ts.map +0 -1
  662. package/esm/validation/database-writer-validation-error.js +0 -160
  663. package/esm/validation/database-writer-validation-error.js.map +0 -1
  664. package/esm/validation/index.d.ts +0 -3
  665. package/esm/validation/index.d.ts.map +0 -1
  666. package/esm/validation/mutators/embed-mutator.d.ts +0 -9
  667. package/esm/validation/mutators/embed-mutator.d.ts.map +0 -1
  668. package/esm/validation/mutators/embed-mutator.js +0 -33
  669. package/esm/validation/mutators/embed-mutator.js.map +0 -1
  670. package/esm/validation/plugins/embed-validator-plugin.d.ts +0 -24
  671. package/esm/validation/plugins/embed-validator-plugin.d.ts.map +0 -1
  672. package/esm/validation/plugins/embed-validator-plugin.js +0 -18
  673. package/esm/validation/plugins/embed-validator-plugin.js.map +0 -1
  674. package/esm/validation/rules/database-model-rule.d.ts +0 -7
  675. package/esm/validation/rules/database-model-rule.d.ts.map +0 -1
  676. package/esm/validation/rules/database-model-rule.js +0 -27
  677. package/esm/validation/rules/database-model-rule.js.map +0 -1
  678. package/esm/validation/transformers/embed-model-transformer.d.ts +0 -3
  679. package/esm/validation/transformers/embed-model-transformer.d.ts.map +0 -1
  680. package/esm/validation/transformers/embed-model-transformer.js +0 -18
  681. package/esm/validation/transformers/embed-model-transformer.js.map +0 -1
  682. package/esm/validation/validators/embed-validator.d.ts +0 -21
  683. package/esm/validation/validators/embed-validator.d.ts.map +0 -1
  684. package/esm/validation/validators/embed-validator.js +0 -43
  685. package/esm/validation/validators/embed-validator.js.map +0 -1
  686. package/esm/writer/database-writer.d.ts +0 -181
  687. package/esm/writer/database-writer.d.ts.map +0 -1
  688. package/esm/writer/database-writer.js +0 -407
  689. package/esm/writer/database-writer.js.map +0 -1
@@ -1,799 +0,0 @@
1
- 'use strict';var copper=require('@mongez/copper'),logger=require('@warlock.js/logger'),node_events=require('node:events'),databaseTransactionContext=require('../../context/database-transaction-context.js'),dataSourceRegistry=require('../../data-source/data-source-registry.js'),databaseDirtyTracker=require('../../database-dirty-tracker.js'),transactionRollback_error=require('../../errors/transaction-rollback.error.js'),isValidDateValue=require('../../utils/is-valid-date-value.js'),mongodbBlueprint=require('./mongodb-blueprint.js'),mongodbIdGenerator=require('./mongodb-id-generator.js'),mongodbMigrationDriver=require('./mongodb-migration-driver.js'),mongodbQueryBuilder=require('./mongodb-query-builder.js'),mongodbSyncAdapter=require('./mongodb-sync-adapter.js');function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}const DEFAULT_TRANSACTION_OPTIONS = {
2
- readPreference: "primary",
3
- readConcern: { level: "local" },
4
- writeConcern: { w: "majority" },
5
- };
6
- // ============================================================
7
- // Lazy-loaded MongoDB SDK Types
8
- // ============================================================
9
- /**
10
- * Cached MongoDB module (loaded once, reused)
11
- */
12
- let MongoDBClient;
13
- let ObjectId;
14
- let isModuleExists = null;
15
- let loadingPromise;
16
- /**
17
- * Installation instructions for MongoDB package
18
- */
19
- const MONGODB_INSTALL_INSTRUCTIONS = `
20
- MongoDB driver requires the mongodb package.
21
- Install it with:
22
-
23
- npm install mongodb
24
-
25
- Or with your preferred package manager:
26
-
27
- pnpm add mongodb
28
- yarn add mongodb
29
- `.trim();
30
- /**
31
- * Load MongoDB module
32
- */
33
- async function loadMongoDB() {
34
- try {
35
- loadingPromise = Promise.resolve().then(function(){return /*#__PURE__*/_interopNamespace(require('mongodb'))});
36
- MongoDBClient = await loadingPromise;
37
- ObjectId = MongoDBClient.ObjectId;
38
- isModuleExists = true;
39
- }
40
- catch {
41
- isModuleExists = false;
42
- }
43
- }
44
- loadMongoDB();
45
- function isMongoDBDriverLoaded() {
46
- return isModuleExists;
47
- }
48
- async function assertModuleIsLoaded() {
49
- if (isModuleExists === false) {
50
- throw new Error(MONGODB_INSTALL_INSTRUCTIONS);
51
- }
52
- if (isModuleExists === null) {
53
- await loadingPromise;
54
- return await assertModuleIsLoaded();
55
- }
56
- }
57
- /**
58
- * MongoDB driver implementation that fulfils the Cascade driver contract.
59
- *
60
- * It encapsulates the native Mongo client, exposes lifecycle events, and
61
- * provides helpers for CRUD, transactions, atomic updates, and sync adapters.
62
- */
63
- class MongoDbDriver {
64
- config;
65
- driverOptions;
66
- events = new node_events.EventEmitter();
67
- client;
68
- database;
69
- connected = false;
70
- syncAdapterInstance;
71
- migrationDriverInstance;
72
- transactionOptions;
73
- idGeneratorInstance;
74
- _blueprint;
75
- get blueprint() {
76
- if (!this._blueprint) {
77
- this._blueprint = new mongodbBlueprint.MongoDBBlueprint(this.database);
78
- }
79
- return this._blueprint;
80
- }
81
- /**
82
- * The name of this driver.
83
- */
84
- name = "mongodb";
85
- /**
86
- * Current database name
87
- */
88
- _databaseName;
89
- /**
90
- * MongoDB driver model defaults.
91
- *
92
- * MongoDB follows NoSQL conventions:
93
- * - camelCase naming for fields (createdAt, updatedAt, deletedAt)
94
- * - Manual ID generation (auto-increment id field separate from _id)
95
- * - Timestamps enabled by default
96
- * - Trash delete strategy with per-collection trash tables
97
- */
98
- modelDefaults = {
99
- namingConvention: "camelCase",
100
- createdAtColumn: "createdAt",
101
- updatedAtColumn: "updatedAt",
102
- deletedAtColumn: "deletedAt",
103
- timestamps: true,
104
- autoGenerateId: true,
105
- strictMode: "strip",
106
- deleteStrategy: "trash",
107
- trashTable: (table) => `${table}Trash`, // Per-collection trash (usersTrash, productsTrash)
108
- };
109
- /**
110
- * Create a new MongoDB driver using the supplied connection options.
111
- *
112
- * @param config - Connection configuration
113
- * @param driverOptions - Driver-specific options
114
- */
115
- constructor(config, driverOptions) {
116
- this.config = config;
117
- this.driverOptions = driverOptions;
118
- this.transactionOptions = {
119
- ...DEFAULT_TRANSACTION_OPTIONS,
120
- ...driverOptions?.transactionOptions,
121
- };
122
- }
123
- /**
124
- * Get data base name
125
- */
126
- get databaseName() {
127
- if (!this._databaseName) {
128
- this.resolveDatabaseName();
129
- }
130
- return this._databaseName;
131
- }
132
- /**
133
- * Resolve database name either from config or uri
134
- */
135
- resolveDatabaseName() {
136
- if (this.config.database) {
137
- this._databaseName = this.config.database;
138
- }
139
- else if (this.config.uri) {
140
- this._databaseName = this.config.uri.split("/").pop()?.split("?")?.[0];
141
- }
142
- }
143
- /**
144
- * Indicates whether the driver currently maintains an active connection.
145
- */
146
- get isConnected() {
147
- return this.connected;
148
- }
149
- /**
150
- * Get the MongoDB database instance.
151
- *
152
- * @returns The MongoDB Db instance
153
- * @throws {Error} If not connected
154
- *
155
- * @example
156
- * ```typescript
157
- * const db = driver.getDatabase();
158
- * const collection = db.collection("users");
159
- * ```
160
- */
161
- getDatabase() {
162
- if (!this.database) {
163
- throw new Error("Database not available. Ensure the driver is connected before accessing the database.");
164
- }
165
- return this.database;
166
- }
167
- /**
168
- * Get the ID generator instance for this driver.
169
- *
170
- * Creates a MongoIdGenerator on first access if autoGenerateId is enabled.
171
- *
172
- * @returns The ID generator instance, or undefined if disabled
173
- *
174
- * @example
175
- * ```typescript
176
- * const idGenerator = driver.getIdGenerator();
177
- * if (idGenerator) {
178
- * const id = await idGenerator.generateNextId({ table: "users" });
179
- * }
180
- * ```
181
- */
182
- getIdGenerator() {
183
- // Return undefined if ID generation is disabled
184
- if (this.driverOptions?.autoGenerateId === false) {
185
- return undefined;
186
- }
187
- // Create ID generator lazily on first access
188
- if (!this.idGeneratorInstance) {
189
- this.idGeneratorInstance = new mongodbIdGenerator.MongoIdGenerator(this, this.driverOptions?.counterCollection);
190
- }
191
- return this.idGeneratorInstance;
192
- }
193
- /**
194
- * Establish a MongoDB connection using the configured options.
195
- * Throws if the connection attempt fails.
196
- */
197
- async connect() {
198
- if (this.connected) {
199
- return;
200
- }
201
- await assertModuleIsLoaded();
202
- const uri = this.resolveUri();
203
- const { MongoClient, ObjectId: ObjectIdMongoDB } = MongoDBClient;
204
- ObjectId = ObjectIdMongoDB;
205
- const client = new MongoClient(uri, this.buildClientOptions());
206
- try {
207
- logger.log.info("database.mongodb", "connection", `Connecting to database ${copper.colors.bold(copper.colors.yellowBright(this.databaseName))}`);
208
- await client.connect();
209
- this.client = client;
210
- this.database = client.db(this.databaseName);
211
- this.connected = true;
212
- logger.log.success("database.mongodb", "connection", "Connected to database");
213
- client.on("close", () => {
214
- if (this.connected) {
215
- this.connected = false;
216
- this.emit("disconnected");
217
- logger.log.warn("database.mongodb", "connection", "Disconnected from database");
218
- }
219
- });
220
- this.emit("connected");
221
- }
222
- catch (error) {
223
- await client.close().catch(() => undefined);
224
- this.emit("disconnected");
225
- logger.log.error("database.mongodb", "connection", `Failed to connect to database: ${error.message}`);
226
- throw error;
227
- }
228
- }
229
- /**
230
- * Close the underlying MongoDB connection.
231
- */
232
- async disconnect() {
233
- if (!this.client) {
234
- return;
235
- }
236
- try {
237
- await this.client.close();
238
- }
239
- finally {
240
- this.connected = false;
241
- this.emit("disconnected");
242
- }
243
- }
244
- /**
245
- * Subscribe to driver lifecycle events.
246
- */
247
- on(event, listener) {
248
- this.events.on(event, listener);
249
- }
250
- /**
251
- * Insert a single document into the given collection.
252
- */
253
- async insert(table, document, options) {
254
- const collection = this.getDatabaseInstance().collection(table);
255
- const mongoOptions = this.withSession(options);
256
- const result = await collection.insertOne(document, mongoOptions);
257
- return {
258
- document: {
259
- ...document,
260
- _id: result.insertedId,
261
- },
262
- };
263
- }
264
- /**
265
- * Insert multiple documents into the given collection.
266
- */
267
- async insertMany(table, documents, options) {
268
- const collection = this.getDatabaseInstance().collection(table);
269
- const mongoOptions = this.withSession(options);
270
- const result = await collection.insertMany(documents, mongoOptions);
271
- return documents.map((document, index) => {
272
- const insertedId = result.insertedIds[index];
273
- return {
274
- document: {
275
- ...document,
276
- _id: insertedId,
277
- },
278
- };
279
- });
280
- }
281
- /**
282
- * Update a single document that matches the provided filter.
283
- */
284
- async update(table, filter, update, options) {
285
- const collection = this.getDatabaseInstance().collection(table);
286
- const mongoOptions = this.withSession(options);
287
- const result = await collection.updateOne(filter, update, mongoOptions);
288
- return { modifiedCount: result.modifiedCount };
289
- }
290
- /**
291
- * Replace a single document that matches the provided filter.
292
- */
293
- async replace(table, filter, document, options) {
294
- const collection = this.getDatabaseInstance().collection(table);
295
- const result = await collection.findOneAndReplace(filter, document);
296
- return result?.value;
297
- }
298
- /**
299
- * Find one and update a single document that matches the provided filter and return the updated document
300
- */
301
- async findOneAndUpdate(table, filter, update, options) {
302
- const collection = this.getDatabaseInstance().collection(table);
303
- const mongoOptions = this.withSession(options);
304
- const result = await collection.findOneAndUpdate(filter, update, {
305
- returnDocument: "after",
306
- ...mongoOptions,
307
- });
308
- return result;
309
- }
310
- /**
311
- * Upsert (insert or update) a single document.
312
- *
313
- * Uses MongoDB's findOneAndUpdate with upsert option.
314
- *
315
- * @param table - Target collection name
316
- * @param filter - Filter conditions to find existing document
317
- * @param document - Document data to insert or update
318
- * @param options - Optional upsert options
319
- * @returns The upserted document
320
- */
321
- async upsert(table, filter, document, options) {
322
- const collection = this.getDatabaseInstance().collection(table);
323
- const mongoOptions = this.withSession(options);
324
- // Use $set to update all fields from document
325
- const update = { $set: document };
326
- const result = await collection.findOneAndUpdate(filter, update, {
327
- upsert: true,
328
- returnDocument: "after",
329
- ...mongoOptions,
330
- });
331
- return result;
332
- }
333
- /**
334
- * Find one and delete a single document that matches the provided filter and return the deleted document.
335
- *
336
- * @param table - Target collection name
337
- * @param filter - Filter conditions
338
- * @param options - Optional delete options
339
- * @returns The deleted document or null if not found
340
- */
341
- async findOneAndDelete(table, filter, options) {
342
- const collection = this.getDatabaseInstance().collection(table);
343
- const mongoOptions = this.withSession(options);
344
- const result = await collection.findOneAndDelete(filter, mongoOptions || {});
345
- return result;
346
- }
347
- /**
348
- * Update multiple documents that match the provided filter.
349
- */
350
- async updateMany(table, filter, update, options) {
351
- const collection = this.getDatabaseInstance().collection(table);
352
- const mongoOptions = this.withSession(options);
353
- const result = await collection.updateMany(filter, update, mongoOptions);
354
- return { modifiedCount: result.modifiedCount };
355
- }
356
- /**
357
- * Delete a single document that matches the provided filter.
358
- */
359
- async delete(table, filter = {}, options) {
360
- const collection = this.getDatabaseInstance().collection(table);
361
- const mongoOptions = this.withSession(options);
362
- const result = await collection.deleteOne(filter, mongoOptions);
363
- return result.deletedCount > 0 ? 1 : 0;
364
- }
365
- /**
366
- * Delete documents that match the provided filter.
367
- */
368
- async deleteMany(table, filter = {}, options) {
369
- const collection = this.getDatabaseInstance().collection(table);
370
- const mongoOptions = this.withSession(options);
371
- const result = await collection.deleteMany(filter, mongoOptions);
372
- return result.deletedCount ?? 0;
373
- }
374
- /**
375
- * Remove all records from a collection.
376
- *
377
- * This uses deleteMany with an empty filter to remove all documents.
378
- * For very large collections, consider using the migration driver's
379
- * dropTable + createTable approach for better performance.
380
- */
381
- async truncateTable(table, options) {
382
- const collection = this.getDatabaseInstance().collection(table);
383
- const mongoOptions = this.withSession(options);
384
- const result = await collection.deleteMany({}, mongoOptions);
385
- return result.deletedCount ?? 0;
386
- }
387
- /**
388
- * Serialize the given data
389
- */
390
- serialize(data) {
391
- for (const [key, value] of Object.entries(data)) {
392
- if (value === undefined) {
393
- continue; // Skip undefined values
394
- }
395
- if (value instanceof ObjectId) {
396
- value.toString();
397
- }
398
- else if (value instanceof Date) {
399
- value.toISOString();
400
- }
401
- else if (typeof value === "bigint") {
402
- value.toString();
403
- }
404
- else ;
405
- }
406
- return data;
407
- }
408
- /**
409
- * Get the dirty tracker for this driver.
410
- */
411
- getDirtyTracker(data) {
412
- return new databaseDirtyTracker.DatabaseDirtyTracker(data);
413
- }
414
- /**
415
- * Deserialize the given data
416
- */
417
- deserialize(data) {
418
- if (data._id && typeof data._id === "string") {
419
- data._id = new ObjectId(data._id);
420
- }
421
- for (const [key, value] of Object.entries(data)) {
422
- // Only re-inflate strings — Mongo driver already returns Date objects from DB reads
423
- if (typeof value === "string" && isValidDateValue.isValidDateValue(value)) {
424
- data[key] = new Date(value);
425
- }
426
- }
427
- return data;
428
- }
429
- /**
430
- * Provide a Mongo-backed query builder instance for the given collection.
431
- */
432
- queryBuilder(table) {
433
- return new mongodbQueryBuilder.MongoQueryBuilder(table, dataSourceRegistry.dataSourceRegistry.get());
434
- }
435
- /**
436
- * Begin a MongoDB transaction, returning commit/rollback helpers.
437
- */
438
- async beginTransaction() {
439
- const client = this.getClientInstance();
440
- const session = client.startSession();
441
- await session.startTransaction(this.transactionOptions);
442
- databaseTransactionContext.databaseTransactionContext.enter({ session });
443
- let finished = false;
444
- const finalize = async (operation) => {
445
- if (finished)
446
- return;
447
- try {
448
- await operation();
449
- }
450
- finally {
451
- finished = true;
452
- databaseTransactionContext.databaseTransactionContext.exit();
453
- await session.endSession().catch(() => undefined);
454
- }
455
- };
456
- return {
457
- context: session,
458
- commit: async () => {
459
- await finalize(async () => {
460
- try {
461
- await session.commitTransaction();
462
- }
463
- catch (error) {
464
- await session.abortTransaction().catch(() => undefined);
465
- throw error;
466
- }
467
- });
468
- },
469
- rollback: async () => {
470
- await finalize(async () => {
471
- await session.abortTransaction();
472
- });
473
- },
474
- };
475
- }
476
- /**
477
- * Execute a function within a transaction scope (recommended pattern).
478
- *
479
- * Automatically commits on success, rolls back on any error, and guarantees
480
- * resource cleanup. This is the recommended way to use transactions.
481
- *
482
- * **MongoDB Requirements:**
483
- * - Requires MongoDB 4.0+ with replica set or sharded cluster
484
- * - Standalone MongoDB instances do not support transactions
485
- *
486
- * @param fn - Async function to execute within transaction
487
- * @param options - Transaction options (read preference, write concern, etc.)
488
- * @returns The return value of the callback function
489
- * @throws {Error} If transaction fails, is explicitly rolled back, or replica set not configured
490
- */
491
- async transaction(fn, options) {
492
- // Prevent nested transaction() calls
493
- if (databaseTransactionContext.databaseTransactionContext.hasActiveTransaction()) {
494
- throw new Error("Nested transaction() calls are not supported. " +
495
- "Use beginTransaction() with savepoints for advanced transaction patterns.");
496
- }
497
- // Check if MongoDB is running as a replica set (required for transactions)
498
- await this.ensureReplicaSetAvailable();
499
- const client = this.getClientInstance();
500
- const session = client.startSession();
501
- try {
502
- await session.startTransaction({
503
- ...this.transactionOptions,
504
- ...options,
505
- });
506
- // Set transaction context for queries within callback
507
- databaseTransactionContext.databaseTransactionContext.enter({ session });
508
- try {
509
- // Create transaction context with rollback method
510
- const ctx = {
511
- rollback(reason) {
512
- throw new transactionRollback_error.TransactionRollbackError(reason);
513
- },
514
- };
515
- // Execute callback
516
- const result = await fn(ctx);
517
- // Auto-commit on success
518
- await session.commitTransaction();
519
- return result;
520
- }
521
- catch (error) {
522
- // Auto-rollback on any error (including explicit rollback)
523
- await session.abortTransaction().catch(() => undefined);
524
- throw error;
525
- }
526
- finally {
527
- // Guaranteed context cleanup
528
- databaseTransactionContext.databaseTransactionContext.exit();
529
- }
530
- }
531
- finally {
532
- // Guaranteed session cleanup
533
- await session.endSession().catch(() => undefined);
534
- }
535
- }
536
- /**
537
- * Execute atomic operations (typically $inc/$set style updates) against documents.
538
- *
539
- * Uses `updateMany` so callers can atomically modify any set of documents.
540
- */
541
- async atomic(table, filter, operations, options) {
542
- const collection = this.getDatabaseInstance().collection(table);
543
- const mongoOptions = this.withSession(options);
544
- const result = await collection.updateMany(filter, operations, mongoOptions);
545
- return { modifiedCount: result.modifiedCount };
546
- }
547
- /**
548
- * Lazily create (and cache) the Mongo sync adapter.
549
- * The adapter uses this driver instance to ensure all operations
550
- * participate in active transactions via the session context.
551
- */
552
- syncAdapter() {
553
- if (!this.syncAdapterInstance) {
554
- this.syncAdapterInstance = new mongodbSyncAdapter.MongoSyncAdapter(this);
555
- }
556
- return this.syncAdapterInstance;
557
- }
558
- /**
559
- * Lazily create (and cache) the Mongo migration driver.
560
- * The migration driver handles schema operations like indexes, collections, etc.
561
- */
562
- migrationDriver() {
563
- if (!this.migrationDriverInstance) {
564
- this.migrationDriverInstance = new mongodbMigrationDriver.MongoMigrationDriver(this);
565
- }
566
- return this.migrationDriverInstance;
567
- }
568
- /**
569
- * Expose the underlying Mongo client for advanced consumers.
570
- */
571
- getClient() {
572
- return this.getClientInstance();
573
- }
574
- /**
575
- * Retrieve the active Mongo client, throwing if the driver is disconnected.
576
- */
577
- getClientInstance() {
578
- if (!this.client) {
579
- throw new Error("Mongo driver is not connected.");
580
- }
581
- return this.client;
582
- }
583
- /**
584
- * Retrieve the active Mongo database, throwing if the driver is disconnected.
585
- * @private
586
- */
587
- getDatabaseInstance() {
588
- if (!this.database) {
589
- throw new Error("Mongo driver is not connected to a database.");
590
- }
591
- return this.database;
592
- }
593
- /**
594
- * Resolve the Mongo connection string based on provided options.
595
- */
596
- resolveUri() {
597
- if (this.config.uri) {
598
- return this.config.uri;
599
- }
600
- const host = this.config.host ?? "localhost";
601
- const port = this.config.port ?? 27017;
602
- return `mongodb://${host}:${port}`;
603
- }
604
- /**
605
- * Build the Mongo client options derived from the driver configuration.
606
- */
607
- buildClientOptions() {
608
- const baseOptions = {
609
- ...(this.config.clientOptions ?? {}),
610
- };
611
- if (this.config.username && !baseOptions.auth) {
612
- baseOptions.auth = {
613
- username: this.config.username,
614
- password: this.config.password,
615
- };
616
- }
617
- if (this.config.authSource && !baseOptions.authSource) {
618
- baseOptions.authSource = this.config.authSource;
619
- }
620
- return baseOptions;
621
- }
622
- /**
623
- * Emit a driver lifecycle event.
624
- */
625
- emit(event, ...args) {
626
- this.events.emit(event, ...args);
627
- }
628
- /**
629
- * Ensure MongoDB is running as a replica set (required for transactions).
630
- *
631
- * @throws {Error} If MongoDB is running as a standalone instance
632
- */
633
- async ensureReplicaSetAvailable() {
634
- try {
635
- const admin = this.database.admin();
636
- const status = await admin.serverStatus();
637
- if (!status.repl) {
638
- throw new Error("MongoDB transactions require a replica set or sharded cluster. " +
639
- "Standalone MongoDB instances do not support transactions.\n\n" +
640
- "For local development:\n" +
641
- " - Run MongoDB with --replSet flag: mongod --replSet rs0\n" +
642
- " - Or use Docker with replica set configuration\n" +
643
- " - Or use MongoDB Atlas (cloud) which provides replica sets by default");
644
- }
645
- }
646
- catch (error) {
647
- if (error.message?.includes("replica set")) {
648
- throw error;
649
- }
650
- throw new Error(`Failed to check MongoDB replica set status: ${error.message}`);
651
- }
652
- }
653
- /**
654
- * Attach the active transaction session (when available) to Mongo options.
655
- */
656
- withSession(options) {
657
- const session = databaseTransactionContext.databaseTransactionContext.getSession();
658
- if (!session) {
659
- return options;
660
- }
661
- const baseOptions = options ? { ...options } : {};
662
- baseOptions.session = session;
663
- return baseOptions;
664
- }
665
- // ============================================================
666
- // SQL Compatibility Operations (Not supported in MongoDB)
667
- // ============================================================
668
- /**
669
- * Return a SQL serializer for this driver's dialect.
670
- * Not supported for MongoDB.
671
- */
672
- getSQLSerializer() {
673
- throw new Error("MongoDB driver does not support SQL serialization.");
674
- }
675
- /**
676
- * Execute a raw SQL query.
677
- * Not supported for MongoDB.
678
- */
679
- async query(_sql, _params) {
680
- throw new Error("MongoDB driver does not support raw SQL queries.");
681
- }
682
- // ============================================================
683
- // Database Lifecycle Operations
684
- // ============================================================
685
- /**
686
- * Create a new database.
687
- *
688
- * In MongoDB, databases are created automatically when data is first written.
689
- * This method creates an empty collection to ensure the database exists.
690
- *
691
- * @param name - Database name to create
692
- * @returns true if created, false if already exists
693
- */
694
- async createDatabase(name) {
695
- const client = this.getClientInstance();
696
- // Check if database already exists
697
- if (await this.databaseExists(name)) {
698
- return false;
699
- }
700
- try {
701
- // MongoDB creates databases on first write, so create a system collection
702
- const db = client.db(name);
703
- await db.createCollection("__init__");
704
- // Drop the temp collection
705
- await db.collection("__init__").drop();
706
- logger.log.success("database", "lifecycle", `Created database ${name}`);
707
- return true;
708
- }
709
- catch (error) {
710
- logger.log.error("database", "lifecycle", `Failed to create database ${name}: ${error}`);
711
- throw error;
712
- }
713
- }
714
- /**
715
- * Drop a database.
716
- *
717
- * @param name - Database name to drop
718
- * @returns true if dropped, false if didn't exist
719
- */
720
- async dropDatabase(name) {
721
- const client = this.getClientInstance();
722
- // Check if database exists
723
- if (!(await this.databaseExists(name))) {
724
- return false;
725
- }
726
- try {
727
- await client.db(name).dropDatabase();
728
- logger.log.success("database", "lifecycle", `Dropped database ${name}`);
729
- return true;
730
- }
731
- catch (error) {
732
- logger.log.error("database", "lifecycle", `Failed to drop database ${name}: ${error}`);
733
- throw error;
734
- }
735
- }
736
- /**
737
- * Check if a database exists.
738
- *
739
- * @param name - Database name to check
740
- * @returns true if database exists
741
- */
742
- async databaseExists(name) {
743
- const client = this.getClientInstance();
744
- const result = await client.db("admin").admin().listDatabases();
745
- return result.databases.some((db) => db.name === name);
746
- }
747
- /**
748
- * List all databases.
749
- *
750
- * @returns Array of database names
751
- */
752
- async listDatabases() {
753
- const client = this.getClientInstance();
754
- const result = await client.db("admin").admin().listDatabases();
755
- return result.databases
756
- .map((db) => db.name)
757
- .filter((name) => !["admin", "local", "config"].includes(name));
758
- }
759
- // ============================================================
760
- // Table/Collection Management Operations
761
- // ============================================================
762
- /**
763
- * Drop a collection.
764
- *
765
- * @param name - Collection name to drop
766
- * @throws Error if collection doesn't exist
767
- */
768
- async dropTable(name) {
769
- const db = this.getDatabaseInstance();
770
- await db.collection(name).drop();
771
- logger.log.success("database", "collection", `Dropped collection ${name}`);
772
- }
773
- /**
774
- * Drop a collection if it exists.
775
- *
776
- * @param name - Collection name to drop
777
- */
778
- async dropTableIfExists(name) {
779
- if (await this.blueprint.tableExists(name)) {
780
- await this.dropTable(name);
781
- }
782
- }
783
- /**
784
- * Drop all collections in the current database.
785
- *
786
- * Useful for `migrate:fresh` command.
787
- */
788
- async dropAllTables() {
789
- const collections = await this.blueprint.listTables();
790
- if (collections.length === 0) {
791
- return;
792
- }
793
- const db = this.getDatabaseInstance();
794
- for (const collection of collections) {
795
- await db.collection(collection).drop();
796
- }
797
- logger.log.success("database", "collection", `Dropped ${collections.length} collections`);
798
- }
799
- }exports.MongoDbDriver=MongoDbDriver;exports.isMongoDBDriverLoaded=isMongoDBDriverLoaded;//# sourceMappingURL=mongodb-driver.js.map