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,15 +1,17 @@
1
- import * as _ from "lodash-es";
2
- import { createImportUrl } from "../utils/esm-utils.js";
3
- import { EntityManager as EntityManager } from "./entity-manager.js";
4
- import { isRelationProp, isVirtualProp, isBelongsToOneRelationProp, isOneToOneRelationProp, isHasManyRelationProp, isManyToManyRelationProp, isEnumProp } from "../types/types.js";
1
+ import assert from "assert";
2
+ import { writeFile } from "node:fs/promises";
5
3
  import inflection from "inflection";
6
4
  import path from "path";
7
- import { writeFile } from "node:fs/promises";
5
+ import { group, unique } from "radashi";
8
6
  import { z } from "zod";
9
7
  import { Sonamu } from "../api/sonamu.js";
10
- import prettier from "prettier";
11
- import { nonNullable } from "../utils/utils.js";
8
+ import { isBelongsToOneRelationProp, isEnumProp, isHasManyRelationProp, isManyToManyRelationProp, isOneToOneRelationProp, isRelationProp, isVirtualProp } from "../types/types.js";
9
+ import { importMembers } from "../utils/esm-utils.js";
10
+ import { formatCode } from "../utils/formatter.js";
12
11
  import { exists } from "../utils/fs-utils.js";
12
+ import { runtimePath } from "../utils/path-utils.js";
13
+ import { assertDefined, nonNullable } from "../utils/utils.js";
14
+ import { EntityManager } from "./entity-manager.js";
13
15
  export class Entity {
14
16
  id;
15
17
  parentId;
@@ -40,19 +42,17 @@ export class Entity {
40
42
  }
41
43
  return prop;
42
44
  });
43
- this.propsDict = props.reduce((result, prop)=>{
44
- return {
45
- ...result,
46
- [prop.name]: prop
47
- };
48
- }, {});
45
+ this.propsDict = Object.fromEntries(props.map((prop)=>{
46
+ return [
47
+ prop.name,
48
+ prop
49
+ ];
50
+ }));
49
51
  // relations
50
- this.relations = props.filter((prop)=>isRelationProp(prop)).reduce((result, prop)=>{
51
- return {
52
- ...result,
53
- [prop.name]: prop
54
- };
55
- }, {});
52
+ this.relations = Object.fromEntries(props.filter((prop)=>isRelationProp(prop)).map((prop)=>[
53
+ prop.name,
54
+ prop
55
+ ]));
56
56
  } else {
57
57
  this.props = [];
58
58
  this.propsDict = {};
@@ -78,6 +78,107 @@ export class Entity {
78
78
  };
79
79
  }
