sonamu 0.6.0 → 0.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (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 +228 -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 +341 -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 +54 -29
  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 +262 -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 +407 -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,11 +1,13 @@
1
- import * as _ from "lodash-es";
2
- import prettier from "prettier";
3
1
  import equal from "fast-deep-equal";
2
+ import { alphabetical, diff, fork, omit } from "radashi";
3
+ import { Naite } from "../index.js";
4
+ import { formatCode } from "../utils/formatter.js";
5
+ import { differenceWith, intersectionBy } from "../utils/utils.js";
4
6
  /**
5
7
  * 테이블 생성하는 케이스 - 컬럼/인덱스 생성
6
8
  */ async function generateCreateCode_ColumnAndIndexes(table, columns, indexes) {
7
9
  // fulltext index 분리
8
- const [ngramIndexes, standardIndexes] = _.partition(indexes, (i)=>i.type === "fulltext" && i.parser === "ngram");
10
+ const [ngramIndexes, standardIndexes] = fork(indexes, (i)=>i.type === "fulltext" && i.parser === "ngram");
9
11
  // 컬럼, 인덱스 처리
10
12
  const lines = [
11
13
  'import { Knex } from "knex";',
@@ -30,9 +32,7 @@ import equal from "fast-deep-equal";
30
32
  table,
31
33
  type: "normal",
32
34
  title: `create__${table}`,
33
- formatted: await prettier.format(lines.join("\n"), {
34
- parser: "typescript"
35
- })
35
+ formatted: formatCode(lines.join("\n"), "typescript", `src/migration/${table}.ts`)
36
36
  };
37
37
  }
38
38
  /**
@@ -43,21 +43,37 @@ import equal from "fast-deep-equal";
43
43
  if (column.name === "id") {
44
44
  return `table.increments().primary();`;
45
45
  }
46
- // FIXME: float(M,D) deprecated -> decimal(M,D) 이용하도록 하고, float/double 처리 추가
47
- if (column.type === "float" || column.type === "decimal") {
48
- chains.push(`${column.type}('${column.name}', ${column.precision}, ${column.scale})`);
46
+ // 배열 타입 처리
47
+ if (column.type.endsWith("[]")) {
48
+ const elementType = column.type.slice(0, -2); // "integer[]" -> "integer"
49
+ const pgType = getPgArrayType(column, elementType);
50
+ chains.push(`specificType('${column.name}', '${pgType}')`);
51
+ } else if (column.type === "numberOrNumeric") {
52
+ // number
53
+ if (column.numberType === "real") {
54
+ chains.push(`float('${column.name}')`);
55
+ } else if (column.numberType === "double precision") {
56
+ chains.push(`double('${column.name}')`);
57
+ } else if ((column.numberType ?? "numeric") === "numeric") {
58
+ chains.push(`decimal('${column.name}', ${column.precision}, ${column.scale})`);
59
+ }
60
+ } else if (column.type === "string") {
61
+ // string
62
+ if (column.length !== undefined) {
63
+ chains.push(`string('${column.name}', ${column.length})`);
64
+ } else {
65
+ chains.push(`text('${column.name}')`);
66
+ }
67
+ } else if (column.type === "date") {
68
+ // date
69
+ chains.push(`timestamp('${column.name}', { useTz: true })`);
70
+ } else if (column.type === "json") {
71
+ // json
72
+ chains.push(`jsonb('${column.name}')`);
49
73
  } else {
50
74
  // type, length
51
- let columnType = column.type;
52
75
  let extraType;
53
- if (columnType.includes("text") && columnType !== "text") {
54
- extraType = columnType;
55
- columnType = "text";
56
- }
57
- chains.push(`${columnType}('${column.name}'${column.length ? `, ${column.length}` : ""}${extraType ? `, '${extraType}'` : ""})`);
58
- }
59
- if (column.unsigned) {
60
- chains.push("unsigned()");
76
+ chains.push(`${column.type}('${column.name}'${column.length ? `, ${column.length}` : ""}${extraType ? `, '${extraType}'` : ""})`);
61
77
  }
62
78
  // nullable
63
79
  chains.push(column.nullable ? "nullable()" : "notNullable()");
@@ -72,6 +88,23 @@ import equal from "fast-deep-equal";
72
88
  return `table.${chains.join(".")};`;
73
89
  });
74
90
  }
91
+ function getPgArrayType(column, elementType) {
92
+ if (elementType === "numberOrNumeric") {
93
+ if (column.numberType === "real") return "real[]";
94
+ if (column.numberType === "double precision") return "double precision[]";
95
+ return `numeric(${column.precision}, ${column.scale})[]`;
96
+ }
97
+ if (elementType === "string") {
98
+ return column.length ? `varchar(${column.length})[]` : "text[]";
99
+ }
100
+ if (elementType === "date") return "timestamptz[]";
101
+ if (elementType === "integer") return "integer[]";
102
+ if (elementType === "bigInteger") return "bigint[]";
103
+ if (elementType === "boolean") return "boolean[]";
104
+ if (elementType === "uuid") return "uuid[]";
105
+ if (elementType === "enum") return "text[]";
106
+ throw new Error(`Unknown array element type: ${elementType}`);
107
+ }
75
108
  /**
76
109
  * 개별 인덱스 정의 생성
77
110
  */ function genIndexDefinition(index, table) {
@@ -120,9 +153,7 @@ import equal from "fast-deep-equal";
120
153
  table,
121
154
  type: "foreign",
122
155
  title: `foreign__${table}__${foreignKeysString}`,
123
- formatted: await prettier.format(lines.join("\n"), {
124
- parser: "typescript"
125
- })
156
+ formatted: formatCode(lines.join("\n"), "typescript", `src/migration/${table}.ts`)
126
157
  }
127
158
  ];
128
159
  }
@@ -162,9 +193,29 @@ import equal from "fast-deep-equal";
162
193
  // 인덱스의 add, drop 여부 확인
163
194
  const alterIndexesTo = getAlterIndexesTo(entityIndexes, dbIndexes);
164
195
  // fulltext index 분리
165
- const [ngramIndexes, standardIndexes] = _.partition(alterIndexesTo.add, (i)=>i.type === "fulltext" && i.parser === "ngram");
196
+ const [ngramIndexes, standardIndexes] = fork(alterIndexesTo.add, (i)=>i.type === "fulltext" && i.parser === "ngram");
166
197
  // 인덱스가 삭제되는 경우, 컬럼과 같이 삭제된 케이스에는 drop에서 제외해야함!
167
198
  const indexNeedsToDrop = alterIndexesTo.drop.filter((index)=>index.columns.every((colName)=>alterColumnsTo.drop.map((col)=>col.name).includes(colName)) === false);
199
+ // 빈 코드 생성 방지
200
+ if (alterColumnLinesTo.add.up.length === 0 && alterColumnLinesTo.drop.up.length === 0 && alterColumnLinesTo.alter.up.length === 0 && standardIndexes.length === 0 && indexNeedsToDrop.length === 0) {
201
+ Naite.t("migrator:generateAlterCode_ColumnAndIndexes:emptyCodeGenerationError", {
202
+ entityColumns,
203
+ dbColumns,
204
+ entityIndexes,
205
+ dbIndexes
206
+ });
207
+ // throw new Error("컬럼/인덱스 변경 코드 생성 오류");
208
+ }
209
+ Naite.t("migrator:generateAlterCode_ColumnAndIndexes:debug", {
210
+ "alterColumnsTo.add.length": alterColumnsTo.add.length,
211
+ "alterColumnsTo.drop.length": alterColumnsTo.drop.length,
212
+ "alterColumnsTo.alter.length": alterColumnsTo.alter.length,
213
+ "alterIndexesTo.add.length": alterIndexesTo.add.length,
214
+ "alterIndexesTo.drop.length": alterIndexesTo.drop.length,
215
+ "standardIndexes.length": standardIndexes.length,
216
+ "indexNeedsToDrop.length": indexNeedsToDrop.length
217
+ });
218
+ // Naite.t("migrator:generateAlterCode_ColumnAndIndexes:alterColumnsTo", alterColumnsTo);
168
219
  const lines = [
169
220
  'import { Knex } from "knex";',
170
221
  "",
@@ -195,9 +246,7 @@ import equal from "fast-deep-equal";
195
246
  "});",
196
247
  "}"
197
248
  ];
198
- const formatted = await prettier.format(lines.join("\n"), {
199
- parser: "typescript"
200
- });
249
+ const formatted = formatCode(lines.join("\n"), "typescript", `src/migration/${table}.ts`);
201
250
  const title = [
202
251
  "alter",
203
252
  table,
@@ -232,8 +281,8 @@ import equal from "fast-deep-equal";
232
281
  };
233
282
  // 컬럼명 기준 비교
234
283
  const extraColumns = {
235
- db: _.differenceBy(dbColumns, entityColumns, (col)=>col.name),
236
- entity: _.differenceBy(entityColumns, dbColumns, (col)=>col.name)
284
+ db: diff(dbColumns, entityColumns, (col)=>col.name),
285
+ entity: diff(entityColumns, dbColumns, (col)=>col.name)
237
286
  };
238
287
  if (extraColumns.entity.length > 0) {
239
288
  columnsTo.add = columnsTo.add.concat(extraColumns.entity);
@@ -242,15 +291,15 @@ import equal from "fast-deep-equal";
242
291
  columnsTo.drop = columnsTo.drop.concat(extraColumns.db);
243
292
  }
244
293
  // 동일 컬럼명의 세부 필드 비교
245
- const sameDbColumns = _.intersectionBy(dbColumns, entityColumns, (col)=>col.name);
246
- const sameMdColumns = _.intersectionBy(entityColumns, dbColumns, (col)=>col.name);
247
- columnsTo.alter = _.differenceWith(sameDbColumns, sameMdColumns, (a, b)=>equal(a, b));
294
+ const sameDbColumns = intersectionBy(dbColumns, entityColumns, (col)=>col.name);
295
+ const sameMdColumns = intersectionBy(entityColumns, dbColumns, (col)=>col.name);
296
+ columnsTo.alter = differenceWith(sameDbColumns, sameMdColumns, (a, b)=>equal(a, b));
248
297
  return columnsTo;
249
298
  }
