sonamu 0.6.0 → 0.7.1

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 (406) hide show
  1. package/.swcrc.project-default +18 -0
  2. package/bin/cli.js +24 -0
  3. package/dist/ai/agents/agent.d.ts +11 -0
  4. package/dist/ai/agents/agent.d.ts.map +1 -0
  5. package/dist/ai/agents/agent.js +65 -0
  6. package/dist/ai/agents/index.d.ts +3 -0
  7. package/dist/ai/agents/index.d.ts.map +1 -0
  8. package/dist/ai/agents/index.js +4 -0
  9. package/dist/ai/agents/types.d.ts +43 -0
  10. package/dist/ai/agents/types.d.ts.map +1 -0
  11. package/dist/ai/agents/types.js +3 -0
  12. package/dist/ai/index.d.ts +2 -0
  13. package/dist/ai/index.d.ts.map +1 -0
  14. package/dist/ai/index.js +3 -0
  15. package/dist/ai/providers/rtzr/api.d.ts +22 -0
  16. package/dist/ai/providers/rtzr/api.d.ts.map +1 -0
  17. package/dist/ai/providers/rtzr/api.js +28 -0
  18. package/dist/ai/providers/rtzr/error.d.ts +18 -0
  19. package/dist/ai/providers/rtzr/error.d.ts.map +1 -0
  20. package/dist/ai/providers/rtzr/error.js +29 -0
  21. package/dist/ai/providers/rtzr/index.d.ts +5 -0
  22. package/dist/ai/providers/rtzr/index.d.ts.map +1 -0
  23. package/dist/ai/providers/rtzr/index.js +6 -0
  24. package/dist/ai/providers/rtzr/model.d.ts +52 -0
  25. package/dist/ai/providers/rtzr/model.d.ts.map +1 -0
  26. package/dist/ai/providers/rtzr/model.js +137 -0
  27. package/dist/ai/providers/rtzr/options.d.ts +7 -0
  28. package/dist/ai/providers/rtzr/options.d.ts.map +1 -0
  29. package/dist/ai/providers/rtzr/options.js +47 -0
  30. package/dist/ai/providers/rtzr/provider.d.ts +18 -0
  31. package/dist/ai/providers/rtzr/provider.d.ts.map +1 -0
  32. package/dist/ai/providers/rtzr/provider.js +54 -0
  33. package/dist/ai/providers/rtzr/utils.d.ts +19 -0
  34. package/dist/ai/providers/rtzr/utils.d.ts.map +1 -0
  35. package/dist/ai/providers/rtzr/utils.js +88 -0
  36. package/dist/api/base-frame.d.ts +2 -2
  37. package/dist/api/base-frame.d.ts.map +1 -1
  38. package/dist/api/base-frame.js +2 -1
  39. package/dist/api/caster.d.ts.map +1 -1
  40. package/dist/api/caster.js +6 -1
  41. package/dist/api/code-converters.d.ts +58 -14
  42. package/dist/api/code-converters.d.ts.map +1 -1
  43. package/dist/api/code-converters.js +178 -409
  44. package/dist/api/config.d.ts +27 -13
  45. package/dist/api/config.d.ts.map +1 -1
  46. package/dist/api/config.js +19 -26
  47. package/dist/api/context.d.ts +4 -3
  48. package/dist/api/context.d.ts.map +1 -1
  49. package/dist/api/context.js +1 -1
  50. package/dist/api/decorators.d.ts +20 -6
  51. package/dist/api/decorators.d.ts.map +1 -1
  52. package/dist/api/decorators.js +111 -18
  53. package/dist/api/index.d.ts +2 -2
  54. package/dist/api/index.d.ts.map +1 -1
  55. package/dist/api/index.js +3 -3
  56. package/dist/api/sonamu.d.ts +7 -7
  57. package/dist/api/sonamu.d.ts.map +1 -1
  58. package/dist/api/sonamu.js +83 -51
  59. package/dist/api/validator.d.ts +6 -0
  60. package/dist/api/validator.d.ts.map +1 -0
  61. package/dist/api/validator.js +81 -0
  62. package/dist/bin/build-config.d.ts +5 -1
  63. package/dist/bin/build-config.d.ts.map +1 -1
  64. package/dist/bin/build-config.js +5 -2
  65. package/dist/bin/cli.js +165 -64
  66. package/dist/bin/loader-register.d.ts +2 -0
  67. package/dist/bin/loader-register.d.ts.map +1 -0
  68. package/dist/bin/loader-register.js +34 -0
  69. package/dist/database/_batch_update.d.ts +5 -3
  70. package/dist/database/_batch_update.d.ts.map +1 -1
  71. package/dist/database/_batch_update.js +30 -13
  72. package/dist/database/base-model.d.ts +96 -10
  73. package/dist/database/base-model.d.ts.map +1 -1
  74. package/dist/database/base-model.js +232 -89
  75. package/dist/database/base-model.types.d.ts +93 -0
  76. package/dist/database/base-model.types.d.ts.map +1 -0
  77. package/dist/database/base-model.types.js +10 -0
  78. package/dist/database/code-generator.d.ts +1 -1
  79. package/dist/database/code-generator.d.ts.map +1 -1
  80. package/dist/database/code-generator.js +11 -10
  81. package/dist/database/db.d.ts +5 -6
  82. package/dist/database/db.d.ts.map +1 -1
  83. package/dist/database/db.js +22 -25
  84. package/dist/database/puri-subset.test-d.js +81 -0
  85. package/dist/database/puri-subset.types.d.ts +123 -0
  86. package/dist/database/puri-subset.types.d.ts.map +1 -0
  87. package/dist/database/puri-subset.types.js +16 -0
  88. package/dist/database/puri-wrapper.d.ts +13 -11
  89. package/dist/database/puri-wrapper.d.ts.map +1 -1
  90. package/dist/database/puri-wrapper.js +2 -2
  91. package/dist/database/puri.d.ts +25 -14
  92. package/dist/database/puri.d.ts.map +1 -1
  93. package/dist/database/puri.js +83 -21
  94. package/dist/database/puri.types.d.ts +21 -7
  95. package/dist/database/puri.types.d.ts.map +1 -1
  96. package/dist/database/puri.types.js +4 -1
  97. package/dist/database/transaction-context.d.ts +1 -1
  98. package/dist/database/transaction-context.d.ts.map +1 -1
  99. package/dist/database/transaction-context.js +1 -1
  100. package/dist/database/upsert-builder.d.ts +9 -3
  101. package/dist/database/upsert-builder.d.ts.map +1 -1
  102. package/dist/database/upsert-builder.js +227 -78
  103. package/dist/entity/entity-manager.d.ts +165 -2
  104. package/dist/entity/entity-manager.d.ts.map +1 -1
  105. package/dist/entity/entity-manager.js +26 -10
  106. package/dist/entity/entity.d.ts +5 -3
  107. package/dist/entity/entity.d.ts.map +1 -1
  108. package/dist/entity/entity.js +153 -54
  109. package/dist/exceptions/error-handler.d.ts +1 -1
  110. package/dist/exceptions/error-handler.d.ts.map +1 -1
  111. package/dist/exceptions/error-handler.js +1 -1
  112. package/dist/exceptions/so-exceptions.d.ts +1 -1
  113. package/dist/exceptions/so-exceptions.d.ts.map +1 -1
  114. package/dist/exceptions/so-exceptions.js +1 -1
  115. package/dist/file-storage/driver.d.ts +1 -1
  116. package/dist/file-storage/driver.d.ts.map +1 -1
  117. package/dist/file-storage/driver.js +1 -1
  118. package/dist/file-storage/file-storage.js +2 -2
  119. package/dist/index.d.ts +18 -11
  120. package/dist/index.d.ts.map +1 -1
  121. package/dist/index.js +19 -13
  122. package/dist/migration/code-generation.d.ts +1 -1
  123. package/dist/migration/code-generation.d.ts.map +1 -1
  124. package/dist/migration/code-generation.js +123 -67
  125. package/dist/migration/migration-set.d.ts +2 -10
  126. package/dist/migration/migration-set.d.ts.map +1 -1
  127. package/dist/migration/migration-set.js +67 -218
  128. package/dist/migration/migrator.d.ts +24 -73
  129. package/dist/migration/migrator.d.ts.map +1 -1
  130. package/dist/migration/migrator.js +121 -301
  131. package/dist/migration/postgresql-schema-reader.d.ts +51 -0
  132. package/dist/migration/postgresql-schema-reader.d.ts.map +1 -0
  133. package/dist/migration/postgresql-schema-reader.js +245 -0
  134. package/dist/migration/types.d.ts +6 -38
  135. package/dist/migration/types.d.ts.map +1 -1
  136. package/dist/migration/types.js +1 -1
  137. package/dist/naite/messaging-types.d.ts +43 -0
  138. package/dist/naite/messaging-types.d.ts.map +1 -0
  139. package/dist/naite/messaging-types.js +7 -0
  140. package/dist/naite/naite-reporter.d.ts +41 -0
  141. package/dist/naite/naite-reporter.d.ts.map +1 -0
  142. package/dist/naite/naite-reporter.js +102 -0
  143. package/dist/naite/naite.d.ts +91 -8
  144. package/dist/naite/naite.d.ts.map +1 -1
  145. package/dist/naite/naite.js +285 -41
  146. package/dist/stream/sse.d.ts +2 -2
  147. package/dist/stream/sse.d.ts.map +1 -1
  148. package/dist/stream/sse.js +1 -1
  149. package/dist/syncer/api-parser.d.ts +3 -13
  150. package/dist/syncer/api-parser.d.ts.map +1 -1
  151. package/dist/syncer/api-parser.js +67 -56
  152. package/dist/syncer/checksum.d.ts +2 -2
  153. package/dist/syncer/checksum.d.ts.map +1 -1
  154. package/dist/syncer/checksum.js +11 -11
  155. package/dist/syncer/code-generator.d.ts +3 -3
  156. package/dist/syncer/code-generator.d.ts.map +1 -1
  157. package/dist/syncer/code-generator.js +37 -17
  158. package/dist/syncer/entity-operations.d.ts +2 -2
  159. package/dist/syncer/entity-operations.d.ts.map +1 -1
  160. package/dist/syncer/entity-operations.js +9 -8
  161. package/dist/syncer/file-patterns.d.ts +1 -1
  162. package/dist/syncer/file-patterns.d.ts.map +1 -1
  163. package/dist/syncer/file-patterns.js +1 -1
  164. package/dist/syncer/index.d.ts +4 -4
  165. package/dist/syncer/index.d.ts.map +1 -1
  166. package/dist/syncer/index.js +5 -5
  167. package/dist/syncer/module-loader.d.ts +4 -4
  168. package/dist/syncer/module-loader.d.ts.map +1 -1
  169. package/dist/syncer/module-loader.js +17 -12
  170. package/dist/syncer/syncer.d.ts +31 -24
  171. package/dist/syncer/syncer.d.ts.map +1 -1
  172. package/dist/syncer/syncer.js +92 -45
  173. package/dist/template/entity-converter.d.ts +1 -1
  174. package/dist/template/entity-converter.d.ts.map +1 -1
  175. package/dist/template/entity-converter.js +15 -8
  176. package/dist/template/helpers.d.ts +2 -2
  177. package/dist/template/helpers.d.ts.map +1 -1
  178. package/dist/template/helpers.js +3 -3
  179. package/dist/template/implementations/entity.template.d.ts +2 -2
  180. package/dist/template/implementations/entity.template.d.ts.map +1 -1
  181. package/dist/template/implementations/entity.template.js +4 -5
  182. package/dist/template/implementations/generated.template.d.ts +2 -3
  183. package/dist/template/implementations/generated.template.d.ts.map +1 -1
  184. package/dist/template/implementations/generated.template.js +46 -29
  185. package/dist/template/implementations/generated_http.template.d.ts +2 -3
  186. package/dist/template/implementations/generated_http.template.d.ts.map +1 -1
  187. package/dist/template/implementations/generated_http.template.js +9 -9
  188. package/dist/template/implementations/generated_sso.template.d.ts +3 -4
  189. package/dist/template/implementations/generated_sso.template.d.ts.map +1 -1
  190. package/dist/template/implementations/generated_sso.template.js +54 -25
  191. package/dist/template/implementations/init_types.template.d.ts +2 -2
  192. package/dist/template/implementations/init_types.template.d.ts.map +1 -1
  193. package/dist/template/implementations/init_types.template.js +2 -2
  194. package/dist/template/implementations/model.template.d.ts +2 -2
  195. package/dist/template/implementations/model.template.d.ts.map +1 -1
  196. package/dist/template/implementations/model.template.js +47 -37
  197. package/dist/template/implementations/model_test.template.d.ts +2 -2
  198. package/dist/template/implementations/model_test.template.d.ts.map +1 -1
  199. package/dist/template/implementations/model_test.template.js +2 -2
  200. package/dist/template/implementations/service.template.d.ts +4 -4
  201. package/dist/template/implementations/service.template.d.ts.map +1 -1
  202. package/dist/template/implementations/service.template.js +24 -16
  203. package/dist/template/implementations/view_enums_buttonset.template.d.ts +2 -2
  204. package/dist/template/implementations/view_enums_buttonset.template.d.ts.map +1 -1
  205. package/dist/template/implementations/view_enums_buttonset.template.js +1 -1
  206. package/dist/template/implementations/view_enums_dropdown.template.d.ts +2 -2
  207. package/dist/template/implementations/view_enums_dropdown.template.d.ts.map +1 -1
  208. package/dist/template/implementations/view_enums_dropdown.template.js +2 -2
  209. package/dist/template/implementations/view_enums_select.template.d.ts +2 -2
  210. package/dist/template/implementations/view_enums_select.template.d.ts.map +1 -1
  211. package/dist/template/implementations/view_enums_select.template.js +2 -2
  212. package/dist/template/implementations/view_form.template.d.ts +2 -2
  213. package/dist/template/implementations/view_form.template.d.ts.map +1 -1
  214. package/dist/template/implementations/view_form.template.js +4 -4
  215. package/dist/template/implementations/view_id_all_select.template.d.ts +2 -2
  216. package/dist/template/implementations/view_id_all_select.template.d.ts.map +1 -1
  217. package/dist/template/implementations/view_id_all_select.template.js +1 -1
  218. package/dist/template/implementations/view_id_async_select.template.d.ts +2 -2
  219. package/dist/template/implementations/view_id_async_select.template.d.ts.map +1 -1
  220. package/dist/template/implementations/view_id_async_select.template.js +1 -1
  221. package/dist/template/implementations/view_list.template.d.ts +2 -2
  222. package/dist/template/implementations/view_list.template.d.ts.map +1 -1
  223. package/dist/template/implementations/view_list.template.js +29 -19
  224. package/dist/template/implementations/view_list_columns.template.d.ts +3 -3
  225. package/dist/template/implementations/view_list_columns.template.d.ts.map +1 -1
  226. package/dist/template/implementations/view_list_columns.template.js +1 -1
  227. package/dist/template/implementations/view_search_input.template.d.ts +2 -2
  228. package/dist/template/implementations/view_search_input.template.d.ts.map +1 -1
  229. package/dist/template/implementations/view_search_input.template.js +1 -1
  230. package/dist/template/index.d.ts +4 -2
  231. package/dist/template/index.d.ts.map +1 -1
  232. package/dist/template/index.js +5 -3
  233. package/dist/template/template-manager.d.ts +56 -0
  234. package/dist/template/template-manager.d.ts.map +1 -0
  235. package/dist/template/template-manager.js +125 -0
  236. package/dist/template/template-types.d.ts +16 -0
  237. package/dist/template/template-types.d.ts.map +1 -0
  238. package/dist/template/template-types.js +7 -0
  239. package/dist/template/template.d.ts +12 -2
  240. package/dist/template/template.d.ts.map +1 -1
  241. package/dist/template/template.js +19 -6
  242. package/dist/template/zod-converter.d.ts +40 -7
  243. package/dist/template/zod-converter.d.ts.map +1 -1
  244. package/dist/template/zod-converter.js +386 -58
  245. package/dist/testing/_relation-graph.d.ts +1 -1
  246. package/dist/testing/_relation-graph.d.ts.map +1 -1
  247. package/dist/testing/_relation-graph.js +12 -3
  248. package/dist/testing/fixture-manager.d.ts +42 -11
  249. package/dist/testing/fixture-manager.d.ts.map +1 -1
  250. package/dist/testing/fixture-manager.js +338 -236
  251. package/dist/types/types.d.ts +709 -104
  252. package/dist/types/types.d.ts.map +1 -1
  253. package/dist/types/types.js +309 -52
  254. package/dist/typings/knex.d.js +2 -2
  255. package/dist/utils/async-utils.d.ts.map +1 -1
  256. package/dist/utils/async-utils.js +3 -3
  257. package/dist/utils/console-util.js +1 -1
  258. package/dist/utils/controller.d.ts +1 -0
  259. package/dist/utils/controller.d.ts.map +1 -1
  260. package/dist/utils/controller.js +4 -1
  261. package/dist/utils/esm-utils.d.ts +0 -6
  262. package/dist/utils/esm-utils.d.ts.map +1 -1
  263. package/dist/utils/esm-utils.js +2 -9
  264. package/dist/utils/formatter.d.ts +3 -0
  265. package/dist/utils/formatter.d.ts.map +1 -0
  266. package/dist/utils/formatter.js +110 -0
  267. package/dist/utils/fs-utils.d.ts +1 -1
  268. package/dist/utils/fs-utils.d.ts.map +1 -1
  269. package/dist/utils/fs-utils.js +1 -1
  270. package/dist/utils/lodash-able.d.ts.map +1 -1
  271. package/dist/utils/lodash-able.js +1 -1
  272. package/dist/utils/object-utils.d.ts +44 -0
  273. package/dist/utils/object-utils.d.ts.map +1 -0
  274. package/dist/utils/object-utils.js +191 -0
  275. package/dist/utils/path-utils.d.ts +1 -1
  276. package/dist/utils/path-utils.d.ts.map +1 -1
  277. package/dist/utils/path-utils.js +3 -3
  278. package/dist/utils/process-utils.js +1 -1
  279. package/dist/utils/sql-parser.d.ts +5 -1
  280. package/dist/utils/sql-parser.d.ts.map +1 -1
  281. package/dist/utils/sql-parser.js +14 -3
  282. package/dist/utils/type-utils.d.ts +23 -0
  283. package/dist/utils/type-utils.d.ts.map +1 -0
  284. package/dist/utils/type-utils.js +45 -0
  285. package/dist/utils/utils.d.ts +7 -1
  286. package/dist/utils/utils.d.ts.map +1 -1
  287. package/dist/utils/utils.js +44 -5
  288. package/dist/utils/zod-error.d.ts +1 -1
  289. package/dist/utils/zod-error.d.ts.map +1 -1
  290. package/dist/utils/zod-error.js +1 -1
  291. package/package.json +55 -30
  292. package/src/ai/agents/agent.ts +87 -0
  293. package/src/ai/agents/index.ts +2 -0
  294. package/src/ai/agents/types.ts +47 -0
  295. package/src/ai/index.ts +1 -0
  296. package/src/ai/providers/rtzr/api.ts +37 -0
  297. package/src/ai/providers/rtzr/error.ts +34 -0
  298. package/src/ai/providers/rtzr/index.ts +4 -0
  299. package/src/ai/providers/rtzr/model.ts +201 -0
  300. package/src/ai/providers/rtzr/options.ts +49 -0
  301. package/src/ai/providers/rtzr/provider.ts +91 -0
  302. package/src/ai/providers/rtzr/utils.ts +127 -0
  303. package/src/api/base-frame.ts +4 -2
  304. package/src/api/caster.ts +17 -23
  305. package/src/api/code-converters.ts +176 -533
  306. package/src/api/config.ts +39 -56
  307. package/src/api/context.ts +7 -18
  308. package/src/api/decorators.ts +175 -46
  309. package/src/api/index.ts +2 -2
  310. package/src/api/sonamu.ts +133 -124
  311. package/src/api/validator.ts +83 -0
  312. package/src/bin/build-config.ts +7 -1
  313. package/src/bin/cli.ts +192 -110
  314. package/src/bin/loader-register.ts +38 -0
  315. package/src/database/_batch_update.ts +46 -31
  316. package/src/database/base-model.ts +390 -182
  317. package/src/database/base-model.types.ts +155 -0
  318. package/src/database/code-generator.ts +13 -32
  319. package/src/database/db.ts +36 -50
  320. package/src/database/puri-subset.test-d.ts +471 -0
  321. package/src/database/puri-subset.types.ts +195 -0
  322. package/src/database/puri-wrapper.ts +58 -67
  323. package/src/database/puri.ts +182 -126
  324. package/src/database/puri.types.ts +64 -31
  325. package/src/database/transaction-context.ts +1 -1
  326. package/src/database/upsert-builder.ts +261 -132
  327. package/src/entity/entity-manager.ts +36 -28
  328. package/src/entity/entity.ts +330 -249
  329. package/src/exceptions/error-handler.ts +3 -3
  330. package/src/exceptions/so-exceptions.ts +11 -11
  331. package/src/file-storage/driver.ts +5 -5
  332. package/src/file-storage/file-storage.ts +2 -2
  333. package/src/index.ts +18 -12
  334. package/src/migration/code-generation.ts +185 -172
  335. package/src/migration/migration-set.ts +80 -293
  336. package/src/migration/migrator.ts +182 -425
  337. package/src/migration/mysql-schema-reader.ts.txt +272 -0
  338. package/src/migration/postgresql-schema-reader.ts +310 -0
  339. package/src/migration/types.ts +6 -39
  340. package/src/naite/messaging-types.ts +51 -0
  341. package/src/naite/naite-reporter.ts +128 -0
  342. package/src/naite/naite.ts +378 -33
  343. package/src/shared/web.shared.ts.txt +20 -24
  344. package/src/stream/sse.ts +5 -5
  345. package/src/syncer/api-parser.ts +52 -69
  346. package/src/syncer/checksum.ts +25 -37
  347. package/src/syncer/code-generator.ts +58 -62
  348. package/src/syncer/entity-operations.ts +12 -15
  349. package/src/syncer/file-patterns.ts +2 -2
  350. package/src/syncer/index.ts +4 -4
  351. package/src/syncer/module-loader.ts +28 -25
  352. package/src/syncer/syncer.ts +155 -162
  353. package/src/template/entity-converter.ts +18 -27
  354. package/src/template/helpers.ts +8 -11
  355. package/src/template/implementations/entity.template.ts +6 -6
  356. package/src/template/implementations/generated.template.ts +99 -99
  357. package/src/template/implementations/generated_http.template.ts +21 -54
  358. package/src/template/implementations/generated_sso.template.ts +78 -65
  359. package/src/template/implementations/init_types.template.ts +4 -6
  360. package/src/template/implementations/model.template.ts +47 -38
  361. package/src/template/implementations/model_test.template.ts +3 -3
  362. package/src/template/implementations/service.template.ts +56 -80
  363. package/src/template/implementations/view_enums_buttonset.template.ts +2 -2
  364. package/src/template/implementations/view_enums_dropdown.template.ts +4 -4
  365. package/src/template/implementations/view_enums_select.template.ts +3 -3
  366. package/src/template/implementations/view_form.template.ts +34 -75
  367. package/src/template/implementations/view_id_all_select.template.ts +2 -2
  368. package/src/template/implementations/view_id_async_select.template.ts +9 -23
  369. package/src/template/implementations/view_list.template.ts +54 -95
  370. package/src/template/implementations/view_list_columns.template.ts +4 -10
  371. package/src/template/implementations/view_search_input.template.ts +2 -2
  372. package/src/template/index.ts +4 -2
  373. package/src/template/template-manager.ts +166 -0
  374. package/src/template/template-types.ts +16 -0
  375. package/src/template/template.ts +29 -10
  376. package/src/template/zod-converter.ts +459 -101
  377. package/src/testing/_relation-graph.ts +18 -11
  378. package/src/testing/fixture-manager.ts +468 -362
  379. package/src/types/types.ts +516 -248
  380. package/src/typings/knex.d.ts +7 -9
  381. package/src/utils/async-utils.ts +8 -12
  382. package/src/utils/console-util.ts +1 -1
  383. package/src/utils/controller.ts +3 -0
  384. package/src/utils/esm-utils.ts +8 -18
  385. package/src/utils/formatter.ts +109 -0
  386. package/src/utils/fs-utils.ts +1 -1
  387. package/src/utils/lodash-able.ts +1 -4
  388. package/src/utils/object-utils.ts +217 -0
  389. package/src/utils/path-utils.ts +3 -6
  390. package/src/utils/process-utils.ts +1 -1
  391. package/src/utils/sql-parser.ts +23 -5
  392. package/src/utils/type-utils.ts +83 -0
  393. package/src/utils/utils.ts +58 -9
  394. package/src/utils/zod-error.ts +3 -3
  395. package/dist/bin/cli-wrapper.d.ts +0 -3
  396. package/dist/bin/cli-wrapper.d.ts.map +0 -1
  397. package/dist/bin/cli-wrapper.js +0 -72
  398. package/dist/database/knex-plugins/knex-on-duplicate-update.d.ts +0 -2
  399. package/dist/database/knex-plugins/knex-on-duplicate-update.d.ts.map +0 -1
  400. package/dist/database/knex-plugins/knex-on-duplicate-update.js +0 -39
  401. package/dist/entity/entity-utils.d.ts +0 -61
  402. package/dist/entity/entity-utils.d.ts.map +0 -1
  403. package/dist/entity/entity-utils.js +0 -210
  404. package/src/bin/cli-wrapper.ts +0 -82
  405. package/src/database/knex-plugins/knex-on-duplicate-update.ts +0 -45
  406. package/src/entity/entity-utils.ts +0 -291