80
80
  /*
81
+ subset을 Puri 코드로 변환
82
+ */ getPuriSubsetQuery(subsetKey) {
83
+ const subset = this.subsets[subsetKey];
84
+ const subsetQuery = this.resolveSubsetQuery("", subset);
85
+ const lines = [];
86
+ // from
87
+ lines.push(`return qbWrapper`);
88
+ lines.push(`.from("${this.table}")`);
89
+ // join
90
+ for (const join of subsetQuery.joins){
91
+ const joinMethod = join.join === "inner" ? "join" : "leftJoin";
92
+ if ("custom" in join) {
93
+ // custom join clause는 raw 사용
94
+ lines.push(`.${joinMethod}({ ${join.as}: "${join.table}" }, qbWrapper.knex.raw(\`${join.custom}\`))`);
95
+ } else {
96
+ lines.push(`.${joinMethod}({ ${join.as}: "${join.table}" }, "${join.from}", "${join.to}")`);
97
+ }
98
+ }
99
+ // select
100
+ const selectObj = {};
101
+ for (const selectItem of subsetQuery.select){
102
+ // "users.id" 또는 "users.id as user__id" 형태
103
+ const match = selectItem.match(/^(.+?)(?: as (.+))?$/);
104
+ if (match) {
105
+ const [, column, alias] = match;
106
+ const key = alias ?? assertDefined(column.split(".").pop());
107
+ selectObj[key] = `"${column.trim()}"`;
108
+ }
109
+ }
110
+ lines.push(`.select({`);
111
+ Object.entries(selectObj).forEach(([key, value])=>{
112
+ lines.push(`${key}: ${value},`);
113
+ });
114
+ lines.push(`});`);
115
+ return lines.join("\n");
116
+ }
117
+ getPuriLoaderQuery(subsetKey) {
118
+ const subset = this.subsets[subsetKey];
119
+ const { loaders } = this.resolveSubsetQuery("", subset);
120
+ const lines = [
121
+ `[`
122
+ ];
123
+ const parseSelect = (select, table)=>{
124
+ const tablePrefix = `${table}.`;
125
+ if (select.startsWith(tablePrefix)) {
126
+ return `${select.replace(tablePrefix, "")}: "${select}"`;
127
+ }
128
+ if (select.includes(" as ")) {
129
+ const [column, alias] = select.split(" as ");
130
+ return `${alias}: "${column}"`;
131
+ }
132
+ return `${select}: "${select}"`;
133
+ };
134
+ // 재귀적으로 loader 생성하는 헬퍼 함수
135
+ const generateLoaderCode = (loaders)=>{
136
+ const loaderLines = [];
137
+ for (const loader of loaders){
138
+ const { toTable, toCol, through } = loader.manyJoin;
139
+ loaderLines.push("{", `as: "${loader.as}",`, `refId: "${loader.manyJoin.idField}",`, `qb: (qbWrapper: PuriWrapper<DatabaseSchemaExtend>, fromIds: number[]) => {`);
140
+ if (through === undefined) {
141
+ // HasMany
142
+ loaderLines.push(//
143
+ "return qbWrapper", `.from("${toTable}")`);
144
+ loader.oneJoins.forEach((join)=>{
145
+ const joinType = join.join === "inner" ? "join" : "leftJoin";
146
+ if ("custom" in join) {
147
+ // FIXME: 검증 필요
148
+ loaderLines.push(`.${joinType}({ ${join.as}: "${join.table}" }, (j) => {`, `j.on(Puri.rawString("${join.custom}"));`, "})");
149
+ } else {
150
+ loaderLines.push(`.${joinType}({ ${join.as}: "${join.table}" }, "${join.from}", "${join.to}")`);
151
+ }
152
+ });
153
+ loaderLines.push(`.whereIn("${toTable}.${toCol}", fromIds)`, `.select({`, `${loader.select.map((select)=>parseSelect(select, toTable)).join(",")},`, `refId: "${toTable}.${toCol}",`, `});`);
154
+ } else {
155
+ // ManyToMany
156
+ loaderLines.push("return qbWrapper", `.from("${through.table}")`, `.join("${toTable}", "${through.table}.${through.toCol}", "${toTable}.${toCol}")`);
157
+ loader.oneJoins.forEach((join)=>{
158
+ const joinType = join.join === "inner" ? "join" : "leftJoin";
159
+ if ("custom" in join) {
160
+ // FIXME: 검증 필요
161
+ loaderLines.push(`.${joinType}({ ${join.as}: "${join.table}" }, (j) => {`, `j.on(Puri.rawString("${join.custom}"));`, "})");
162
+ } else {
163
+ loaderLines.push(`.${joinType}({ ${join.as}: "${join.table}" }, "${join.from}", "${join.to}")`);
164
+ }
165
+ });
166
+ loaderLines.push(`.whereIn("${through.table}.${through.fromCol}", fromIds)`, `.select({`, `${loader.select.map((select)=>parseSelect(select, toTable)).join(",")},`, `refId: "${through.table}.${through.fromCol}",`, `});`);
167
+ }
168
+ loaderLines.push(`},`);
169
+ // 중첩 loaders 처리
170
+ if (loader.loaders && loader.loaders.length > 0) {
171
+ loaderLines.push("loaders: [", ...generateLoaderCode(loader.loaders), "],");
172
+ }
173
+ loaderLines.push("},");
174
+ }
175
+ return loaderLines;
176
+ };
177
+ lines.push(...generateLoaderCode(loaders));
178
+ lines.push(`]`);
179
+ return lines.join("\n");
180
+ }
181
+ /*
81
182
  subset SELECT/JOIN/LOADER 결과 리턴
82
183
  */ getSubsetQuery(subsetKey) {
83
184
  const subset = this.subsets[subsetKey];
@@ -89,7 +190,7 @@ export class Entity {
89
190
  // prefix 치환 (prefix는 ToOneRelation이 복수로 붙은 경우 모두 __로 변경됨)
90
191
  prefix = prefix.replace(/\./g, "__");
91
192
  // 서브셋을 1뎁스만 분리하여 그룹핑
92
- const subsetGroup = _.groupBy(fields, (field)=>{
193
+ const subsetGroup = group(fields, (field)=>{
93
194
  if (field.includes(".")) {
94
195
  const [rel] = field.split(".");
95
196
  return rel;
@@ -99,6 +200,7 @@ export class Entity {
99
200
  });
100
201
  const result = Object.keys(subsetGroup).reduce((r, groupKey)=>{
101
202
  const fields = subsetGroup[groupKey];
203
+ assert(fields !== undefined, "fields is undefined");
102
204
  // 현재 테이블 필드셋은 select, virtual에 추가하고 리턴
103
205
  if (groupKey === "") {
104
206
  const realFields = fields.filter((field)=>!isVirtualProp(this.propsDict[field]));
@@ -149,10 +251,10 @@ export class Entity {
149
251
  }
150
252
  }
151
253
  })();
152
- const relSubsetQuery = relEntity.resolveSubsetQuery(`${prefix !== "" ? prefix + "." : ""}${groupKey}`, relFields, innerOrOuter === "outer");
254
+ const relSubsetQuery = relEntity.resolveSubsetQuery(`${prefix !== "" ? `${prefix}.` : ""}${groupKey}`, relFields, innerOrOuter === "outer");
153
255
  r.select = r.select.concat(relSubsetQuery.select);
154
256
  r.virtual = r.virtual.concat(relSubsetQuery.virtual);
155
- const joinAs = prefix === "" ? groupKey : prefix + "__" + groupKey;
257
+ const joinAs = prefix === "" ? groupKey : `${prefix}__${groupKey}`;
156
258
  const fromTable = prefix === "" ? this.table : prefix;
157
259
  let joinClause;
158
260
  if (relation.customJoinClause) {
@@ -167,7 +269,7 @@ export class Entity {
167
269
  to = `${joinAs}.id`;
168
270
  } else {
169
271
  from = `${fromTable}.id`;
170
- to = `${joinAs}.${inflection.underscore(this.names.fs.replace(/\-/g, "_"))}_id`;
272
+ to = `${joinAs}.${inflection.underscore(this.names.fs.replace(/-/g, "_"))}_id`;
171
273
  }
172
274
  } else {
173
275
  from = `${fromTable}.${relation.name}_id`;
@@ -269,7 +371,7 @@ export class Entity {
269
371
  result[key] = (result[key] ?? []).concat(value);
270
372
  return result;
271
373
  }, {});
272
- return Object.keys(groups).map((key)=>{
374
+ return Object.keys(groups).flatMap((key)=>{
273
375
  const group = groups[key];
274
376
  // 일반 prop 처리
275
377
  if (key === "") {
@@ -309,14 +411,14 @@ export class Entity {
309
411
  const relEntity = EntityManager.get(prop.with);
310
412
  // relation -One 에 id 필드 하나인 경우
311
413
  if (isBelongsToOneRelationProp(prop) || isOneToOneRelationProp(prop)) {
312
- if (group.length == 1 && (group[0] === "id" || group[0] == "id?")) {
414
+ if (group.length === 1 && (group[0] === "id" || group[0] === "id?")) {
313
415
  // id 하나만 있는지 체크해서, 하나만 있으면 상위 prop으로 id를 리턴
314
416
  const idProp = relEntity.propsDict.id;
315
417
  return {
316
418
  nodeType: "plain",
317
419
  prop: {
318
420
  ...idProp,
319
- name: key + "_id",
421
+ name: `${key}_id`,
320
422
  nullable: prop.nullable
321
423
  },
322
424
  children: []
@@ -333,10 +435,10 @@ export class Entity {
333
435
  children,
334
436
  nodeType
335
437
  };
336
- }).flat();
438
+ });
337
439
  }
338
440
  getFieldExprs(prefix = "", maxDepth = 3, froms = []) {
339
- return this.props.map((prop)=>{
441
+ return this.props.flatMap((prop)=>{
340
442
  const propName = [
341
443
  prefix,
342
444
  prop.name
@@ -360,7 +462,7 @@ export class Entity {
360
462
  ]);
361
463
  }
362
464
  return propName;
363
- }).flat().filter((f)=>f !== null);
465
+ }).filter((f)=>f !== null);
364
466
  }
365
467
  getTableColumns() {
366
468
  return this.props.map((prop)=>{
@@ -388,27 +490,26 @@ export class Entity {
388
490
  if (Object.keys(this.subsets).length > 0) {
389
491
  EntityManager.setModulePath(`${this.id}SubsetKey`, `sonamu.generated`);
390
492
  EntityManager.setModulePath(`${this.id}SubsetMapping`, `sonamu.generated`);
391
- Object.keys(this.subsets).map((subsetKey)=>{
493
+ for (const subsetKey of Object.keys(this.subsets)){
392
494
  EntityManager.setModulePath(`${this.id}Subset${subsetKey.toUpperCase()}`, `sonamu.generated`);
393
- });
495
+ }
394
496
  }
395
497
  // enums
396
- Object.keys(this.enumLabels).map((enumId)=>{
498
+ for (const enumId of Object.keys(this.enumLabels)){
397
499
  EntityManager.setModulePath(enumId, `sonamu.generated`);
398
- });
500
+ }
399
501
  // types
400
502
  const typesModulePath = `${basePath}/${this.names.parentFs}.types`;
401
- const typesFileDistPath = path.join(Sonamu.apiRootPath, `dist/application/${typesModulePath}.js`);
402
- if (await exists(typesFileDistPath)) {
403
- const importUrl = createImportUrl(typesFileDistPath);
404
- const t = await import(importUrl);
405
- this.types = Object.keys(t).reduce((result, key)=>{
406
- EntityManager.setModulePath(key, typesModulePath);
407
- return {
408
- ...result,
409
- [key]: t[key]
410
- };
411
- }, {});
503
+ const typesFilePath = path.join(Sonamu.apiRootPath, runtimePath(`dist/application/${typesModulePath}.js`));
504
+ if (await exists(typesFilePath)) {
505
+ const importedMembers = await importMembers(typesFilePath);
506
+ this.types = Object.fromEntries(importedMembers.map(({ name, value })=>{
507
+ EntityManager.setModulePath(name, typesModulePath);
508
+ return [
509
+ name,
510
+ value
511
+ ];
512
+ }));
412
513
  }
413
514
  }
414
515
  registerTableSpecs() {
@@ -442,9 +543,7 @@ export class Entity {
442
543
  // save
443
544
  const jsonPath = path.join(Sonamu.apiRootPath, `src/application/${this.names.parentFs}/${this.names.fs}.entity.json`);
444
545
  const json = this.toJson();
445
- await writeFile(jsonPath, await prettier.format(JSON.stringify(json), {
446
- parser: "json"
447
- }));
546
+ await writeFile(jsonPath, formatCode(JSON.stringify(json), "json", jsonPath));
448
547
  // reload
449
548
  await EntityManager.register(json);
450
549
  }
@@ -454,12 +553,12 @@ export class Entity {
454
553
  }
455
554
  const subsets = _subsets ?? this.subsets;
456
555
  const subsetKeys = Object.keys(subsets);
457
- const allFields = _.uniq(subsetKeys.map((key)=>subsets[key]).flat());
556
+ const allFields = unique(subsetKeys.flatMap((key)=>subsets[key]));
458
557
  return this.props.map((prop)=>{
459
- if (prop.type === "relation" && allFields.find((f)=>f.startsWith([
558
+ if (prop.type === "relation" && allFields.find((f)=>f.startsWith(`${[
460
559
  ...prefixes,
461
560
  prop.name
462
- ].join(".") + "."))) {
561
+ ].join(".")}.`))) {
463
562
  const relEntity = EntityManager.get(prop.with);
464
563
  const children = relEntity.getSubsetRows(subsets, [
465
564
  ...prefixes,
@@ -491,7 +590,7 @@ export class Entity {
491
590
  ...prefixes,
492
591
  prop.name
493
592
  ].join(".");
494
- return f === field || f.startsWith(field + ".");
593
+ return f === field || f.startsWith(`${field}.`);
495
594
  });
496
595
  return [
497
596
  subsetKey,
@@ -607,9 +706,9 @@ export class Entity {
607
706
  }
608
707
  }
609
708
  // 현재 엔티티의 인덱스에서 제외
610
- EntityManager.get(this.id).indexes.map((index)=>{
709
+ for (const index of EntityManager.get(this.id).indexes){
611
710
  index.columns = index.columns.filter((col)=>col !== oldName);
612
- });
711
+ }
613
712
  // 프롭 삭제
614
713
  this.props.splice(at, 1);
615
714
  await Promise.all(entities.map(async (entity)=>entity.save()));
@@ -648,4 +747,4 @@ export class Entity {
648
747
  }
649
748
  }
650
749
 
651
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/entity/entity.ts"],"sourcesContent":["import * as _ from \"lodash-es\";\nimport { createImportUrl } from \"../utils/esm-utils\";\nimport { EntityManager as EntityManager } from \"./entity-manager\";\nimport {\n  EntityProp,\n  RelationProp,\n  isRelationProp,\n  SubsetQuery,\n  isVirtualProp,\n  isBelongsToOneRelationProp,\n  isOneToOneRelationProp,\n  isHasManyRelationProp,\n  isManyToManyRelationProp,\n  EntityPropNode,\n  isEnumProp,\n  StringProp,\n  EntityIndex,\n  EntityJson,\n  EntitySubsetRow,\n} from \"../types/types\";\nimport inflection from \"inflection\";\nimport path from \"path\";\nimport { writeFile } from \"fs/promises\";\nimport { z } from \"zod\";\nimport { Sonamu } from \"../api/sonamu\";\nimport prettier from \"prettier\";\nimport { nonNullable } from \"../utils/utils\";\nimport { exists } from \"../utils/fs-utils\";\n\nexport class Entity {\n  id: string;\n  parentId?: string;\n  table: string;\n  title: string;\n  names: {\n    parentFs: string;\n    fs: string;\n    module: string;\n  };\n  props: EntityProp[];\n  propsDict: {\n    [key: string]: EntityProp;\n  };\n  relations: {\n    [key: string]: RelationProp;\n  };\n  indexes: EntityIndex[];\n  subsets: {\n    [key: string]: string[];\n  };\n  types: {\n    [name: string]: z.ZodTypeAny;\n  } = {};\n  enums: {\n    [enumId: string]: z.ZodEnum<any>;\n  } = {};\n  enumLabels: {\n    [enumId: string]: {\n      [key: string]: string;\n    };\n  } = {};\n\n  constructor({\n    id,\n    parentId,\n    table,\n    title,\n    props,\n    indexes,\n    subsets,\n    enums,\n  }: EntityJson) {\n    // id\n    this.id = id;\n    this.parentId = parentId;\n    this.title = title ?? this.id;\n    this.table = table ?? inflection.underscore(inflection.pluralize(id));\n\n    // props\n    if (props) {\n      this.props = props.map((prop) => {\n        if (isEnumProp(prop)) {\n          if (prop.id.includes(\"$Model\")) {\n            prop.id = prop.id.replace(\"$Model\", id);\n          }\n        }\n        return prop;\n      });\n      this.propsDict = props.reduce((result, prop) => {\n        return {\n          ...result,\n          [prop.name]: prop,\n        };\n      }, {});\n\n      // relations\n      this.relations = props\n        .filter((prop) => isRelationProp(prop))\n        .reduce((result, prop) => {\n          return {\n            ...result,\n            [prop.name]: prop,\n          };\n        }, {});\n    } else {\n      this.props = [];\n      this.propsDict = {};\n      this.relations = {};\n    }\n\n    // indexes\n    this.indexes = indexes ?? [];\n\n    // subsets\n    this.subsets = subsets ?? {};\n\n    // enums\n    this.enumLabels = enums ?? {};\n    this.enums = Object.fromEntries(\n      Object.entries(this.enumLabels).map(([key, enumLabel]) => {\n        return [\n          key,\n          z.enum(\n            Object.keys(enumLabel) as unknown as readonly [string, ...string[]]\n          ),\n        ];\n      })\n    );\n\n    // names\n    this.names = {\n      parentFs: inflection\n        .dasherize(inflection.underscore(parentId ?? id))\n        .toLowerCase(),\n      fs: inflection.dasherize(inflection.underscore(id)).toLowerCase(),\n      module: id,\n    };\n  }\n\n  /*\n    subset SELECT/JOIN/LOADER 결과 리턴\n  */\n  getSubsetQuery(subsetKey: string): SubsetQuery {\n    const subset = this.subsets[subsetKey];\n\n    const result: SubsetQuery = this.resolveSubsetQuery(\"\", subset);\n    return result;\n  }\n\n  /*\n   */\n  resolveSubsetQuery(\n    prefix: string,\n    fields: string[],\n    isAlreadyOuterJoined: boolean = false\n  ): SubsetQuery {\n    // prefix 치환 (prefix는 ToOneRelation이 복수로 붙은 경우 모두 __로 변경됨)\n    prefix = prefix.replace(/\\./g, \"__\");\n\n    // 서브셋을 1뎁스만 분리하여 그룹핑\n    const subsetGroup = _.groupBy(fields, (field) => {\n      if (field.includes(\".\")) {\n        const [rel] = field.split(\".\");\n        return rel;\n      } else {\n        return \"\";\n      }\n    });\n\n    const result = Object.keys(subsetGroup).reduce(\n      (r, groupKey) => {\n        const fields = subsetGroup[groupKey];\n        // 현재 테이블 필드셋은 select, virtual에 추가하고 리턴\n        if (groupKey === \"\") {\n          const realFields = fields.filter(\n            (field) => !isVirtualProp(this.propsDict[field])\n          );\n          const virtualFields = fields.filter((field) =>\n            isVirtualProp(this.propsDict[field])\n          );\n\n          if (prefix === \"\") {\n            // 현재 테이블인 경우\n            r.select = r.select.concat(\n              realFields.map((field) => `${this.table}.${field}`)\n            );\n            r.virtual = r.virtual.concat(virtualFields);\n          } else {\n            // 넘어온 테이블인 경우\n            r.select = r.select.concat(\n              realFields.map(\n                (field) => `${prefix}.${field} as ${prefix}__${field}`\n              )\n            );\n          }\n\n          return r;\n        }\n\n        const relation = this.relations[groupKey];\n        if (relation === undefined) {\n          throw new Error(`존재하지 않는 relation 참조 ${groupKey}`);\n        }\n        const relEntity = EntityManager.get(relation.with);\n\n        if (\n          isOneToOneRelationProp(relation) ||\n          isBelongsToOneRelationProp(relation)\n        ) {\n          // -One Relation: JOIN 으로 처리\n          const relFields = fields.map((field) =>\n            field.split(\".\").slice(1).join(\".\")\n          );\n\n          // -One Relation에서 id 필드만 참조하는 경우 릴레이션 넘기지 않고 리턴\n          if (relFields.length === 1 && relFields[0] === \"id\") {\n            if (prefix === \"\") {\n              r.select = r.select.concat(`${this.table}.${groupKey}_id`);\n            } else {\n              r.select = r.select.concat(\n                `${prefix}.${groupKey}_id as ${prefix}__${groupKey}_id`\n              );\n            }\n            return r;\n          }\n\n          // innerOrOuter\n          const innerOrOuter = (() => {\n            if (isAlreadyOuterJoined) {\n              return \"outer\";\n            }\n\n            if (isOneToOneRelationProp(relation)) {\n              if (\n                relation.hasJoinColumn === true &&\n                (relation.nullable ?? false) === false\n              ) {\n                return \"inner\";\n              } else {\n                return \"outer\";\n              }\n            } else {\n              if (relation.nullable) {\n                return \"outer\";\n              } else {\n                return \"inner\";\n              }\n            }\n          })();\n          const relSubsetQuery = relEntity.resolveSubsetQuery(\n            `${prefix !== \"\" ? prefix + \".\" : \"\"}${groupKey}`,\n            relFields,\n            innerOrOuter === \"outer\"\n          );\n          r.select = r.select.concat(relSubsetQuery.select);\n          r.virtual = r.virtual.concat(relSubsetQuery.virtual);\n\n          const joinAs = prefix === \"\" ? groupKey : prefix + \"__\" + groupKey;\n          const fromTable = prefix === \"\" ? this.table : prefix;\n\n          let joinClause;\n          if (relation.customJoinClause) {\n            joinClause = {\n              custom: relation.customJoinClause,\n            };\n          } else {\n            let from, to;\n            if (isOneToOneRelationProp(relation)) {\n              if (relation.hasJoinColumn) {\n                from = `${fromTable}.${relation.name}_id`;\n                to = `${joinAs}.id`;\n              } else {\n                from = `${fromTable}.id`;\n                to = `${joinAs}.${inflection.underscore(\n                  this.names.fs.replace(/\\-/g, \"_\")\n                )}_id`;\n              }\n            } else {\n              from = `${fromTable}.${relation.name}_id`;\n              to = `${joinAs}.id`;\n            }\n            joinClause = {\n              from,\n              to,\n            };\n          }\n\n          r.joins.push({\n            as: joinAs,\n            join: innerOrOuter,\n            table: relEntity.table,\n            ...joinClause,\n          });\n\n          // BelongsToOne 밑에 HasMany가 붙은 경우\n          if (relSubsetQuery.loaders.length > 0) {\n            const convertedLoaders = relSubsetQuery.loaders.map((loader) => {\n              const newAs = [groupKey, loader.as].join(\"__\");\n              return {\n                as: newAs,\n                table: loader.table,\n                manyJoin: loader.manyJoin,\n                oneJoins: loader.oneJoins,\n                select: loader.select,\n                loaders: loader.loaders,\n              };\n            });\n\n            r.loaders = [...r.loaders, ...convertedLoaders];\n          }\n\n          r.joins = r.joins.concat(relSubsetQuery.joins);\n        } else if (\n          isHasManyRelationProp(relation) ||\n          isManyToManyRelationProp(relation)\n        ) {\n          // -Many Relation: Loader 로 처리\n          const relFields = fields.map((field) =>\n            field.split(\".\").slice(1).join(\".\")\n          );\n          const relSubsetQuery = relEntity.resolveSubsetQuery(\"\", relFields);\n\n          let manyJoin: SubsetQuery[\"loaders\"][number][\"manyJoin\"];\n          if (isHasManyRelationProp(relation)) {\n            const fromCol = relation?.fromColumn ?? \"id\";\n            manyJoin = {\n              fromTable: this.table,\n              fromCol,\n              idField: prefix === \"\" ? `${fromCol}` : `${prefix}__${fromCol}`,\n              toTable: relEntity.table,\n              toCol: relation.joinColumn,\n            };\n          } else if (isManyToManyRelationProp(relation)) {\n            manyJoin = {\n              fromTable: this.table,\n              fromCol: \"id\",\n              idField: prefix === \"\" ? `id` : `${prefix}__id`,\n              through: {\n                table: relation.joinTable,\n                fromCol: `${inflection.singularize(this.table)}_id`,\n                toCol: `${inflection.singularize(relEntity.table)}_id`,\n              },\n              toTable: relEntity.table,\n              toCol: \"id\",\n            };\n          } else {\n            throw new Error();\n          }\n\n          r.loaders.push({\n            as: groupKey,\n            table: relEntity.table,\n            manyJoin,\n            oneJoins: relSubsetQuery.joins,\n            select: relSubsetQuery.select,\n            loaders: relSubsetQuery.loaders,\n          });\n        }\n\n        return r;\n      },\n      {\n        select: [],\n        virtual: [],\n        joins: [],\n        loaders: [],\n      } as SubsetQuery\n    );\n    return result;\n  }\n\n  /*\n    FieldExpr[] 을 EntityPropNode[] 로 변환\n  */\n  fieldExprsToPropNodes(\n    fieldExprs: string[],\n    entity: Entity = this\n  ): EntityPropNode[] {\n    const groups = fieldExprs.reduce(\n      (result, fieldExpr) => {\n        let key, value, elseExpr;\n        if (fieldExpr.includes(\".\")) {\n          [key, ...elseExpr] = fieldExpr.split(\".\");\n          value = elseExpr.join(\".\");\n        } else {\n          key = \"\";\n          value = fieldExpr;\n        }\n        result[key] = (result[key] ?? []).concat(value);\n\n        return result;\n      },\n      {} as {\n        [k: string]: string[];\n      }\n    );\n\n    return Object.keys(groups)\n      .map((key) => {\n        const group = groups[key];\n\n        // 일반 prop 처리\n        if (key === \"\") {\n          return group.map((propName) => {\n            // uuid 개별 처리\n            if (propName === \"uuid\") {\n              return {\n                nodeType: \"plain\" as const,\n                prop: {\n                  type: \"string\",\n                  name: \"uuid\",\n                  length: 128,\n                } as StringProp,\n                children: [],\n              };\n            }\n\n            const prop = entity.props.find((p) => p.name === propName);\n            if (prop === undefined) {\n              console.log({ propName, groups });\n              throw new Error(`${entity.id} -- 잘못된 FieldExpr ${propName}`);\n            }\n            return {\n              nodeType: \"plain\" as const,\n              prop,\n              children: [],\n            };\n          });\n        }\n\n        // relation prop 처리\n        const prop = entity.propsDict[key];\n        if (!isRelationProp(prop)) {\n          throw new Error(`잘못된 FieldExpr ${key}.${group[0]}`);\n        }\n        const relEntity = EntityManager.get(prop.with);\n\n        // relation -One 에 id 필드 하나인 경우\n        if (isBelongsToOneRelationProp(prop) || isOneToOneRelationProp(prop)) {\n          if (group.length == 1 && (group[0] === \"id\" || group[0] == \"id?\")) {\n            // id 하나만 있는지 체크해서, 하나만 있으면 상위 prop으로 id를 리턴\n            const idProp = relEntity.propsDict.id;\n            return {\n              nodeType: \"plain\" as const,\n              prop: {\n                ...idProp,\n                name: key + \"_id\",\n                nullable: prop.nullable,\n              },\n              children: [],\n            };\n          }\n        }\n\n        // -One 그외의 경우 object로 리턴\n        // -Many의 경우 array로 리턴\n        // Recursive 로 뎁스 처리\n        const children = this.fieldExprsToPropNodes(group, relEntity);\n        const nodeType =\n          isBelongsToOneRelationProp(prop) || isOneToOneRelationProp(prop)\n            ? (\"object\" as const)\n            : (\"array\" as const);\n\n        return {\n          prop,\n          children,\n          nodeType,\n        };\n      })\n      .flat();\n  }\n\n  getFieldExprs(\n    prefix = \"\",\n    maxDepth: number = 3,\n    froms: string[] = []\n  ): string[] {\n    return this.props\n      .map((prop) => {\n        const propName = [prefix, prop.name].filter((v) => v !== \"\").join(\".\");\n        if (propName === prefix) {\n          return null;\n        }\n        if (isRelationProp(prop)) {\n          if (maxDepth < 0) {\n            return null;\n          }\n          if (froms.includes(prop.with)) {\n            // 역방향 relation인 경우 제외\n            return null;\n          }\n          // 정방향 relation인 경우 recursive 콜\n          const relMd = EntityManager.get(prop.with);\n          return relMd.getFieldExprs(propName, maxDepth - 1, [\n            ...froms,\n            this.id,\n          ]);\n        }\n        return propName;\n      })\n      .flat()\n      .filter((f) => f !== null) as string[];\n  }\n\n  getTableColumns(): { name: string; type: string }[] {\n    return this.props\n      .map((prop) => {\n        if (prop.type === \"relation\") {\n          if (\n            prop.relationType === \"BelongsToOne\" ||\n            (prop.relationType === \"OneToOne\" && prop.hasJoinColumn === true)\n          ) {\n            return { name: `${prop.name}_id`, type: \"int_unsigned\" };\n          } else {\n            return null;\n          }\n        }\n        return { name: prop.name, type: prop.type };\n      })\n      .filter(nonNullable);\n  }\n\n  async registerModulePaths() {\n    const basePath = `${this.names.parentFs}`;\n\n    // base-scheme\n    EntityManager.setModulePath(`${this.id}BaseSchema`, `sonamu.generated`);\n\n    // subset\n    if (Object.keys(this.subsets).length > 0) {\n      EntityManager.setModulePath(`${this.id}SubsetKey`, `sonamu.generated`);\n      EntityManager.setModulePath(\n        `${this.id}SubsetMapping`,\n        `sonamu.generated`\n      );\n      Object.keys(this.subsets).map((subsetKey) => {\n        EntityManager.setModulePath(\n          `${this.id}Subset${subsetKey.toUpperCase()}`,\n          `sonamu.generated`\n        );\n      });\n    }\n\n    // enums\n    Object.keys(this.enumLabels).map((enumId) => {\n      EntityManager.setModulePath(enumId, `sonamu.generated`);\n    });\n\n    // types\n    const typesModulePath = `${basePath}/${this.names.parentFs}.types`;\n    const typesFileDistPath = path.join(\n      Sonamu.apiRootPath,\n      `dist/application/${typesModulePath}.js`\n    );\n\n    if (await exists(typesFileDistPath)) {\n      const importUrl = createImportUrl(typesFileDistPath);\n      const t = await import(importUrl);\n      this.types = Object.keys(t).reduce((result, key) => {\n        EntityManager.setModulePath(key, typesModulePath);\n        return {\n          ...result,\n          [key]: t[key],\n        };\n      }, {});\n    }\n  }\n\n  registerTableSpecs(): void {\n    const uniqueIndexes = this.indexes.filter((idx) => idx.type === \"unique\");\n\n    EntityManager.setTableSpec({\n      name: this.table,\n      uniqueIndexes,\n    });\n  }\n\n  toJson(): EntityJson {\n    return {\n      id: this.id,\n      parentId: this.parentId,\n      table: this.table,\n      title: this.title,\n      props: this.props,\n      indexes: this.indexes,\n      subsets: this.subsets,\n      enums: this.enumLabels,\n    };\n  }\n\n  async save(): Promise<void> {\n    // sort: subsets\n    const subsetRows = this.getSubsetRows();\n    this.subsets = Object.fromEntries(\n      Object.entries(this.subsets).map(([subsetKey]) => {\n        return [\n          subsetKey,\n          this.subsetRowsToSubsetFields(subsetRows, subsetKey),\n        ];\n      })\n    );\n\n    // save\n    const jsonPath = path.join(\n      Sonamu.apiRootPath,\n      `src/application/${this.names.parentFs}/${this.names.fs}.entity.json`\n    );\n    const json = this.toJson();\n    await writeFile(\n      jsonPath,\n      await prettier.format(JSON.stringify(json), {\n        parser: \"json\",\n      })\n    );\n\n    // reload\n    await EntityManager.register(json);\n  }\n\n  getSubsetRows(\n    _subsets?: { [key: string]: string[] },\n    prefixes: string[] = []\n  ): EntitySubsetRow[] {\n    if (prefixes.length > 10) {\n      return [];\n    }\n\n    const subsets = _subsets ?? this.subsets;\n    const subsetKeys = Object.keys(subsets);\n    const allFields = _.uniq(subsetKeys.map((key) => subsets[key]).flat());\n\n    return this.props.map((prop) => {\n      if (\n        prop.type === \"relation\" &&\n        allFields.find((f) =>\n          f.startsWith([...prefixes, prop.name].join(\".\") + \".\")\n        )\n      ) {\n        const relEntity = EntityManager.get(prop.with);\n        const children = relEntity.getSubsetRows(subsets, [\n          ...prefixes,\n          `${prop.name}`,\n        ]);\n\n        return {\n          field: prop.name,\n          children,\n          relationEntity: prop.with,\n          prefixes,\n          isOpen: children.length > 0,\n          has: Object.fromEntries(\n            subsetKeys.map((subsetKey) => {\n              return [\n                subsetKey,\n                children.every((child) => child.has[subsetKey] === true),\n              ];\n            })\n          ),\n        };\n      }\n\n      return {\n        field: prop.name,\n        children: [],\n        relationEntity: prop.type === \"relation\" ? prop.with : undefined,\n        prefixes,\n        has: Object.fromEntries(\n          subsetKeys.map((subsetKey) => {\n            const subsetFields = subsets[subsetKey];\n            const has = subsetFields.some((f) => {\n              const field = [...prefixes, prop.name].join(\".\");\n              return f === field || f.startsWith(field + \".\");\n            });\n            return [subsetKey, has];\n          })\n        ),\n      };\n    });\n  }\n\n  subsetRowsToSubsetFields(\n    subsetRows: EntitySubsetRow[],\n    subsetKey: string\n  ): string[] {\n    return subsetRows\n      .map((subsetRow) => {\n        if (subsetRow.children.length > 0) {\n          return this.subsetRowsToSubsetFields(subsetRow.children, subsetKey);\n        } else if (subsetRow.has[subsetKey]) {\n          return subsetRow.prefixes.concat(subsetRow.field).join(\".\");\n        } else {\n          return null;\n        }\n      })\n      .filter(nonNullable)\n      .flat();\n  }\n\n  async createProp(prop: EntityProp, at?: number): Promise<void> {\n    if (!at) {\n      this.props.push(prop);\n    } else {\n      this.props.splice(at, 0, prop);\n    }\n    await this.save();\n  }\n\n  analyzeSubsetField(subsetField: string): {\n    entityId: string;\n    propName: string;\n  }[] {\n    const arr = subsetField.split(\".\");\n\n    let entityId = this.id;\n    const result: {\n      entityId: string;\n      propName: string;\n    }[] = [];\n    for (let i = 0; i < arr.length; i++) {\n      const propName = arr[i];\n      result.push({\n        entityId,\n        propName,\n      });\n\n      const prop = EntityManager.get(entityId).props.find(\n        (p) => p.name === propName\n      );\n      if (!prop) {\n        throw new Error(`${entityId}의 잘못된 서브셋키 ${subsetField}`);\n      }\n      if (isRelationProp(prop)) {\n        entityId = prop.with;\n      }\n    }\n    return result;\n  }\n\n  async modifyProp(newProp: EntityProp, at: number): Promise<void> {\n    // 이전 프롭 이름 저장\n    const oldName = this.props[at].name;\n\n    // 저장할 엔티티\n    const entities: Entity[] = [this];\n\n    // 이름이 바뀐 경우\n    if (oldName !== newProp.name) {\n      // 전체 엔티티에서 현재 수정된 프롭을 참조하고 있는 모든 서브셋필드 찾아서 수정\n      const allEntityIds = EntityManager.getAllIds();\n      for (const relEntityId of allEntityIds) {\n        const relEntity = EntityManager.get(relEntityId);\n        const relEntitySubsetKeys = Object.keys(relEntity.subsets);\n        for (const subsetKey of relEntitySubsetKeys) {\n          const subset = relEntity.subsets[subsetKey];\n\n          // 서브셋 필드를 순회하며, 엔티티-프롭 단위로 분석한 후 현재 엔티티-프롭과 일치하는 경우 수정 처리\n          const modifiedSubsetFields = subset.map((subsetField) => {\n            const analyzed = relEntity.analyzeSubsetField(subsetField);\n            const modified = analyzed.map((a) =>\n              a.propName === oldName && a.entityId === this.id\n                ? {\n                    ...a,\n                    propName: newProp.name,\n                  }\n                : a\n            );\n            // 분석한 필드를 다시 서브셋 필드로 복구\n            return modified.map((a) => a.propName).join(\".\");\n          });\n\n          if (subset.join(\",\") !== modifiedSubsetFields.join(\",\")) {\n            relEntity.subsets[subsetKey] = modifiedSubsetFields;\n            entities.push(relEntity);\n          }\n        }\n      }\n    }\n\n    // 프롭 수정\n    this.props[at] = newProp;\n\n    await Promise.all(entities.map(async (entity) => entity.save()));\n  }\n\n  async delProp(at: number): Promise<void> {\n    // 이전 프롭 이름 저장\n    const oldName = this.props[at].name;\n\n    // 저장할 엔티티\n    const entities: Entity[] = [this];\n\n    // 전체 엔티티에서 현재 삭제된 프롭을 참조하고 있는 모든 서브셋필드 찾아서 제외\n    const allEntityIds = EntityManager.getAllIds();\n    for (const relEntityId of allEntityIds) {\n      const relEntity = EntityManager.get(relEntityId);\n      const relEntitySubsetKeys = Object.keys(relEntity.subsets);\n      for (const subsetKey of relEntitySubsetKeys) {\n        const subset = relEntity.subsets[subsetKey];\n        // 서브셋 필드를 순회하며, 엔티티-프롭 단위로 분석한 후 현재 엔티티-프롭과 일치하는 경우 이후의 필드를 제외\n        const modifiedSubsetFields = subset\n          .map((subsetField) => {\n            const analyzed = relEntity.analyzeSubsetField(subsetField);\n            if (\n              analyzed.find(\n                (a) => a.propName === oldName && a.entityId === this.id\n              )\n            ) {\n              return null;\n            } else {\n              return subsetField;\n            }\n          })\n          .filter(nonNullable);\n\n        if (subset.join(\",\") !== modifiedSubsetFields.join(\",\")) {\n          relEntity.subsets[subsetKey] = modifiedSubsetFields;\n          entities.push(relEntity);\n        }\n      }\n    }\n\n    // 현재 엔티티의 인덱스에서 제외\n    EntityManager.get(this.id).indexes.map((index) => {\n      index.columns = index.columns.filter((col) => col !== oldName);\n    });\n\n    // 프롭 삭제\n    this.props.splice(at, 1);\n\n    await Promise.all(entities.map(async (entity) => entity.save()));\n  }\n\n  getEntityIdFromSubsetField(subsetField: string): string {\n    if (subsetField.includes(\".\") === false) {\n      return this.id;\n    }\n\n    // 서브셋 필드의 마지막은 프롭이므로 제외\n    const arr = subsetField.split(\".\").slice(0, -1);\n\n    // 서브셋 필드를 내려가면서 마지막으로 relation된 엔티티를 찾음\n    const lastEntityId = arr.reduce((entityId, field) => {\n      const relProp = EntityManager.get(entityId).props.find(\n        (p) => p.name === field\n      );\n      if (!relProp || relProp.type !== \"relation\") {\n        console.debug({ arr, thisId: this.id, entityId, field });\n        throw new Error(`잘못된 서브셋키 ${subsetField}`);\n      }\n      return relProp.with;\n    }, this.id);\n    return lastEntityId;\n  }\n\n  async moveProp(at: number, to: number): Promise<void> {\n    const prop = this.props[at];\n    const newProps = [...this.props];\n    newProps.splice(to, 0, prop);\n    newProps.splice(at < to ? at : at + 1, 1);\n    this.props = newProps;\n\n    await this.save();\n  }\n}\n"],"names":["_","createImportUrl","EntityManager","isRelationProp","isVirtualProp","isBelongsToOneRelationProp","isOneToOneRelationProp","isHasManyRelationProp","isManyToManyRelationProp","isEnumProp","inflection","path","writeFile","z","Sonamu","prettier","nonNullable","exists","Entity","id","parentId","table","title","names","props","propsDict","relations","indexes","subsets","types","enums","enumLabels","underscore","pluralize","map","prop","includes","replace","reduce","result","name","filter","Object","fromEntries","entries","key","enumLabel","enum","keys","parentFs","dasherize","toLowerCase","fs","module","getSubsetQuery","subsetKey","subset","resolveSubsetQuery","prefix","fields","isAlreadyOuterJoined","subsetGroup","groupBy","field","rel","split","r","groupKey","realFields","virtualFields","select","concat","virtual","relation","undefined","Error","relEntity","get","with","relFields","slice","join","length","innerOrOuter","hasJoinColumn","nullable","relSubsetQuery","joinAs","fromTable","joinClause","customJoinClause","custom","from","to","joins","push","as","loaders","convertedLoaders","loader","newAs","manyJoin","oneJoins","fromCol","fromColumn","idField","toTable","toCol","joinColumn","through","joinTable","singularize","fieldExprsToPropNodes","fieldExprs","entity","groups","fieldExpr","value","elseExpr","group","propName","nodeType","type","children","find","p","console","log","idProp","flat","getFieldExprs","maxDepth","froms","v","relMd","f","getTableColumns","relationType","registerModulePaths","basePath","setModulePath","toUpperCase","enumId","typesModulePath","typesFileDistPath","apiRootPath","importUrl","t","registerTableSpecs","uniqueIndexes","idx","setTableSpec","toJson","save","subsetRows","getSubsetRows","subsetRowsToSubsetFields","jsonPath","json","format","JSON","stringify","parser","register","_subsets","prefixes","subsetKeys","allFields","uniq","startsWith","relationEntity","isOpen","has","every","child","subsetFields","some","subsetRow","createProp","at","splice","analyzeSubsetField","subsetField","arr","entityId","i","modifyProp","newProp","oldName","entities","allEntityIds","getAllIds","relEntityId","relEntitySubsetKeys","modifiedSubsetFields","analyzed","modified","a","Promise","all","delProp","index","columns","col","getEntityIdFromSubsetField","lastEntityId","relProp","debug","thisId","moveProp","newProps"],"mappings":"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"}
750
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/entity/entity.ts"],"sourcesContent":["import assert from \"assert\";\nimport { writeFile } from \"fs/promises\";\nimport inflection from \"inflection\";\nimport path from \"path\";\nimport { group, unique } from \"radashi\";\nimport { z } from \"zod\";\nimport { Sonamu } from \"../api/sonamu\";\nimport {\n  type EntityIndex,\n  type EntityJson,\n  type EntityProp,\n  type EntityPropNode,\n  type EntitySubsetRow,\n  isBelongsToOneRelationProp,\n  isEnumProp,\n  isHasManyRelationProp,\n  isManyToManyRelationProp,\n  isOneToOneRelationProp,\n  isRelationProp,\n  isVirtualProp,\n  type RelationProp,\n  type StringProp,\n  type SubsetQuery,\n} from \"../types/types\";\nimport { importMembers } from \"../utils/esm-utils\";\nimport { formatCode } from \"../utils/formatter\";\nimport { exists } from \"../utils/fs-utils\";\nimport { runtimePath } from \"../utils/path-utils\";\nimport { assertDefined, nonNullable } from \"../utils/utils\";\nimport { EntityManager } from \"./entity-manager\";\n\nexport class Entity {\n  id: string;\n  parentId?: string;\n  table: string;\n  title: string;\n  names: {\n    parentFs: string;\n    fs: string;\n    module: string;\n  };\n  props: EntityProp[];\n  propsDict: {\n    [key: string]: EntityProp;\n  };\n  relations: {\n    [key: string]: RelationProp;\n  };\n  indexes: EntityIndex[];\n  subsets: {\n    [key: string]: string[];\n  };\n  types: {\n    [name: string]: z.ZodTypeAny;\n  } = {};\n  enums: {\n    [enumId: string]: z.ZodEnum<Readonly<Record<string, string>>>;\n  } = {};\n  enumLabels: {\n    [enumId: string]: {\n      [key: string]: string;\n    };\n  } = {};\n\n  constructor({ id, parentId, table, title, props, indexes, subsets, enums }: EntityJson) {\n    // id\n    this.id = id;\n    this.parentId = parentId;\n    this.title = title ?? this.id;\n    this.table = table ?? inflection.underscore(inflection.pluralize(id));\n\n    // props\n    if (props) {\n      this.props = props.map((prop) => {\n        if (isEnumProp(prop)) {\n          if (prop.id.includes(\"$Model\")) {\n            prop.id = prop.id.replace(\"$Model\", id);\n          }\n        }\n        return prop;\n      });\n      this.propsDict = Object.fromEntries(\n        props.map((prop) => {\n          return [prop.name, prop];\n        }),\n      );\n\n      // relations\n      this.relations = Object.fromEntries(\n        props.filter((prop) => isRelationProp(prop)).map((prop) => [prop.name, prop]),\n      );\n    } else {\n      this.props = [];\n      this.propsDict = {};\n      this.relations = {};\n    }\n\n    // indexes\n    this.indexes = indexes ?? [];\n\n    // subsets\n    this.subsets = subsets ?? {};\n\n    // enums\n    this.enumLabels = enums ?? {};\n    this.enums = Object.fromEntries(\n      Object.entries(this.enumLabels).map(([key, enumLabel]) => {\n        return [key, z.enum(Object.keys(enumLabel) as unknown as readonly [string, ...string[]])];\n      }),\n    );\n\n    // names\n    this.names = {\n      parentFs: inflection.dasherize(inflection.underscore(parentId ?? id)).toLowerCase(),\n      fs: inflection.dasherize(inflection.underscore(id)).toLowerCase(),\n      module: id,\n    };\n  }\n\n  /*\n    subset을 Puri 코드로 변환\n  */\n  getPuriSubsetQuery(subsetKey: string): string {\n    const subset = this.subsets[subsetKey];\n    const subsetQuery = this.resolveSubsetQuery(\"\", subset);\n\n    const lines: string[] = [];\n\n    // from\n    lines.push(`return qbWrapper`);\n    lines.push(`.from(\"${this.table}\")`);\n\n    // join\n    for (const join of subsetQuery.joins) {\n      const joinMethod = join.join === \"inner\" ? \"join\" : \"leftJoin\";\n\n      if (\"custom\" in join) {\n        // custom join clause는 raw 사용\n        lines.push(\n          `.${joinMethod}({ ${join.as}: \"${join.table}\" }, qbWrapper.knex.raw(\\`${join.custom}\\`))`,\n        );\n      } else {\n        lines.push(`.${joinMethod}({ ${join.as}: \"${join.table}\" }, \"${join.from}\", \"${join.to}\")`);\n      }\n    }\n\n    // select\n    const selectObj: Record<string, string> = {};\n    for (const selectItem of subsetQuery.select) {\n      // \"users.id\" 또는 \"users.id as user__id\" 형태\n      const match = selectItem.match(/^(.+?)(?: as (.+))?$/);\n      if (match) {\n        const [, column, alias] = match;\n        const key = alias ?? assertDefined(column.split(\".\").pop());\n        selectObj[key] = `\"${column.trim()}\"`;\n      }\n    }\n\n    lines.push(`.select({`);\n    Object.entries(selectObj).forEach(([key, value]) => {\n      lines.push(`${key}: ${value},`);\n    });\n    lines.push(`});`);\n\n    return lines.join(\"\\n\");\n  }\n\n  getPuriLoaderQuery(subsetKey: string): string {\n    const subset = this.subsets[subsetKey];\n    const { loaders } = this.resolveSubsetQuery(\"\", subset);\n\n    const lines: string[] = [`[`];\n\n    const parseSelect = (select: string, table: string) => {\n      const tablePrefix = `${table}.`;\n      if (select.startsWith(tablePrefix)) {\n        return `${select.replace(tablePrefix, \"\")}: \"${select}\"`;\n      }\n\n      if (select.includes(\" as \")) {\n        const [column, alias] = select.split(\" as \");\n        return `${alias}: \"${column}\"`;\n      }\n      return `${select}: \"${select}\"`;\n    };\n\n    // 재귀적으로 loader 생성하는 헬퍼 함수\n    const generateLoaderCode = (loaders: SubsetQuery[\"loaders\"]): string[] => {\n      const loaderLines: string[] = [];\n\n      for (const loader of loaders) {\n        const { toTable, toCol, through } = loader.manyJoin;\n        loaderLines.push(\n          \"{\",\n          `as: \"${loader.as}\",`,\n          `refId: \"${loader.manyJoin.idField}\",`,\n          `qb: (qbWrapper: PuriWrapper<DatabaseSchemaExtend>, fromIds: number[]) => {`,\n        );\n\n        if (through === undefined) {\n          // HasMany\n          loaderLines.push(\n            //\n            \"return qbWrapper\",\n            `.from(\"${toTable}\")`,\n          );\n\n          loader.oneJoins.forEach((join: SubsetQuery[\"joins\"][number]) => {\n            const joinType = join.join === \"inner\" ? \"join\" : \"leftJoin\";\n            if (\"custom\" in join) {\n              // FIXME: 검증 필요\n              loaderLines.push(\n                `.${joinType}({ ${join.as}: \"${join.table}\" }, (j) => {`,\n                `j.on(Puri.rawString(\"${join.custom}\"));`,\n                \"})\",\n              );\n            } else {\n              loaderLines.push(\n                `.${joinType}({ ${join.as}: \"${join.table}\" }, \"${join.from}\", \"${join.to}\")`,\n              );\n            }\n          });\n\n          loaderLines.push(\n            `.whereIn(\"${toTable}.${toCol}\", fromIds)`,\n            `.select({`,\n            `${loader.select.map((select: string) => parseSelect(select, toTable)).join(\",\")},`,\n            `refId: \"${toTable}.${toCol}\",`,\n            `});`,\n          );\n        } else {\n          // ManyToMany\n          loaderLines.push(\n            \"return qbWrapper\",\n            `.from(\"${through.table}\")`,\n            `.join(\"${toTable}\", \"${through.table}.${through.toCol}\", \"${toTable}.${toCol}\")`,\n          );\n\n          loader.oneJoins.forEach((join: SubsetQuery[\"joins\"][number]) => {\n            const joinType = join.join === \"inner\" ? \"join\" : \"leftJoin\";\n            if (\"custom\" in join) {\n              // FIXME: 검증 필요\n              loaderLines.push(\n                `.${joinType}({ ${join.as}: \"${join.table}\" }, (j) => {`,\n                `j.on(Puri.rawString(\"${join.custom}\"));`,\n                \"})\",\n              );\n            } else {\n              loaderLines.push(\n                `.${joinType}({ ${join.as}: \"${join.table}\" }, \"${join.from}\", \"${join.to}\")`,\n              );\n            }\n          });\n          loaderLines.push(\n            `.whereIn(\"${through.table}.${through.fromCol}\", fromIds)`,\n            `.select({`,\n            `${loader.select.map((select: string) => parseSelect(select, toTable)).join(\",\")},`,\n            `refId: \"${through.table}.${through.fromCol}\",`,\n            `});`,\n          );\n        }\n\n        loaderLines.push(`},`);\n\n        // 중첩 loaders 처리\n        if (loader.loaders && loader.loaders.length > 0) {\n          loaderLines.push(\"loaders: [\", ...generateLoaderCode(loader.loaders), \"],\");\n        }\n\n        loaderLines.push(\"},\");\n      }\n\n      return loaderLines;\n    };\n\n    lines.push(...generateLoaderCode(loaders));\n    lines.push(`]`);\n\n    return lines.join(\"\\n\");\n  }\n\n  /*\n    subset SELECT/JOIN/LOADER 결과 리턴\n  */\n  getSubsetQuery(subsetKey: string): SubsetQuery {\n    const subset = this.subsets[subsetKey];\n\n    const result: SubsetQuery = this.resolveSubsetQuery(\"\", subset);\n    return result;\n  }\n\n  /*\n   */\n  resolveSubsetQuery(\n    prefix: string,\n    fields: string[],\n    isAlreadyOuterJoined: boolean = false,\n  ): SubsetQuery {\n    // prefix 치환 (prefix는 ToOneRelation이 복수로 붙은 경우 모두 __로 변경됨)\n    prefix = prefix.replace(/\\./g, \"__\");\n\n    // 서브셋을 1뎁스만 분리하여 그룹핑\n    const subsetGroup = group(fields, (field) => {\n      if (field.includes(\".\")) {\n        const [rel] = field.split(\".\");\n        return rel;\n      } else {\n        return \"\";\n      }\n    });\n\n    const result = Object.keys(subsetGroup).reduce(\n      (r, groupKey) => {\n        const fields = subsetGroup[groupKey];\n        assert(fields !== undefined, \"fields is undefined\");\n\n        // 현재 테이블 필드셋은 select, virtual에 추가하고 리턴\n        if (groupKey === \"\") {\n          const realFields = fields.filter((field) => !isVirtualProp(this.propsDict[field]));\n          const virtualFields = fields.filter((field) => isVirtualProp(this.propsDict[field]));\n\n          if (prefix === \"\") {\n            // 현재 테이블인 경우\n            r.select = r.select.concat(realFields.map((field) => `${this.table}.${field}`));\n            r.virtual = r.virtual.concat(virtualFields);\n          } else {\n            // 넘어온 테이블인 경우\n            r.select = r.select.concat(\n              realFields.map((field) => `${prefix}.${field} as ${prefix}__${field}`),\n            );\n          }\n\n          return r;\n        }\n\n        const relation = this.relations[groupKey];\n        if (relation === undefined) {\n          throw new Error(`존재하지 않는 relation 참조 ${groupKey}`);\n        }\n        const relEntity = EntityManager.get(relation.with);\n\n        if (isOneToOneRelationProp(relation) || isBelongsToOneRelationProp(relation)) {\n          // -One Relation: JOIN 으로 처리\n          const relFields = fields.map((field) => field.split(\".\").slice(1).join(\".\"));\n\n          // -One Relation에서 id 필드만 참조하는 경우 릴레이션 넘기지 않고 리턴\n          if (relFields.length === 1 && relFields[0] === \"id\") {\n            if (prefix === \"\") {\n              r.select = r.select.concat(`${this.table}.${groupKey}_id`);\n            } else {\n              r.select = r.select.concat(`${prefix}.${groupKey}_id as ${prefix}__${groupKey}_id`);\n            }\n            return r;\n          }\n\n          // innerOrOuter\n          const innerOrOuter = (() => {\n            if (isAlreadyOuterJoined) {\n              return \"outer\";\n            }\n\n            if (isOneToOneRelationProp(relation)) {\n              if (relation.hasJoinColumn === true && (relation.nullable ?? false) === false) {\n                return \"inner\";\n              } else {\n                return \"outer\";\n              }\n            } else {\n              if (relation.nullable) {\n                return \"outer\";\n              } else {\n                return \"inner\";\n              }\n            }\n          })();\n          const relSubsetQuery = relEntity.resolveSubsetQuery(\n            `${prefix !== \"\" ? `${prefix}.` : \"\"}${groupKey}`,\n            relFields,\n            innerOrOuter === \"outer\",\n          );\n          r.select = r.select.concat(relSubsetQuery.select);\n          r.virtual = r.virtual.concat(relSubsetQuery.virtual);\n\n          const joinAs = prefix === \"\" ? groupKey : `${prefix}__${groupKey}`;\n          const fromTable = prefix === \"\" ? this.table : prefix;\n\n          let joinClause:\n            | {\n                from: string;\n                to: string;\n              }\n            | {\n                custom: string;\n              };\n          if (relation.customJoinClause) {\n            joinClause = {\n              custom: relation.customJoinClause,\n            };\n          } else {\n            let from: string, to: string;\n            if (isOneToOneRelationProp(relation)) {\n              if (relation.hasJoinColumn) {\n                from = `${fromTable}.${relation.name}_id`;\n                to = `${joinAs}.id`;\n              } else {\n                from = `${fromTable}.id`;\n                to = `${joinAs}.${inflection.underscore(this.names.fs.replace(/-/g, \"_\"))}_id`;\n              }\n            } else {\n              from = `${fromTable}.${relation.name}_id`;\n              to = `${joinAs}.id`;\n            }\n            joinClause = {\n              from,\n              to,\n            };\n          }\n\n          r.joins.push({\n            as: joinAs,\n            join: innerOrOuter,\n            table: relEntity.table,\n            ...joinClause,\n          });\n\n          // BelongsToOne 밑에 HasMany가 붙은 경우\n          if (relSubsetQuery.loaders.length > 0) {\n            const convertedLoaders = relSubsetQuery.loaders.map((loader) => {\n              const newAs = [groupKey, loader.as].join(\"__\");\n              return {\n                as: newAs,\n                table: loader.table,\n                manyJoin: loader.manyJoin,\n                oneJoins: loader.oneJoins,\n                select: loader.select,\n                loaders: loader.loaders,\n              };\n            });\n\n            r.loaders = [...r.loaders, ...convertedLoaders];\n          }\n\n          r.joins = r.joins.concat(relSubsetQuery.joins);\n        } else if (isHasManyRelationProp(relation) || isManyToManyRelationProp(relation)) {\n          // -Many Relation: Loader 로 처리\n          const relFields = fields.map((field) => field.split(\".\").slice(1).join(\".\"));\n          const relSubsetQuery = relEntity.resolveSubsetQuery(\"\", relFields);\n\n          let manyJoin: SubsetQuery[\"loaders\"][number][\"manyJoin\"];\n          if (isHasManyRelationProp(relation)) {\n            const fromCol = relation?.fromColumn ?? \"id\";\n            manyJoin = {\n              fromTable: this.table,\n              fromCol,\n              idField: prefix === \"\" ? `${fromCol}` : `${prefix}__${fromCol}`,\n              toTable: relEntity.table,\n              toCol: relation.joinColumn,\n            };\n          } else if (isManyToManyRelationProp(relation)) {\n            manyJoin = {\n              fromTable: this.table,\n              fromCol: \"id\",\n              idField: prefix === \"\" ? `id` : `${prefix}__id`,\n              through: {\n                table: relation.joinTable,\n                fromCol: `${inflection.singularize(this.table)}_id`,\n                toCol: `${inflection.singularize(relEntity.table)}_id`,\n              },\n              toTable: relEntity.table,\n              toCol: \"id\",\n            };\n          } else {\n            throw new Error();\n          }\n\n          r.loaders.push({\n            as: groupKey,\n            table: relEntity.table,\n            manyJoin,\n            oneJoins: relSubsetQuery.joins,\n            select: relSubsetQuery.select,\n            loaders: relSubsetQuery.loaders,\n          });\n        }\n\n        return r;\n      },\n      {\n        select: [],\n        virtual: [],\n        joins: [],\n        loaders: [],\n      } as SubsetQuery,\n    );\n    return result;\n  }\n\n  /*\n    FieldExpr[] 을 EntityPropNode[] 로 변환\n  */\n  fieldExprsToPropNodes(fieldExprs: string[], entity: Entity = this): EntityPropNode[] {\n    const groups = fieldExprs.reduce(\n      (result, fieldExpr) => {\n        let key: string, value: string, elseExpr: string[];\n        if (fieldExpr.includes(\".\")) {\n          [key, ...elseExpr] = fieldExpr.split(\".\");\n          value = elseExpr.join(\".\");\n        } else {\n          key = \"\";\n          value = fieldExpr;\n        }\n        result[key] = (result[key] ?? []).concat(value);\n\n        return result;\n      },\n      {} as {\n        [k: string]: string[];\n      },\n    );\n\n    return Object.keys(groups).flatMap((key) => {\n      const group = groups[key];\n\n      // 일반 prop 처리\n      if (key === \"\") {\n        return group.map((propName) => {\n          // uuid 개별 처리\n          if (propName === \"uuid\") {\n            return {\n              nodeType: \"plain\" as const,\n              prop: {\n                type: \"string\",\n                name: \"uuid\",\n                length: 128,\n              } as StringProp,\n              children: [],\n            } as EntityPropNode;\n          }\n\n          const prop = entity.props.find((p) => p.name === propName);\n          if (prop === undefined) {\n            console.log({ propName, groups });\n            throw new Error(`${entity.id} -- 잘못된 FieldExpr ${propName}`);\n          }\n          return {\n            nodeType: \"plain\" as const,\n            prop,\n            children: [],\n          };\n        });\n      }\n\n      // relation prop 처리\n      const prop = entity.propsDict[key];\n      if (!isRelationProp(prop)) {\n        throw new Error(`잘못된 FieldExpr ${key}.${group[0]}`);\n      }\n      const relEntity = EntityManager.get(prop.with);\n\n      // relation -One 에 id 필드 하나인 경우\n      if (isBelongsToOneRelationProp(prop) || isOneToOneRelationProp(prop)) {\n        if (group.length === 1 && (group[0] === \"id\" || group[0] === \"id?\")) {\n          // id 하나만 있는지 체크해서, 하나만 있으면 상위 prop으로 id를 리턴\n          const idProp = relEntity.propsDict.id;\n          return {\n            nodeType: \"plain\" as const,\n            prop: {\n              ...idProp,\n              name: `${key}_id`,\n              nullable: prop.nullable,\n            },\n            children: [],\n          };\n        }\n      }\n\n      // -One 그외의 경우 object로 리턴\n      // -Many의 경우 array로 리턴\n      // Recursive 로 뎁스 처리\n      const children = this.fieldExprsToPropNodes(group, relEntity);\n      const nodeType =\n        isBelongsToOneRelationProp(prop) || isOneToOneRelationProp(prop)\n          ? (\"object\" as const)\n          : (\"array\" as const);\n\n      return {\n        prop,\n        children,\n        nodeType,\n      };\n    });\n  }\n\n  getFieldExprs(prefix = \"\", maxDepth: number = 3, froms: string[] = []): string[] {\n    return this.props\n      .flatMap((prop) => {\n        const propName = [prefix, prop.name].filter((v) => v !== \"\").join(\".\");\n        if (propName === prefix) {\n          return null;\n        }\n        if (isRelationProp(prop)) {\n          if (maxDepth < 0) {\n            return null;\n          }\n          if (froms.includes(prop.with)) {\n            // 역방향 relation인 경우 제외\n            return null;\n          }\n          // 정방향 relation인 경우 recursive 콜\n          const relMd = EntityManager.get(prop.with);\n          return relMd.getFieldExprs(propName, maxDepth - 1, [...froms, this.id]);\n        }\n        return propName;\n      })\n      .filter((f) => f !== null) as string[];\n  }\n\n  getTableColumns(): { name: string; type: string }[] {\n    return this.props\n      .map((prop) => {\n        if (prop.type === \"relation\") {\n          if (\n            prop.relationType === \"BelongsToOne\" ||\n            (prop.relationType === \"OneToOne\" && prop.hasJoinColumn === true)\n          ) {\n            return { name: `${prop.name}_id`, type: \"int_unsigned\" };\n          } else {\n            return null;\n          }\n        }\n        return { name: prop.name, type: prop.type };\n      })\n      .filter(nonNullable);\n  }\n\n  async registerModulePaths() {\n    const basePath = `${this.names.parentFs}`;\n\n    // base-scheme\n    EntityManager.setModulePath(`${this.id}BaseSchema`, `sonamu.generated`);\n\n    // subset\n    if (Object.keys(this.subsets).length > 0) {\n      EntityManager.setModulePath(`${this.id}SubsetKey`, `sonamu.generated`);\n      EntityManager.setModulePath(`${this.id}SubsetMapping`, `sonamu.generated`);\n      for (const subsetKey of Object.keys(this.subsets)) {\n        EntityManager.setModulePath(\n          `${this.id}Subset${subsetKey.toUpperCase()}`,\n          `sonamu.generated`,\n        );\n      }\n    }\n\n    // enums\n    for (const enumId of Object.keys(this.enumLabels)) {\n      EntityManager.setModulePath(enumId, `sonamu.generated`);\n    }\n\n    // types\n    const typesModulePath = `${basePath}/${this.names.parentFs}.types`;\n    const typesFilePath = path.join(\n      Sonamu.apiRootPath,\n      runtimePath(`dist/application/${typesModulePath}.js`),\n    );\n\n    if (await exists(typesFilePath)) {\n      const importedMembers = await importMembers<z.ZodTypeAny>(typesFilePath);\n      this.types = Object.fromEntries(\n        importedMembers.map(({ name, value }) => {\n          EntityManager.setModulePath(name, typesModulePath);\n          return [name, value];\n        }),\n      ) as { [name: string]: z.ZodTypeAny };\n    }\n  }\n\n  registerTableSpecs(): void {\n    const uniqueIndexes = this.indexes.filter((idx) => idx.type === \"unique\");\n\n    EntityManager.setTableSpec({\n      name: this.table,\n      uniqueIndexes,\n    });\n  }\n\n  toJson(): EntityJson {\n    return {\n      id: this.id,\n      parentId: this.parentId,\n      table: this.table,\n      title: this.title,\n      props: this.props,\n      indexes: this.indexes,\n      subsets: this.subsets,\n      enums: this.enumLabels,\n    };\n  }\n\n  async save(): Promise<void> {\n    // sort: subsets\n    const subsetRows = this.getSubsetRows();\n    this.subsets = Object.fromEntries(\n      Object.entries(this.subsets).map(([subsetKey]) => {\n        return [subsetKey, this.subsetRowsToSubsetFields(subsetRows, subsetKey)];\n      }),\n    );\n\n    // save\n    const jsonPath = path.join(\n      Sonamu.apiRootPath,\n      `src/application/${this.names.parentFs}/${this.names.fs}.entity.json`,\n    );\n    const json = this.toJson();\n    await writeFile(jsonPath, formatCode(JSON.stringify(json), \"json\", jsonPath));\n\n    // reload\n    await EntityManager.register(json);\n  }\n\n  getSubsetRows(\n    _subsets?: { [key: string]: string[] },\n    prefixes: string[] = [],\n  ): EntitySubsetRow[] {\n    if (prefixes.length > 10) {\n      return [];\n    }\n\n    const subsets = _subsets ?? this.subsets;\n    const subsetKeys = Object.keys(subsets);\n    const allFields = unique(subsetKeys.flatMap((key) => subsets[key]));\n\n    return this.props.map((prop) => {\n      if (\n        prop.type === \"relation\" &&\n        allFields.find((f) => f.startsWith(`${[...prefixes, prop.name].join(\".\")}.`))\n      ) {\n        const relEntity = EntityManager.get(prop.with);\n        const children = relEntity.getSubsetRows(subsets, [...prefixes, `${prop.name}`]);\n\n        return {\n          field: prop.name,\n          children,\n          relationEntity: prop.with,\n          prefixes,\n          isOpen: children.length > 0,\n          has: Object.fromEntries(\n            subsetKeys.map((subsetKey) => {\n              return [subsetKey, children.every((child) => child.has[subsetKey] === true)];\n            }),\n          ),\n        };\n      }\n\n      return {\n        field: prop.name,\n        children: [],\n        relationEntity: prop.type === \"relation\" ? prop.with : undefined,\n        prefixes,\n        has: Object.fromEntries(\n          subsetKeys.map((subsetKey) => {\n            const subsetFields = subsets[subsetKey];\n            const has = subsetFields.some((f) => {\n              const field = [...prefixes, prop.name].join(\".\");\n              return f === field || f.startsWith(`${field}.`);\n            });\n            return [subsetKey, has];\n          }),\n        ),\n      };\n    });\n  }\n\n  subsetRowsToSubsetFields(subsetRows: EntitySubsetRow[], subsetKey: string): string[] {\n    return subsetRows\n      .map((subsetRow) => {\n        if (subsetRow.children.length > 0) {\n          return this.subsetRowsToSubsetFields(subsetRow.children, subsetKey);\n        } else if (subsetRow.has[subsetKey]) {\n          return subsetRow.prefixes.concat(subsetRow.field).join(\".\");\n        } else {\n          return null;\n        }\n      })\n      .filter(nonNullable)\n      .flat();\n  }\n\n  async createProp(prop: EntityProp, at?: number): Promise<void> {\n    if (!at) {\n      this.props.push(prop);\n    } else {\n      this.props.splice(at, 0, prop);\n    }\n    await this.save();\n  }\n\n  analyzeSubsetField(subsetField: string): {\n    entityId: string;\n    propName: string;\n  }[] {\n    const arr = subsetField.split(\".\");\n\n    let entityId = this.id;\n    const result: {\n      entityId: string;\n      propName: string;\n    }[] = [];\n    for (let i = 0; i < arr.length; i++) {\n      const propName = arr[i];\n      result.push({\n        entityId,\n        propName,\n      });\n\n      const prop = EntityManager.get(entityId).props.find((p) => p.name === propName);\n      if (!prop) {\n        throw new Error(`${entityId}의 잘못된 서브셋키 ${subsetField}`);\n      }\n      if (isRelationProp(prop)) {\n        entityId = prop.with;\n      }\n    }\n    return result;\n  }\n\n  async modifyProp(newProp: EntityProp, at: number): Promise<void> {\n    // 이전 프롭 이름 저장\n    const oldName = this.props[at].name;\n\n    // 저장할 엔티티\n    const entities: Entity[] = [this];\n\n    // 이름이 바뀐 경우\n    if (oldName !== newProp.name) {\n      // 전체 엔티티에서 현재 수정된 프롭을 참조하고 있는 모든 서브셋필드 찾아서 수정\n      const allEntityIds = EntityManager.getAllIds();\n      for (const relEntityId of allEntityIds) {\n        const relEntity = EntityManager.get(relEntityId);\n        const relEntitySubsetKeys = Object.keys(relEntity.subsets);\n        for (const subsetKey of relEntitySubsetKeys) {\n          const subset = relEntity.subsets[subsetKey];\n\n          // 서브셋 필드를 순회하며, 엔티티-프롭 단위로 분석한 후 현재 엔티티-프롭과 일치하는 경우 수정 처리\n          const modifiedSubsetFields = subset.map((subsetField) => {\n            const analyzed = relEntity.analyzeSubsetField(subsetField);\n            const modified = analyzed.map((a) =>\n              a.propName === oldName && a.entityId === this.id\n                ? {\n                    ...a,\n                    propName: newProp.name,\n                  }\n                : a,\n            );\n            // 분석한 필드를 다시 서브셋 필드로 복구\n            return modified.map((a) => a.propName).join(\".\");\n          });\n\n          if (subset.join(\",\") !== modifiedSubsetFields.join(\",\")) {\n            relEntity.subsets[subsetKey] = modifiedSubsetFields;\n            entities.push(relEntity);\n          }\n        }\n      }\n    }\n\n    // 프롭 수정\n    this.props[at] = newProp;\n\n    await Promise.all(entities.map(async (entity) => entity.save()));\n  }\n\n  async delProp(at: number): Promise<void> {\n    // 이전 프롭 이름 저장\n    const oldName = this.props[at].name;\n\n    // 저장할 엔티티\n    const entities: Entity[] = [this];\n\n    // 전체 엔티티에서 현재 삭제된 프롭을 참조하고 있는 모든 서브셋필드 찾아서 제외\n    const allEntityIds = EntityManager.getAllIds();\n    for (const relEntityId of allEntityIds) {\n      const relEntity = EntityManager.get(relEntityId);\n      const relEntitySubsetKeys = Object.keys(relEntity.subsets);\n      for (const subsetKey of relEntitySubsetKeys) {\n        const subset = relEntity.subsets[subsetKey];\n        // 서브셋 필드를 순회하며, 엔티티-프롭 단위로 분석한 후 현재 엔티티-프롭과 일치하는 경우 이후의 필드를 제외\n        const modifiedSubsetFields = subset\n          .map((subsetField) => {\n            const analyzed = relEntity.analyzeSubsetField(subsetField);\n            if (analyzed.find((a) => a.propName === oldName && a.entityId === this.id)) {\n              return null;\n            } else {\n              return subsetField;\n            }\n          })\n          .filter(nonNullable);\n\n        if (subset.join(\",\") !== modifiedSubsetFields.join(\",\")) {\n          relEntity.subsets[subsetKey] = modifiedSubsetFields;\n          entities.push(relEntity);\n        }\n      }\n    }\n\n    // 현재 엔티티의 인덱스에서 제외\n    for (const index of EntityManager.get(this.id).indexes) {\n      index.columns = index.columns.filter((col) => col !== oldName);\n    }\n\n    // 프롭 삭제\n    this.props.splice(at, 1);\n\n    await Promise.all(entities.map(async (entity) => entity.save()));\n  }\n\n  getEntityIdFromSubsetField(subsetField: string): string {\n    if (subsetField.includes(\".\") === false) {\n      return this.id;\n    }\n\n    // 서브셋 필드의 마지막은 프롭이므로 제외\n    const arr = subsetField.split(\".\").slice(0, -1);\n\n    // 서브셋 필드를 내려가면서 마지막으로 relation된 엔티티를 찾음\n    const lastEntityId = arr.reduce((entityId, field) => {\n      const relProp = EntityManager.get(entityId).props.find((p) => p.name === field);\n      if (!relProp || relProp.type !== \"relation\") {\n        console.debug({ arr, thisId: this.id, entityId, field });\n        throw new Error(`잘못된 서브셋키 ${subsetField}`);\n      }\n      return relProp.with;\n    }, this.id);\n    return lastEntityId;\n  }\n\n  async moveProp(at: number, to: number): Promise<void> {\n    const prop = this.props[at];\n    const newProps = [...this.props];\n    newProps.splice(to, 0, prop);\n    newProps.splice(at < to ? at : at + 1, 1);\n    this.props = newProps;\n\n    await this.save();\n  }\n}\n"],"names":["assert","writeFile","inflection","path","group","unique","z","Sonamu","isBelongsToOneRelationProp","isEnumProp","isHasManyRelationProp","isManyToManyRelationProp","isOneToOneRelationProp","isRelationProp","isVirtualProp","importMembers","formatCode","exists","runtimePath","assertDefined","nonNullable","EntityManager","Entity","id","parentId","table","title","names","props","propsDict","relations","indexes","subsets","types","enums","enumLabels","underscore","pluralize","map","prop","includes","replace","Object","fromEntries","name","filter","entries","key","enumLabel","enum","keys","parentFs","dasherize","toLowerCase","fs","module","getPuriSubsetQuery","subsetKey","subset","subsetQuery","resolveSubsetQuery","lines","push","join","joins","joinMethod","as","custom","from","to","selectObj","selectItem","select","match","column","alias","split","pop","trim","forEach","value","getPuriLoaderQuery","loaders","parseSelect","tablePrefix","startsWith","generateLoaderCode","loaderLines","loader","toTable","toCol","through","manyJoin","idField","undefined","oneJoins","joinType","fromCol","length","getSubsetQuery","result","prefix","fields","isAlreadyOuterJoined","subsetGroup","field","rel","reduce","r","groupKey","realFields","virtualFields","concat","virtual","relation","Error","relEntity","get","with","relFields","slice","innerOrOuter","hasJoinColumn","nullable","relSubsetQuery","joinAs","fromTable","joinClause","customJoinClause","convertedLoaders","newAs","fromColumn","joinColumn","joinTable","singularize","fieldExprsToPropNodes","fieldExprs","entity","groups","fieldExpr","elseExpr","flatMap","propName","nodeType","type","children","find","p","console","log","idProp","getFieldExprs","maxDepth","froms","v","relMd","f","getTableColumns","relationType","registerModulePaths","basePath","setModulePath","toUpperCase","enumId","typesModulePath","typesFilePath","apiRootPath","importedMembers","registerTableSpecs","uniqueIndexes","idx","setTableSpec","toJson","save","subsetRows","getSubsetRows","subsetRowsToSubsetFields","jsonPath","json","JSON","stringify","register","_subsets","prefixes","subsetKeys","allFields","relationEntity","isOpen","has","every","child","subsetFields","some","subsetRow","flat","createProp","at","splice","analyzeSubsetField","subsetField","arr","entityId","i","modifyProp","newProp","oldName","entities","allEntityIds","getAllIds","relEntityId","relEntitySubsetKeys","modifiedSubsetFields","analyzed","modified","a","Promise","all","delProp","index","columns","col","getEntityIdFromSubsetField","lastEntityId","relProp","debug","thisId","moveProp","newProps"],"mappings":"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"}