sonamu 0.5.7 → 0.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (358) hide show
  1. package/dist/api/base-frame.js +12 -2
  2. package/dist/api/caster.js +66 -2
  3. package/dist/api/code-converters.js +489 -2
  4. package/dist/api/config.d.ts +76 -0
  5. package/dist/api/config.d.ts.map +1 -0
  6. package/dist/api/config.js +32 -0
  7. package/dist/api/context.d.ts +1 -0
  8. package/dist/api/context.d.ts.map +1 -1
  9. package/dist/api/context.js +3 -2
  10. package/dist/api/decorators.d.ts.map +1 -1
  11. package/dist/api/decorators.js +142 -2
  12. package/dist/api/index.js +9 -2
  13. package/dist/api/sonamu.d.ts +8 -22
  14. package/dist/api/sonamu.d.ts.map +1 -1
  15. package/dist/api/sonamu.js +482 -2
  16. package/dist/bin/build-config.d.ts +2 -1
  17. package/dist/bin/build-config.d.ts.map +1 -1
  18. package/dist/bin/build-config.js +12 -2
  19. package/dist/bin/cli-wrapper.js +71 -2
  20. package/dist/bin/cli.js +418 -2
  21. package/dist/bin/hot-hook-register.d.ts +11 -0
  22. package/dist/bin/hot-hook-register.d.ts.map +1 -0
  23. package/dist/bin/hot-hook-register.js +21 -0
  24. package/dist/database/_batch_update.js +78 -2
  25. package/dist/database/base-model.js +247 -2
  26. package/dist/database/code-generator.js +53 -2
  27. package/dist/database/db.d.ts +2 -16
  28. package/dist/database/db.d.ts.map +1 -1
  29. package/dist/database/db.js +132 -2
  30. package/dist/database/knex-plugins/knex-on-duplicate-update.js +39 -2
  31. package/dist/database/puri-wrapper.js +109 -2
  32. package/dist/database/puri.d.ts +23 -16
  33. package/dist/database/puri.d.ts.map +1 -1
  34. package/dist/database/puri.js +539 -2
  35. package/dist/database/puri.types.d.ts +8 -3
  36. package/dist/database/puri.types.d.ts.map +1 -1
  37. package/dist/database/puri.types.js +3 -2
  38. package/dist/database/transaction-context.js +14 -2
  39. package/dist/database/upsert-builder.js +215 -2
  40. package/dist/entity/entity-manager.d.ts +3 -1
  41. package/dist/entity/entity-manager.d.ts.map +1 -1
  42. package/dist/entity/entity-manager.js +114 -2
  43. package/dist/entity/entity-utils.js +210 -2
  44. package/dist/entity/entity.d.ts.map +1 -1
  45. package/dist/entity/entity.js +651 -2
  46. package/dist/exceptions/error-handler.js +29 -2
  47. package/dist/exceptions/so-exceptions.js +85 -2
  48. package/dist/file-storage/driver.js +79 -2
  49. package/dist/file-storage/file-storage.js +75 -2
  50. package/dist/index.d.ts +2 -0
  51. package/dist/index.d.ts.map +1 -1
  52. package/dist/index.js +28 -2
  53. package/dist/migration/code-generation.js +558 -2
  54. package/dist/migration/migration-set.js +364 -2
  55. package/dist/migration/migrator.d.ts +0 -9
  56. package/dist/migration/migrator.d.ts.map +1 -1
  57. package/dist/migration/migrator.js +510 -2
  58. package/dist/migration/types.js +3 -2
  59. package/dist/naite/naite.d.ts +12 -0
  60. package/dist/naite/naite.d.ts.map +1 -0
  61. package/dist/naite/naite.js +72 -0
  62. package/dist/stream/index.js +3 -2
  63. package/dist/stream/sse.js +38 -2
  64. package/dist/syncer/api-parser.d.ts +20 -0
  65. package/dist/syncer/api-parser.d.ts.map +1 -0
  66. package/dist/syncer/api-parser.js +229 -0
  67. package/dist/syncer/checksum.d.ts +21 -0
  68. package/dist/syncer/checksum.d.ts.map +1 -0
  69. package/dist/syncer/checksum.js +98 -0
  70. package/dist/syncer/code-generator.d.ts +20 -0
  71. package/dist/syncer/code-generator.d.ts.map +1 -0
  72. package/dist/syncer/code-generator.js +141 -0
  73. package/dist/syncer/entity-operations.d.ts +17 -0
  74. package/dist/syncer/entity-operations.d.ts.map +1 -0
  75. package/dist/syncer/entity-operations.js +58 -0
  76. package/dist/syncer/file-patterns.d.ts +29 -0
  77. package/dist/syncer/file-patterns.d.ts.map +1 -0
  78. package/dist/syncer/file-patterns.js +38 -0
  79. package/dist/syncer/index.d.ts +6 -0
  80. package/dist/syncer/index.d.ts.map +1 -1
  81. package/dist/syncer/index.js +9 -2
  82. package/dist/syncer/module-loader.d.ts +35 -0
  83. package/dist/syncer/module-loader.d.ts.map +1 -0
  84. package/dist/syncer/module-loader.js +82 -0
  85. package/dist/syncer/syncer.d.ts +93 -108
  86. package/dist/syncer/syncer.d.ts.map +1 -1
  87. package/dist/syncer/syncer.js +375 -2
  88. package/dist/template/entity-converter.d.ts +14 -0
  89. package/dist/template/entity-converter.d.ts.map +1 -0
  90. package/dist/template/entity-converter.js +101 -0
  91. package/dist/template/helpers.d.ts +23 -0
  92. package/dist/template/helpers.d.ts.map +1 -0
  93. package/dist/template/helpers.js +64 -0
  94. package/dist/{templates → template/implementations}/entity.template.d.ts +3 -3
  95. package/dist/template/implementations/entity.template.d.ts.map +1 -0
  96. package/dist/template/implementations/entity.template.js +87 -0
  97. package/dist/{templates → template/implementations}/generated.template.d.ts +3 -3
  98. package/dist/template/implementations/generated.template.d.ts.map +1 -0
  99. package/dist/template/implementations/generated.template.js +232 -0
  100. package/dist/{templates → template/implementations}/generated_http.template.d.ts +3 -3
  101. package/dist/template/implementations/generated_http.template.d.ts.map +1 -0
  102. package/dist/template/implementations/generated_http.template.js +131 -0
  103. package/dist/{templates → template/implementations}/generated_sso.template.d.ts +3 -3
  104. package/dist/template/implementations/generated_sso.template.d.ts.map +1 -0
  105. package/dist/template/implementations/generated_sso.template.js +105 -0
  106. package/dist/{templates → template/implementations}/init_types.template.d.ts +3 -3
  107. package/dist/template/implementations/init_types.template.d.ts.map +1 -0
  108. package/dist/template/implementations/init_types.template.js +38 -0
  109. package/dist/template/implementations/model.template.d.ts +17 -0
  110. package/dist/template/implementations/model.template.d.ts.map +1 -0
  111. package/dist/template/implementations/model.template.js +171 -0
  112. package/dist/{templates → template/implementations}/model_test.template.d.ts +3 -3
  113. package/dist/template/implementations/model_test.template.d.ts.map +1 -0
  114. package/dist/template/implementations/model_test.template.js +35 -0
  115. package/dist/{templates → template/implementations}/service.template.d.ts +6 -6
  116. package/dist/template/implementations/service.template.d.ts.map +1 -0
  117. package/dist/template/implementations/service.template.js +193 -0
  118. package/dist/{templates → template/implementations}/view_enums_buttonset.template.d.ts +3 -3
  119. package/dist/template/implementations/view_enums_buttonset.template.d.ts.map +1 -0
  120. package/dist/template/implementations/view_enums_buttonset.template.js +31 -0
  121. package/dist/{templates → template/implementations}/view_enums_dropdown.template.d.ts +3 -4
  122. package/dist/template/implementations/view_enums_dropdown.template.d.ts.map +1 -0
  123. package/dist/template/implementations/view_enums_dropdown.template.js +50 -0
  124. package/dist/{templates → template/implementations}/view_enums_select.template.d.ts +3 -3
  125. package/dist/template/implementations/view_enums_select.template.d.ts.map +1 -0
  126. package/dist/template/implementations/view_enums_select.template.js +55 -0
  127. package/dist/{templates → template/implementations}/view_form.template.d.ts +5 -5
  128. package/dist/template/implementations/view_form.template.d.ts.map +1 -0
  129. package/dist/template/implementations/view_form.template.js +337 -0
  130. package/dist/{templates → template/implementations}/view_id_all_select.template.d.ts +3 -3
  131. package/dist/template/implementations/view_id_all_select.template.d.ts.map +1 -0
  132. package/dist/template/implementations/view_id_all_select.template.js +31 -0
  133. package/dist/{templates → template/implementations}/view_id_async_select.template.d.ts +3 -3
  134. package/dist/template/implementations/view_id_async_select.template.d.ts.map +1 -0
  135. package/dist/template/implementations/view_id_async_select.template.js +105 -0
  136. package/dist/{templates → template/implementations}/view_list.template.d.ts +5 -13
  137. package/dist/template/implementations/view_list.template.d.ts.map +1 -0
  138. package/dist/template/implementations/view_list.template.js +465 -0
  139. package/dist/{templates → template/implementations}/view_list_columns.template.d.ts +3 -3
  140. package/dist/template/implementations/view_list_columns.template.d.ts.map +1 -0
  141. package/dist/template/implementations/view_list_columns.template.js +49 -0
  142. package/dist/{templates → template/implementations}/view_search_input.template.d.ts +3 -3
  143. package/dist/template/implementations/view_search_input.template.d.ts.map +1 -0
  144. package/dist/template/implementations/view_search_input.template.js +64 -0
  145. package/dist/template/index.d.ts +5 -0
  146. package/dist/template/index.d.ts.map +1 -0
  147. package/dist/template/index.js +6 -0
  148. package/dist/template/template.d.ts +39 -0
  149. package/dist/template/template.d.ts.map +1 -0
  150. package/dist/template/template.js +47 -0
  151. package/dist/template/zod-converter.d.ts +18 -0
  152. package/dist/template/zod-converter.d.ts.map +1 -0
  153. package/dist/template/zod-converter.js +166 -0
  154. package/dist/testing/_relation-graph.js +80 -2
  155. package/dist/testing/fixture-manager.d.ts.map +1 -1
  156. package/dist/testing/fixture-manager.js +521 -2
  157. package/dist/types/types.d.ts +39 -40
  158. package/dist/types/types.d.ts.map +1 -1
  159. package/dist/types/types.js +289 -2
  160. package/dist/typings/knex.d.js +3 -2
  161. package/dist/utils/async-utils.d.ts +7 -0
  162. package/dist/utils/async-utils.d.ts.map +1 -1
  163. package/dist/utils/async-utils.js +57 -2
  164. package/dist/utils/console-util.d.ts +2 -0
  165. package/dist/utils/console-util.d.ts.map +1 -0
  166. package/dist/utils/console-util.js +6 -0
  167. package/dist/utils/controller.js +26 -2
  168. package/dist/utils/esm-utils.d.ts +45 -0
  169. package/dist/utils/esm-utils.d.ts.map +1 -0
  170. package/dist/utils/esm-utils.js +56 -0
  171. package/dist/utils/fs-utils.js +17 -2
  172. package/dist/utils/lodash-able.js +6 -2
  173. package/dist/utils/model.js +22 -2
  174. package/dist/utils/path-utils.d.ts +89 -0
  175. package/dist/utils/path-utils.d.ts.map +1 -0
  176. package/dist/utils/path-utils.js +60 -0
  177. package/dist/utils/process-utils.d.ts +13 -0
  178. package/dist/utils/process-utils.d.ts.map +1 -0
  179. package/dist/utils/process-utils.js +36 -0
  180. package/dist/utils/sql-parser.js +35 -2
  181. package/dist/utils/utils.d.ts +4 -7
  182. package/dist/utils/utils.d.ts.map +1 -1
  183. package/dist/utils/utils.js +33 -2
  184. package/dist/utils/zod-error.d.ts.map +1 -1
  185. package/dist/utils/zod-error.js +19 -2
  186. package/package.json +21 -8
  187. package/src/api/code-converters.ts +2 -2
  188. package/src/api/config.ts +142 -0
  189. package/src/api/context.ts +1 -0
  190. package/src/api/decorators.ts +1 -0
  191. package/src/api/sonamu.ts +81 -67
  192. package/src/bin/build-config.ts +2 -1
  193. package/src/bin/cli-wrapper.ts +10 -3
  194. package/src/bin/cli.ts +108 -56
  195. package/src/bin/hot-hook-register.ts +22 -0
  196. package/src/database/base-model.ts +1 -1
  197. package/src/database/code-generator.ts +1 -1
  198. package/src/database/db.ts +10 -52
  199. package/src/database/puri.ts +78 -53
  200. package/src/database/puri.types.ts +18 -5
  201. package/src/database/upsert-builder.ts +1 -1
  202. package/src/entity/entity-manager.ts +19 -15
  203. package/src/entity/entity.ts +4 -3
  204. package/src/index.ts +2 -0
  205. package/src/migration/code-generation.ts +1 -1
  206. package/src/migration/migration-set.ts +1 -1
  207. package/src/migration/migrator.ts +23 -152
  208. package/src/naite/naite.ts +70 -0
  209. package/src/syncer/api-parser.ts +299 -0
  210. package/src/syncer/checksum.ts +152 -0
  211. package/src/syncer/code-generator.ts +202 -0
  212. package/src/syncer/entity-operations.ts +68 -0
  213. package/src/syncer/file-patterns.ts +56 -0
  214. package/src/syncer/index.ts +6 -0
  215. package/src/syncer/module-loader.ts +125 -0
  216. package/src/syncer/syncer.ts +363 -1420
  217. package/src/template/entity-converter.ts +123 -0
  218. package/src/template/helpers.ts +84 -0
  219. package/src/{templates → template/implementations}/entity.template.ts +4 -4
  220. package/src/{templates → template/implementations}/generated.template.ts +9 -9
  221. package/src/{templates → template/implementations}/generated_http.template.ts +9 -6
  222. package/src/{templates → template/implementations}/generated_sso.template.ts +7 -7
  223. package/src/{templates → template/implementations}/init_types.template.ts +4 -4
  224. package/src/{templates → template/implementations}/model.template.ts +9 -9
  225. package/src/{templates → template/implementations}/model_test.template.ts +5 -5
  226. package/src/{templates → template/implementations}/service.template.ts +19 -11
  227. package/src/{templates → template/implementations}/view_enums_buttonset.template.ts +3 -3
  228. package/src/{templates → template/implementations}/view_enums_dropdown.template.ts +5 -21
  229. package/src/{templates → template/implementations}/view_enums_select.template.ts +4 -4
  230. package/src/{templates → template/implementations}/view_form.template.ts +11 -13
  231. package/src/{templates → template/implementations}/view_id_all_select.template.ts +3 -3
  232. package/src/{templates → template/implementations}/view_id_async_select.template.ts +3 -3
  233. package/src/{templates → template/implementations}/view_list.template.ts +13 -64
  234. package/src/{templates → template/implementations}/view_list_columns.template.ts +3 -3
  235. package/src/{templates → template/implementations}/view_search_input.template.ts +3 -3
  236. package/src/template/index.ts +4 -0
  237. package/src/template/template.ts +86 -0
  238. package/src/template/zod-converter.ts +219 -0
  239. package/src/testing/fixture-manager.ts +8 -1
  240. package/src/types/types.ts +38 -61
  241. package/src/utils/async-utils.ts +17 -0
  242. package/src/utils/console-util.ts +4 -0
  243. package/src/utils/esm-utils.ts +69 -0
  244. package/src/utils/path-utils.ts +102 -0
  245. package/src/utils/process-utils.ts +46 -0
  246. package/src/utils/sql-parser.ts +1 -1
  247. package/src/utils/utils.ts +14 -40
  248. package/src/utils/zod-error.ts +0 -1
  249. package/dist/api/base-frame.js.map +0 -1
  250. package/dist/api/caster.js.map +0 -1
  251. package/dist/api/code-converters.js.map +0 -1
  252. package/dist/api/context.js.map +0 -1
  253. package/dist/api/decorators.js.map +0 -1
  254. package/dist/api/index.js.map +0 -1
  255. package/dist/api/sonamu.js.map +0 -1
  256. package/dist/bin/build-config.js.map +0 -1
  257. package/dist/bin/cli-wrapper.js.map +0 -1
  258. package/dist/bin/cli.js.map +0 -1
  259. package/dist/database/_batch_update.js.map +0 -1
  260. package/dist/database/base-model.js.map +0 -1
  261. package/dist/database/code-generator.js.map +0 -1
  262. package/dist/database/db.js.map +0 -1
  263. package/dist/database/knex-plugins/knex-on-duplicate-update.js.map +0 -1
  264. package/dist/database/puri-wrapper.js.map +0 -1
  265. package/dist/database/puri.js.map +0 -1
  266. package/dist/database/puri.types.js.map +0 -1
  267. package/dist/database/transaction-context.js.map +0 -1
  268. package/dist/database/upsert-builder.js.map +0 -1
  269. package/dist/entity/entity-manager.js.map +0 -1
  270. package/dist/entity/entity-utils.js.map +0 -1
  271. package/dist/entity/entity.js.map +0 -1
  272. package/dist/exceptions/error-handler.js.map +0 -1
  273. package/dist/exceptions/so-exceptions.js.map +0 -1
  274. package/dist/file-storage/driver.js.map +0 -1
  275. package/dist/file-storage/file-storage.js.map +0 -1
  276. package/dist/index.js.map +0 -1
  277. package/dist/migration/code-generation.js.map +0 -1
  278. package/dist/migration/migration-set.js.map +0 -1
  279. package/dist/migration/migrator.js.map +0 -1
  280. package/dist/migration/types.js.map +0 -1
  281. package/dist/stream/index.js.map +0 -1
  282. package/dist/stream/sse.js.map +0 -1
  283. package/dist/syncer/index.js.map +0 -1
  284. package/dist/syncer/syncer.js.map +0 -1
  285. package/dist/templates/base-template.d.ts +0 -13
  286. package/dist/templates/base-template.d.ts.map +0 -1
  287. package/dist/templates/base-template.js +0 -2
  288. package/dist/templates/base-template.js.map +0 -1
  289. package/dist/templates/entity.template.d.ts.map +0 -1
  290. package/dist/templates/entity.template.js +0 -2
  291. package/dist/templates/entity.template.js.map +0 -1
  292. package/dist/templates/generated.template.d.ts.map +0 -1
  293. package/dist/templates/generated.template.js +0 -2
  294. package/dist/templates/generated.template.js.map +0 -1
  295. package/dist/templates/generated_http.template.d.ts.map +0 -1
  296. package/dist/templates/generated_http.template.js +0 -2
  297. package/dist/templates/generated_http.template.js.map +0 -1
  298. package/dist/templates/generated_sso.template.d.ts.map +0 -1
  299. package/dist/templates/generated_sso.template.js +0 -2
  300. package/dist/templates/generated_sso.template.js.map +0 -1
  301. package/dist/templates/index.d.ts +0 -2
  302. package/dist/templates/index.d.ts.map +0 -1
  303. package/dist/templates/index.js +0 -2
  304. package/dist/templates/index.js.map +0 -1
  305. package/dist/templates/init_types.template.d.ts.map +0 -1
  306. package/dist/templates/init_types.template.js +0 -2
  307. package/dist/templates/init_types.template.js.map +0 -1
  308. package/dist/templates/model.template.d.ts +0 -17
  309. package/dist/templates/model.template.d.ts.map +0 -1
  310. package/dist/templates/model.template.js +0 -2
  311. package/dist/templates/model.template.js.map +0 -1
  312. package/dist/templates/model_test.template.d.ts.map +0 -1
  313. package/dist/templates/model_test.template.js +0 -2
  314. package/dist/templates/model_test.template.js.map +0 -1
  315. package/dist/templates/service.template.d.ts.map +0 -1
  316. package/dist/templates/service.template.js +0 -2
  317. package/dist/templates/service.template.js.map +0 -1
  318. package/dist/templates/view_enums_buttonset.template.d.ts.map +0 -1
  319. package/dist/templates/view_enums_buttonset.template.js +0 -2
  320. package/dist/templates/view_enums_buttonset.template.js.map +0 -1
  321. package/dist/templates/view_enums_dropdown.template.d.ts.map +0 -1
  322. package/dist/templates/view_enums_dropdown.template.js +0 -2
  323. package/dist/templates/view_enums_dropdown.template.js.map +0 -1
  324. package/dist/templates/view_enums_select.template.d.ts.map +0 -1
  325. package/dist/templates/view_enums_select.template.js +0 -2
  326. package/dist/templates/view_enums_select.template.js.map +0 -1
  327. package/dist/templates/view_form.template.d.ts.map +0 -1
  328. package/dist/templates/view_form.template.js +0 -2
  329. package/dist/templates/view_form.template.js.map +0 -1
  330. package/dist/templates/view_id_all_select.template.d.ts.map +0 -1
  331. package/dist/templates/view_id_all_select.template.js +0 -2
  332. package/dist/templates/view_id_all_select.template.js.map +0 -1
  333. package/dist/templates/view_id_async_select.template.d.ts.map +0 -1
  334. package/dist/templates/view_id_async_select.template.js +0 -2
  335. package/dist/templates/view_id_async_select.template.js.map +0 -1
  336. package/dist/templates/view_list.template.d.ts.map +0 -1
  337. package/dist/templates/view_list.template.js +0 -2
  338. package/dist/templates/view_list.template.js.map +0 -1
  339. package/dist/templates/view_list_columns.template.d.ts.map +0 -1
  340. package/dist/templates/view_list_columns.template.js +0 -2
  341. package/dist/templates/view_list_columns.template.js.map +0 -1
  342. package/dist/templates/view_search_input.template.d.ts.map +0 -1
  343. package/dist/templates/view_search_input.template.js +0 -2
  344. package/dist/templates/view_search_input.template.js.map +0 -1
  345. package/dist/testing/_relation-graph.js.map +0 -1
  346. package/dist/testing/fixture-manager.js.map +0 -1
  347. package/dist/types/types.js.map +0 -1
  348. package/dist/typings/knex.d.js.map +0 -1
  349. package/dist/utils/async-utils.js.map +0 -1
  350. package/dist/utils/controller.js.map +0 -1
  351. package/dist/utils/fs-utils.js.map +0 -1
  352. package/dist/utils/lodash-able.js.map +0 -1
  353. package/dist/utils/model.js.map +0 -1
  354. package/dist/utils/sql-parser.js.map +0 -1
  355. package/dist/utils/utils.js.map +0 -1
  356. package/dist/utils/zod-error.js.map +0 -1
  357. package/src/templates/base-template.ts +0 -19
  358. package/src/templates/index.ts +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"build-config.d.ts","sourceRoot":"","sources":["../../src/bin/build-config.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,eAAO,MAAM,SAAS,SAAS,CAAC;AAEhC;;GAEG;AACH,eAAO,MAAM,iBAAiB,gKAAwK,CAAC;AAEvM;;GAEG;AACH,eAAO,MAAM,sBAAsB,iBAAiB,CAAC"}