@@ -1,274 +1,32 @@
1
- import { Knex } from "knex";
2
- import { DBColumn, DBForeign, DBIndex } from "./types";
3
- import * as _ from "lodash-es";
4
1
  import inflection from "inflection";
5
- import { Entity } from "../entity/entity";
2
+ import type { Entity } from "../entity/entity";
6
3
  import { EntityManager } from "../entity/entity-manager";
7
4
  import {
8
- isKnexError,
9
- MigrationSet,
10
- RelationOn,
5
+ type EntityProp,
11
6
  isBelongsToOneRelationProp,
12
- isDecimalProp,
13
- isEnumProp,
14
- isFloatProp,
15
7
  isHasManyRelationProp,
16
- isIntegerProp,
17
8
  isManyToManyRelationProp,
9
+ isNumberProp,
10
+ isNumericProp,
18
11
  isOneToOneRelationProp,
19
12
  isRelationProp,
20
13
  isStringProp,
21
- isTextProp,
22
14
  isVirtualProp,
23
- KnexColumnType,
24
- MigrationColumn,
25
- MigrationForeign,
26
- MigrationIndex,
27
- MigrationJoinTable,
28
- MigrationSetAndJoinTable,
15
+ type MigrationColumn,
16
+ type MigrationColumnType,
17
+ type MigrationForeign,
18
+ type MigrationIndex,
19
+ type MigrationJoinTable,
20
+ type MigrationSetAndJoinTable,
29
21
  } from "../types/types";