250
299
  /**
251
300
  * 추출된 컬럼들을 기준으로 각각 라인 생성
252
301
  */ function getAlterColumnLinesTo(columnsTo, entityColumns, table, dbForeigns) {
253
- let linesTo = {
302
+ const linesTo = {
254
303
  add: {
255
304
  up: [],
256
305
  down: []
@@ -301,17 +350,17 @@ import equal from "fast-deep-equal";
301
350
  ]
302
351
  };
303
352
  linesTo.alter = columnsTo.alter.reduce((r, dbColumn)=>{
304
- const entityColumn = entityColumns.find((col)=>col.name == dbColumn.name);
353
+ const entityColumn = entityColumns.find((col)=>col.name === dbColumn.name);
305
354
  if (entityColumn === undefined) {
306
355
  return r;
307
356
  }
308
357
  // 컬럼 변경사항
309
- const columnDiffUp = _.difference(genColumnDefinitions([
358
+ const columnDiffUp = diff(genColumnDefinitions([
310
359
  entityColumn
311
360
  ]), genColumnDefinitions([
312
361
  dbColumn
313
362
  ]));
314
- const columnDiffDown = _.difference(genColumnDefinitions([
363
+ const columnDiffDown = diff(genColumnDefinitions([
315
364
  dbColumn
316
365
  ]), genColumnDefinitions([
317
366
  entityColumn
@@ -320,12 +369,12 @@ import equal from "fast-deep-equal";
320
369
  r.up = [
321
370
  ...r.up,
322
371
  "// alter column",
323
- ...columnDiffUp.map((l)=>l.replace(";", "") + ".alter();")
372
+ ...columnDiffUp.map((l)=>`${l.replace(";", "")}.alter();`)
324
373
  ];
325
374
  r.down = [
326
375
  ...r.down,
327
376
  "// rollback - alter column",
328
- ...columnDiffDown.map((l)=>l.replace(";", "") + ".alter();")
377
+ ...columnDiffDown.map((l)=>`${l.replace(";", "")}.alter();`)
329
378
  ];
330
379
  }
331
380
  return r;
@@ -339,16 +388,16 @@ import equal from "fast-deep-equal";
339
388
  * 인덱스의 add, drop 여부 확인
340
389
  */ function getAlterIndexesTo(entityIndexes, dbIndexes) {
341
390
  // 인덱스 비교
342
- let indexesTo = {
391
+ const indexesTo = {
343
392
  add: [],
344
393
  drop: []
345
394
  };
346
395
  const extraIndexes = {
347
- db: _.differenceBy(dbIndexes, entityIndexes, (col)=>[
396
+ db: diff(dbIndexes, entityIndexes, (col)=>[
348
397
  col.type,
349
398
  col.columns.join("-")
350
399
  ].join("//")),
351
- entity: _.differenceBy(entityIndexes, dbIndexes, (col)=>[
400
+ entity: diff(entityIndexes, dbIndexes, (col)=>[
352
401
  col.type,
353
402
  col.columns.join("-")
354
403
  ].join("//"))
@@ -425,6 +474,14 @@ import equal from "fast-deep-equal";
425
474
  if (!hasLines) {
426
475
  return [];
427
476
  }
477
+ if (linesTo.add.up.length === 0 && linesTo.drop.up.length === 0 && linesTo.alterSrc.up.length === 0 && linesTo.alterDst.up.length === 0) {
478
+ Naite.t("migrator:generateAlterCode_Foreigns:fkChangeCodeGenerationError", {
479
+ table,
480
+ entityForeigns,
481
+ dbForeigns
482
+ });
483
+ throw new Error("FK 변경 코드 생성 오류");
484
+ }
428
485
  const lines = [
429
486
  'import { Knex } from "knex";',
430
487
  "",
@@ -446,9 +503,7 @@ import equal from "fast-deep-equal";
446
503
  "})",
447
504
  "}"
448
505
  ];
449
- const formatted = await prettier.format(lines.join("\n"), {
450
- parser: "typescript"
451
- });
506
+ const formatted = formatCode(lines.join("\n"), "typescript", `src/migration/${table}.ts`);
452
507
  const title = [
453
508
  "alter",
454
509
  table,
@@ -481,26 +536,27 @@ import equal from "fast-deep-equal";
481
536
  */ export async function generateAlterCode(entitySet, dbSet) {
482
537
  const replaceColumnDefaultTo = (col)=>{
483
538
  // float인 경우 기본값을 0으로 지정하는 경우 "0.00"으로 변환되는 케이스 대응
484
- if (col.type === "float" && col.defaultTo && String(col.defaultTo).includes('"') === false) {
485
- col.defaultTo = `"${Number(col.defaultTo).toFixed(col.scale ?? 2)}"`;
486
- }
487
- // string인 경우 기본값이 빈 스트링인 경우 대응
488
- if (col.type === "string" && col.defaultTo === "") {
489
- col.defaultTo = '""';
490
- }
491
- // boolean인 경우 기본값 정규화 (MySQL에서는 TINYINT(1)로 저장되므로 0 또는 1로 정규화)
492
- // TODO: db.ts에 typeCase 설정 확인하여 처리하도록 수정 필요
493
- if (col.type === "boolean" && col.defaultTo !== undefined) {
494
- if (col.defaultTo === "0" || col.defaultTo.toLowerCase() === "false") {
495
- col.defaultTo = "0";
496
- } else if (col.defaultTo === "1" || col.defaultTo.toLowerCase() === "true") {
497
- col.defaultTo = "1";
498
- }
499
- }
539
+ // if (col.type === "float" && col.defaultTo && String(col.defaultTo).includes('"') === false) {
540
+ // col.defaultTo = `"${Number(col.defaultTo).toFixed(col.scale ?? 2)}"`;
541
+ // }
542
+ // // string인 경우 기본값이 빈 스트링인 경우 대응
543
+ // if (col.type === "string" && col.defaultTo === "") {
544
+ // col.defaultTo = '""';
545
+ // }
546
+ // // boolean인 경우 기본값 정규화 (MySQL에서는 TINYINT(1)로 저장되므로 0 또는 1로 정규화)
547
+ // // TODO: db.ts에 typeCase 설정 확인하여 처리하도록 수정 필요
548
+ // if (col.type === "boolean" && col.defaultTo !== undefined) {
549
+ // if (col.defaultTo === "0" || col.defaultTo.toLowerCase() === "false") {
550
+ // col.defaultTo = "0";
551
+ // } else if (col.defaultTo === "1" || col.defaultTo.toLowerCase() === "true") {
552
+ // col.defaultTo = "1";
553
+ // }
554
+ // }
555
+ // FIXME: 일단 MySQL 상황에서 발생했던 이슈의 workaround 이므로 Pg에서 재확인 후 대응 추가
500
556
  return col;
501
557
  };
502
- const entityColumns = _.sortBy(entitySet.columns, (a)=>a.name).map(replaceColumnDefaultTo);
503
- const dbColumns = _.sortBy(dbSet.columns, (a)=>a.name).map(replaceColumnDefaultTo);
558
+ const entityColumns = alphabetical(entitySet.columns, (a)=>a.name).map(replaceColumnDefaultTo);
559
+ const dbColumns = alphabetical(dbSet.columns, (a)=>a.name).map(replaceColumnDefaultTo);
504
560
  /* 디버깅용 코드, 특정 컬럼에서 불일치 발생할 때 확인
505
561
  const entityColumn = entitySet.columns.find(
506
562
  (col) => col.name === "price_krw"
@@ -509,11 +565,11 @@ import equal from "fast-deep-equal";
509
565
  (col) => col.name === "price_krw"
510
566
  );
511
567
  console.debug({ entityColumn, dbColumn });
512
- */ const entityIndexes = _.sortBy(entitySet.indexes, (a)=>[
568
+ */ const entityIndexes = alphabetical(entitySet.indexes, (a)=>[
513
569
  a.type,
514
570
  ...a.columns.sort((c1, c2)=>c1 > c2 ? 1 : -1)
515
571
  ].join("-"));
516
- const dbIndexes = _.sortBy(dbSet.indexes, (a)=>[
572
+ const dbIndexes = alphabetical(dbSet.indexes, (a)=>[
517
573
  a.type,
518
574
  ...a.columns.sort((c1, c2)=>c1 > c2 ? 1 : -1)
519
575
  ].join("-"));
@@ -526,20 +582,20 @@ import equal from "fast-deep-equal";
526
582
  onDelete: onDelete === "RESTRICT" ? "NO ACTION" : onDelete
527
583
  };
528
584
  };
529
- const entityForeigns = _.sortBy(entitySet.foreigns, (a)=>[
585
+ const entityForeigns = alphabetical(entitySet.foreigns, (a)=>[
530
586
  a.to,
531
587
  ...a.columns
532
588
  ].join("-")).map((f)=>replaceNoActionOnMySQL(f));
533
- const dbForeigns = _.sortBy(dbSet.foreigns, (a)=>[
589
+ const dbForeigns = alphabetical(dbSet.foreigns, (a)=>[
534
590
  a.to,
535
591
  ...a.columns
536
592
  ].join("-")).map((f)=>replaceNoActionOnMySQL(f));
537
593
  // 삭제될 컬럼 목록 계산
538
- const droppingColumns = _.differenceBy(dbColumns, entityColumns, (col)=>col.name);
594
+ const droppingColumns = diff(dbColumns, entityColumns, (col)=>col.name);
539
595
  const alterCodes = [];
540
596
  // 1. columnsAndIndexes 처리
541
597
  const isEqualColumns = equal(entityColumns, dbColumns);
542
- const isEqualIndexes = equal(entityIndexes.map((index)=>_.omit(index, [
598
+ const isEqualIndexes = equal(entityIndexes.map((index)=>omit(index, [
543
599
  "parser"
544
600
  ])), dbIndexes);
545
601
  if (!isEqualColumns || !isEqualIndexes) {
@@ -555,4 +611,4 @@ import equal from "fast-deep-equal";
555
611
  return alterCodes.filter((alterCode)=>alterCode !== null).flat();
556
612
  }
557
613
 
558
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/migration/code-generation.ts"],"sourcesContent":["import * as _ from \"lodash-es\";\nimport prettier from \"prettier\";\nimport equal from \"fast-deep-equal\";\nimport {\n  GenMigrationCode,\n  MigrationColumn,\n  MigrationForeign,\n  MigrationIndex,\n  MigrationSet,\n} from \"../types/types\";\n\n/**\n * 테이블 생성하는 케이스 - 컬럼/인덱스 생성\n */\nasync function generateCreateCode_ColumnAndIndexes(\n  table: string,\n  columns: MigrationColumn[],\n  indexes: MigrationIndex[]\n): Promise<GenMigrationCode> {\n  // fulltext index 분리\n  const [ngramIndexes, standardIndexes] = _.partition(\n    indexes,\n    (i) => i.type === \"fulltext\" && i.parser === \"ngram\"\n  );\n\n  // 컬럼, 인덱스 처리\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `await knex.schema.createTable(\"${table}\", (table) => {`,\n    \"// columns\",\n    ...genColumnDefinitions(columns),\n    \"\",\n    \"// indexes\",\n    ...standardIndexes.map((index) => genIndexDefinition(index, table)),\n    \"});\",\n    // ngram은 knex.raw로 처리하므로 createTable 밖에서 실행\n    ...ngramIndexes.map((index) => genIndexDefinition(index, table)),\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    ` return knex.schema.dropTable(\"${table}\");`,\n    \"}\",\n  ];\n  return {\n    table,\n    type: \"normal\",\n    title: `create__${table}`,\n    formatted: await prettier.format(lines.join(\"\\n\"), {\n      parser: \"typescript\",\n    }),\n  };\n}\n\n/**\n * MigrationColumn[] 읽어서 컬럼 정의하는 구문 생성\n */\nfunction genColumnDefinitions(columns: MigrationColumn[]): string[] {\n  return columns.map((column) => {\n    const chains: string[] = [];\n    if (column.name === \"id\") {\n      return `table.increments().primary();`;\n    }\n\n    // FIXME: float(M,D) deprecated -> decimal(M,D) 이용하도록 하고, float/double 처리 추가\n    if (column.type === \"float\" || column.type === \"decimal\") {\n      chains.push(\n        `${column.type}('${column.name}', ${column.precision}, ${column.scale})`\n      );\n    } else {\n      // type, length\n      let columnType = column.type;\n      let extraType: string | undefined;\n      if (columnType.includes(\"text\") && columnType !== \"text\") {\n        extraType = columnType;\n        columnType = \"text\";\n      }\n      chains.push(\n        `${columnType}('${column.name}'${\n          column.length ? `, ${column.length}` : \"\"\n        }${extraType ? `, '${extraType}'` : \"\"})`\n      );\n    }\n    if (column.unsigned) {\n      chains.push(\"unsigned()\");\n    }\n\n    // nullable\n    chains.push(column.nullable ? \"nullable()\" : \"notNullable()\");\n\n    // defaultTo\n    if (column.defaultTo !== undefined) {\n      if (\n        typeof column.defaultTo === \"string\" &&\n        column.defaultTo.startsWith(`\"`)\n      ) {\n        chains.push(`defaultTo(${column.defaultTo})`);\n      } else {\n        chains.push(`defaultTo(knex.raw('${column.defaultTo}'))`);\n      }\n    }\n\n    return `table.${chains.join(\".\")};`;\n  });\n}\n\n/**\n * 개별 인덱스 정의 생성\n */\nfunction genIndexDefinition(index: MigrationIndex, table: string) {\n  const methodMap = {\n    index: \"index\",\n    fulltext: \"index\",\n    unique: \"unique\",\n  };\n\n  if (index.type === \"fulltext\" && index.parser === \"ngram\") {\n    const indexName = `${table}_${index.columns.join(\"_\")}_index`;\n    return `await knex.raw(\\`ALTER TABLE ${table} ADD FULLTEXT INDEX ${indexName} (${index.columns.join(\n      \", \"\n    )}) WITH PARSER ngram\\`);`;\n  }\n\n  return `table.${methodMap[index.type]}([${index.columns\n    .map((col) => `'${col}'`)\n    .join(\",\")}]${index.type === \"fulltext\" ? \", undefined, 'FULLTEXT'\" : \"\"})`;\n}\n\n/**\n * 테이블 생성하는 케이스 - FK 생성\n */\nasync function generateCreateCode_Foreign(\n  table: string,\n  foreigns: MigrationForeign[]\n): Promise<GenMigrationCode[]> {\n  if (foreigns.length === 0) {\n    return [];\n  }\n\n  const { up, down } = genForeignDefinitions(table, foreigns);\n  if (up.length === 0 && down.length === 0) {\n    console.log(\"fk 가 뭔가 다릅니다\");\n    return [];\n  }\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    \"// create fk\",\n    ...up,\n    \"});\",\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    \"// drop fk\",\n    ...down,\n    \"});\",\n    \"}\",\n  ];\n\n  const foreignKeysString = foreigns\n    .map((foreign) => foreign.columns.join(\"_\"))\n    .join(\"_\");\n  return [\n    {\n      table,\n      type: \"foreign\",\n      title: `foreign__${table}__${foreignKeysString}`,\n      formatted: await prettier.format(lines.join(\"\\n\"), {\n        parser: \"typescript\",\n      }),\n    },\n  ];\n}\n\n/**\n * MigrationForeign[] 읽어서 외부키 constraint 정의하는 구문 생성\n */\nfunction genForeignDefinitions(\n  table: string,\n  foreigns: MigrationForeign[]\n): { up: string[]; down: string[] } {\n  return foreigns.reduce(\n    (r, foreign) => {\n      const columnsStringQuote = foreign.columns\n        .map((col) => `'${col.replace(`${table}.`, \"\")}'`)\n        .join(\",\");\n      r.up.push(\n        `table.foreign('${foreign.columns.join(\",\")}')\n            .references('${foreign.to}')\n            .onUpdate('${foreign.onUpdate}')\n            .onDelete('${foreign.onDelete}')`\n      );\n      r.down.push(`table.dropForeign([${columnsStringQuote}])`);\n      return r;\n    },\n    {\n      up: [] as string[],\n      down: [] as string[],\n    }\n  );\n}\n\n/**\n * 테이블 변경 케이스 - 컬럼/인덱스 변경\n */\nasync function generateAlterCode_ColumnAndIndexes(\n  table: string,\n  entityColumns: MigrationColumn[],\n  entityIndexes: MigrationIndex[],\n  dbColumns: MigrationColumn[],\n  dbIndexes: MigrationIndex[],\n  dbForeigns: MigrationForeign[]\n): Promise<GenMigrationCode[]> {\n  /*\n    세부 비교 후 다른점 찾아서 코드 생성\n\n    1. 컬럼갯수 다름: MD에 있으나, DB에 없다면 추가\n    2. 컬럼갯수 다름: MD에 없으나, DB에 있다면 삭제\n    3. 그외 컬럼(컬럼 갯수가 동일하거나, 다른 경우 동일한 컬럼끼리) => alter\n    4. 다른거 다 동일하고 index만 변경되는 경우\n\n    ** 컬럼명을 변경하는 경우는 따로 핸들링하지 않음\n    => drop/add 형태의 마이그레이션 코드가 생성되는데, 수동으로 rename 코드로 수정하여 처리\n  */\n\n  // 각 컬럼 이름 기준으로 add, drop, alter 여부 확인\n  const alterColumnsTo = getAlterColumnsTo(entityColumns, dbColumns);\n\n  // 추출된 컬럼들을 기준으로 각각 라인 생성\n  const alterColumnLinesTo = getAlterColumnLinesTo(\n    alterColumnsTo,\n    entityColumns,\n    table,\n    dbForeigns\n  );\n\n  // 인덱스의 add, drop 여부 확인\n  const alterIndexesTo = getAlterIndexesTo(entityIndexes, dbIndexes);\n\n  // fulltext index 분리\n  const [ngramIndexes, standardIndexes] = _.partition(\n    alterIndexesTo.add,\n    (i) => i.type === \"fulltext\" && i.parser === \"ngram\"\n  );\n\n  // 인덱스가 삭제되는 경우, 컬럼과 같이 삭제된 케이스에는 drop에서 제외해야함!\n  const indexNeedsToDrop = alterIndexesTo.drop.filter(\n    (index) =>\n      index.columns.every((colName) =>\n        alterColumnsTo.drop.map((col) => col.name).includes(colName)\n      ) === false\n  );\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `await knex.schema.alterTable(\"${table}\", (table) => {`,\n    // 1. add column\n    ...(alterColumnsTo.add.length > 0 ? alterColumnLinesTo.add.up : []),\n    // 2. drop column\n    ...(alterColumnsTo.drop.length > 0 ? alterColumnLinesTo.drop.up : []),\n    // 3. alter column\n    ...(alterColumnsTo.alter.length > 0 ? alterColumnLinesTo.alter.up : []),\n    // 4. add index\n    ...standardIndexes.map((index) => genIndexDefinition(index, table)),\n    // 5. drop index\n    ...indexNeedsToDrop.map(genIndexDropDefinition),\n    \"});\",\n    // ngram은 knex.raw로 처리하므로 alterTable 밖에서 실행\n    ...ngramIndexes.map((index) => genIndexDefinition(index, table)),\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...(alterColumnsTo.add.length > 0 ? alterColumnLinesTo.add.down : []),\n    ...(alterColumnsTo.drop.length > 0 ? alterColumnLinesTo.drop.down : []),\n    ...(alterColumnsTo.alter.length > 0 ? alterColumnLinesTo.alter.down : []),\n    ...alterIndexesTo.add\n      .filter(\n        (index) =>\n          index.columns.every((colName) =>\n            alterColumnsTo.add.map((col) => col.name).includes(colName)\n          ) === false\n      )\n      .map(genIndexDropDefinition),\n    ...indexNeedsToDrop.map((index) => genIndexDefinition(index, table)),\n    \"});\",\n    \"}\",\n  ];\n\n  const formatted = await prettier.format(lines.join(\"\\n\"), {\n    parser: \"typescript\",\n  });\n\n  const title = [\n    \"alter\",\n    table,\n    ...([\"add\", \"drop\", \"alter\"] as const)\n      .map((action) => {\n        const len = alterColumnsTo[action].length;\n        if (len > 0) {\n          return action + len;\n        }\n        return null;\n      })\n      .filter((part) => part !== null),\n  ].join(\"_\");\n\n  return [\n    {\n      table,\n      title,\n      formatted,\n      type: \"normal\",\n    },\n  ];\n}\n\n/**\n * 각 컬럼 이름 기준으로 add, drop, alter 여부 확인\n */\nfunction getAlterColumnsTo(\n  entityColumns: MigrationColumn[],\n  dbColumns: MigrationColumn[]\n) {\n  const columnsTo = {\n    add: [] as MigrationColumn[],\n    drop: [] as MigrationColumn[],\n    alter: [] as MigrationColumn[],\n  };\n\n  // 컬럼명 기준 비교\n  const extraColumns = {\n    db: _.differenceBy(dbColumns, entityColumns, (col) => col.name),\n    entity: _.differenceBy(entityColumns, dbColumns, (col) => col.name),\n  };\n  if (extraColumns.entity.length > 0) {\n    columnsTo.add = columnsTo.add.concat(extraColumns.entity);\n  }\n  if (extraColumns.db.length > 0) {\n    columnsTo.drop = columnsTo.drop.concat(extraColumns.db);\n  }\n\n  // 동일 컬럼명의 세부 필드 비교\n  const sameDbColumns = _.intersectionBy(\n    dbColumns,\n    entityColumns,\n    (col) => col.name\n  );\n  const sameMdColumns = _.intersectionBy(\n    entityColumns,\n    dbColumns,\n    (col) => col.name\n  );\n  columnsTo.alter = _.differenceWith(sameDbColumns, sameMdColumns, (a, b) =>\n    equal(a, b)\n  );\n\n  return columnsTo;\n}\n\n/**\n * 추출된 컬럼들을 기준으로 각각 라인 생성\n */\nfunction getAlterColumnLinesTo(\n  columnsTo: ReturnType<typeof getAlterColumnsTo>,\n  entityColumns: MigrationColumn[],\n  table: string,\n  dbForeigns: MigrationForeign[]\n) {\n  let linesTo = {\n    add: {\n      up: [] as string[],\n      down: [] as string[],\n    },\n    drop: {\n      up: [] as string[],\n      down: [] as string[],\n    },\n    alter: {\n      up: [] as string[],\n      down: [] as string[],\n    },\n  };\n\n  linesTo.add = {\n    up: [\"// add\", ...genColumnDefinitions(columnsTo.add)],\n    down: [\n      \"// rollback - add\",\n      `table.dropColumns(${columnsTo.add\n        .map((col) => `'${col.name}'`)\n        .join(\", \")})`,\n    ],\n  };\n\n  // drop할 컬럼에 걸린 FK 찾기\n  const dropColumnNames = columnsTo.drop.map((col) => col.name);\n  const fkToDropBeforeColumn = dbForeigns.filter((fk) =>\n    fk.columns.some((col) => dropColumnNames.includes(col))\n  );\n\n  const dropFkLines = fkToDropBeforeColumn.map((fk) => {\n    const columnsStringQuote = fk.columns.map((col) => `'${col}'`).join(\",\");\n    return `table.dropForeign([${columnsStringQuote}])`;\n  });\n\n  const restoreFkLines = genForeignDefinitions(table, fkToDropBeforeColumn).up;\n\n  linesTo.drop = {\n    up: [\n      ...(dropFkLines.length > 0\n        ? [\"// drop foreign keys on columns to be dropped\", ...dropFkLines]\n        : []),\n      \"// drop columns\",\n      `table.dropColumns(${columnsTo.drop\n        .map((col) => `'${col.name}'`)\n        .join(\", \")})`,\n    ],\n    down: [\n      \"// rollback - drop columns\",\n      ...genColumnDefinitions(columnsTo.drop),\n      ...(restoreFkLines.length > 0\n        ? [\"// restore foreign keys\", ...restoreFkLines]\n        : []),\n    ],\n  };\n  linesTo.alter = columnsTo.alter.reduce(\n    (r, dbColumn) => {\n      const entityColumn = entityColumns.find(\n        (col) => col.name == dbColumn.name\n      );\n      if (entityColumn === undefined) {\n        return r;\n      }\n\n      // 컬럼 변경사항\n      const columnDiffUp = _.difference(\n        genColumnDefinitions([entityColumn]),\n        genColumnDefinitions([dbColumn])\n      );\n      const columnDiffDown = _.difference(\n        genColumnDefinitions([dbColumn]),\n        genColumnDefinitions([entityColumn])\n      );\n      if (columnDiffUp.length > 0) {\n        r.up = [\n          ...r.up,\n          \"// alter column\",\n          ...columnDiffUp.map((l) => l.replace(\";\", \"\") + \".alter();\"),\n        ];\n        r.down = [\n          ...r.down,\n          \"// rollback - alter column\",\n          ...columnDiffDown.map((l) => l.replace(\";\", \"\") + \".alter();\"),\n        ];\n      }\n\n      return r;\n    },\n    {\n      up: [] as string[],\n      down: [] as string[],\n    }\n  );\n\n  return linesTo;\n}\n\n/**\n * 인덱스의 add, drop 여부 확인\n */\nfunction getAlterIndexesTo(\n  entityIndexes: MigrationIndex[],\n  dbIndexes: MigrationIndex[]\n) {\n  // 인덱스 비교\n  let indexesTo = {\n    add: [] as MigrationIndex[],\n    drop: [] as MigrationIndex[],\n  };\n  const extraIndexes = {\n    db: _.differenceBy(dbIndexes, entityIndexes, (col) =>\n      [col.type, col.columns.join(\"-\")].join(\"//\")\n    ),\n    entity: _.differenceBy(entityIndexes, dbIndexes, (col) =>\n      [col.type, col.columns.join(\"-\")].join(\"//\")\n    ),\n  };\n  if (extraIndexes.entity.length > 0) {\n    indexesTo.add = indexesTo.add.concat(extraIndexes.entity);\n  }\n  if (extraIndexes.db.length > 0) {\n    indexesTo.drop = indexesTo.drop.concat(extraIndexes.db);\n  }\n\n  return indexesTo;\n}\n\n/**\n * 인덱스 삭제 정의 생성\n */\nfunction genIndexDropDefinition(index: MigrationIndex) {\n  const methodMap = {\n    index: \"Index\",\n    fulltext: \"Index\",\n    unique: \"Unique\",\n  };\n\n  return `table.drop${methodMap[index.type]}([${index.columns\n    .map((columnName) => `'${columnName}'`)\n    .join(\",\")}])`;\n}\n\n/**\n * 테이블 변경 케이스 - Foreign Key 변경\n */\nasync function generateAlterCode_Foreigns(\n  table: string,\n  entityForeigns: MigrationForeign[],\n  dbForeigns: MigrationForeign[],\n  droppingColumns: MigrationColumn[] = []\n): Promise<GenMigrationCode[]> {\n  // console.log({ entityForeigns, dbForeigns });\n\n  const getKey = (mf: MigrationForeign): string => {\n    return [mf.columns.join(\"-\"), mf.to].join(\"///\");\n  };\n\n  // 삭제될 컬럼명 목록\n  const droppingColumnNames = droppingColumns.map((col) => col.name);\n\n  const fkTo = entityForeigns.reduce(\n    (result, entityF) => {\n      const matchingDbF = dbForeigns.find(\n        (dbF) => getKey(entityF) === getKey(dbF)\n      );\n      if (!matchingDbF) {\n        result.add.push(entityF);\n        return result;\n      }\n\n      if (equal(entityF, matchingDbF) === false) {\n        result.alterSrc.push(matchingDbF);\n        result.alterDst.push(entityF);\n        return result;\n      }\n      return result;\n    },\n    {\n      add: [] as MigrationForeign[],\n      drop: [] as MigrationForeign[],\n      alterSrc: [] as MigrationForeign[],\n      alterDst: [] as MigrationForeign[],\n    }\n  );\n\n  // dbForeigns에는 있지만 entityForeigns에는 없는 경우 (삭제된 FK)\n  // 단, 삭제될 컬럼의 FK는 제외 (generateAlterCode_ColumnAndIndexes에서 처리)\n  dbForeigns.forEach((dbF) => {\n    const matchingEntityF = entityForeigns.find(\n      (entityF) => getKey(entityF) === getKey(dbF)\n    );\n    if (!matchingEntityF) {\n      // 이 FK의 컬럼이 삭제될 컬럼 목록에 있는지 확인\n      const isColumnDropping = dbF.columns.some((col) =>\n        droppingColumnNames.includes(col)\n      );\n      // 컬럼이 삭제되지 않는 경우에만 FK drop 목록에 추가\n      if (!isColumnDropping) {\n        fkTo.drop.push(dbF);\n      }\n    }\n  });\n\n  const linesTo = {\n    add: genForeignDefinitions(table, fkTo.add),\n    drop: genForeignDefinitions(table, fkTo.drop),\n    alterSrc: genForeignDefinitions(table, fkTo.alterSrc),\n    alterDst: genForeignDefinitions(table, fkTo.alterDst),\n  };\n\n  // drop fk columns인 경우(생성될 코드 없는 경우) 패스\n  const hasLines = Object.values(linesTo).some(\n    (l) => l.up.length > 0 || l.down.length > 0\n  );\n  if (!hasLines) {\n    return [];\n  }\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...linesTo.drop.down,\n    ...linesTo.add.up,\n    ...linesTo.alterSrc.down,\n    ...linesTo.alterDst.up,\n    \"})\",\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...linesTo.add.down,\n    ...linesTo.alterDst.down,\n    ...linesTo.alterSrc.up,\n    ...linesTo.drop.up,\n    \"})\",\n    \"}\",\n  ];\n\n  const formatted = await prettier.format(lines.join(\"\\n\"), {\n    parser: \"typescript\",\n  });\n\n  const title = [\n    \"alter\",\n    table,\n    \"foreigns\",\n    // TODO 바뀌는 부분\n  ].join(\"_\");\n\n  return [\n    {\n      table,\n      title,\n      formatted,\n      type: \"normal\",\n    },\n  ];\n}\n\n/**\n * 주어진 EntitySet을 기반으로 테이블 CREATE 마이그레이션 코드를 생성합니다.\n * @param entitySet\n * @returns CREATE 마이그레이션 코드\n */\nexport async function generateCreateCode(\n  entitySet: MigrationSet\n): Promise<GenMigrationCode[]> {\n  return [\n    await generateCreateCode_ColumnAndIndexes(\n      entitySet.table,\n      entitySet.columns,\n      entitySet.indexes\n    ),\n    ...(await generateCreateCode_Foreign(entitySet.table, entitySet.foreigns)),\n  ];\n}\n\n/**\n * 주어진 entitySet을 목표로, dbSet을 현 상황으로 하여 테이블 ALTER 마이그레이션 코드를 생성합니다.\n * @param entitySet 현 상황의 MigrationSet\n * @param dbSet 목표 상황의 MigrationSet\n * @returns ALTER 마이그레이션 코드\n */\nexport async function generateAlterCode(\n  entitySet: MigrationSet,\n  dbSet: MigrationSet\n): Promise<GenMigrationCode[]> {\n  const replaceColumnDefaultTo = (col: MigrationColumn) => {\n    // float인 경우 기본값을 0으로 지정하는 경우 \"0.00\"으로 변환되는 케이스 대응\n    if (\n      col.type === \"float\" &&\n      col.defaultTo &&\n      String(col.defaultTo).includes('\"') === false\n    ) {\n      col.defaultTo = `\"${Number(col.defaultTo).toFixed(col.scale ?? 2)}\"`;\n    }\n    // string인 경우 기본값이 빈 스트링인 경우 대응\n    if (col.type === \"string\" && col.defaultTo === \"\") {\n      col.defaultTo = '\"\"';\n    }\n    // boolean인 경우 기본값 정규화 (MySQL에서는 TINYINT(1)로 저장되므로 0 또는 1로 정규화)\n    // TODO: db.ts에 typeCase 설정 확인하여 처리하도록 수정 필요\n    if (col.type === \"boolean\" && col.defaultTo !== undefined) {\n      if (col.defaultTo === \"0\" || col.defaultTo.toLowerCase() === \"false\") {\n        col.defaultTo = \"0\";\n      } else if (col.defaultTo === \"1\" || col.defaultTo.toLowerCase() === \"true\") {\n        col.defaultTo = \"1\";\n      }\n    }\n    return col;\n  };\n  const entityColumns = _.sortBy(entitySet.columns, (a) => a.name).map(\n    replaceColumnDefaultTo\n  );\n  const dbColumns = _.sortBy(dbSet.columns, (a) => a.name).map(\n    replaceColumnDefaultTo\n  );\n\n  /* 디버깅용 코드, 특정 컬럼에서 불일치 발생할 때 확인\n        const entityColumn = entitySet.columns.find(\n          (col) => col.name === \"price_krw\"\n        );\n        const dbColumn = dbSet.columns.find(\n          (col) => col.name === \"price_krw\"\n        );\n        console.debug({ entityColumn, dbColumn });\n         */\n\n  const entityIndexes = _.sortBy(entitySet.indexes, (a) =>\n    [a.type, ...a.columns.sort((c1, c2) => (c1 > c2 ? 1 : -1))].join(\"-\")\n  );\n  const dbIndexes = _.sortBy(dbSet.indexes, (a) =>\n    [a.type, ...a.columns.sort((c1, c2) => (c1 > c2 ? 1 : -1))].join(\"-\")\n  );\n\n  const replaceNoActionOnMySQL = (f: MigrationForeign) => {\n    // MySQL에서 RESTRICT와 NO ACTION은 동일함\n    const { onDelete, onUpdate } = f;\n    return {\n      ...f,\n      onUpdate: onUpdate === \"RESTRICT\" ? \"NO ACTION\" : onUpdate,\n      onDelete: onDelete === \"RESTRICT\" ? \"NO ACTION\" : onDelete,\n    };\n  };\n\n  const entityForeigns = _.sortBy(entitySet.foreigns, (a) =>\n    [a.to, ...a.columns].join(\"-\")\n  ).map((f) => replaceNoActionOnMySQL(f));\n  const dbForeigns = _.sortBy(dbSet.foreigns, (a) =>\n    [a.to, ...a.columns].join(\"-\")\n  ).map((f) => replaceNoActionOnMySQL(f));\n\n  // 삭제될 컬럼 목록 계산\n  const droppingColumns = _.differenceBy(\n    dbColumns,\n    entityColumns,\n    (col) => col.name\n  );\n\n  const alterCodes: (GenMigrationCode | GenMigrationCode[] | null)[] = [];\n\n  // 1. columnsAndIndexes 처리\n  const isEqualColumns = equal(entityColumns, dbColumns);\n  const isEqualIndexes = equal(\n    entityIndexes.map((index) => _.omit(index, [\"parser\"])),\n    dbIndexes\n  );\n  if (!isEqualColumns || !isEqualIndexes) {\n    alterCodes.push(\n      await generateAlterCode_ColumnAndIndexes(\n        entitySet.table,\n        entityColumns,\n        entityIndexes,\n        dbColumns,\n        dbIndexes,\n        dbSet.foreigns\n      )\n    );\n  }\n\n  // 2. foreigns 처리 (삭제될 컬럼 정보 전달)\n  if (equal(entityForeigns, dbForeigns) === false) {\n    alterCodes.push(\n      await generateAlterCode_Foreigns(\n        entitySet.table,\n        entityForeigns,\n        dbForeigns,\n        droppingColumns\n      )\n    );\n  }\n\n  if (alterCodes.every((alterCode) => alterCode === null)) {\n    return [];\n  }\n\n  return alterCodes.filter((alterCode) => alterCode !== null).flat();\n}\n"],"names":["_","prettier","equal","generateCreateCode_ColumnAndIndexes","table","columns","indexes","ngramIndexes","standardIndexes","partition","i","type","parser","lines","genColumnDefinitions","map","index","genIndexDefinition","title","formatted","format","join","column","chains","name","push","precision","scale","columnType","extraType","includes","length","unsigned","nullable","defaultTo","undefined","startsWith","methodMap","fulltext","unique","indexName","col","generateCreateCode_Foreign","foreigns","up","down","genForeignDefinitions","console","log","foreignKeysString","foreign","reduce","r","columnsStringQuote","replace","to","onUpdate","onDelete","generateAlterCode_ColumnAndIndexes","entityColumns","entityIndexes","dbColumns","dbIndexes","dbForeigns","alterColumnsTo","getAlterColumnsTo","alterColumnLinesTo","getAlterColumnLinesTo","alterIndexesTo","getAlterIndexesTo","add","indexNeedsToDrop","drop","filter","every","colName","alter","genIndexDropDefinition","action","len","part","columnsTo","extraColumns","db","differenceBy","entity","concat","sameDbColumns","intersectionBy","sameMdColumns","differenceWith","a","b","linesTo","dropColumnNames","fkToDropBeforeColumn","fk","some","dropFkLines","restoreFkLines","dbColumn","entityColumn","find","columnDiffUp","difference","columnDiffDown","l","indexesTo","extraIndexes","columnName","generateAlterCode_Foreigns","entityForeigns","droppingColumns","getKey","mf","droppingColumnNames","fkTo","result","entityF","matchingDbF","dbF","alterSrc","alterDst","forEach","matchingEntityF","isColumnDropping","hasLines","Object","values","generateCreateCode","entitySet","generateAlterCode","dbSet","replaceColumnDefaultTo","String","Number","toFixed","toLowerCase","sortBy","sort","c1","c2","replaceNoActionOnMySQL","f","alterCodes","isEqualColumns","isEqualIndexes","omit","alterCode","flat"],"mappings":"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"}
614
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/migration/code-generation.ts"],"sourcesContent":["import equal from \"fast-deep-equal\";\nimport { alphabetical, diff, fork, omit } from \"radashi\";\nimport { Naite } from \"..\";\nimport type {\n  GenMigrationCode,\n  MigrationColumn,\n  MigrationForeign,\n  MigrationIndex,\n  MigrationSet,\n} from \"../types/types\";\nimport { formatCode } from \"../utils/formatter\";\nimport { differenceWith, intersectionBy } from \"../utils/utils\";\n\n/**\n * 테이블 생성하는 케이스 - 컬럼/인덱스 생성\n */\nasync function generateCreateCode_ColumnAndIndexes(\n  table: string,\n  columns: MigrationColumn[],\n  indexes: MigrationIndex[],\n): Promise<GenMigrationCode> {\n  // fulltext index 분리\n  const [ngramIndexes, standardIndexes] = fork(\n    indexes,\n    (i) => i.type === \"fulltext\" && i.parser === \"ngram\",\n  );\n\n  // 컬럼, 인덱스 처리\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `await knex.schema.createTable(\"${table}\", (table) => {`,\n    \"// columns\",\n    ...genColumnDefinitions(columns),\n    \"\",\n    \"// indexes\",\n    ...standardIndexes.map((index) => genIndexDefinition(index, table)),\n    \"});\",\n    // ngram은 knex.raw로 처리하므로 createTable 밖에서 실행\n    ...ngramIndexes.map((index) => genIndexDefinition(index, table)),\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    ` return knex.schema.dropTable(\"${table}\");`,\n    \"}\",\n  ];\n  return {\n    table,\n    type: \"normal\",\n    title: `create__${table}`,\n    formatted: formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`),\n  };\n}\n\n/**\n * MigrationColumn[] 읽어서 컬럼 정의하는 구문 생성\n */\nfunction genColumnDefinitions(columns: MigrationColumn[]): string[] {\n  return columns.map((column) => {\n    const chains: string[] = [];\n    if (column.name === \"id\") {\n      return `table.increments().primary();`;\n    }\n\n    // 배열 타입 처리\n    if (column.type.endsWith(\"[]\")) {\n      const elementType = column.type.slice(0, -2); // \"integer[]\" -> \"integer\"\n      const pgType = getPgArrayType(column, elementType);\n      chains.push(`specificType('${column.name}', '${pgType}')`);\n    } else if (column.type === \"numberOrNumeric\") {\n      // number\n      if (column.numberType === \"real\") {\n        chains.push(`float('${column.name}')`);\n      } else if (column.numberType === \"double precision\") {\n        chains.push(`double('${column.name}')`);\n      } else if ((column.numberType ?? \"numeric\") === \"numeric\") {\n        chains.push(`decimal('${column.name}', ${column.precision}, ${column.scale})`);\n      }\n    } else if (column.type === \"string\") {\n      // string\n      if (column.length !== undefined) {\n        chains.push(`string('${column.name}', ${column.length})`);\n      } else {\n        chains.push(`text('${column.name}')`);\n      }\n    } else if (column.type === \"date\") {\n      // date\n      chains.push(`timestamp('${column.name}', { useTz: true })`);\n    } else if (column.type === \"json\") {\n      // json\n      chains.push(`jsonb('${column.name}')`);\n    } else {\n      // type, length\n      let extraType: string | undefined;\n      chains.push(\n        `${column.type}('${column.name}'${\n          column.length ? `, ${column.length}` : \"\"\n        }${extraType ? `, '${extraType}'` : \"\"})`,\n      );\n    }\n\n    // nullable\n    chains.push(column.nullable ? \"nullable()\" : \"notNullable()\");\n\n    // defaultTo\n    if (column.defaultTo !== undefined) {\n      if (typeof column.defaultTo === \"string\" && column.defaultTo.startsWith(`\"`)) {\n        chains.push(`defaultTo(${column.defaultTo})`);\n      } else {\n        chains.push(`defaultTo(knex.raw('${column.defaultTo}'))`);\n      }\n    }\n\n    return `table.${chains.join(\".\")};`;\n  });\n}\n\nfunction getPgArrayType(column: MigrationColumn, elementType: string): string {\n  if (elementType === \"numberOrNumeric\") {\n    if (column.numberType === \"real\") return \"real[]\";\n    if (column.numberType === \"double precision\") return \"double precision[]\";\n    return `numeric(${column.precision}, ${column.scale})[]`;\n  }\n  if (elementType === \"string\") {\n    return column.length ? `varchar(${column.length})[]` : \"text[]\";\n  }\n  if (elementType === \"date\") return \"timestamptz[]\";\n  if (elementType === \"integer\") return \"integer[]\";\n  if (elementType === \"bigInteger\") return \"bigint[]\";\n  if (elementType === \"boolean\") return \"boolean[]\";\n  if (elementType === \"uuid\") return \"uuid[]\";\n  if (elementType === \"enum\") return \"text[]\";\n\n  throw new Error(`Unknown array element type: ${elementType}`);\n}\n\n/**\n * 개별 인덱스 정의 생성\n */\nfunction genIndexDefinition(index: MigrationIndex, table: string) {\n  const methodMap = {\n    index: \"index\",\n    fulltext: \"index\",\n    unique: \"unique\",\n  };\n\n  if (index.type === \"fulltext\" && index.parser === \"ngram\") {\n    const indexName = `${table}_${index.columns.join(\"_\")}_index`;\n    return `await knex.raw(\\`ALTER TABLE ${table} ADD FULLTEXT INDEX ${indexName} (${index.columns.join(\n      \", \",\n    )}) WITH PARSER ngram\\`);`;\n  }\n\n  return `table.${methodMap[index.type]}([${index.columns\n    .map((col) => `'${col}'`)\n    .join(\",\")}]${index.type === \"fulltext\" ? \", undefined, 'FULLTEXT'\" : \"\"})`;\n}\n\n/**\n * 테이블 생성하는 케이스 - FK 생성\n */\nasync function generateCreateCode_Foreign(\n  table: string,\n  foreigns: MigrationForeign[],\n): Promise<GenMigrationCode[]> {\n  if (foreigns.length === 0) {\n    return [];\n  }\n\n  const { up, down } = genForeignDefinitions(table, foreigns);\n  if (up.length === 0 && down.length === 0) {\n    console.log(\"fk 가 뭔가 다릅니다\");\n    return [];\n  }\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    \"// create fk\",\n    ...up,\n    \"});\",\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    \"// drop fk\",\n    ...down,\n    \"});\",\n    \"}\",\n  ];\n\n  const foreignKeysString = foreigns.map((foreign) => foreign.columns.join(\"_\")).join(\"_\");\n  return [\n    {\n      table,\n      type: \"foreign\",\n      title: `foreign__${table}__${foreignKeysString}`,\n      formatted: formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`),\n    },\n  ];\n}\n\n/**\n * MigrationForeign[] 읽어서 외부키 constraint 정의하는 구문 생성\n */\nfunction genForeignDefinitions(\n  table: string,\n  foreigns: MigrationForeign[],\n): { up: string[]; down: string[] } {\n  return foreigns.reduce(\n    (r, foreign) => {\n      const columnsStringQuote = foreign.columns\n        .map((col) => `'${col.replace(`${table}.`, \"\")}'`)\n        .join(\",\");\n      r.up.push(\n        `table.foreign('${foreign.columns.join(\",\")}')\n            .references('${foreign.to}')\n            .onUpdate('${foreign.onUpdate}')\n            .onDelete('${foreign.onDelete}')`,\n      );\n      r.down.push(`table.dropForeign([${columnsStringQuote}])`);\n      return r;\n    },\n    {\n      up: [] as string[],\n      down: [] as string[],\n    },\n  );\n}\n\n/**\n * 테이블 변경 케이스 - 컬럼/인덱스 변경\n */\nasync function generateAlterCode_ColumnAndIndexes(\n  table: string,\n  entityColumns: MigrationColumn[],\n  entityIndexes: MigrationIndex[],\n  dbColumns: MigrationColumn[],\n  dbIndexes: MigrationIndex[],\n  dbForeigns: MigrationForeign[],\n): Promise<GenMigrationCode[]> {\n  /*\n    세부 비교 후 다른점 찾아서 코드 생성\n\n    1. 컬럼갯수 다름: MD에 있으나, DB에 없다면 추가\n    2. 컬럼갯수 다름: MD에 없으나, DB에 있다면 삭제\n    3. 그외 컬럼(컬럼 갯수가 동일하거나, 다른 경우 동일한 컬럼끼리) => alter\n    4. 다른거 다 동일하고 index만 변경되는 경우\n\n    ** 컬럼명을 변경하는 경우는 따로 핸들링하지 않음\n    => drop/add 형태의 마이그레이션 코드가 생성되는데, 수동으로 rename 코드로 수정하여 처리\n  */\n\n  // 각 컬럼 이름 기준으로 add, drop, alter 여부 확인\n  const alterColumnsTo = getAlterColumnsTo(entityColumns, dbColumns);\n\n  // 추출된 컬럼들을 기준으로 각각 라인 생성\n  const alterColumnLinesTo = getAlterColumnLinesTo(\n    alterColumnsTo,\n    entityColumns,\n    table,\n    dbForeigns,\n  );\n\n  // 인덱스의 add, drop 여부 확인\n  const alterIndexesTo = getAlterIndexesTo(entityIndexes, dbIndexes);\n\n  // fulltext index 분리\n  const [ngramIndexes, standardIndexes] = fork(\n    alterIndexesTo.add,\n    (i) => i.type === \"fulltext\" && i.parser === \"ngram\",\n  );\n\n  // 인덱스가 삭제되는 경우, 컬럼과 같이 삭제된 케이스에는 drop에서 제외해야함!\n  const indexNeedsToDrop = alterIndexesTo.drop.filter(\n    (index) =>\n      index.columns.every((colName) =>\n        alterColumnsTo.drop.map((col) => col.name).includes(colName),\n      ) === false,\n  );\n\n  // 빈 코드 생성 방지\n  if (\n    alterColumnLinesTo.add.up.length === 0 &&\n    alterColumnLinesTo.drop.up.length === 0 &&\n    alterColumnLinesTo.alter.up.length === 0 &&\n    standardIndexes.length === 0 &&\n    indexNeedsToDrop.length === 0\n  ) {\n    Naite.t(\"migrator:generateAlterCode_ColumnAndIndexes:emptyCodeGenerationError\", {\n      entityColumns,\n      dbColumns,\n      entityIndexes,\n      dbIndexes,\n    });\n    // throw new Error(\"컬럼/인덱스 변경 코드 생성 오류\");\n  }\n  Naite.t(\"migrator:generateAlterCode_ColumnAndIndexes:debug\", {\n    \"alterColumnsTo.add.length\": alterColumnsTo.add.length,\n    \"alterColumnsTo.drop.length\": alterColumnsTo.drop.length,\n    \"alterColumnsTo.alter.length\": alterColumnsTo.alter.length,\n    \"alterIndexesTo.add.length\": alterIndexesTo.add.length,\n    \"alterIndexesTo.drop.length\": alterIndexesTo.drop.length,\n    \"standardIndexes.length\": standardIndexes.length,\n    \"indexNeedsToDrop.length\": indexNeedsToDrop.length,\n  });\n  // Naite.t(\"migrator:generateAlterCode_ColumnAndIndexes:alterColumnsTo\", alterColumnsTo);\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `await knex.schema.alterTable(\"${table}\", (table) => {`,\n    // 1. add column\n    ...(alterColumnsTo.add.length > 0 ? alterColumnLinesTo.add.up : []),\n    // 2. drop column\n    ...(alterColumnsTo.drop.length > 0 ? alterColumnLinesTo.drop.up : []),\n    // 3. alter column\n    ...(alterColumnsTo.alter.length > 0 ? alterColumnLinesTo.alter.up : []),\n    // 4. add index\n    ...standardIndexes.map((index) => genIndexDefinition(index, table)),\n    // 5. drop index\n    ...indexNeedsToDrop.map(genIndexDropDefinition),\n    \"});\",\n    // ngram은 knex.raw로 처리하므로 alterTable 밖에서 실행\n    ...ngramIndexes.map((index) => genIndexDefinition(index, table)),\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...(alterColumnsTo.add.length > 0 ? alterColumnLinesTo.add.down : []),\n    ...(alterColumnsTo.drop.length > 0 ? alterColumnLinesTo.drop.down : []),\n    ...(alterColumnsTo.alter.length > 0 ? alterColumnLinesTo.alter.down : []),\n    ...alterIndexesTo.add\n      .filter(\n        (index) =>\n          index.columns.every((colName) =>\n            alterColumnsTo.add.map((col) => col.name).includes(colName),\n          ) === false,\n      )\n      .map(genIndexDropDefinition),\n    ...indexNeedsToDrop.map((index) => genIndexDefinition(index, table)),\n    \"});\",\n    \"}\",\n  ];\n\n  const formatted = formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`);\n  const title = [\n    \"alter\",\n    table,\n    ...([\"add\", \"drop\", \"alter\"] as const)\n      .map((action) => {\n        const len = alterColumnsTo[action].length;\n        if (len > 0) {\n          return action + len;\n        }\n        return null;\n      })\n      .filter((part) => part !== null),\n  ].join(\"_\");\n\n  return [\n    {\n      table,\n      title,\n      formatted,\n      type: \"normal\",\n    },\n  ];\n}\n\n/**\n * 각 컬럼 이름 기준으로 add, drop, alter 여부 확인\n */\nfunction getAlterColumnsTo(entityColumns: MigrationColumn[], dbColumns: MigrationColumn[]) {\n  const columnsTo = {\n    add: [] as MigrationColumn[],\n    drop: [] as MigrationColumn[],\n    alter: [] as MigrationColumn[],\n  };\n\n  // 컬럼명 기준 비교\n  const extraColumns = {\n    db: diff(dbColumns, entityColumns, (col) => col.name),\n    entity: diff(entityColumns, dbColumns, (col) => col.name),\n  };\n  if (extraColumns.entity.length > 0) {\n    columnsTo.add = columnsTo.add.concat(extraColumns.entity);\n  }\n  if (extraColumns.db.length > 0) {\n    columnsTo.drop = columnsTo.drop.concat(extraColumns.db);\n  }\n\n  // 동일 컬럼명의 세부 필드 비교\n  const sameDbColumns = intersectionBy(dbColumns, entityColumns, (col) => col.name);\n  const sameMdColumns = intersectionBy(entityColumns, dbColumns, (col) => col.name);\n  columnsTo.alter = differenceWith(sameDbColumns, sameMdColumns, (a, b) => equal(a, b));\n\n  return columnsTo;\n}\n\n/**\n * 추출된 컬럼들을 기준으로 각각 라인 생성\n */\nfunction getAlterColumnLinesTo(\n  columnsTo: ReturnType<typeof getAlterColumnsTo>,\n  entityColumns: MigrationColumn[],\n  table: string,\n  dbForeigns: MigrationForeign[],\n) {\n  const linesTo = {\n    add: {\n      up: [] as string[],\n      down: [] as string[],\n    },\n    drop: {\n      up: [] as string[],\n      down: [] as string[],\n    },\n    alter: {\n      up: [] as string[],\n      down: [] as string[],\n    },\n  };\n\n  linesTo.add = {\n    up: [\"// add\", ...genColumnDefinitions(columnsTo.add)],\n    down: [\n      \"// rollback - add\",\n      `table.dropColumns(${columnsTo.add.map((col) => `'${col.name}'`).join(\", \")})`,\n    ],\n  };\n\n  // drop할 컬럼에 걸린 FK 찾기\n  const dropColumnNames = columnsTo.drop.map((col) => col.name);\n  const fkToDropBeforeColumn = dbForeigns.filter((fk) =>\n    fk.columns.some((col) => dropColumnNames.includes(col)),\n  );\n\n  const dropFkLines = fkToDropBeforeColumn.map((fk) => {\n    const columnsStringQuote = fk.columns.map((col) => `'${col}'`).join(\",\");\n    return `table.dropForeign([${columnsStringQuote}])`;\n  });\n\n  const restoreFkLines = genForeignDefinitions(table, fkToDropBeforeColumn).up;\n\n  linesTo.drop = {\n    up: [\n      ...(dropFkLines.length > 0\n        ? [\"// drop foreign keys on columns to be dropped\", ...dropFkLines]\n        : []),\n      \"// drop columns\",\n      `table.dropColumns(${columnsTo.drop.map((col) => `'${col.name}'`).join(\", \")})`,\n    ],\n    down: [\n      \"// rollback - drop columns\",\n      ...genColumnDefinitions(columnsTo.drop),\n      ...(restoreFkLines.length > 0 ? [\"// restore foreign keys\", ...restoreFkLines] : []),\n    ],\n  };\n  linesTo.alter = columnsTo.alter.reduce(\n    (r, dbColumn) => {\n      const entityColumn = entityColumns.find((col) => col.name === dbColumn.name);\n      if (entityColumn === undefined) {\n        return r;\n      }\n\n      // 컬럼 변경사항\n      const columnDiffUp = diff(\n        genColumnDefinitions([entityColumn]),\n        genColumnDefinitions([dbColumn]),\n      );\n      const columnDiffDown = diff(\n        genColumnDefinitions([dbColumn]),\n        genColumnDefinitions([entityColumn]),\n      );\n      if (columnDiffUp.length > 0) {\n        r.up = [\n          ...r.up,\n          \"// alter column\",\n          ...columnDiffUp.map((l) => `${l.replace(\";\", \"\")}.alter();`),\n        ];\n        r.down = [\n          ...r.down,\n          \"// rollback - alter column\",\n          ...columnDiffDown.map((l) => `${l.replace(\";\", \"\")}.alter();`),\n        ];\n      }\n\n      return r;\n    },\n    {\n      up: [] as string[],\n      down: [] as string[],\n    },\n  );\n\n  return linesTo;\n}\n\n/**\n * 인덱스의 add, drop 여부 확인\n */\nfunction getAlterIndexesTo(entityIndexes: MigrationIndex[], dbIndexes: MigrationIndex[]) {\n  // 인덱스 비교\n  const indexesTo = {\n    add: [] as MigrationIndex[],\n    drop: [] as MigrationIndex[],\n  };\n  const extraIndexes = {\n    db: diff(dbIndexes, entityIndexes, (col) => [col.type, col.columns.join(\"-\")].join(\"//\")),\n    entity: diff(entityIndexes, dbIndexes, (col) => [col.type, col.columns.join(\"-\")].join(\"//\")),\n  };\n  if (extraIndexes.entity.length > 0) {\n    indexesTo.add = indexesTo.add.concat(extraIndexes.entity);\n  }\n  if (extraIndexes.db.length > 0) {\n    indexesTo.drop = indexesTo.drop.concat(extraIndexes.db);\n  }\n\n  return indexesTo;\n}\n\n/**\n * 인덱스 삭제 정의 생성\n */\nfunction genIndexDropDefinition(index: MigrationIndex) {\n  const methodMap = {\n    index: \"Index\",\n    fulltext: \"Index\",\n    unique: \"Unique\",\n  };\n\n  return `table.drop${methodMap[index.type]}([${index.columns\n    .map((columnName) => `'${columnName}'`)\n    .join(\",\")}])`;\n}\n\n/**\n * 테이블 변경 케이스 - Foreign Key 변경\n */\nasync function generateAlterCode_Foreigns(\n  table: string,\n  entityForeigns: MigrationForeign[],\n  dbForeigns: MigrationForeign[],\n  droppingColumns: MigrationColumn[] = [],\n): Promise<GenMigrationCode[]> {\n  // console.log({ entityForeigns, dbForeigns });\n\n  const getKey = (mf: MigrationForeign): string => {\n    return [mf.columns.join(\"-\"), mf.to].join(\"///\");\n  };\n\n  // 삭제될 컬럼명 목록\n  const droppingColumnNames = droppingColumns.map((col) => col.name);\n\n  const fkTo = entityForeigns.reduce(\n    (result, entityF) => {\n      const matchingDbF = dbForeigns.find((dbF) => getKey(entityF) === getKey(dbF));\n      if (!matchingDbF) {\n        result.add.push(entityF);\n        return result;\n      }\n\n      if (equal(entityF, matchingDbF) === false) {\n        result.alterSrc.push(matchingDbF);\n        result.alterDst.push(entityF);\n        return result;\n      }\n      return result;\n    },\n    {\n      add: [] as MigrationForeign[],\n      drop: [] as MigrationForeign[],\n      alterSrc: [] as MigrationForeign[],\n      alterDst: [] as MigrationForeign[],\n    },\n  );\n\n  // dbForeigns에는 있지만 entityForeigns에는 없는 경우 (삭제된 FK)\n  // 단, 삭제될 컬럼의 FK는 제외 (generateAlterCode_ColumnAndIndexes에서 처리)\n  dbForeigns.forEach((dbF) => {\n    const matchingEntityF = entityForeigns.find((entityF) => getKey(entityF) === getKey(dbF));\n    if (!matchingEntityF) {\n      // 이 FK의 컬럼이 삭제될 컬럼 목록에 있는지 확인\n      const isColumnDropping = dbF.columns.some((col) => droppingColumnNames.includes(col));\n      // 컬럼이 삭제되지 않는 경우에만 FK drop 목록에 추가\n      if (!isColumnDropping) {\n        fkTo.drop.push(dbF);\n      }\n    }\n  });\n\n  const linesTo = {\n    add: genForeignDefinitions(table, fkTo.add),\n    drop: genForeignDefinitions(table, fkTo.drop),\n    alterSrc: genForeignDefinitions(table, fkTo.alterSrc),\n    alterDst: genForeignDefinitions(table, fkTo.alterDst),\n  };\n\n  // drop fk columns인 경우(생성될 코드 없는 경우) 패스\n  const hasLines = Object.values(linesTo).some((l) => l.up.length > 0 || l.down.length > 0);\n  if (!hasLines) {\n    return [];\n  }\n\n  if (\n    linesTo.add.up.length === 0 &&\n    linesTo.drop.up.length === 0 &&\n    linesTo.alterSrc.up.length === 0 &&\n    linesTo.alterDst.up.length === 0\n  ) {\n    Naite.t(\"migrator:generateAlterCode_Foreigns:fkChangeCodeGenerationError\", {\n      table,\n      entityForeigns,\n      dbForeigns,\n    });\n    throw new Error(\"FK 변경 코드 생성 오류\");\n  }\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...linesTo.drop.down,\n    ...linesTo.add.up,\n    ...linesTo.alterSrc.down,\n    ...linesTo.alterDst.up,\n    \"})\",\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...linesTo.add.down,\n    ...linesTo.alterDst.down,\n    ...linesTo.alterSrc.up,\n    ...linesTo.drop.up,\n    \"})\",\n    \"}\",\n  ];\n\n  const formatted = formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`);\n  const title = [\n    \"alter\",\n    table,\n    \"foreigns\",\n    // TODO 바뀌는 부분\n  ].join(\"_\");\n\n  return [\n    {\n      table,\n      title,\n      formatted,\n      type: \"normal\",\n    },\n  ];\n}\n\n/**\n * 주어진 EntitySet을 기반으로 테이블 CREATE 마이그레이션 코드를 생성합니다.\n * @param entitySet\n * @returns CREATE 마이그레이션 코드\n */\nexport async function generateCreateCode(entitySet: MigrationSet): Promise<GenMigrationCode[]> {\n  return [\n    await generateCreateCode_ColumnAndIndexes(\n      entitySet.table,\n      entitySet.columns,\n      entitySet.indexes,\n    ),\n    ...(await generateCreateCode_Foreign(entitySet.table, entitySet.foreigns)),\n  ];\n}\n\n/**\n * 주어진 entitySet을 목표로, dbSet을 현 상황으로 하여 테이블 ALTER 마이그레이션 코드를 생성합니다.\n * @param entitySet 현 상황의 MigrationSet\n * @param dbSet 목표 상황의 MigrationSet\n * @returns ALTER 마이그레이션 코드\n */\nexport async function generateAlterCode(\n  entitySet: MigrationSet,\n  dbSet: MigrationSet,\n): Promise<GenMigrationCode[]> {\n  const replaceColumnDefaultTo = (col: MigrationColumn) => {\n    // float인 경우 기본값을 0으로 지정하는 경우 \"0.00\"으로 변환되는 케이스 대응\n    // if (col.type === \"float\" && col.defaultTo && String(col.defaultTo).includes('\"') === false) {\n    //   col.defaultTo = `\"${Number(col.defaultTo).toFixed(col.scale ?? 2)}\"`;\n    // }\n    // // string인 경우 기본값이 빈 스트링인 경우 대응\n    // if (col.type === \"string\" && col.defaultTo === \"\") {\n    //   col.defaultTo = '\"\"';\n    // }\n    // // boolean인 경우 기본값 정규화 (MySQL에서는 TINYINT(1)로 저장되므로 0 또는 1로 정규화)\n    // // TODO: db.ts에 typeCase 설정 확인하여 처리하도록 수정 필요\n    // if (col.type === \"boolean\" && col.defaultTo !== undefined) {\n    //   if (col.defaultTo === \"0\" || col.defaultTo.toLowerCase() === \"false\") {\n    //     col.defaultTo = \"0\";\n    //   } else if (col.defaultTo === \"1\" || col.defaultTo.toLowerCase() === \"true\") {\n    //     col.defaultTo = \"1\";\n    //   }\n    // }\n\n    // FIXME: 일단 MySQL 상황에서 발생했던 이슈의 workaround 이므로 Pg에서 재확인 후 대응 추가\n    return col;\n  };\n  const entityColumns = alphabetical(entitySet.columns, (a) => a.name).map(replaceColumnDefaultTo);\n  const dbColumns = alphabetical(dbSet.columns, (a) => a.name).map(replaceColumnDefaultTo);\n\n  /* 디버깅용 코드, 특정 컬럼에서 불일치 발생할 때 확인\n        const entityColumn = entitySet.columns.find(\n          (col) => col.name === \"price_krw\"\n        );\n        const dbColumn = dbSet.columns.find(\n          (col) => col.name === \"price_krw\"\n        );\n        console.debug({ entityColumn, dbColumn });\n         */\n\n  const entityIndexes = alphabetical(entitySet.indexes, (a) =>\n    [a.type, ...a.columns.sort((c1, c2) => (c1 > c2 ? 1 : -1))].join(\"-\"),\n  );\n  const dbIndexes = alphabetical(dbSet.indexes, (a) =>\n    [a.type, ...a.columns.sort((c1, c2) => (c1 > c2 ? 1 : -1))].join(\"-\"),\n  );\n\n  const replaceNoActionOnMySQL = (f: MigrationForeign) => {\n    // MySQL에서 RESTRICT와 NO ACTION은 동일함\n    const { onDelete, onUpdate } = f;\n    return {\n      ...f,\n      onUpdate: onUpdate === \"RESTRICT\" ? \"NO ACTION\" : onUpdate,\n      onDelete: onDelete === \"RESTRICT\" ? \"NO ACTION\" : onDelete,\n    };\n  };\n\n  const entityForeigns = alphabetical(entitySet.foreigns, (a) =>\n    [a.to, ...a.columns].join(\"-\"),\n  ).map((f) => replaceNoActionOnMySQL(f));\n  const dbForeigns = alphabetical(dbSet.foreigns, (a) => [a.to, ...a.columns].join(\"-\")).map((f) =>\n    replaceNoActionOnMySQL(f),\n  );\n\n  // 삭제될 컬럼 목록 계산\n  const droppingColumns = diff(dbColumns, entityColumns, (col) => col.name);\n\n  const alterCodes: (GenMigrationCode | GenMigrationCode[] | null)[] = [];\n\n  // 1. columnsAndIndexes 처리\n  const isEqualColumns = equal(entityColumns, dbColumns);\n  const isEqualIndexes = equal(\n    entityIndexes.map((index) => omit(index, [\"parser\"])),\n    dbIndexes,\n  );\n  if (!isEqualColumns || !isEqualIndexes) {\n    alterCodes.push(\n      await generateAlterCode_ColumnAndIndexes(\n        entitySet.table,\n        entityColumns,\n        entityIndexes,\n        dbColumns,\n        dbIndexes,\n        dbSet.foreigns,\n      ),\n    );\n  }\n\n  // 2. foreigns 처리 (삭제될 컬럼 정보 전달)\n  if (equal(entityForeigns, dbForeigns) === false) {\n    alterCodes.push(\n      await generateAlterCode_Foreigns(\n        entitySet.table,\n        entityForeigns,\n        dbForeigns,\n        droppingColumns,\n      ),\n    );\n  }\n\n  if (alterCodes.every((alterCode) => alterCode === null)) {\n    return [];\n  }\n\n  return alterCodes.filter((alterCode) => alterCode !== null).flat();\n}\n"],"names":["equal","alphabetical","diff","fork","omit","Naite","formatCode","differenceWith","intersectionBy","generateCreateCode_ColumnAndIndexes","table","columns","indexes","ngramIndexes","standardIndexes","i","type","parser","lines","genColumnDefinitions","map","index","genIndexDefinition","title","formatted","join","column","chains","name","endsWith","elementType","slice","pgType","getPgArrayType","push","numberType","precision","scale","length","undefined","extraType","nullable","defaultTo","startsWith","Error","methodMap","fulltext","unique","indexName","col","generateCreateCode_Foreign","foreigns","up","down","genForeignDefinitions","console","log","foreignKeysString","foreign","reduce","r","columnsStringQuote","replace","to","onUpdate","onDelete","generateAlterCode_ColumnAndIndexes","entityColumns","entityIndexes","dbColumns","dbIndexes","dbForeigns","alterColumnsTo","getAlterColumnsTo","alterColumnLinesTo","getAlterColumnLinesTo","alterIndexesTo","getAlterIndexesTo","add","indexNeedsToDrop","drop","filter","every","colName","includes","alter","t","genIndexDropDefinition","action","len","part","columnsTo","extraColumns","db","entity","concat","sameDbColumns","sameMdColumns","a","b","linesTo","dropColumnNames","fkToDropBeforeColumn","fk","some","dropFkLines","restoreFkLines","dbColumn","entityColumn","find","columnDiffUp","columnDiffDown","l","indexesTo","extraIndexes","columnName","generateAlterCode_Foreigns","entityForeigns","droppingColumns","getKey","mf","droppingColumnNames","fkTo","result","entityF","matchingDbF","dbF","alterSrc","alterDst","forEach","matchingEntityF","isColumnDropping","hasLines","Object","values","generateCreateCode","entitySet","generateAlterCode","dbSet","replaceColumnDefaultTo","sort","c1","c2","replaceNoActionOnMySQL","f","alterCodes","isEqualColumns","isEqualIndexes","alterCode","flat"],"mappings":"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"}
@@ -1,13 +1,5 @@
1
- import { Knex } from "knex";
2
- import { Entity } from "../entity/entity";
3
- import { MigrationSet, MigrationSetAndJoinTable } from "../types/types";
4
- /**
5
- * DB에서 테이블 정보를 읽어서 MigrationSet을 만들어옵니다.
6
- * @param compareDB Knex 인스턴스
7
- * @param table 테이블 이름
8
- * @returns MigrationSet 객체
9
- */
10
- export declare function getMigrationSetFromDB(compareDB: Knex, table: string): Promise<MigrationSet | null>;
1
+ import type { Entity } from "../entity/entity";
2
+ import { type MigrationSetAndJoinTable } from "../types/types";
11
3
  /**
12
4
  * Entity를 읽어서 MigrationSetAndJoinTable을 만들어옵니다.
13
5
  * @param entity Entity 객체
@@ -1 +1 @@
1
- {"version":3,"file":"migration-set.d.ts","sourceRoot":"","sources":["../../src/migration/migration-set.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAI5B,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE1C,OAAO,EAEL,YAAY,EAmBZ,wBAAwB,EACzB,MAAM,gBAAgB,CAAC;AAExB;;;;;GAKG;AACH,wBAAsB,qBAAqB,CACzC,SAAS,EAAE,IAAI,EACf,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,CA2E9B;AAqJD;;;;GAIG;AACH,wBAAgB,yBAAyB,CACvC,MAAM,EAAE,MAAM,GACb,wBAAwB,CAsL1B"}
1
+ {"version":3,"file":"migration-set.d.ts","sourceRoot":"","sources":["../../src/migration/migration-set.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE/C,OAAO,EAgBL,KAAK,wBAAwB,EAC9B,MAAM,gBAAgB,CAAC;AAGxB;;;;GAIG;AACH,wBAAgB,yBAAyB,CAAC,MAAM,EAAE,MAAM,GAAG,wBAAwB,CAiKlF"}