1
+ {"version":3,"file":"build-config.d.ts","sourceRoot":"","sources":["../../src/bin/build-config.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,eAAO,MAAM,SAAS,SAAS,CAAC;AAEhC;;;GAGG;AACH,eAAO,MAAM,iBAAiB,0CAAkD,CAAC;AAEjF;;GAEG;AACH,eAAO,MAAM,sBAAsB,iBAAiB,CAAC"}
@@ -1,2 +1,12 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:true});function _export(target,all){for(var name in all)Object.defineProperty(target,name,{enumerable:true,get:Object.getOwnPropertyDescriptor(all,name).get})}_export(exports,{get BUILD_DIR(){return BUILD_DIR},get SWC_BUILD_COMMAND(){return SWC_BUILD_COMMAND},get TSC_TYPE_CHECK_COMMAND(){return TSC_TYPE_CHECK_COMMAND}});var BUILD_DIR="dist";var SWC_BUILD_COMMAND="swc src -d ".concat(BUILD_DIR," --strip-leading-paths --source-maps -C module.type=commonjs -C jsc.parser.syntax=typescript -C jsc.parser.decorators=true -C jsc.target=es5");var TSC_TYPE_CHECK_COMMAND="tsc --noEmit";
2
- //# sourceMappingURL=build-config.js.map
1
+ /**
2
+ * 빌드 결과물이 담길 디렉토리 경로
3
+ */ export const BUILD_DIR = "dist";
4
+ /**
5
+ * SWC 빌드 명령어
6
+ * .swcrc 설정 사용
7
+ */ export const SWC_BUILD_COMMAND = `swc src -d ${BUILD_DIR} --strip-leading-paths`;
8
+ /**
9
+ * TSC 타입 체크 명령어
10
+ */ export const TSC_TYPE_CHECK_COMMAND = `tsc --noEmit`;
11
+
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9iaW4vYnVpbGQtY29uZmlnLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICog67mM65OcIOqysOqzvOusvOydtCDri7TquLgg65SU66CJ7Yag66asIOqyveuhnFxuICovXG5leHBvcnQgY29uc3QgQlVJTERfRElSID0gXCJkaXN0XCI7XG5cbi8qKlxuICogU1dDIOu5jOuTnCDrqoXroLnslrRcbiAqIC5zd2NyYyDshKTsoJUg7IKs7JqpXG4gKi9cbmV4cG9ydCBjb25zdCBTV0NfQlVJTERfQ09NTUFORCA9IGBzd2Mgc3JjIC1kICR7QlVJTERfRElSfSAtLXN0cmlwLWxlYWRpbmctcGF0aHNgO1xuXG4vKipcbiAqIFRTQyDtg4DsnoUg7LK07YGsIOuqheugueyWtFxuICovXG5leHBvcnQgY29uc3QgVFNDX1RZUEVfQ0hFQ0tfQ09NTUFORCA9IGB0c2MgLS1ub0VtaXRgO1xuIl0sIm5hbWVzIjpbIkJVSUxEX0RJUiIsIlNXQ19CVUlMRF9DT01NQU5EIiwiVFNDX1RZUEVfQ0hFQ0tfQ09NTUFORCJdLCJtYXBwaW5ncyI6IkFBQUE7O0NBRUMsR0FDRCxPQUFPLE1BQU1BLFlBQVksT0FBTztBQUVoQzs7O0NBR0MsR0FDRCxPQUFPLE1BQU1DLG9CQUFvQixDQUFDLFdBQVcsRUFBRUQsVUFBVSxzQkFBc0IsQ0FBQyxDQUFDO0FBRWpGOztDQUVDLEdBQ0QsT0FBTyxNQUFNRSx5QkFBeUIsQ0FBQyxZQUFZLENBQUMsQ0FBQyJ9
@@ -1,3 +1,72 @@
1
1
  #!/usr/bin/env ts-node