30
-
31
- /**
32
- * DB에서 테이블 정보를 읽어서 MigrationSet을 만들어옵니다.
33
- * @param compareDB Knex 인스턴스
34
- * @param table 테이블 이름
35
- * @returns MigrationSet 객체
36
- */
37
- export async function getMigrationSetFromDB(
38
- compareDB: Knex,
39
- table: string
40
- ): Promise<MigrationSet | null> {
41
- let dbColumns: DBColumn[], dbIndexes: DBIndex[], dbForeigns: DBForeign[];
42
- try {
43
- [dbColumns, dbIndexes, dbForeigns] = await readTable(compareDB, table);
44
- } catch (e: unknown) {
45
- if (isKnexError(e) && e.code === "ER_NO_SUCH_TABLE") {
46
- return null;
47
- }
48
- console.error(e);
49
- return null;
50
- }
51
-
52
- const columns: MigrationColumn[] = dbColumns.map((dbColumn) => {
53
- const dbColType = resolveDBColType(dbColumn.Type, dbColumn.Field);
54
- return {
55
- name: dbColumn.Field,
56
- nullable: dbColumn.Null !== "NO",
57
- ...dbColType,
58
- ...(() => {
59
- if (dbColumn.Default !== null) {
60
- return {
61
- defaultTo: dbColumn.Default,
62
- };
63
- }
64
- return {};
65
- })(),
66
- };
67
- });
68
-
69
- const dbIndexesGroup = _.groupBy(
70
- dbIndexes.filter(
71
- (dbIndex) =>
72
- dbIndex.Key_name !== "PRIMARY" &&
73
- !dbForeigns.find((dbForeign) => dbForeign.keyName === dbIndex.Key_name)
74
- ),
75
- (dbIndex) => dbIndex.Key_name
76
- );
77
-
78
- const parseIndexType = (index: DBIndex) => {
79
- if (index.Index_type === "FULLTEXT") {
80
- return "fulltext";
81
- }
82
- return index.Non_unique === 1 ? "index" : "unique";
83
- };
84
-
85
- // indexes 처리
86
- const indexes: MigrationIndex[] = Object.keys(dbIndexesGroup).map(
87
- (keyName) => {
88
- const currentIndexes = dbIndexesGroup[keyName];
89
- return {
90
- type: parseIndexType(currentIndexes[0]),
91
- columns: currentIndexes.map((currentIndex) => currentIndex.Column_name),
92
- };
93
- }
94
- );
95
- // console.log(table);
96
- // console.table(dbIndexes);
97
- // console.table(dbForeigns);
98
-
99
- // foreigns 처리
100
- const foreigns: MigrationForeign[] = dbForeigns.map((dbForeign) => {
101
- return {
102
- columns: [dbForeign.from],
103
- to: `${dbForeign.referencesTable}.${dbForeign.referencesField}`,
104
- onUpdate: dbForeign.onUpdate as RelationOn,
105
- onDelete: dbForeign.onDelete as RelationOn,
106
- };
107
- });
108
-
109
- return {
110
- table,
111
- columns,
112
- indexes,
113
- foreigns,
114
- };
115
- }
116
-
117
- /*
118
- * 기존 테이블 읽어서 cols, indexes 반환
119
- */
120
- async function readTable(
121
- compareDB: Knex,
122
- tableName: string
123
- ): Promise<[DBColumn[], DBIndex[], DBForeign[]]> {
124
- // 테이블 정보
125
- try {
126
- const [_cols] = (await compareDB.raw(`SHOW FIELDS FROM ${tableName}`)) as [
127
- DBColumn[],
128
- ];
129
- const cols = _cols.map((col) => ({
130
- ...col,
131
- // Default 값은 숫자나 MySQL Expression이 아닌 경우 ""로 감싸줌
132
- ...(col.Default !== null && {
133
- Default:
134
- col.Default.replace(/[0-9]+/g, "").length > 0 &&
135
- col.Extra !== "DEFAULT_GENERATED"
136
- ? `"${col.Default}"`
137
- : col.Default,
138
- }),
139
- }));
140
-
141
- const [indexes] = await compareDB.raw(`SHOW INDEX FROM ${tableName}`);
142
- const [[row]] = await compareDB.raw(`SHOW CREATE TABLE ${tableName}`);
143
- const ddl = row["Create Table"];
144
- const matched = ddl.match(/CONSTRAINT .+/g);
145
- const foreignKeys = (matched ?? []).map((line: string) => {
146
- // 해당 라인을 정규식으로 파싱
147
- const matched = line.match(
148
- /CONSTRAINT `(.+)` FOREIGN KEY \(`(.+)`\) REFERENCES `(.+)` \(`(.+)`\)( ON [A-Z ]+)*/
149
- );
150
- if (!matched) {
151
- throw new Error(`인식할 수 없는 FOREIGN KEY CONSTRAINT ${line}`);
152
- }
153
- const [, keyName, from, referencesTable, referencesField, onClause] =
154
- matched;
155
- // console.debug({ tableName, line, onClause });
156
-
157
- const [onUpdateFull, _onUpdate] =
158
- (onClause ?? "").match(/ON UPDATE ([A-Z ]+)$/) ?? [];
159
- const onUpdate = _onUpdate ?? "NO ACTION";
160
-
161
- const onDelete =
162
- (onClause ?? "")
163
- .replace(onUpdateFull ?? "", "")
164
- .match(/ON DELETE ([A-Z ]+)/)?.[1]
165
- ?.trim() ?? "NO ACTION";
166
-
167
- return {
168
- keyName,
169
- from,
170
- referencesTable,
171
- referencesField,
172
- onDelete,
173
- onUpdate,
174
- };
175
- });
176
- return [cols, indexes, foreignKeys];
177
- } catch (e) {
178
- throw e;
179
- }
180
- }
181
-
182
- function resolveDBColType(
183
- colType: string,
184
- colField: string
185
- ): Pick<
186
- MigrationColumn,
187
- "type" | "unsigned" | "length" | "precision" | "scale"
188
- > {
189
- let [rawType, unsigned] = colType.split(" ");
190
- const matched = rawType.match(/\(([0-9]+)\)/);
191
- let length;
192
- if (matched !== null && matched[1]) {
193
- rawType = rawType.replace(/\(([0-9]+)\)/, "");
194
- length = parseInt(matched[1]);
195
- }
196
-
197
- if (rawType === "char" && colField === "uuid") {
198
- return {
199
- type: "uuid",
200
- };
201
- }
202
-
203
- switch (rawType) {
204
- case "int":
205
- return {
206
- type: "integer",
207
- unsigned: unsigned === "unsigned",
208
- };
209
- case "varchar":
210
- // case "char":
211
- return {
212
- type: "string",
213
- ...(length !== undefined && {
214
- length,
215
- }),
216
- };
217
- case "text":
218
- case "mediumtext":
219
- case "longtext":
220
- case "timestamp":
221
- case "json":
222
- case "date":
223
- case "time":
224
- return {
225
- type: rawType,
226
- };
227
- case "datetime":
228
- return {
229
- type: "datetime",
230
- };
231
- case "tinyint":
232
- return {
233
- type: "boolean",
234
- };
235
- default:
236
- // decimal 처리
237
- if (rawType.startsWith("decimal")) {
238
- const [, precision, scale] =
239
- rawType.match(/decimal\(([0-9]+),([0-9]+)\)/) ?? [];
240
- return {
241
- type: "decimal",
242
- precision: parseInt(precision),
243
- scale: parseInt(scale),
244
- ...(unsigned === "unsigned" && {
245
- unsigned: true,
246
- }),
247
- };
248
- } else if (rawType.startsWith("float")) {
249
- const [, precision, scale] =
250
- rawType.match(/float\(([0-9]+),([0-9]+)\)/) ?? [];
251
- return {
252
- type: "float",
253
- precision: parseInt(precision),
254
- scale: parseInt(scale),
255
- ...(unsigned === "unsigned" && {
256
- unsigned: true,
257
- }),
258
- };
259
- }
260
- throw new Error(`resolve 불가능한 DB컬럼 타입 ${colType} ${rawType}`);
261
- }
262
- }
22
+ import { exhaustive } from "../utils/utils";
263
23
 
264
24
  /**
265
25
  * Entity를 읽어서 MigrationSetAndJoinTable을 만들어옵니다.
266
26
  * @param entity Entity 객체
267
27
  * @returns MigrationSetAndJoinTable 객체
268
28
  */
269
- export function getMigrationSetFromEntity(
270
- entity: Entity
271
- ): MigrationSetAndJoinTable {
29
+ export function getMigrationSetFromEntity(entity: Entity): MigrationSetAndJoinTable {
272
30
  const migrationSet: MigrationSetAndJoinTable = entity.props.reduce(
273
31
  (r, prop) => {
274
32
  // virtual 필드 제외
@@ -282,23 +40,9 @@ export function getMigrationSetFromEntity(
282
40
 
283
41
  // 일반 컬럼
284
42
  if (!isRelationProp(prop)) {
285
- // type resolve
286
- let type: KnexColumnType;
287
- if (isTextProp(prop)) {
288
- type = prop.textType;
289
- } else if (isEnumProp(prop)) {
290
- type = "string";
291
- } else {
292
- type = prop.type as KnexColumnType;
293
- }
294
-
295
43
  const column = {
296
44
  name: prop.name,
297
- type,
298
- ...(isIntegerProp(prop) && { unsigned: prop.unsigned === true }),
299
- ...((isStringProp(prop) || isEnumProp(prop)) && {
300
- length: prop.length,
301
- }),
45
+ type: resolveEntityPropTypeToMigrationColumnType(prop),
302
46
  nullable: prop.nullable === true,
303
47
  ...(() => {
304
48
  if (prop.dbDefault !== undefined) {
@@ -308,11 +52,16 @@ export function getMigrationSetFromEntity(
308
52
  }
309
53
  return {};
310
54
  })(),
311
- // FIXME: float(N, M) deprecated
312
- // Decimal, Float 타입의 경우 precision, scale 추가
313
- ...((isDecimalProp(prop) || isFloatProp(prop)) && {
314
- precision: prop.precision ?? 8,
315
- scale: prop.scale ?? 2,
55
+ // String 타입에 length 있는 경우 추가
56
+ ...(isStringProp(prop) &&
57
+ prop.length !== undefined && {
58
+ length: prop.length,
59
+ }),
60
+ // Number/Numeric 타입의 경우 precision, scale 추가
61
+ ...((isNumberProp(prop) || isNumericProp(prop)) && {
62
+ precision: prop.precision,
63
+ scale: prop.scale,
64
+ numberType: isNumberProp(prop) ? (prop.numberType ?? "numeric") : "numeric",
316
65
  }),
317
66
  };
318
67
 
@@ -345,14 +94,10 @@ export function getMigrationSetFromEntity(
345
94
  },
346
95
  // 조인 테이블에 걸린 인덱스 찾아와서 연결
347
96
  ...entity.indexes
348
- .filter((index) =>
349
- index.columns.find((col) => col.includes(prop.joinTable + "."))
350
- )
97
+ .filter((index) => index.columns.find((col) => col.includes(`${prop.joinTable}.`)))
351
98
  .map((index) => ({
352
99
  ...index,
353
- columns: index.columns.map((col) =>
354
- col.replace(prop.joinTable + ".", "")
355
- ),
100
+ columns: index.columns.map((col) => col.replace(`${prop.joinTable}.`, "")),
356
101
  })),
357
102
  ],
358
103
  columns: [
@@ -360,14 +105,12 @@ export function getMigrationSetFromEntity(
360
105
  name: "id",
361
106
  type: "integer",
362
107
  nullable: false,
363
- unsigned: true,
364
108
  },
365
109
  ...fields.map((field) => {
366
110
  return {
367
111
  name: field.split(".")[1],
368
112
  type: "integer",
369
113
  nullable: false,
370
- unsigned: true,
371
114
  } as MigrationColumn;
372
115
  }),
373
116
  {
@@ -380,10 +123,7 @@ export function getMigrationSetFromEntity(
380
123
  // 현재 필드가 어떤 테이블에 속하는지 판단
381
124
  const col = field.split(".")[1];
382
125
  const to = (() => {
383
- if (
384
- inflection.singularize(join.to.split(".")[0]) + "_id" ===
385
- col
386
- ) {
126
+ if (`${inflection.singularize(join.to.split(".")[0])}_id` === col) {
387
127
  return join.to;
388
128
  } else {
389
129
  return join.from;
@@ -403,19 +143,16 @@ export function getMigrationSetFromEntity(
403
143
  (isOneToOneRelationProp(prop) && prop.hasJoinColumn)
404
144
  ) {
405
145
  // -OneRelation 케이스
406
- const idColumnName = prop.name + "_id";
146
+ const idColumnName = `${prop.name}_id`;
407
147
  r.columns.push({
408
148
  name: idColumnName,
409
149
  type: "integer",
410
- unsigned: true,
411
150
  nullable: prop.nullable ?? false,
412
151
  });
413
152
  if ((prop.useConstraint ?? true) === true) {
414
153
  r.foreigns.push({
415
154
  columns: [idColumnName],
416
- to: `${inflection
417
- .underscore(inflection.pluralize(prop.with))
418
- .toLowerCase()}.id`,
155
+ to: `${inflection.underscore(inflection.pluralize(prop.with)).toLowerCase()}.id`,
419
156
  onUpdate: prop.onUpdate ?? "RESTRICT",
420
157
  onDelete: prop.onDelete ?? "RESTRICT",
421
158
  });
@@ -430,12 +167,12 @@ export function getMigrationSetFromEntity(
430
167
  indexes: [] as MigrationIndex[],
431
168
  foreigns: [] as MigrationForeign[],
432
169
  joinTables: [] as MigrationJoinTable[],
433
- }
170
+ },
434
171
  );
435
172
 
436
173
  // indexes
437
174
  migrationSet.indexes = entity.indexes.filter((index) =>
438
- index.columns.find((col) => col.includes(".") === false)
175
+ index.columns.find((col) => col.includes(".") === false),
439
176
  );
440
177
 
441
178
  // uuid
@@ -451,3 +188,53 @@ export function getMigrationSetFromEntity(
451
188
 
452
189
  return migrationSet;
453
190
  }
191
+
192
+ function resolveEntityPropTypeToMigrationColumnType(prop: EntityProp): MigrationColumnType {
193
+ if (prop.type === "relation" || prop.type === "virtual") {
194
+ throw new Error(`Unresolved column type: ${prop.type}`);
195
+ }
196
+
197
+ switch (prop.type) {
198
+ case "string":
199
+ return "string";
200
+ case "string[]":
201
+ return "string[]";
202
+ case "enum":
203
+ return "string";
204
+ case "enum[]":
205
+ return "string[]";
206
+ case "integer":
207
+ return "integer";
208
+ case "integer[]":
209
+ return "integer[]";
210
+ case "bigInteger":
211
+ return "bigInteger";
212
+ case "bigInteger[]":
213
+ return "bigInteger[]";
214
+ case "number":
215
+ return "numberOrNumeric";
216
+ case "number[]":
217
+ return "numberOrNumeric[]";
218
+ case "numeric":
219
+ return "numberOrNumeric";
220
+ case "numeric[]":
221
+ return "numberOrNumeric[]";
222
+ case "boolean":
223
+ return "boolean";
224
+ case "boolean[]":
225
+ return "boolean[]";
226
+ case "date":
227
+ return "date";
228
+ case "date[]":
229
+ return "date[]";
230
+ case "uuid":
231
+ return "uuid";
232
+ case "uuid[]":
233
+ return "uuid[]";
234
+ case "json":
235
+ return "json";
236
+ default:
237
+ exhaustive(prop);
238
+ throw new Error(`Unknown entity prop type: ${(prop as { type: string }).type}`);
239
+ }
240
+ }