2
- "use strict";Object.defineProperty(exports,"__esModule",{value:true});var _child_process=require("child_process");var _path=require("path");var _fs=require("fs");var _chalk=/*#__PURE__*/_interop_require_default(require("chalk"));var _buildconfig=require("./build-config");function _array_like_to_array(arr,len){if(len==null||len>arr.length)len=arr.length;for(var i=0,arr2=new Array(len);i<len;i++)arr2[i]=arr[i];return arr2}function _array_without_holes(arr){if(Array.isArray(arr))return _array_like_to_array(arr)}function _interop_require_default(obj){return obj&&obj.__esModule?obj:{default:obj}}function _iterable_to_array(iter){if(typeof Symbol!=="undefined"&&iter[Symbol.iterator]!=null||iter["@@iterator"]!=null)return Array.from(iter)}function _non_iterable_spread(){throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _to_consumable_array(arr){return _array_without_holes(arr)||_iterable_to_array(arr)||_unsupported_iterable_to_array(arr)||_non_iterable_spread()}function _unsupported_iterable_to_array(o,minLen){if(!o)return;if(typeof o==="string")return _array_like_to_array(o,minLen);var n=Object.prototype.toString.call(o).slice(8,-1);if(n==="Object"&&o.constructor)n=o.constructor.name;if(n==="Map"||n==="Set")return Array.from(n);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return _array_like_to_array(o,minLen)}var scriptPath=(0,_path.resolve)(__dirname,"cli.js");var args=process.argv.slice(2);function build(){try{console.log(_chalk.default.blue("Removing build directory..."));if((0,_fs.existsSync)(_buildconfig.BUILD_DIR)){(0,_fs.rmSync)(_buildconfig.BUILD_DIR,{recursive:true,force:true})}}catch(error){console.error(_chalk.default.red("Remove build directory failed."),error);process.exit(1)}try{console.log(_chalk.default.blue("Building with swc..."));(0,_child_process.execSync)(_buildconfig.SWC_BUILD_COMMAND,{cwd:process.cwd(),stdio:"inherit"})}catch(error){console.error(_chalk.default.red("Build failed."),error);process.exit(1)}}function checkTypes(){try{console.log(_chalk.default.blue("Checking types with tsc..."));(0,_child_process.execSync)(_buildconfig.TSC_TYPE_CHECK_COMMAND,{cwd:process.cwd(),stdio:"inherit"})}catch(error){console.error(_chalk.default.red("Type check failed."),error);process.exit(1)}}if(args[0]==="build"){console.log(_chalk.default.blue("Building the project..."));build();checkTypes();console.log(_chalk.default.green("Build completed successfully."));process.exit(0)}if(args[0]==="dev:serve"){build()}if(!(0,_fs.existsSync)(scriptPath)){console.error("Error: Script not found at ".concat(scriptPath));process.exit(1)}var result=(0,_child_process.spawnSync)(process.execPath,["-r","source-map-support/register","--no-warnings",scriptPath].concat(_to_consumable_array(args)),{stdio:"inherit"});var _result_status;process.exit((_result_status=result.status)!==null&&_result_status!==void 0?_result_status:1);
3
- //# sourceMappingURL=cli-wrapper.js.map
2
+ import { spawnSync, execSync } from "child_process";
3
+ import { resolve } from "path";
4
+ import { existsSync, rmSync } from "fs";
5
+ import chalk from "chalk";
6
+ import { BUILD_DIR, SWC_BUILD_COMMAND, TSC_TYPE_CHECK_COMMAND } from "./build-config.js";
7
+ const scriptPath = resolve(import.meta.dirname, "cli.js");
8
+ const args = process.argv.slice(2);
9
+ // build 명령어는 dist 없이도 실행 가능하도록 cli.ts 외부에서 처리(Sonamu.init에서 dist 필요)
10
+ function build() {
11
+ try {
12
+ console.log(chalk.blue("Removing build directory..."));
13
+ if (existsSync(BUILD_DIR)) {
14
+ rmSync(BUILD_DIR, {
15
+ recursive: true,
16
+ force: true
17
+ });
18
+ }
19
+ } catch (error) {
20
+ console.error(chalk.red("Remove build directory failed."), error);
21
+ process.exit(1);
22
+ }
23
+ try {
24
+ console.log(chalk.blue("Building with swc..."));
25
+ execSync(SWC_BUILD_COMMAND, {
26
+ cwd: process.cwd(),
27
+ stdio: "inherit"
28
+ });
29
+ } catch (error) {
30
+ console.error(chalk.red("Build failed."), error);
31
+ process.exit(1);
32
+ }
33
+ }
34
+ function checkTypes() {
35
+ try {
36
+ console.log(chalk.blue("Checking types with tsc..."));
37
+ execSync(TSC_TYPE_CHECK_COMMAND, {
38
+ cwd: process.cwd(),
39
+ stdio: "inherit"
40
+ });
41
+ } catch (error) {
42
+ console.error(chalk.red("Type check failed."), error);
43
+ process.exit(1);
44
+ }
45
+ }
46
+ if (args[0] === "build") {
47
+ console.log(chalk.blue("Building the project..."));
48
+ build();
49
+ checkTypes();
50
+ console.log(chalk.green("Build completed successfully."));
51
+ process.exit(0);
52
+ }
53
+ if (args[0] === "dev:serve") {
54
+ // build();
55
+ }
56
+ if (!existsSync(scriptPath)) {
57
+ console.error(`Error: Script not found at ${scriptPath}`);
58
+ process.exit(1);
59
+ }
60
+ const result = spawnSync(process.execPath, [
61
+ "--import",
62
+ "@sonamu-kit/loader",
63
+ "--enable-source-maps",
64
+ "--no-warnings",
65
+ scriptPath,
66
+ ...args
67
+ ], {
68
+ stdio: "inherit"
69
+ });
70
+ process.exit(result.status ?? 1);
71
+
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9iaW4vY2xpLXdyYXBwZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiIyEvdXNyL2Jpbi9lbnYgdHMtbm9kZVxuXG5pbXBvcnQgeyBzcGF3blN5bmMsIGV4ZWNTeW5jIH0gZnJvbSBcImNoaWxkX3Byb2Nlc3NcIjtcbmltcG9ydCB7IHJlc29sdmUgfSBmcm9tIFwicGF0aFwiO1xuaW1wb3J0IHsgZXhpc3RzU3luYywgcm1TeW5jIH0gZnJvbSBcImZzXCI7XG5pbXBvcnQgY2hhbGsgZnJvbSBcImNoYWxrXCI7XG5pbXBvcnQge1xuICBCVUlMRF9ESVIsXG4gIFNXQ19CVUlMRF9DT01NQU5ELFxuICBUU0NfVFlQRV9DSEVDS19DT01NQU5ELFxufSBmcm9tIFwiLi9idWlsZC1jb25maWdcIjtcblxuY29uc3Qgc2NyaXB0UGF0aCA9IHJlc29sdmUoaW1wb3J0Lm1ldGEuZGlybmFtZSwgXCJjbGkuanNcIik7XG5jb25zdCBhcmdzID0gcHJvY2Vzcy5hcmd2LnNsaWNlKDIpO1xuXG4vLyBidWlsZCDrqoXroLnslrTripQgZGlzdCDsl4bsnbTrj4Qg7Iuk7ZaJIOqwgOuKpe2VmOuPhOuhnSBjbGkudHMg7Jm467aA7JeQ7IScIOyymOumrChTb25hbXUuaW5pdOyXkOyEnCBkaXN0IO2VhOyalClcbmZ1bmN0aW9uIGJ1aWxkKCkge1xuICB0cnkge1xuICAgIGNvbnNvbGUubG9nKGNoYWxrLmJsdWUoXCJSZW1vdmluZyBidWlsZCBkaXJlY3RvcnkuLi5cIikpO1xuICAgIGlmIChleGlzdHNTeW5jKEJVSUxEX0RJUikpIHtcbiAgICAgIHJtU3luYyhCVUlMRF9ESVIsIHsgcmVjdXJzaXZlOiB0cnVlLCBmb3JjZTogdHJ1ZSB9KTtcbiAgICB9XG4gIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgY29uc29sZS5lcnJvcihjaGFsay5yZWQoXCJSZW1vdmUgYnVpbGQgZGlyZWN0b3J5IGZhaWxlZC5cIiksIGVycm9yKTtcbiAgICBwcm9jZXNzLmV4aXQoMSk7XG4gIH1cblxuICB0cnkge1xuICAgIGNvbnNvbGUubG9nKGNoYWxrLmJsdWUoXCJCdWlsZGluZyB3aXRoIHN3Yy4uLlwiKSk7XG4gICAgZXhlY1N5bmMoU1dDX0JVSUxEX0NPTU1BTkQsIHsgY3dkOiBwcm9jZXNzLmN3ZCgpLCBzdGRpbzogXCJpbmhlcml0XCIgfSk7XG4gIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgY29uc29sZS5lcnJvcihjaGFsay5yZWQoXCJCdWlsZCBmYWlsZWQuXCIpLCBlcnJvcik7XG4gICAgcHJvY2Vzcy5leGl0KDEpO1xuICB9XG59XG5cbmZ1bmN0aW9uIGNoZWNrVHlwZXMoKSB7XG4gIHRyeSB7XG4gICAgY29uc29sZS5sb2coY2hhbGsuYmx1ZShcIkNoZWNraW5nIHR5cGVzIHdpdGggdHNjLi4uXCIpKTtcbiAgICBleGVjU3luYyhUU0NfVFlQRV9DSEVDS19DT01NQU5ELCB7XG4gICAgICBjd2Q6IHByb2Nlc3MuY3dkKCksXG4gICAgICBzdGRpbzogXCJpbmhlcml0XCIsXG4gICAgfSk7XG4gIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgY29uc29sZS5lcnJvcihjaGFsay5yZWQoXCJUeXBlIGNoZWNrIGZhaWxlZC5cIiksIGVycm9yKTtcbiAgICBwcm9jZXNzLmV4aXQoMSk7XG4gIH1cbn1cblxuaWYgKGFyZ3NbMF0gPT09IFwiYnVpbGRcIikge1xuICBjb25zb2xlLmxvZyhjaGFsay5ibHVlKFwiQnVpbGRpbmcgdGhlIHByb2plY3QuLi5cIikpO1xuICBidWlsZCgpO1xuICBjaGVja1R5cGVzKCk7XG4gIGNvbnNvbGUubG9nKGNoYWxrLmdyZWVuKFwiQnVpbGQgY29tcGxldGVkIHN1Y2Nlc3NmdWxseS5cIikpO1xuICBwcm9jZXNzLmV4aXQoMCk7XG59XG5cbmlmIChhcmdzWzBdID09PSBcImRldjpzZXJ2ZVwiKSB7XG4gIC8vIGJ1aWxkKCk7XG59XG5cbmlmICghZXhpc3RzU3luYyhzY3JpcHRQYXRoKSkge1xuICBjb25zb2xlLmVycm9yKGBFcnJvcjogU2NyaXB0IG5vdCBmb3VuZCBhdCAke3NjcmlwdFBhdGh9YCk7XG4gIHByb2Nlc3MuZXhpdCgxKTtcbn1cblxuY29uc3QgcmVzdWx0ID0gc3Bhd25TeW5jKFxuICBwcm9jZXNzLmV4ZWNQYXRoLFxuICBbXG4gICAgXCItLWltcG9ydFwiLFxuICAgIFwiQHNvbmFtdS1raXQvbG9hZGVyXCIsIC8vIFNvbmFtdSBVSeuPhCBzeW5jZXLrpbwg64uk66Oo66+A66GcLCB0cyDroZzrk5wg64ql66Cl7J20IO2VhOyalO2VqeuLiOuLpC5cbiAgICBcIi0tZW5hYmxlLXNvdXJjZS1tYXBzXCIsXG4gICAgXCItLW5vLXdhcm5pbmdzXCIsXG4gICAgc2NyaXB0UGF0aCxcbiAgICAuLi5hcmdzXG4gIF0sXG4gIHtcbiAgICBzdGRpbzogXCJpbmhlcml0XCIsXG4gIH1cbik7XG5cbnByb2Nlc3MuZXhpdChyZXN1bHQuc3RhdHVzID8/IDEpO1xuIl0sIm5hbWVzIjpbInNwYXduU3luYyIsImV4ZWNTeW5jIiwicmVzb2x2ZSIsImV4aXN0c1N5bmMiLCJybVN5bmMiLCJjaGFsayIsIkJVSUxEX0RJUiIsIlNXQ19CVUlMRF9DT01NQU5EIiwiVFNDX1RZUEVfQ0hFQ0tfQ09NTUFORCIsInNjcmlwdFBhdGgiLCJkaXJuYW1lIiwiYXJncyIsInByb2Nlc3MiLCJhcmd2Iiwic2xpY2UiLCJidWlsZCIsImNvbnNvbGUiLCJsb2ciLCJibHVlIiwicmVjdXJzaXZlIiwiZm9yY2UiLCJlcnJvciIsInJlZCIsImV4aXQiLCJjd2QiLCJzdGRpbyIsImNoZWNrVHlwZXMiLCJncmVlbiIsInJlc3VsdCIsImV4ZWNQYXRoIiwic3RhdHVzIl0sIm1hcHBpbmdzIjoiO0FBRUEsU0FBU0EsU0FBUyxFQUFFQyxRQUFRLFFBQVEsZ0JBQWdCO0FBQ3BELFNBQVNDLE9BQU8sUUFBUSxPQUFPO0FBQy9CLFNBQVNDLFVBQVUsRUFBRUMsTUFBTSxRQUFRLEtBQUs7QUFDeEMsT0FBT0MsV0FBVyxRQUFRO0FBQzFCLFNBQ0VDLFNBQVMsRUFDVEMsaUJBQWlCLEVBQ2pCQyxzQkFBc0IsUUFDakIsb0JBQWlCO0FBRXhCLE1BQU1DLGFBQWFQLFFBQVEsWUFBWVEsT0FBTyxFQUFFO0FBQ2hELE1BQU1DLE9BQU9DLFFBQVFDLElBQUksQ0FBQ0MsS0FBSyxDQUFDO0FBRWhDLHFFQUFxRTtBQUNyRSxTQUFTQztJQUNQLElBQUk7UUFDRkMsUUFBUUMsR0FBRyxDQUFDWixNQUFNYSxJQUFJLENBQUM7UUFDdkIsSUFBSWYsV0FBV0csWUFBWTtZQUN6QkYsT0FBT0UsV0FBVztnQkFBRWEsV0FBVztnQkFBTUMsT0FBTztZQUFLO1FBQ25EO0lBQ0YsRUFBRSxPQUFPQyxPQUFPO1FBQ2RMLFFBQVFLLEtBQUssQ0FBQ2hCLE1BQU1pQixHQUFHLENBQUMsbUNBQW1DRDtRQUMzRFQsUUFBUVcsSUFBSSxDQUFDO0lBQ2Y7SUFFQSxJQUFJO1FBQ0ZQLFFBQVFDLEdBQUcsQ0FBQ1osTUFBTWEsSUFBSSxDQUFDO1FBQ3ZCakIsU0FBU00sbUJBQW1CO1lBQUVpQixLQUFLWixRQUFRWSxHQUFHO1lBQUlDLE9BQU87UUFBVTtJQUNyRSxFQUFFLE9BQU9KLE9BQU87UUFDZEwsUUFBUUssS0FBSyxDQUFDaEIsTUFBTWlCLEdBQUcsQ0FBQyxrQkFBa0JEO1FBQzFDVCxRQUFRVyxJQUFJLENBQUM7SUFDZjtBQUNGO0FBRUEsU0FBU0c7SUFDUCxJQUFJO1FBQ0ZWLFFBQVFDLEdBQUcsQ0FBQ1osTUFBTWEsSUFBSSxDQUFDO1FBQ3ZCakIsU0FBU08sd0JBQXdCO1lBQy9CZ0IsS0FBS1osUUFBUVksR0FBRztZQUNoQkMsT0FBTztRQUNUO0lBQ0YsRUFBRSxPQUFPSixPQUFPO1FBQ2RMLFFBQVFLLEtBQUssQ0FBQ2hCLE1BQU1pQixHQUFHLENBQUMsdUJBQXVCRDtRQUMvQ1QsUUFBUVcsSUFBSSxDQUFDO0lBQ2Y7QUFDRjtBQUVBLElBQUlaLElBQUksQ0FBQyxFQUFFLEtBQUssU0FBUztJQUN2QkssUUFBUUMsR0FBRyxDQUFDWixNQUFNYSxJQUFJLENBQUM7SUFDdkJIO0lBQ0FXO0lBQ0FWLFFBQVFDLEdBQUcsQ0FBQ1osTUFBTXNCLEtBQUssQ0FBQztJQUN4QmYsUUFBUVcsSUFBSSxDQUFDO0FBQ2Y7QUFFQSxJQUFJWixJQUFJLENBQUMsRUFBRSxLQUFLLGFBQWE7QUFDM0IsV0FBVztBQUNiO0FBRUEsSUFBSSxDQUFDUixXQUFXTSxhQUFhO0lBQzNCTyxRQUFRSyxLQUFLLENBQUMsQ0FBQywyQkFBMkIsRUFBRVosWUFBWTtJQUN4REcsUUFBUVcsSUFBSSxDQUFDO0FBQ2Y7QUFFQSxNQUFNSyxTQUFTNUIsVUFDYlksUUFBUWlCLFFBQVEsRUFDaEI7SUFDRTtJQUNBO0lBQ0E7SUFDQTtJQUNBcEI7T0FDR0U7Q0FDSixFQUNEO0lBQ0VjLE9BQU87QUFDVDtBQUdGYixRQUFRVyxJQUFJLENBQUNLLE9BQU9FLE1BQU0sSUFBSSJ9
package/dist/bin/cli.js CHANGED
@@ -1,2 +1,418 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:true});var _chalk=/*#__PURE__*/_interop_require_default(require("chalk"));var _dotenv=/*#__PURE__*/_interop_require_default(require("dotenv"));var _path=/*#__PURE__*/_interop_require_default(require("path"));var _tsicli=require("tsicli");var _child_process=require("child_process");var _promises=require("fs/promises");var _fsutils=require("../utils/fs-utils");var _process=/*#__PURE__*/_interop_require_default(require("process"));var _api=require("../api");var _knex=/*#__PURE__*/_interop_require_default(require("knex"));var _utils=require("../utils/utils");var _entitymanager=require("../entity/entity-manager");var _migrator=require("../migration/migrator");var _fixturemanager=require("../testing/fixture-manager");function _array_like_to_array(arr,len){if(len==null||len>arr.length)len=arr.length;for(var i=0,arr2=new Array(len);i<len;i++)arr2[i]=arr[i];return arr2}function _array_with_holes(arr){if(Array.isArray(arr))return arr}function _async_iterator(iterable){var method,async,sync,retry=2;for("undefined"!=typeof Symbol&&(async=Symbol.asyncIterator,sync=Symbol.iterator);retry--;){if(async&&null!=(method=iterable[async]))return method.call(iterable);if(sync&&null!=(method=iterable[sync]))return new AsyncFromSyncIterator(method.call(iterable));async="@@asyncIterator",sync="@@iterator"}throw new TypeError("Object is not async iterable")}function AsyncFromSyncIterator(s){function AsyncFromSyncIteratorContinuation(r){if(Object(r)!==r)return Promise.reject(new TypeError(r+" is not an object."));var done=r.done;return Promise.resolve(r.value).then(function(value){return{value:value,done:done}})}return AsyncFromSyncIterator=function(s){this.s=s,this.n=s.next},AsyncFromSyncIterator.prototype={s:null,n:null,next:function(){return AsyncFromSyncIteratorContinuation(this.n.apply(this.s,arguments))},return:function(value){var ret=this.s.return;return void 0===ret?Promise.resolve({value:value,done:!0}):AsyncFromSyncIteratorContinuation(ret.apply(this.s,arguments))},throw:function(value){var thr=this.s.return;return void 0===thr?Promise.reject(value):AsyncFromSyncIteratorContinuation(thr.apply(this.s,arguments))}},new AsyncFromSyncIterator(s)}function asyncGeneratorStep(gen,resolve,reject,_next,_throw,key,arg){try{var info=gen[key](arg);var value=info.value}catch(error){reject(error);return}if(info.done){resolve(value)}else{Promise.resolve(value).then(_next,_throw)}}function _async_to_generator(fn){return function(){var self=this,args=arguments;return new Promise(function(resolve,reject){var gen=fn.apply(self,args);function _next(value){asyncGeneratorStep(gen,resolve,reject,_next,_throw,"next",value)}function _throw(err){asyncGeneratorStep(gen,resolve,reject,_next,_throw,"throw",err)}_next(undefined)})}}function _define_property(obj,key,value){if(key in obj){Object.defineProperty(obj,key,{value:value,enumerable:true,configurable:true,writable:true})}else{obj[key]=value}return obj}function _instanceof(left,right){if(right!=null&&typeof Symbol!=="undefined"&&right[Symbol.hasInstance]){return!!right[Symbol.hasInstance](left)}else{return left instanceof right}}function _interop_require_default(obj){return obj&&obj.__esModule?obj:{default:obj}}function _getRequireWildcardCache(nodeInterop){if(typeof WeakMap!=="function")return null;var cacheBabelInterop=new WeakMap;var cacheNodeInterop=new WeakMap;return(_getRequireWildcardCache=function(nodeInterop){return nodeInterop?cacheNodeInterop:cacheBabelInterop})(nodeInterop)}function _interop_require_wildcard(obj,nodeInterop){if(!nodeInterop&&obj&&obj.__esModule){return obj}if(obj===null||typeof obj!=="object"&&typeof obj!=="function"){return{default:obj}}var cache=_getRequireWildcardCache(nodeInterop);if(cache&&cache.has(obj)){return cache.get(obj)}var newObj={__proto__:null};var hasPropertyDescriptor=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var key in obj){if(key!=="default"&&Object.prototype.hasOwnProperty.call(obj,key)){var desc=hasPropertyDescriptor?Object.getOwnPropertyDescriptor(obj,key):null;if(desc&&(desc.get||desc.set)){Object.defineProperty(newObj,key,desc)}else{newObj[key]=obj[key]}}}newObj.default=obj;if(cache){cache.set(obj,newObj)}return newObj}function _iterable_to_array_limit(arr,i){var _i=arr==null?null:typeof Symbol!=="undefined"&&arr[Symbol.iterator]||arr["@@iterator"];if(_i==null)return;var _arr=[];var _n=true;var _d=false;var _s,_e;try{for(_i=_i.call(arr);!(_n=(_s=_i.next()).done);_n=true){_arr.push(_s.value);if(i&&_arr.length===i)break}}catch(err){_d=true;_e=err}finally{try{if(!_n&&_i["return"]!=null)_i["return"]()}finally{if(_d)throw _e}}return _arr}function _non_iterable_rest(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _object_spread(target){for(var i=1;i<arguments.length;i++){var source=arguments[i]!=null?arguments[i]:{};var ownKeys=Object.keys(source);if(typeof Object.getOwnPropertySymbols==="function"){ownKeys=ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym){return Object.getOwnPropertyDescriptor(source,sym).enumerable}))}ownKeys.forEach(function(key){_define_property(target,key,source[key])})}return target}function ownKeys(object,enumerableOnly){var keys=Object.keys(object);if(Object.getOwnPropertySymbols){var symbols=Object.getOwnPropertySymbols(object);if(enumerableOnly){symbols=symbols.filter(function(sym){return Object.getOwnPropertyDescriptor(object,sym).enumerable})}keys.push.apply(keys,symbols)}return keys}function _object_spread_props(target,source){source=source!=null?source:{};if(Object.getOwnPropertyDescriptors){Object.defineProperties(target,Object.getOwnPropertyDescriptors(source))}else{ownKeys(Object(source)).forEach(function(key){Object.defineProperty(target,key,Object.getOwnPropertyDescriptor(source,key))})}return target}function _sliced_to_array(arr,i){return _array_with_holes(arr)||_iterable_to_array_limit(arr,i)||_unsupported_iterable_to_array(arr,i)||_non_iterable_rest()}function _unsupported_iterable_to_array(o,minLen){if(!o)return;if(typeof o==="string")return _array_like_to_array(o,minLen);var n=Object.prototype.toString.call(o).slice(8,-1);if(n==="Object"&&o.constructor)n=o.constructor.name;if(n==="Map"||n==="Set")return Array.from(n);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return _array_like_to_array(o,minLen)}function _ts_generator(thisArg,body){var f,y,t,_={label:0,sent:function(){if(t[0]&1)throw t[1];return t[1]},trys:[],ops:[]},g=Object.create((typeof Iterator==="function"?Iterator:Object).prototype);return g.next=verb(0),g["throw"]=verb(1),g["return"]=verb(2),typeof Symbol==="function"&&(g[Symbol.iterator]=function(){return this}),g;function verb(n){return function(v){return step([n,v])}}function step(op){if(f)throw new TypeError("Generator is already executing.");while(g&&(g=0,op[0]&&(_=0)),_)try{if(f=1,y&&(t=op[0]&2?y["return"]:op[0]?y["throw"]||((t=y["return"])&&t.call(y),0):y.next)&&!(t=t.call(y,op[1])).done)return t;if(y=0,t)op=[op[0]&2,t.value];switch(op[0]){case 0:case 1:t=op;break;case 4:_.label++;return{value:op[1],done:false};case 5:_.label++;y=op[1];op=[0];continue;case 7:op=_.ops.pop();_.trys.pop();continue;default:if(!(t=_.trys,t=t.length>0&&t[t.length-1])&&(op[0]===6||op[0]===2)){_=0;continue}if(op[0]===3&&(!t||op[1]>t[0]&&op[1]<t[3])){_.label=op[1];break}if(op[0]===6&&_.label<t[1]){_.label=t[1];t=op;break}if(t&&_.label<t[2]){_.label=t[2];_.ops.push(op);break}if(t[2])_.ops.pop();_.trys.pop();continue}op=body.call(thisArg,_)}catch(e){op=[6,e];y=0}finally{f=t=0}if(op[0]&5)throw op[1];return{value:op[0]?op[1]:void 0,done:true}}}_dotenv.default.config();var migrator;function bootstrap(){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:if(!(_process.default.argv[2]!=="dev:serve"))return[3,2];return[4,_api.Sonamu.init(false,false)];case 1:_state.sent();_state.label=2;case 2:return[4,(0,_tsicli.tsicli)(_process.default.argv,{types:{"#entityId":{type:"autocomplete",name:"#entityId",message:"Please input #entityId",choices:_entitymanager.EntityManager.getAllParentIds().map(function(entityId){return{title:entityId,value:entityId}})},"#recordIds":"number[]","#name":"string"},args:[["fixture","init"],["fixture","import","#entityId","#recordIds"],["fixture","sync"],["migrate","run"],["migrate","check"],["migrate","rollback"],["migrate","reset"],["migrate","clear"],["migrate","status"],["stub","practice","#name"],["stub","entity","#name"],["scaffold","model","#entityId"],["scaffold","model_test","#entityId"],["scaffold","view_list","#entityId"],["scaffold","view_form","#entityId"],["ui"],["dev:serve"],["serve"]],runners:{migrate_run:migrate_run,migrate_check:migrate_check,migrate_rollback:migrate_rollback,migrate_clear:migrate_clear,migrate_reset:migrate_reset,migrate_status:migrate_status,fixture_init:fixture_init,fixture_import:fixture_import,fixture_sync:fixture_sync,stub_practice:stub_practice,stub_entity:stub_entity,scaffold_model:scaffold_model,scaffold_model_test:scaffold_model_test,ui:ui,"dev:serve":dev_serve,serve:serve}})];case 3:_state.sent();return[2]}})})()}bootstrap().finally(function(){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:if(!migrator)return[3,2];return[4,migrator.destroy()];case 1:_state.sent();_state.label=2;case 2:return[4,_fixturemanager.FixtureManager.destroy()];case 3:_state.sent();return[2]}})})()});function dev_serve(){return _async_to_generator(function(){var nodemon,nodemonConfig,cleanup;return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,Promise.resolve().then(function(){return /*#__PURE__*/_interop_require_wildcard(require("nodemon"))})];case 1:nodemon=_state.sent();return[4,function(){return _async_to_generator(function(){var projectNodemonPath,hasProjectNodemon,_;return _ts_generator(this,function(_state){switch(_state.label){case 0:projectNodemonPath=_path.default.join((0,_utils.findApiRootPath)(),"nodemon.json");return[4,(0,_fsutils.exists)(projectNodemonPath)];case 1:hasProjectNodemon=_state.sent();if(!hasProjectNodemon)return[3,3];_=JSON.parse;return[4,(0,_promises.readFile)(projectNodemonPath,"utf8")];case 2:return[2,_.apply(JSON,[_state.sent()])];case 3:return[2,{watch:["src/index.ts"],ignore:["dist/**","**/*.js","**/*.d.ts"],exec:["node --no-warnings -r source-map-support/register -r dotenv/config dist/index.js"].join(" && ")}]}})})()}()];case 2:nodemonConfig=_state.sent();nodemon.default(nodemonConfig);cleanup=function(){return _async_to_generator(function(){var _Sonamu_server;return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,(_Sonamu_server=_api.Sonamu.server)===null||_Sonamu_server===void 0?void 0:_Sonamu_server.close()];case 1:_state.sent();_process.default.exit(0);return[2]}})})()};_process.default.on("SIGINT",cleanup);_process.default.on("SIGTERM",cleanup);_process.default.on("SIGUSR2",cleanup);return[2]}})})()}function serve(){return _async_to_generator(function(){var distIndexPath,spawn,serverProcess;return _ts_generator(this,function(_state){switch(_state.label){case 0:distIndexPath=_path.default.join(_api.Sonamu.apiRootPath,"dist","index.js");return[4,(0,_fsutils.exists)(distIndexPath)];case 1:if(!_state.sent()){console.log(_chalk.default.red("dist/index.js not found. Please build your project first."));console.log(_chalk.default.blue("Run: yarn sonamu build"));return[2]}return[4,Promise.resolve().then(function(){return /*#__PURE__*/_interop_require_wildcard(require("child_process"))})];case 2:spawn=_state.sent().spawn;serverProcess=spawn("node",["-r","source-map-support/register","-r","dotenv/config",distIndexPath],{cwd:_api.Sonamu.apiRootPath,stdio:"inherit"});_process.default.on("SIGINT",function(){serverProcess.kill("SIGTERM");_process.default.exit(0)});return[2]}})})()}function setupMigrator(){return _async_to_generator(function(){return _ts_generator(this,function(_state){migrator=new _migrator.Migrator({mode:"dev"});return[2]})})()}function setupFixtureManager(){return _async_to_generator(function(){return _ts_generator(this,function(_state){_fixturemanager.FixtureManager.init();return[2]})})()}function migrate_run(){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,setupMigrator()];case 1:_state.sent();return[4,migrator.cleanUpDist()];case 2:_state.sent();return[4,migrator.run()];case 3:_state.sent();return[2]}})})()}function migrate_check(){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,setupMigrator()];case 1:_state.sent();return[4,migrator.cleanUpDist()];case 2:_state.sent();return[4,migrator.check()];case 3:_state.sent();return[2]}})})()}function migrate_status(){return _async_to_generator(function(){var status;return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,setupMigrator()];case 1:_state.sent();return[4,migrator.getStatus()];case 2:status=_state.sent();console.log(status);return[2]}})})()}function migrate_rollback(){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,setupMigrator()];case 1:_state.sent();return[4,migrator.rollback()];case 2:_state.sent();return[2]}})})()}function migrate_clear(){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,setupMigrator()];case 1:_state.sent();return[4,migrator.clearPendingList()];case 2:_state.sent();return[2]}})})()}function migrate_reset(){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,setupMigrator()];case 1:_state.sent();return[4,migrator.resetAll()];case 2:_state.sent();return[2]}})})()}function fixture_init(){return _async_to_generator(function(){var srcConfig,targets,dumpFilename,srcConn,migrationsDump,_db,_ref,_ref_,migrations,_iteratorAbruptCompletion,_didIteratorError,_iteratorError,_iterator,_step,_value,label,config,toSkip,conn,_config_connection,db,_ref1,_ref_1,row,mysqlCmd,err;return _ts_generator(this,function(_state){switch(_state.label){case 0:srcConfig=_api.Sonamu.dbConfig.development_master;targets=[{label:"(REMOTE) Fixture DB",config:_api.Sonamu.dbConfig.fixture_remote},{label:"(LOCAL) Fixture DB",config:_api.Sonamu.dbConfig.fixture_local,toSkip:function(){var remoteConn=_api.Sonamu.dbConfig.fixture_remote.connection;var localConn=_api.Sonamu.dbConfig.fixture_local.connection;return remoteConn.host===localConn.host&&remoteConn.database===localConn.database}()},{label:"(LOCAL) Testing DB",config:_api.Sonamu.dbConfig.test}];console.log("DUMP...");dumpFilename="/tmp/sonamu-fixture-init-".concat(Date.now(),".sql");srcConn=srcConfig.connection;migrationsDump="/tmp/sonamu-fixture-init-migrations-".concat(Date.now(),".sql");(0,_child_process.execSync)("mysqldump -h".concat(srcConn.host," -u").concat(srcConn.user," -p").concat(srcConn.password," --single-transaction -d --no-create-db --triggers ").concat(srcConn.database," > ").concat(dumpFilename));_db=(0,_knex.default)(srcConfig);return[4,_db.raw("SELECT COUNT(*) as count FROM information_schema.tables WHERE table_schema = ? AND table_name = 'knex_migrations'",[srcConn.database])];case 1:_ref=_sliced_to_array.apply(void 0,[_state.sent(),1]),_ref_=_sliced_to_array(_ref[0],1),migrations=_ref_[0];if(migrations.count>0){(0,_child_process.execSync)("mysqldump -h".concat(srcConn.host," -u").concat(srcConn.user," -p").concat(srcConn.password," --single-transaction --no-create-db --triggers ").concat(srcConn.database," knex_migrations knex_migrations_lock > ").concat(migrationsDump))}_iteratorAbruptCompletion=false,_didIteratorError=false;_state.label=2;case 2:_state.trys.push([2,12,13,18]);_iterator=_async_iterator(targets);_state.label=3;case 3:return[4,_iterator.next()];case 4:if(!(_iteratorAbruptCompletion=!(_step=_state.sent()).done))return[3,11];_value=_step.value;label=_value.label,config=_value.config,toSkip=_value.toSkip;conn=config.connection;if(toSkip===true){console.log(_chalk.default.red("".concat(label,": Skipped!")));return[3,10]}db=(0,_knex.default)(_object_spread_props(_object_spread({},config),{connection:_object_spread_props(_object_spread({},(_config_connection=config.connection)!==null&&_config_connection!==void 0?_config_connection:{}),{database:undefined})}));return[4,db.raw('SHOW DATABASES LIKE "'.concat(conn.database,'"'))];case 5:_ref1=_sliced_to_array.apply(void 0,[_state.sent(),1]),_ref_1=_sliced_to_array(_ref1[0],1),row=_ref_1[0];if(!row)return[3,7];console.log(_chalk.default.yellow("".concat(label,': Database "').concat(conn.database,'" Already exists')));return[4,db.destroy()];case 6:_state.sent();return[3,10];case 7:console.log("SYNC to ".concat(label,"..."));mysqlCmd="mysql -h".concat(conn.host," -u").concat(conn.user," -p").concat(conn.password);(0,_child_process.execSync)("".concat(mysqlCmd," -e 'DROP DATABASE IF EXISTS `").concat(conn.database,"`'"));(0,_child_process.execSync)("".concat(mysqlCmd," -e 'CREATE DATABASE `").concat(conn.database,"`'"));(0,_child_process.execSync)("".concat(mysqlCmd," ").concat(conn.database," < ").concat(dumpFilename));return[4,(0,_fsutils.exists)(migrationsDump)];case 8:if(_state.sent()){(0,_child_process.execSync)("".concat(mysqlCmd," ").concat(conn.database," < ").concat(migrationsDump))}return[4,db.destroy()];case 9:_state.sent();_state.label=10;case 10:_iteratorAbruptCompletion=false;return[3,3];case 11:return[3,18];case 12:err=_state.sent();_didIteratorError=true;_iteratorError=err;return[3,18];case 13:_state.trys.push([13,,16,17]);if(!(_iteratorAbruptCompletion&&_iterator.return!=null))return[3,15];return[4,_iterator.return()];case 14:_state.sent();_state.label=15;case 15:return[3,17];case 16:if(_didIteratorError){throw _iteratorError}return[7];case 17:return[7];case 18:return[4,_db.destroy()];case 19:_state.sent();return[2]}})})()}function fixture_import(entityId,recordIds){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,setupFixtureManager()];case 1:_state.sent();return[4,_fixturemanager.FixtureManager.importFixture(entityId,recordIds)];case 2:_state.sent();return[4,_fixturemanager.FixtureManager.sync()];case 3:_state.sent();return[2]}})})()}function fixture_sync(){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,setupFixtureManager()];case 1:_state.sent();return[4,_fixturemanager.FixtureManager.sync()];case 2:_state.sent();return[2]}})})()}function stub_practice(name){return _async_to_generator(function(){var practiceDir,fileNames,maxSeqNo,currentSeqNo,fileName,dstPath,code,runCode;return _ts_generator(this,function(_state){switch(_state.label){case 0:practiceDir=_path.default.join(_api.Sonamu.apiRootPath,"src","practices");return[4,(0,_promises.readdir)(practiceDir)];case 1:fileNames=_state.sent();return[4,function(){return _async_to_generator(function(){var filteredSeqs;return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,(0,_fsutils.exists)(practiceDir)];case 1:if(!!_state.sent())return[3,3];return[4,(0,_promises.mkdir)(practiceDir,{recursive:true})];case 2:_state.sent();_state.label=3;case 3:filteredSeqs=fileNames.filter(function(fileName){return fileName.startsWith("p")&&fileName.endsWith(".ts")}).map(function(fileName){var _fileName_match;var _ref=_sliced_to_array((_fileName_match=fileName.match(/^p([0-9]+)\-/))!==null&&_fileName_match!==void 0?_fileName_match:["0","0"],2),seqNo=_ref[1];return parseInt(seqNo)}).sort(function(a,b){return b-a});if(filteredSeqs.length>0){return[2,filteredSeqs[0]]}return[2,0]}})})()}()];case 2:maxSeqNo=_state.sent();currentSeqNo=maxSeqNo+1;fileName="p".concat(currentSeqNo,"-").concat(name,".ts");dstPath=_path.default.join(practiceDir,fileName);code=['import { Sonamu } from "sonamu";',"","console.clear();",'console.log("'.concat(fileName,'");'),"","Sonamu.runScript(async () => {"," // TODO","});",""].join("\n");return[4,(0,_promises.writeFile)(dstPath,code)];case 3:_state.sent();(0,_child_process.execSync)("code ".concat(dstPath));runCode="yarn node -r dotenv/config -r source-map-support/register dist/practices/".concat(fileName.replace(".ts",".js"));console.log("".concat(_chalk.default.blue(runCode)," copied to clipboard."));(0,_child_process.execSync)('echo "'.concat(runCode,'" | pbcopy'));return[2]}})})()}function stub_entity(entityId){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,_api.Sonamu.syncer.createEntity({entityId:entityId})];case 1:_state.sent();return[2]}})})()}function scaffold_model(entityId){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,_api.Sonamu.syncer.generateTemplate("model",{entityId:entityId})];case 1:_state.sent();return[2]}})})()}function scaffold_model_test(entityId){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,_api.Sonamu.syncer.generateTemplate("model_test",{entityId:entityId})];case 1:_state.sent();return[2]}})})()}function ui(){return _async_to_generator(function(){var _Sonamu_config_ui,sonamuUI,_Sonamu_config_projectName,_Sonamu_config_ui_port,e;return _ts_generator(this,function(_state){switch(_state.label){case 0:_state.trys.push([0,2,,3]);return[4,Promise.resolve().then(function(){return /*#__PURE__*/_interop_require_wildcard(require("@sonamu-kit/ui"))})];case 1:sonamuUI=_state.sent();sonamuUI.startServers({projectName:(_Sonamu_config_projectName=_api.Sonamu.config.projectName)!==null&&_Sonamu_config_projectName!==void 0?_Sonamu_config_projectName:_path.default.basename(_api.Sonamu.apiRootPath),apiRootPath:_api.Sonamu.apiRootPath,port:(_Sonamu_config_ui_port=(_Sonamu_config_ui=_api.Sonamu.config.ui)===null||_Sonamu_config_ui===void 0?void 0:_Sonamu_config_ui.port)!==null&&_Sonamu_config_ui_port!==void 0?_Sonamu_config_ui_port:57e3});return[3,3];case 2:e=_state.sent();if(_instanceof(e,Error)&&e.message.includes("isn't declared")){console.log("You need to install ".concat(_chalk.default.blue("@sonamu-kit/ui")," first."));return[2]}throw e;case 3:return[2]}})})()}
2
- //# sourceMappingURL=cli.js.map
1
+ import chalk from "chalk";
2
+ import dotenv from "dotenv";
3
+ dotenv.config();
4
+ import path from "path";
5
+ import { fileURLToPath } from "url";
6
+ import { tsicli } from "tsicli";
7
+ import { execSync, spawn } from "child_process";
8
+ import { mkdir, readdir, writeFile } from "node:fs/promises";
9
+ import { exists } from "../utils/fs-utils.js";
10
+ import process from "process";
11
+ import { Sonamu } from "../api/index.js";
12
+ import knex from "knex";
13
+ import { EntityManager } from "../entity/entity-manager.js";
14
+ import { Migrator } from "../migration/migrator.js";
15
+ import { FixtureManager } from "../testing/fixture-manager.js";
16
+ import { findApiRootPath } from "../utils/utils.js";
17
+ let migrator;
18
+ async function bootstrap() {
19
+ // dev 명령어가 아닌 경우에만 Sonamu 초기화
20
+ if (process.argv[2] !== "dev") {
21
+ await Sonamu.init(false, false);
22
+ }
23
+ await tsicli(process.argv, {
24
+ types: {
25
+ "#entityId": {
26
+ type: "autocomplete",
27
+ name: "#entityId",
28
+ message: "Please input #entityId",
29
+ choices: EntityManager.getAllParentIds().map((entityId)=>({
30
+ title: entityId,
31
+ value: entityId
32
+ }))
33
+ },
34
+ "#recordIds": "number[]",
35
+ "#name": "string"
36
+ },
37
+ args: [
38
+ [
39
+ "fixture",
40
+ "init"
41
+ ],
42
+ [
43
+ "fixture",
44
+ "import",
45
+ "#entityId",
46
+ "#recordIds"
47
+ ],
48
+ [
49
+ "fixture",
50
+ "sync"
51
+ ],
52
+ [
53
+ "migrate",
54
+ "run"
55
+ ],
56
+ [
57
+ "migrate",
58
+ "check"
59
+ ],
60
+ [
61
+ "migrate",
62
+ "rollback"
63
+ ],
64
+ [
65
+ "migrate",
66
+ "reset"
67
+ ],
68
+ [
69
+ "migrate",
70
+ "clear"
71
+ ],
72
+ [
73
+ "migrate",
74
+ "status"
75
+ ],
76
+ [
77
+ "stub",
78
+ "practice",
79
+ "#name"
80
+ ],
81
+ [
82
+ "stub",
83
+ "entity",
84
+ "#name"
85
+ ],
86
+ [
87
+ "scaffold",
88
+ "model",
89
+ "#entityId"
90
+ ],
91
+ [
92
+ "scaffold",
93
+ "model_test",
94
+ "#entityId"
95
+ ],
96
+ [
97
+ "scaffold",
98
+ "view_list",
99
+ "#entityId"
100
+ ],
101
+ [
102
+ "scaffold",
103
+ "view_form",
104
+ "#entityId"
105
+ ],
106
+ [
107
+ "ui"
108
+ ],
109
+ [
110
+ "dev"
111
+ ],
112
+ [
113
+ "start"
114
+ ]
115
+ ],
116
+ runners: {
117
+ migrate_run,
118
+ migrate_check,
119
+ migrate_rollback,
120
+ migrate_clear,
121
+ migrate_reset,
122
+ migrate_status,
123
+ fixture_init,
124
+ fixture_import,
125
+ fixture_sync,
126
+ stub_practice,
127
+ stub_entity,
128
+ scaffold_model,
129
+ scaffold_model_test,
130
+ ui,
131
+ // scaffold_view_list,
132
+ // scaffold_view_form,
133
+ dev,
134
+ start
135
+ }
136
+ });
137
+ }
138
+ bootstrap().finally(async ()=>{
139
+ if (migrator) {
140
+ await migrator.destroy();
141
+ }
142
+ await FixtureManager.destroy();
143
+ });
144
+ async function dev() {
145
+ const apiRoot = findApiRootPath();
146
+ const entryPoint = 'src/index.ts';
147
+ console.log(chalk.yellow.bold('🚀 Starting Sonamu dev server...\n'));
148
+ const serverProcess = spawn("hot-runner", [
149
+ "--clear-screen=false",
150
+ "--node-args=--import=@sonamu-kit/loader",
151
+ "--node-args=--import=sonamu/hot-hook-register",
152
+ "--node-args=--enable-source-maps",
153
+ entryPoint
154
+ ], {
155
+ cwd: apiRoot,
156
+ stdio: "inherit",
157
+ env: {
158
+ ...process.env,
159
+ NODE_ENV: "development",
160
+ HOT: "yes",
161
+ API_ROOT_PATH: apiRoot
162
+ }
163
+ });
164
+ // 종료 처리
165
+ const cleanup = ()=>{
166
+ console.log(chalk.yellow('\n\n👋 Shutting down...'));
167
+ serverProcess.kill('SIGTERM');
168
+ process.exit(0);
169
+ };
170
+ process.on('SIGINT', cleanup);
171
+ process.on('SIGTERM', cleanup);
172
+ serverProcess.on('exit', (code)=>{
173
+ if (code !== 0) {
174
+ console.error(chalk.red(`❌ Server exited with code ${code}`));
175
+ process.exit(code || 1);
176
+ }
177
+ });
178
+ }
179
+ async function start() {
180
+ const entryPoint = 'dist/index.js';
181
+ if (!await exists(entryPoint)) {
182
+ console.log(chalk.red(`${entryPoint} not found. Please build your project first.`));
183
+ console.log(chalk.blue("Run: yarn sonamu build"));
184
+ return;
185
+ }
186
+ const { spawn } = await import("child_process");
187
+ const serverProcess = spawn("node", [
188
+ "--enable-source-maps",
189
+ "-r",
190
+ "dotenv/config",
191
+ entryPoint
192
+ ], {
193
+ cwd: Sonamu.apiRootPath,
194
+ stdio: "inherit"
195
+ });
196
+ process.on("SIGINT", ()=>{
197
+ serverProcess.kill("SIGTERM");
198
+ process.exit(0);
199
+ });
200
+ }
201
+ async function setupMigrator() {
202
+ // migrator
203
+ migrator = new Migrator({
204
+ mode: "dev"
205
+ });
206
+ }
207
+ async function setupFixtureManager() {
208
+ FixtureManager.init();
209
+ }
210
+ async function migrate_run() {
211
+ await setupMigrator();
212
+ await migrator.run();
213
+ }
214
+ async function migrate_check() {
215
+ await setupMigrator();
216
+ await migrator.check();
217
+ }
218
+ async function migrate_status() {
219
+ await setupMigrator();
220
+ const status = await migrator.getStatus();
221
+ // status;
222
+ console.log(status);
223
+ }
224
+ async function migrate_rollback() {
225
+ await setupMigrator();
226
+ await migrator.rollback();
227
+ }
228
+ async function migrate_clear() {
229
+ await setupMigrator();
230
+ await migrator.clearPendingList();
231
+ }
232
+ async function migrate_reset() {
233
+ await setupMigrator();
234
+ await migrator.resetAll();
235
+ }
236
+ async function fixture_init() {
237
+ const srcConfig = Sonamu.dbConfig.development_master;
238
+ const targets = [
239
+ {
240
+ label: "(REMOTE) Fixture DB",
241
+ config: Sonamu.dbConfig.fixture_remote
242
+ },
243
+ {
244
+ label: "(LOCAL) Fixture DB",
245
+ config: Sonamu.dbConfig.fixture_local,
246
+ toSkip: (()=>{
247
+ const remoteConn = Sonamu.dbConfig.fixture_remote.connection;
248
+ const localConn = Sonamu.dbConfig.fixture_local.connection;
249
+ return remoteConn.host === localConn.host && remoteConn.database === localConn.database;
250
+ })()
251
+ },
252
+ {
253
+ label: "(LOCAL) Testing DB",
254
+ config: Sonamu.dbConfig.test
255
+ }
256
+ ];
257
+ // 1. 기준DB 스키마를 덤프
258
+ console.log("DUMP...");
259
+ const dumpFilename = `/tmp/sonamu-fixture-init-${Date.now()}.sql`;
260
+ const srcConn = srcConfig.connection;
261
+ const migrationsDump = `/tmp/sonamu-fixture-init-migrations-${Date.now()}.sql`;
262
+ execSync(`mysqldump -h${srcConn.host} -u${srcConn.user} -p${srcConn.password} --single-transaction -d --no-create-db --triggers ${srcConn.database} > ${dumpFilename}`);
263
+ const _db = knex(srcConfig);
264
+ const [[migrations]] = await _db.raw("SELECT COUNT(*) as count FROM information_schema.tables WHERE table_schema = ? AND table_name = 'knex_migrations'", [
265
+ srcConn.database
266
+ ]);
267
+ if (migrations.count > 0) {
268
+ execSync(`mysqldump -h${srcConn.host} -u${srcConn.user} -p${srcConn.password} --single-transaction --no-create-db --triggers ${srcConn.database} knex_migrations knex_migrations_lock > ${migrationsDump}`);
269
+ }
270
+ // 2. 대상DB 각각에 대하여 존재여부 확인 후 붓기
271
+ for await (const { label, config, toSkip } of targets){
272
+ const conn = config.connection;
273
+ if (toSkip === true) {
274
+ console.log(chalk.red(`${label}: Skipped!`));
275
+ continue;
276
+ }
277
+ const db = knex({
278
+ ...config,
279
+ connection: {
280
+ ...config.connection ?? {},
281
+ database: undefined
282
+ }
283
+ });
284
+ const [[row]] = await db.raw(`SHOW DATABASES LIKE "${conn.database}"`);
285
+ if (row) {
286
+ console.log(chalk.yellow(`${label}: Database "${conn.database}" Already exists`));
287
+ await db.destroy();
288
+ continue;
289
+ }
290
+ console.log(`SYNC to ${label}...`);
291
+ const mysqlCmd = `mysql -h${conn.host} -u${conn.user} -p${conn.password}`;
292
+ execSync(`${mysqlCmd} -e 'DROP DATABASE IF EXISTS \`${conn.database}\`'`);
293
+ execSync(`${mysqlCmd} -e 'CREATE DATABASE \`${conn.database}\`'`);
294
+ execSync(`${mysqlCmd} ${conn.database} < ${dumpFilename}`);
295
+ if (await exists(migrationsDump)) {
296
+ execSync(`${mysqlCmd} ${conn.database} < ${migrationsDump}`);
297
+ }
298
+ await db.destroy();
299
+ }
300
+ await _db.destroy();
301
+ }
302
+ async function fixture_import(entityId, recordIds) {
303
+ await setupFixtureManager();
304
+ await FixtureManager.importFixture(entityId, recordIds);
305
+ await FixtureManager.sync();
306
+ }
307
+ async function fixture_sync() {
308
+ await setupFixtureManager();
309
+ await FixtureManager.sync();
310
+ }
311
+ async function stub_practice(name) {
312
+ const practiceDir = path.join(Sonamu.apiRootPath, "src", "practices");
313
+ const fileNames = await readdir(practiceDir);
314
+ const maxSeqNo = await (async ()=>{
315
+ if (!await exists(practiceDir)) {
316
+ await mkdir(practiceDir, {
317
+ recursive: true
318
+ });
319
+ }
320
+ const filteredSeqs = fileNames.filter((fileName)=>fileName.startsWith("p") && fileName.endsWith(".ts")).map((fileName)=>{
321
+ const [, seqNo] = fileName.match(/^p([0-9]+)\-/) ?? [
322
+ "0",
323
+ "0"
324
+ ];
325
+ return parseInt(seqNo);
326
+ }).sort((a, b)=>b - a);
327
+ if (filteredSeqs.length > 0) {
328
+ return filteredSeqs[0];
329
+ }
330
+ return 0;
331
+ })();
332
+ const currentSeqNo = maxSeqNo + 1;
333
+ const fileName = `p${currentSeqNo}-${name}.ts`;
334
+ const dstPath = path.join(practiceDir, fileName);
335
+ const code = [
336
+ `import { Sonamu } from "sonamu";`,
337
+ "",
338
+ `console.clear();`,
339
+ `console.log("${fileName}");`,
340
+ "",
341
+ `Sonamu.runScript(async () => {`,
342
+ ` // TODO`,
343
+ `});`,
344
+ ""
345
+ ].join("\n");
346
+ await writeFile(dstPath, code);
347
+ execSync(`code ${dstPath}`);
348
+ const runCode = `yarn node -r dotenv/config --enable-source-maps dist/practices/${fileName.replace(".ts", ".js")}`;
349
+ console.log(`${chalk.blue(runCode)} copied to clipboard.`);
350
+ execSync(`echo "${runCode}" | pbcopy`);
351
+ }
352
+ async function stub_entity(entityId) {
353
+ await Sonamu.syncer.createEntity({
354
+ entityId
355
+ });
356
+ }
357
+ async function scaffold_model(entityId) {
358
+ await Sonamu.syncer.generateTemplate("model", {
359
+ entityId
360
+ });
361
+ }
362
+ async function scaffold_model_test(entityId) {
363
+ await Sonamu.syncer.generateTemplate("model_test", {
364
+ entityId
365
+ });
366
+ }
367
+ async function ui() {
368
+ try {
369
+ // @sonamu-kit/ui의 run-ui.ts 스크립트 경로 찾기
370
+ const uiModulePath = await import.meta.resolve("@sonamu-kit/ui");
371
+ const uiNodePath = path.join(path.dirname(fileURLToPath(uiModulePath)), "run-ui.js");
372
+ if (!await exists(uiNodePath)) {
373
+ console.log(chalk.red(`UI runner script not found at ${uiNodePath}. Please rebuild @sonamu-kit/ui.`));
374
+ return;
375
+ }
376
+ // UI를 별도 프로세스로 실행 (hot-hook 활성화)
377
+ const uiProcess = spawn(process.execPath, [
378
+ "--import",
379
+ "@sonamu-kit/loader",
380
+ "--import",
381
+ "sonamu/hot-hook-register",
382
+ "--enable-source-maps",
383
+ "--no-warnings",
384
+ uiNodePath
385
+ ], {
386
+ stdio: "inherit",
387
+ env: {
388
+ ...process.env,
389
+ HOT: "yes",
390
+ PROJECT_NAME: Sonamu.config.projectName ?? path.basename(Sonamu.apiRootPath),
391
+ API_ROOT_PATH: Sonamu.apiRootPath,
392
+ UI_PORT: (Sonamu.config.ui?.port ?? 57000).toString()
393
+ }
394
+ });
395
+ // 종료 처리
396
+ const cleanup = ()=>{
397
+ console.log(chalk.yellow("\n\n👋 Shutting down UI server..."));
398
+ uiProcess.kill("SIGTERM");
399
+ process.exit(0);
400
+ };
401
+ process.on("SIGINT", cleanup);
402
+ process.on("SIGTERM", cleanup);
403
+ uiProcess.on("exit", (code)=>{
404
+ if (code !== 0) {
405
+ console.error(chalk.red(`❌ UI server exited with code ${code}`));
406
+ process.exit(code || 1);
407
+ }
408
+ });
409
+ } catch (e) {
410
+ if (e instanceof Error && e.message.includes("isn't declared")) {
411
+ console.log(`You need to install ${chalk.blue(`@sonamu-kit/ui`)} first.`);
412
+ return;
413
+ }
414
+ throw e;
415
+ }
416
+ }
417
+
418
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9iaW4vY2xpLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjaGFsayBmcm9tIFwiY2hhbGtcIjtcbmltcG9ydCBkb3RlbnYgZnJvbSBcImRvdGVudlwiO1xuZG90ZW52LmNvbmZpZygpO1xuXG5pbXBvcnQgcGF0aCBmcm9tIFwicGF0aFwiO1xuaW1wb3J0IHsgZmlsZVVSTFRvUGF0aCB9IGZyb20gXCJ1cmxcIjtcbmltcG9ydCB7IHRzaWNsaSB9IGZyb20gXCJ0c2ljbGlcIjtcbmltcG9ydCB7IGV4ZWNTeW5jLCBzcGF3biB9IGZyb20gXCJjaGlsZF9wcm9jZXNzXCI7XG5pbXBvcnQgeyBta2RpciwgcmVhZGRpciwgd3JpdGVGaWxlIH0gZnJvbSBcImZzL3Byb21pc2VzXCI7XG5pbXBvcnQgeyBleGlzdHMgfSBmcm9tIFwiLi4vdXRpbHMvZnMtdXRpbHNcIjtcbmltcG9ydCBwcm9jZXNzIGZyb20gXCJwcm9jZXNzXCI7XG5pbXBvcnQgeyBTb25hbXUgfSBmcm9tIFwiLi4vYXBpXCI7XG5pbXBvcnQga25leCwgeyBLbmV4IH0gZnJvbSBcImtuZXhcIjtcbmltcG9ydCB7IEVudGl0eU1hbmFnZXIgfSBmcm9tIFwiLi4vZW50aXR5L2VudGl0eS1tYW5hZ2VyXCI7XG5pbXBvcnQgeyBNaWdyYXRvciB9IGZyb20gXCIuLi9taWdyYXRpb24vbWlncmF0b3JcIjtcbmltcG9ydCB7IEZpeHR1cmVNYW5hZ2VyIH0gZnJvbSBcIi4uL3Rlc3RpbmcvZml4dHVyZS1tYW5hZ2VyXCI7XG5pbXBvcnQgeyBmaW5kQXBpUm9vdFBhdGggfSBmcm9tIFwiLi4vdXRpbHMvdXRpbHNcIjtcblxubGV0IG1pZ3JhdG9yOiBNaWdyYXRvcjtcblxuYXN5bmMgZnVuY3Rpb24gYm9vdHN0cmFwKCkge1xuICAvLyBkZXYg66qF66C57Ja06rCAIOyVhOuLjCDqsr3smrDsl5Drp4wgU29uYW11IOy0iOq4sO2ZlFxuICBpZiAocHJvY2Vzcy5hcmd2WzJdICE9PSBcImRldlwiKSB7XG4gICAgYXdhaXQgU29uYW11LmluaXQoZmFsc2UsIGZhbHNlKTtcbiAgfVxuXG4gIGF3YWl0IHRzaWNsaShwcm9jZXNzLmFyZ3YsIHtcbiAgICB0eXBlczoge1xuICAgICAgXCIjZW50aXR5SWRcIjoge1xuICAgICAgICB0eXBlOiBcImF1dG9jb21wbGV0ZVwiLFxuICAgICAgICBuYW1lOiBcIiNlbnRpdHlJZFwiLFxuICAgICAgICBtZXNzYWdlOiBcIlBsZWFzZSBpbnB1dCAjZW50aXR5SWRcIixcbiAgICAgICAgY2hvaWNlczogRW50aXR5TWFuYWdlci5nZXRBbGxQYXJlbnRJZHMoKS5tYXAoKGVudGl0eUlkKSA9PiAoe1xuICAgICAgICAgIHRpdGxlOiBlbnRpdHlJZCxcbiAgICAgICAgICB2YWx1ZTogZW50aXR5SWQsXG4gICAgICAgIH0pKSxcbiAgICAgIH0sXG4gICAgICBcIiNyZWNvcmRJZHNcIjogXCJudW1iZXJbXVwiLFxuICAgICAgXCIjbmFtZVwiOiBcInN0cmluZ1wiLFxuICAgIH0sXG4gICAgYXJnczogW1xuICAgICAgW1wiZml4dHVyZVwiLCBcImluaXRcIl0sXG4gICAgICBbXCJmaXh0dXJlXCIsIFwiaW1wb3J0XCIsIFwiI2VudGl0eUlkXCIsIFwiI3JlY29yZElkc1wiXSxcbiAgICAgIFtcImZpeHR1cmVcIiwgXCJzeW5jXCJdLFxuICAgICAgW1wibWlncmF0ZVwiLCBcInJ1blwiXSxcbiAgICAgIFtcIm1pZ3JhdGVcIiwgXCJjaGVja1wiXSxcbiAgICAgIFtcIm1pZ3JhdGVcIiwgXCJyb2xsYmFja1wiXSxcbiAgICAgIFtcIm1pZ3JhdGVcIiwgXCJyZXNldFwiXSxcbiAgICAgIFtcIm1pZ3JhdGVcIiwgXCJjbGVhclwiXSxcbiAgICAgIFtcIm1pZ3JhdGVcIiwgXCJzdGF0dXNcIl0sXG4gICAgICBbXCJzdHViXCIsIFwicHJhY3RpY2VcIiwgXCIjbmFtZVwiXSxcbiAgICAgIFtcInN0dWJcIiwgXCJlbnRpdHlcIiwgXCIjbmFtZVwiXSxcbiAgICAgIFtcInNjYWZmb2xkXCIsIFwibW9kZWxcIiwgXCIjZW50aXR5SWRcIl0sXG4gICAgICBbXCJzY2FmZm9sZFwiLCBcIm1vZGVsX3Rlc3RcIiwgXCIjZW50aXR5SWRcIl0sXG4gICAgICBbXCJzY2FmZm9sZFwiLCBcInZpZXdfbGlzdFwiLCBcIiNlbnRpdHlJZFwiXSxcbiAgICAgIFtcInNjYWZmb2xkXCIsIFwidmlld19mb3JtXCIsIFwiI2VudGl0eUlkXCJdLFxuICAgICAgW1widWlcIl0sXG4gICAgICBbXCJkZXZcIl0sXG4gICAgICBbXCJzdGFydFwiXSxcbiAgICBdLFxuICAgIHJ1bm5lcnM6IHtcbiAgICAgIG1pZ3JhdGVfcnVuLFxuICAgICAgbWlncmF0ZV9jaGVjayxcbiAgICAgIG1pZ3JhdGVfcm9sbGJhY2ssXG4gICAgICBtaWdyYXRlX2NsZWFyLFxuICAgICAgbWlncmF0ZV9yZXNldCxcbiAgICAgIG1pZ3JhdGVfc3RhdHVzLFxuICAgICAgZml4dHVyZV9pbml0LFxuICAgICAgZml4dHVyZV9pbXBvcnQsXG4gICAgICBmaXh0dXJlX3N5bmMsXG4gICAgICBzdHViX3ByYWN0aWNlLFxuICAgICAgc3R1Yl9lbnRpdHksXG4gICAgICBzY2FmZm9sZF9tb2RlbCxcbiAgICAgIHNjYWZmb2xkX21vZGVsX3Rlc3QsXG4gICAgICB1aSxcbiAgICAgIC8vIHNjYWZmb2xkX3ZpZXdfbGlzdCxcbiAgICAgIC8vIHNjYWZmb2xkX3ZpZXdfZm9ybSxcbiAgICAgIGRldixcbiAgICAgIHN0YXJ0LFxuICAgIH0sXG4gIH0pO1xufVxuYm9vdHN0cmFwKCkuZmluYWxseShhc3luYyAoKSA9PiB7XG4gIGlmIChtaWdyYXRvcikge1xuICAgIGF3YWl0IG1pZ3JhdG9yLmRlc3Ryb3koKTtcbiAgfVxuICBhd2FpdCBGaXh0dXJlTWFuYWdlci5kZXN0cm95KCk7XG59KTtcblxuYXN5bmMgZnVuY3Rpb24gZGV2KCkge1xuICBjb25zdCBhcGlSb290ID0gZmluZEFwaVJvb3RQYXRoKCk7XG4gIGNvbnN0IGVudHJ5UG9pbnQgPSAnc3JjL2luZGV4LnRzJzsgICBcblxuICBjb25zb2xlLmxvZyhjaGFsay55ZWxsb3cuYm9sZCgn8J+agCBTdGFydGluZyBTb25hbXUgZGV2IHNlcnZlci4uLlxcbicpKTtcblxuICBjb25zdCBzZXJ2ZXJQcm9jZXNzID0gc3Bhd24oXG4gICAgXCJob3QtcnVubmVyXCIsXG4gICAgW1xuICAgICAgXCItLWNsZWFyLXNjcmVlbj1mYWxzZVwiLFxuICAgICAgXCItLW5vZGUtYXJncz0tLWltcG9ydD1Ac29uYW11LWtpdC9sb2FkZXJcIixcbiAgICAgIFwiLS1ub2RlLWFyZ3M9LS1pbXBvcnQ9c29uYW11L2hvdC1ob29rLXJlZ2lzdGVyXCIsXG4gICAgICBcIi0tbm9kZS1hcmdzPS0tZW5hYmxlLXNvdXJjZS1tYXBzXCIsXG4gICAgICBlbnRyeVBvaW50LFxuICAgIF0sXG4gICAge1xuICAgICAgY3dkOiBhcGlSb290LFxuICAgICAgc3RkaW86IFwiaW5oZXJpdFwiLFxuICAgICAgZW52OiB7XG4gICAgICAgIC4uLnByb2Nlc3MuZW52LFxuICAgICAgICBOT0RFX0VOVjogXCJkZXZlbG9wbWVudFwiLFxuICAgICAgICBIT1Q6IFwieWVzXCIsXG4gICAgICAgIEFQSV9ST09UX1BBVEg6IGFwaVJvb3QsXG4gICAgICB9LFxuICAgIH1cbiAgKTtcblxuICAvLyDsooXro4wg7LKY66asXG4gIGNvbnN0IGNsZWFudXAgPSAoKSA9PiB7XG4gICAgY29uc29sZS5sb2coY2hhbGsueWVsbG93KCdcXG5cXG7wn5GLIFNodXR0aW5nIGRvd24uLi4nKSk7XG4gICAgc2VydmVyUHJvY2Vzcy5raWxsKCdTSUdURVJNJyk7XG4gICAgcHJvY2Vzcy5leGl0KDApO1xuICB9O1xuXG4gIHByb2Nlc3Mub24oJ1NJR0lOVCcsIGNsZWFudXApO1xuICBwcm9jZXNzLm9uKCdTSUdURVJNJywgY2xlYW51cCk7XG5cbiAgc2VydmVyUHJvY2Vzcy5vbignZXhpdCcsIChjb2RlKSA9PiB7XG4gICAgaWYgKGNvZGUgIT09IDApIHtcbiAgICAgIGNvbnNvbGUuZXJyb3IoY2hhbGsucmVkKGDinYwgU2VydmVyIGV4aXRlZCB3aXRoIGNvZGUgJHtjb2RlfWApKTtcbiAgICAgIHByb2Nlc3MuZXhpdChjb2RlIHx8IDEpO1xuICAgIH1cbiAgfSk7XG59XG5cbmFzeW5jIGZ1bmN0aW9uIHN0YXJ0KCkge1xuICBjb25zdCBlbnRyeVBvaW50ID0gJ2Rpc3QvaW5kZXguanMnOyAgXG5cbiAgaWYgKCEoYXdhaXQgZXhpc3RzKGVudHJ5UG9pbnQpKSkge1xuICAgIGNvbnNvbGUubG9nKFxuICAgICAgY2hhbGsucmVkKGAke2VudHJ5UG9pbnR9IG5vdCBmb3VuZC4gUGxlYXNlIGJ1aWxkIHlvdXIgcHJvamVjdCBmaXJzdC5gKVxuICAgICk7XG4gICAgY29uc29sZS5sb2coY2hhbGsuYmx1ZShcIlJ1bjogeWFybiBzb25hbXUgYnVpbGRcIikpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IHsgc3Bhd24gfSA9IGF3YWl0IGltcG9ydChcImNoaWxkX3Byb2Nlc3NcIik7XG4gIGNvbnN0IHNlcnZlclByb2Nlc3MgPSBzcGF3bihcbiAgICBcIm5vZGVcIixcbiAgICBbXCItLWVuYWJsZS1zb3VyY2UtbWFwc1wiLCBcIi1yXCIsIFwiZG90ZW52L2NvbmZpZ1wiLCBlbnRyeVBvaW50XSxcbiAgICB7XG4gICAgICBjd2Q6IFNvbmFtdS5hcGlSb290UGF0aCxcbiAgICAgIHN0ZGlvOiBcImluaGVyaXRcIixcbiAgICB9XG4gICk7XG5cbiAgcHJvY2Vzcy5vbihcIlNJR0lOVFwiLCAoKSA9PiB7XG4gICAgc2VydmVyUHJvY2Vzcy5raWxsKFwiU0lHVEVSTVwiKTtcbiAgICBwcm9jZXNzLmV4aXQoMCk7XG4gIH0pO1xufVxuXG5hc3luYyBmdW5jdGlvbiBzZXR1cE1pZ3JhdG9yKCkge1xuICAvLyBtaWdyYXRvclxuICBtaWdyYXRvciA9IG5ldyBNaWdyYXRvcih7XG4gICAgbW9kZTogXCJkZXZcIixcbiAgfSk7XG59XG5cbmFzeW5jIGZ1bmN0aW9uIHNldHVwRml4dHVyZU1hbmFnZXIoKSB7XG4gIEZpeHR1cmVNYW5hZ2VyLmluaXQoKTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gbWlncmF0ZV9ydW4oKSB7XG4gIGF3YWl0IHNldHVwTWlncmF0b3IoKTtcblxuICBhd2FpdCBtaWdyYXRvci5ydW4oKTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gbWlncmF0ZV9jaGVjaygpIHtcbiAgYXdhaXQgc2V0dXBNaWdyYXRvcigpO1xuXG4gIGF3YWl0IG1pZ3JhdG9yLmNoZWNrKCk7XG59XG5cbmFzeW5jIGZ1bmN0aW9uIG1pZ3JhdGVfc3RhdHVzKCkge1xuICBhd2FpdCBzZXR1cE1pZ3JhdG9yKCk7XG5cbiAgY29uc3Qgc3RhdHVzID0gYXdhaXQgbWlncmF0b3IuZ2V0U3RhdHVzKCk7XG4gIC8vIHN0YXR1cztcbiAgY29uc29sZS5sb2coc3RhdHVzKTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gbWlncmF0ZV9yb2xsYmFjaygpIHtcbiAgYXdhaXQgc2V0dXBNaWdyYXRvcigpO1xuXG4gIGF3YWl0IG1pZ3JhdG9yLnJvbGxiYWNrKCk7XG59XG5cbmFzeW5jIGZ1bmN0aW9uIG1pZ3JhdGVfY2xlYXIoKSB7XG4gIGF3YWl0IHNldHVwTWlncmF0b3IoKTtcblxuICBhd2FpdCBtaWdyYXRvci5jbGVhclBlbmRpbmdMaXN0KCk7XG59XG5cbmFzeW5jIGZ1bmN0aW9uIG1pZ3JhdGVfcmVzZXQoKSB7XG4gIGF3YWl0IHNldHVwTWlncmF0b3IoKTtcblxuICBhd2FpdCBtaWdyYXRvci5yZXNldEFsbCgpO1xufVxuXG5hc3luYyBmdW5jdGlvbiBmaXh0dXJlX2luaXQoKSB7XG4gIGNvbnN0IHNyY0NvbmZpZyA9IFNvbmFtdS5kYkNvbmZpZy5kZXZlbG9wbWVudF9tYXN0ZXI7XG4gIGNvbnN0IHRhcmdldHMgPSBbXG4gICAge1xuICAgICAgbGFiZWw6IFwiKFJFTU9URSkgRml4dHVyZSBEQlwiLFxuICAgICAgY29uZmlnOiBTb25hbXUuZGJDb25maWcuZml4dHVyZV9yZW1vdGUsXG4gICAgfSxcbiAgICB7XG4gICAgICBsYWJlbDogXCIoTE9DQUwpIEZpeHR1cmUgREJcIixcbiAgICAgIGNvbmZpZzogU29uYW11LmRiQ29uZmlnLmZpeHR1cmVfbG9jYWwsXG4gICAgICB0b1NraXA6ICgoKSA9PiB7XG4gICAgICAgIGNvbnN0IHJlbW90ZUNvbm4gPSBTb25hbXUuZGJDb25maWcuZml4dHVyZV9yZW1vdGVcbiAgICAgICAgICAuY29ubmVjdGlvbiBhcyBLbmV4LkNvbm5lY3Rpb25Db25maWc7XG4gICAgICAgIGNvbnN0IGxvY2FsQ29ubiA9IFNvbmFtdS5kYkNvbmZpZy5maXh0dXJlX2xvY2FsXG4gICAgICAgICAgLmNvbm5lY3Rpb24gYXMgS25leC5Db25uZWN0aW9uQ29uZmlnO1xuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIHJlbW90ZUNvbm4uaG9zdCA9PT0gbG9jYWxDb25uLmhvc3QgJiZcbiAgICAgICAgICByZW1vdGVDb25uLmRhdGFiYXNlID09PSBsb2NhbENvbm4uZGF0YWJhc2VcbiAgICAgICAgKTtcbiAgICAgIH0pKCksXG4gICAgfSxcbiAgICB7XG4gICAgICBsYWJlbDogXCIoTE9DQUwpIFRlc3RpbmcgREJcIixcbiAgICAgIGNvbmZpZzogU29uYW11LmRiQ29uZmlnLnRlc3QsXG4gICAgfSxcbiAgXSBhcyB7XG4gICAgbGFiZWw6IHN0cmluZztcbiAgICBjb25maWc6IEtuZXguQ29uZmlnO1xuICAgIHRvU2tpcD86IGJvb2xlYW47XG4gIH1bXTtcblxuICAvLyAxLiDquLDspIBEQiDsiqTtgqTrp4jrpbwg642k7ZSEXG4gIGNvbnNvbGUubG9nKFwiRFVNUC4uLlwiKTtcbiAgY29uc3QgZHVtcEZpbGVuYW1lID0gYC90bXAvc29uYW11LWZpeHR1cmUtaW5pdC0ke0RhdGUubm93KCl9LnNxbGA7XG4gIGNvbnN0IHNyY0Nvbm4gPSBzcmNDb25maWcuY29ubmVjdGlvbiBhcyBLbmV4LkNvbm5lY3Rpb25Db25maWc7XG4gIGNvbnN0IG1pZ3JhdGlvbnNEdW1wID0gYC90bXAvc29uYW11LWZpeHR1cmUtaW5pdC1taWdyYXRpb25zLSR7RGF0ZS5ub3coKX0uc3FsYDtcbiAgZXhlY1N5bmMoXG4gICAgYG15c3FsZHVtcCAtaCR7c3JjQ29ubi5ob3N0fSAtdSR7c3JjQ29ubi51c2VyfSAtcCR7c3JjQ29ubi5wYXNzd29yZH0gLS1zaW5nbGUtdHJhbnNhY3Rpb24gLWQgLS1uby1jcmVhdGUtZGIgLS10cmlnZ2VycyAke3NyY0Nvbm4uZGF0YWJhc2V9ID4gJHtkdW1wRmlsZW5hbWV9YFxuICApO1xuICBjb25zdCBfZGIgPSBrbmV4KHNyY0NvbmZpZyk7XG4gIGNvbnN0IFtbbWlncmF0aW9uc11dID0gYXdhaXQgX2RiLnJhdyhcbiAgICBcIlNFTEVDVCBDT1VOVCgqKSBhcyBjb3VudCBGUk9NIGluZm9ybWF0aW9uX3NjaGVtYS50YWJsZXMgV0hFUkUgdGFibGVfc2NoZW1hID0gPyBBTkQgdGFibGVfbmFtZSA9ICdrbmV4X21pZ3JhdGlvbnMnXCIsXG4gICAgW3NyY0Nvbm4uZGF0YWJhc2VdXG4gICk7XG4gIGlmIChtaWdyYXRpb25zLmNvdW50ID4gMCkge1xuICAgIGV4ZWNTeW5jKFxuICAgICAgYG15c3FsZHVtcCAtaCR7c3JjQ29ubi5ob3N0fSAtdSR7c3JjQ29ubi51c2VyfSAtcCR7c3JjQ29ubi5wYXNzd29yZH0gLS1zaW5nbGUtdHJhbnNhY3Rpb24gLS1uby1jcmVhdGUtZGIgLS10cmlnZ2VycyAke3NyY0Nvbm4uZGF0YWJhc2V9IGtuZXhfbWlncmF0aW9ucyBrbmV4X21pZ3JhdGlvbnNfbG9jayA+ICR7bWlncmF0aW9uc0R1bXB9YFxuICAgICk7XG4gIH1cblxuICAvLyAyLiDrjIDsg4FEQiDqsIHqsIHsl5Ag64yA7ZWY7JesIOyhtOyerOyXrOu2gCDtmZXsnbgg7ZuEIOu2k+q4sFxuICBmb3IgYXdhaXQgKGNvbnN0IHsgbGFiZWwsIGNvbmZpZywgdG9Ta2lwIH0gb2YgdGFyZ2V0cykge1xuICAgIGNvbnN0IGNvbm4gPSBjb25maWcuY29ubmVjdGlvbiBhcyBLbmV4LkNvbm5lY3Rpb25Db25maWc7XG5cbiAgICBpZiAodG9Ta2lwID09PSB0cnVlKSB7XG4gICAgICBjb25zb2xlLmxvZyhjaGFsay5yZWQoYCR7bGFiZWx9OiBTa2lwcGVkIWApKTtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGNvbnN0IGRiID0ga25leCh7XG4gICAgICAuLi5jb25maWcsXG4gICAgICBjb25uZWN0aW9uOiB7XG4gICAgICAgIC4uLigoY29uZmlnLmNvbm5lY3Rpb24gPz8ge30pIGFzIEtuZXguQ29ubmVjdGlvbkNvbmZpZyksXG4gICAgICAgIGRhdGFiYXNlOiB1bmRlZmluZWQsXG4gICAgICB9LFxuICAgIH0pO1xuICAgIGNvbnN0IFtbcm93XV0gPSBhd2FpdCBkYi5yYXcoYFNIT1cgREFUQUJBU0VTIExJS0UgXCIke2Nvbm4uZGF0YWJhc2V9XCJgKTtcbiAgICBpZiAocm93KSB7XG4gICAgICBjb25zb2xlLmxvZyhcbiAgICAgICAgY2hhbGsueWVsbG93KGAke2xhYmVsfTogRGF0YWJhc2UgXCIke2Nvbm4uZGF0YWJhc2V9XCIgQWxyZWFkeSBleGlzdHNgKVxuICAgICAgKTtcbiAgICAgIGF3YWl0IGRiLmRlc3Ryb3koKTtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGNvbnNvbGUubG9nKGBTWU5DIHRvICR7bGFiZWx9Li4uYCk7XG4gICAgY29uc3QgbXlzcWxDbWQgPSBgbXlzcWwgLWgke2Nvbm4uaG9zdH0gLXUke2Nvbm4udXNlcn0gLXAke2Nvbm4ucGFzc3dvcmR9YDtcbiAgICBleGVjU3luYyhgJHtteXNxbENtZH0gLWUgJ0RST1AgREFUQUJBU0UgSUYgRVhJU1RTIFxcYCR7Y29ubi5kYXRhYmFzZX1cXGAnYCk7XG4gICAgZXhlY1N5bmMoYCR7bXlzcWxDbWR9IC1lICdDUkVBVEUgREFUQUJBU0UgXFxgJHtjb25uLmRhdGFiYXNlfVxcYCdgKTtcbiAgICBleGVjU3luYyhgJHtteXNxbENtZH0gJHtjb25uLmRhdGFiYXNlfSA8ICR7ZHVtcEZpbGVuYW1lfWApO1xuICAgIGlmIChhd2FpdCBleGlzdHMobWlncmF0aW9uc0R1bXApKSB7XG4gICAgICBleGVjU3luYyhgJHtteXNxbENtZH0gJHtjb25uLmRhdGFiYXNlfSA8ICR7bWlncmF0aW9uc0R1bXB9YCk7XG4gICAgfVxuXG4gICAgYXdhaXQgZGIuZGVzdHJveSgpO1xuICB9XG5cbiAgYXdhaXQgX2RiLmRlc3Ryb3koKTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gZml4dHVyZV9pbXBvcnQoZW50aXR5SWQ6IHN0cmluZywgcmVjb3JkSWRzOiBudW1iZXJbXSkge1xuICBhd2FpdCBzZXR1cEZpeHR1cmVNYW5hZ2VyKCk7XG5cbiAgYXdhaXQgRml4dHVyZU1hbmFnZXIuaW1wb3J0Rml4dHVyZShlbnRpdHlJZCwgcmVjb3JkSWRzKTtcbiAgYXdhaXQgRml4dHVyZU1hbmFnZXIuc3luYygpO1xufVxuXG5hc3luYyBmdW5jdGlvbiBmaXh0dXJlX3N5bmMoKSB7XG4gIGF3YWl0IHNldHVwRml4dHVyZU1hbmFnZXIoKTtcblxuICBhd2FpdCBGaXh0dXJlTWFuYWdlci5zeW5jKCk7XG59XG5cbmFzeW5jIGZ1bmN0aW9uIHN0dWJfcHJhY3RpY2UobmFtZTogc3RyaW5nKSB7XG4gIGNvbnN0IHByYWN0aWNlRGlyID0gcGF0aC5qb2luKFNvbmFtdS5hcGlSb290UGF0aCwgXCJzcmNcIiwgXCJwcmFjdGljZXNcIik7XG4gIGNvbnN0IGZpbGVOYW1lcyA9IGF3YWl0IHJlYWRkaXIocHJhY3RpY2VEaXIpO1xuXG4gIGNvbnN0IG1heFNlcU5vID0gYXdhaXQgKGFzeW5jICgpID0+IHtcbiAgICBpZiAoIShhd2FpdCBleGlzdHMocHJhY3RpY2VEaXIpKSkge1xuICAgICAgYXdhaXQgbWtkaXIocHJhY3RpY2VEaXIsIHsgcmVjdXJzaXZlOiB0cnVlIH0pO1xuICAgIH1cblxuICAgIGNvbnN0IGZpbHRlcmVkU2VxcyA9IGZpbGVOYW1lc1xuICAgICAgLmZpbHRlcihcbiAgICAgICAgKGZpbGVOYW1lKSA9PiBmaWxlTmFtZS5zdGFydHNXaXRoKFwicFwiKSAmJiBmaWxlTmFtZS5lbmRzV2l0aChcIi50c1wiKVxuICAgICAgKVxuICAgICAgLm1hcCgoZmlsZU5hbWUpID0+IHtcbiAgICAgICAgY29uc3QgWywgc2VxTm9dID0gZmlsZU5hbWUubWF0Y2goL15wKFswLTldKylcXC0vKSA/PyBbXCIwXCIsIFwiMFwiXTtcbiAgICAgICAgcmV0dXJuIHBhcnNlSW50KHNlcU5vKTtcbiAgICAgIH0pXG4gICAgICAuc29ydCgoYSwgYikgPT4gYiAtIGEpO1xuXG4gICAgaWYgKGZpbHRlcmVkU2Vxcy5sZW5ndGggPiAwKSB7XG4gICAgICByZXR1cm4gZmlsdGVyZWRTZXFzWzBdO1xuICAgIH1cblxuICAgIHJldHVybiAwO1xuICB9KSgpO1xuXG4gIGNvbnN0IGN1cnJlbnRTZXFObyA9IG1heFNlcU5vICsgMTtcbiAgY29uc3QgZmlsZU5hbWUgPSBgcCR7Y3VycmVudFNlcU5vfS0ke25hbWV9LnRzYDtcbiAgY29uc3QgZHN0UGF0aCA9IHBhdGguam9pbihwcmFjdGljZURpciwgZmlsZU5hbWUpO1xuXG4gIGNvbnN0IGNvZGUgPSBbXG4gICAgYGltcG9ydCB7IFNvbmFtdSB9IGZyb20gXCJzb25hbXVcIjtgLFxuICAgIFwiXCIsXG4gICAgYGNvbnNvbGUuY2xlYXIoKTtgLFxuICAgIGBjb25zb2xlLmxvZyhcIiR7ZmlsZU5hbWV9XCIpO2AsXG4gICAgXCJcIixcbiAgICBgU29uYW11LnJ1blNjcmlwdChhc3luYyAoKSA9PiB7YCxcbiAgICBgIC8vIFRPRE9gLFxuICAgIGB9KTtgLFxuICAgIFwiXCIsXG4gIF0uam9pbihcIlxcblwiKTtcbiAgYXdhaXQgd3JpdGVGaWxlKGRzdFBhdGgsIGNvZGUpO1xuXG4gIGV4ZWNTeW5jKGBjb2RlICR7ZHN0UGF0aH1gKTtcblxuICBjb25zdCBydW5Db2RlID0gYHlhcm4gbm9kZSAtciBkb3RlbnYvY29uZmlnIC0tZW5hYmxlLXNvdXJjZS1tYXBzIGRpc3QvcHJhY3RpY2VzLyR7ZmlsZU5hbWUucmVwbGFjZShcbiAgICBcIi50c1wiLFxuICAgIFwiLmpzXCJcbiAgKX1gO1xuICBjb25zb2xlLmxvZyhgJHtjaGFsay5ibHVlKHJ1bkNvZGUpfSBjb3BpZWQgdG8gY2xpcGJvYXJkLmApO1xuICBleGVjU3luYyhgZWNobyBcIiR7cnVuQ29kZX1cIiB8IHBiY29weWApO1xufVxuXG5hc3luYyBmdW5jdGlvbiBzdHViX2VudGl0eShlbnRpdHlJZDogc3RyaW5nKSB7XG4gIGF3YWl0IFNvbmFtdS5zeW5jZXIuY3JlYXRlRW50aXR5KHsgZW50aXR5SWQgfSk7XG59XG5cbmFzeW5jIGZ1bmN0aW9uIHNjYWZmb2xkX21vZGVsKGVudGl0eUlkOiBzdHJpbmcpIHtcbiAgYXdhaXQgU29uYW11LnN5bmNlci5nZW5lcmF0ZVRlbXBsYXRlKFwibW9kZWxcIiwge1xuICAgIGVudGl0eUlkLFxuICB9KTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gc2NhZmZvbGRfbW9kZWxfdGVzdChlbnRpdHlJZDogc3RyaW5nKSB7XG4gIGF3YWl0IFNvbmFtdS5zeW5jZXIuZ2VuZXJhdGVUZW1wbGF0ZShcIm1vZGVsX3Rlc3RcIiwge1xuICAgIGVudGl0eUlkLFxuICB9KTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gdWkoKSB7XG4gIHRyeSB7XG4gICAgLy8gQHNvbmFtdS1raXQvdWnsnZggcnVuLXVpLnRzIOyKpO2BrOumve2KuCDqsr3roZwg7LC+6riwXG4gICAgY29uc3QgdWlNb2R1bGVQYXRoID0gYXdhaXQgaW1wb3J0Lm1ldGEucmVzb2x2ZShcIkBzb25hbXUta2l0L3VpXCIpO1xuICAgIGNvbnN0IHVpTm9kZVBhdGggPSBwYXRoLmpvaW4oXG4gICAgICBwYXRoLmRpcm5hbWUoZmlsZVVSTFRvUGF0aCh1aU1vZHVsZVBhdGgpKSxcbiAgICAgIFwicnVuLXVpLmpzXCJcbiAgICApO1xuXG4gICAgaWYgKCEoYXdhaXQgZXhpc3RzKHVpTm9kZVBhdGgpKSkge1xuICAgICAgY29uc29sZS5sb2coXG4gICAgICAgIGNoYWxrLnJlZChcbiAgICAgICAgICBgVUkgcnVubmVyIHNjcmlwdCBub3QgZm91bmQgYXQgJHt1aU5vZGVQYXRofS4gUGxlYXNlIHJlYnVpbGQgQHNvbmFtdS1raXQvdWkuYFxuICAgICAgICApXG4gICAgICApO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIC8vIFVJ66W8IOuzhOuPhCDtlITroZzshLjsiqTroZwg7Iuk7ZaJIChob3QtaG9vayDtmZzshLHtmZQpXG4gICAgY29uc3QgdWlQcm9jZXNzID0gc3Bhd24oXG4gICAgICBwcm9jZXNzLmV4ZWNQYXRoLFxuICAgICAgW1xuICAgICAgICBcIi0taW1wb3J0XCIsIFwiQHNvbmFtdS1raXQvbG9hZGVyXCIsXG4gICAgICAgIFwiLS1pbXBvcnRcIiwgXCJzb25hbXUvaG90LWhvb2stcmVnaXN0ZXJcIixcbiAgICAgICAgXCItLWVuYWJsZS1zb3VyY2UtbWFwc1wiLFxuICAgICAgICBcIi0tbm8td2FybmluZ3NcIixcbiAgICAgICAgdWlOb2RlUGF0aCxcbiAgICAgIF0sXG4gICAgICB7XG4gICAgICAgIHN0ZGlvOiBcImluaGVyaXRcIixcbiAgICAgICAgZW52OiB7XG4gICAgICAgICAgLi4ucHJvY2Vzcy5lbnYsXG4gICAgICAgICAgSE9UOiBcInllc1wiLFxuICAgICAgICAgIFBST0pFQ1RfTkFNRTpcbiAgICAgICAgICAgIFNvbmFtdS5jb25maWcucHJvamVjdE5hbWUgPz8gcGF0aC5iYXNlbmFtZShTb25hbXUuYXBpUm9vdFBhdGgpLFxuICAgICAgICAgIEFQSV9ST09UX1BBVEg6IFNvbmFtdS5hcGlSb290UGF0aCxcbiAgICAgICAgICBVSV9QT1JUOiAoU29uYW11LmNvbmZpZy51aT8ucG9ydCA/PyA1NzAwMCkudG9TdHJpbmcoKSxcbiAgICAgICAgfSxcbiAgICAgIH1cbiAgICApO1xuXG4gICAgLy8g7KKF66OMIOyymOumrFxuICAgIGNvbnN0IGNsZWFudXAgPSAoKSA9PiB7XG4gICAgICBjb25zb2xlLmxvZyhjaGFsay55ZWxsb3coXCJcXG5cXG7wn5GLIFNodXR0aW5nIGRvd24gVUkgc2VydmVyLi4uXCIpKTtcbiAgICAgIHVpUHJvY2Vzcy5raWxsKFwiU0lHVEVSTVwiKTtcbiAgICAgIHByb2Nlc3MuZXhpdCgwKTtcbiAgICB9O1xuXG4gICAgcHJvY2Vzcy5vbihcIlNJR0lOVFwiLCBjbGVhbnVwKTtcbiAgICBwcm9jZXNzLm9uKFwiU0lHVEVSTVwiLCBjbGVhbnVwKTtcblxuICAgIHVpUHJvY2Vzcy5vbihcImV4aXRcIiwgKGNvZGUpID0+IHtcbiAgICAgIGlmIChjb2RlICE9PSAwKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoY2hhbGsucmVkKGDinYwgVUkgc2VydmVyIGV4aXRlZCB3aXRoIGNvZGUgJHtjb2RlfWApKTtcbiAgICAgICAgcHJvY2Vzcy5leGl0KGNvZGUgfHwgMSk7XG4gICAgICB9XG4gICAgfSk7XG4gIH0gY2F0Y2ggKGU6IHVua25vd24pIHtcbiAgICBpZiAoZSBpbnN0YW5jZW9mIEVycm9yICYmIGUubWVzc2FnZS5pbmNsdWRlcyhcImlzbid0IGRlY2xhcmVkXCIpKSB7XG4gICAgICBjb25zb2xlLmxvZyhcbiAgICAgICAgYFlvdSBuZWVkIHRvIGluc3RhbGwgJHtjaGFsay5ibHVlKGBAc29uYW11LWtpdC91aWApfSBmaXJzdC5gXG4gICAgICApO1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICB0aHJvdyBlO1xuICB9XG59XG4iXSwibmFtZXMiOlsiY2hhbGsiLCJkb3RlbnYiLCJjb25maWciLCJwYXRoIiwiZmlsZVVSTFRvUGF0aCIsInRzaWNsaSIsImV4ZWNTeW5jIiwic3Bhd24iLCJta2RpciIsInJlYWRkaXIiLCJ3cml0ZUZpbGUiLCJleGlzdHMiLCJwcm9jZXNzIiwiU29uYW11Iiwia25leCIsIkVudGl0eU1hbmFnZXIiLCJNaWdyYXRvciIsIkZpeHR1cmVNYW5hZ2VyIiwiZmluZEFwaVJvb3RQYXRoIiwibWlncmF0b3IiLCJib290c3RyYXAiLCJhcmd2IiwiaW5pdCIsInR5cGVzIiwidHlwZSIsIm5hbWUiLCJtZXNzYWdlIiwiY2hvaWNlcyIsImdldEFsbFBhcmVudElkcyIsIm1hcCIsImVudGl0eUlkIiwidGl0bGUiLCJ2YWx1ZSIsImFyZ3MiLCJydW5uZXJzIiwibWlncmF0ZV9ydW4iLCJtaWdyYXRlX2NoZWNrIiwibWlncmF0ZV9yb2xsYmFjayIsIm1pZ3JhdGVfY2xlYXIiLCJtaWdyYXRlX3Jlc2V0IiwibWlncmF0ZV9zdGF0dXMiLCJmaXh0dXJlX2luaXQiLCJmaXh0dXJlX2ltcG9ydCIsImZpeHR1cmVfc3luYyIsInN0dWJfcHJhY3RpY2UiLCJzdHViX2VudGl0eSIsInNjYWZmb2xkX21vZGVsIiwic2NhZmZvbGRfbW9kZWxfdGVzdCIsInVpIiwiZGV2Iiwic3RhcnQiLCJmaW5hbGx5IiwiZGVzdHJveSIsImFwaVJvb3QiLCJlbnRyeVBvaW50IiwiY29uc29sZSIsImxvZyIsInllbGxvdyIsImJvbGQiLCJzZXJ2ZXJQcm9jZXNzIiwiY3dkIiwic3RkaW8iLCJlbnYiLCJOT0RFX0VOViIsIkhPVCIsIkFQSV9ST09UX1BBVEgiLCJjbGVhbnVwIiwia2lsbCIsImV4aXQiLCJvbiIsImNvZGUiLCJlcnJvciIsInJlZCIsImJsdWUiLCJhcGlSb290UGF0aCIsInNldHVwTWlncmF0b3IiLCJtb2RlIiwic2V0dXBGaXh0dXJlTWFuYWdlciIsInJ1biIsImNoZWNrIiwic3RhdHVzIiwiZ2V0U3RhdHVzIiwicm9sbGJhY2siLCJjbGVhclBlbmRpbmdMaXN0IiwicmVzZXRBbGwiLCJzcmNDb25maWciLCJkYkNvbmZpZyIsImRldmVsb3BtZW50X21hc3RlciIsInRhcmdldHMiLCJsYWJlbCIsImZpeHR1cmVfcmVtb3RlIiwiZml4dHVyZV9sb2NhbCIsInRvU2tpcCIsInJlbW90ZUNvbm4iLCJjb25uZWN0aW9uIiwibG9jYWxDb25uIiwiaG9zdCIsImRhdGFiYXNlIiwidGVzdCIsImR1bXBGaWxlbmFtZSIsIkRhdGUiLCJub3ciLCJzcmNDb25uIiwibWlncmF0aW9uc0R1bXAiLCJ1c2VyIiwicGFzc3dvcmQiLCJfZGIiLCJtaWdyYXRpb25zIiwicmF3IiwiY291bnQiLCJjb25uIiwiZGIiLCJ1bmRlZmluZWQiLCJyb3ciLCJteXNxbENtZCIsInJlY29yZElkcyIsImltcG9ydEZpeHR1cmUiLCJzeW5jIiwicHJhY3RpY2VEaXIiLCJqb2luIiwiZmlsZU5hbWVzIiwibWF4U2VxTm8iLCJyZWN1cnNpdmUiLCJmaWx0ZXJlZFNlcXMiLCJmaWx0ZXIiLCJmaWxlTmFtZSIsInN0YXJ0c1dpdGgiLCJlbmRzV2l0aCIsInNlcU5vIiwibWF0Y2giLCJwYXJzZUludCIsInNvcnQiLCJhIiwiYiIsImxlbmd0aCIsImN1cnJlbnRTZXFObyIsImRzdFBhdGgiLCJydW5Db2RlIiwicmVwbGFjZSIsInN5bmNlciIsImNyZWF0ZUVudGl0eSIsImdlbmVyYXRlVGVtcGxhdGUiLCJ1aU1vZHVsZVBhdGgiLCJyZXNvbHZlIiwidWlOb2RlUGF0aCIsImRpcm5hbWUiLCJ1aVByb2Nlc3MiLCJleGVjUGF0aCIsIlBST0pFQ1RfTkFNRSIsInByb2plY3ROYW1lIiwiYmFzZW5hbWUiLCJVSV9QT1JUIiwicG9ydCIsInRvU3RyaW5nIiwiZSIsIkVycm9yIiwiaW5jbHVkZXMiXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLFdBQVcsUUFBUTtBQUMxQixPQUFPQyxZQUFZLFNBQVM7QUFDNUJBLE9BQU9DLE1BQU07QUFFYixPQUFPQyxVQUFVLE9BQU87QUFDeEIsU0FBU0MsYUFBYSxRQUFRLE1BQU07QUFDcEMsU0FBU0MsTUFBTSxRQUFRLFNBQVM7QUFDaEMsU0FBU0MsUUFBUSxFQUFFQyxLQUFLLFFBQVEsZ0JBQWdCO0FBQ2hELFNBQVNDLEtBQUssRUFBRUMsT0FBTyxFQUFFQyxTQUFTLFFBQVEsbUJBQWM7QUFDeEQsU0FBU0MsTUFBTSxRQUFRLHVCQUFvQjtBQUMzQyxPQUFPQyxhQUFhLFVBQVU7QUFDOUIsU0FBU0MsTUFBTSxRQUFRLGtCQUFTO0FBQ2hDLE9BQU9DLFVBQW9CLE9BQU87QUFDbEMsU0FBU0MsYUFBYSxRQUFRLDhCQUEyQjtBQUN6RCxTQUFTQyxRQUFRLFFBQVEsMkJBQXdCO0FBQ2pELFNB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
@@ -0,0 +1,11 @@
1
+ /**
2
+ * hot-hook 초기화하는 모듈입니다.
3
+ *
4
+ * 이 파일은 --import 플래그로 프로세스 시작 시 로드되어야 합니다.
5
+ *
6
+ * 환경변수:
7
+ * - API_ROOT_PATH: 사용자 프로젝트의 API 루트 경로
8
+ * - HOT: 'yes'일 때만 hot-hook 활성화
9
+ */
10
+ export {};
11
+ //# sourceMappingURL=hot-hook-register.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hot-hook-register.d.ts","sourceRoot":"","sources":["../../src/bin/hot-hook-register.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAaH,OAAO,EAAE,CAAC"}