sonamu 0.5.6 → 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.
- package/dist/api/base-frame.js +12 -2
- package/dist/api/caster.js +66 -2
- package/dist/api/code-converters.js +489 -2
- package/dist/api/config.d.ts +76 -0
- package/dist/api/config.d.ts.map +1 -0
- package/dist/api/config.js +32 -0
- package/dist/api/context.d.ts +1 -0
- package/dist/api/context.d.ts.map +1 -1
- package/dist/api/context.js +3 -2
- package/dist/api/decorators.d.ts +1 -0
- package/dist/api/decorators.d.ts.map +1 -1
- package/dist/api/decorators.js +142 -2
- package/dist/api/index.js +9 -2
- package/dist/api/sonamu.d.ts +8 -22
- package/dist/api/sonamu.d.ts.map +1 -1
- package/dist/api/sonamu.js +482 -2
- package/dist/bin/build-config.d.ts +2 -1
- package/dist/bin/build-config.d.ts.map +1 -1
- package/dist/bin/build-config.js +12 -2
- package/dist/bin/cli-wrapper.js +71 -2
- package/dist/bin/cli.js +418 -2
- package/dist/bin/hot-hook-register.d.ts +11 -0
- package/dist/bin/hot-hook-register.d.ts.map +1 -0
- package/dist/bin/hot-hook-register.js +21 -0
- package/dist/database/_batch_update.js +78 -2
- package/dist/database/base-model.js +247 -2
- package/dist/database/code-generator.js +53 -2
- package/dist/database/db.d.ts +5 -16
- package/dist/database/db.d.ts.map +1 -1
- package/dist/database/db.js +132 -2
- package/dist/database/knex-plugins/knex-on-duplicate-update.js +39 -2
- package/dist/database/puri-wrapper.d.ts +22 -10
- package/dist/database/puri-wrapper.d.ts.map +1 -1
- package/dist/database/puri-wrapper.js +109 -2
- package/dist/database/puri.d.ts +105 -73
- package/dist/database/puri.d.ts.map +1 -1
- package/dist/database/puri.js +539 -2
- package/dist/database/puri.types.d.ts +33 -42
- package/dist/database/puri.types.d.ts.map +1 -1
- package/dist/database/puri.types.js +3 -2
- package/dist/database/transaction-context.d.ts +3 -3
- package/dist/database/transaction-context.d.ts.map +1 -1
- package/dist/database/transaction-context.js +14 -2
- package/dist/database/upsert-builder.js +215 -2
- package/dist/entity/entity-manager.d.ts +3 -1
- package/dist/entity/entity-manager.d.ts.map +1 -1
- package/dist/entity/entity-manager.js +114 -2
- package/dist/entity/entity-utils.js +210 -2
- package/dist/entity/entity.d.ts.map +1 -1
- package/dist/entity/entity.js +651 -2
- package/dist/exceptions/error-handler.js +29 -2
- package/dist/exceptions/so-exceptions.js +85 -2
- package/dist/file-storage/driver.js +79 -2
- package/dist/file-storage/file-storage.js +75 -2
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +28 -2
- package/dist/migration/code-generation.js +558 -2
- package/dist/migration/migration-set.js +364 -2
- package/dist/migration/migrator.d.ts +0 -9
- package/dist/migration/migrator.d.ts.map +1 -1
- package/dist/migration/migrator.js +510 -2
- package/dist/migration/types.js +3 -2
- package/dist/naite/naite.d.ts +12 -0
- package/dist/naite/naite.d.ts.map +1 -0
- package/dist/naite/naite.js +72 -0
- package/dist/stream/index.js +3 -2
- package/dist/stream/sse.js +38 -2
- package/dist/syncer/api-parser.d.ts +20 -0
- package/dist/syncer/api-parser.d.ts.map +1 -0
- package/dist/syncer/api-parser.js +229 -0
- package/dist/syncer/checksum.d.ts +21 -0
- package/dist/syncer/checksum.d.ts.map +1 -0
- package/dist/syncer/checksum.js +98 -0
- package/dist/syncer/code-generator.d.ts +20 -0
- package/dist/syncer/code-generator.d.ts.map +1 -0
- package/dist/syncer/code-generator.js +141 -0
- package/dist/syncer/entity-operations.d.ts +17 -0
- package/dist/syncer/entity-operations.d.ts.map +1 -0
- package/dist/syncer/entity-operations.js +58 -0
- package/dist/syncer/file-patterns.d.ts +29 -0
- package/dist/syncer/file-patterns.d.ts.map +1 -0
- package/dist/syncer/file-patterns.js +38 -0
- package/dist/syncer/index.d.ts +6 -0
- package/dist/syncer/index.d.ts.map +1 -1
- package/dist/syncer/index.js +9 -2
- package/dist/syncer/module-loader.d.ts +35 -0
- package/dist/syncer/module-loader.d.ts.map +1 -0
- package/dist/syncer/module-loader.js +82 -0
- package/dist/syncer/syncer.d.ts +93 -108
- package/dist/syncer/syncer.d.ts.map +1 -1
- package/dist/syncer/syncer.js +375 -2
- package/dist/template/entity-converter.d.ts +14 -0
- package/dist/template/entity-converter.d.ts.map +1 -0
- package/dist/template/entity-converter.js +101 -0
- package/dist/template/helpers.d.ts +23 -0
- package/dist/template/helpers.d.ts.map +1 -0
- package/dist/template/helpers.js +64 -0
- package/dist/{templates → template/implementations}/entity.template.d.ts +3 -3
- package/dist/template/implementations/entity.template.d.ts.map +1 -0
- package/dist/template/implementations/entity.template.js +87 -0
- package/dist/{templates → template/implementations}/generated.template.d.ts +3 -3
- package/dist/template/implementations/generated.template.d.ts.map +1 -0
- package/dist/template/implementations/generated.template.js +232 -0
- package/dist/{templates → template/implementations}/generated_http.template.d.ts +3 -3
- package/dist/template/implementations/generated_http.template.d.ts.map +1 -0
- package/dist/template/implementations/generated_http.template.js +131 -0
- package/dist/{templates → template/implementations}/generated_sso.template.d.ts +3 -3
- package/dist/template/implementations/generated_sso.template.d.ts.map +1 -0
- package/dist/template/implementations/generated_sso.template.js +105 -0
- package/dist/{templates → template/implementations}/init_types.template.d.ts +3 -3
- package/dist/template/implementations/init_types.template.d.ts.map +1 -0
- package/dist/template/implementations/init_types.template.js +38 -0
- package/dist/template/implementations/model.template.d.ts +17 -0
- package/dist/template/implementations/model.template.d.ts.map +1 -0
- package/dist/template/implementations/model.template.js +171 -0
- package/dist/{templates → template/implementations}/model_test.template.d.ts +3 -3
- package/dist/template/implementations/model_test.template.d.ts.map +1 -0
- package/dist/template/implementations/model_test.template.js +35 -0
- package/dist/{templates → template/implementations}/service.template.d.ts +6 -6
- package/dist/template/implementations/service.template.d.ts.map +1 -0
- package/dist/template/implementations/service.template.js +193 -0
- package/dist/{templates → template/implementations}/view_enums_buttonset.template.d.ts +3 -3
- package/dist/template/implementations/view_enums_buttonset.template.d.ts.map +1 -0
- package/dist/template/implementations/view_enums_buttonset.template.js +31 -0
- package/dist/{templates → template/implementations}/view_enums_dropdown.template.d.ts +3 -4
- package/dist/template/implementations/view_enums_dropdown.template.d.ts.map +1 -0
- package/dist/template/implementations/view_enums_dropdown.template.js +50 -0
- package/dist/{templates → template/implementations}/view_enums_select.template.d.ts +3 -3
- package/dist/template/implementations/view_enums_select.template.d.ts.map +1 -0
- package/dist/template/implementations/view_enums_select.template.js +55 -0
- package/dist/{templates → template/implementations}/view_form.template.d.ts +5 -5
- package/dist/template/implementations/view_form.template.d.ts.map +1 -0
- package/dist/template/implementations/view_form.template.js +337 -0
- package/dist/{templates → template/implementations}/view_id_all_select.template.d.ts +3 -3
- package/dist/template/implementations/view_id_all_select.template.d.ts.map +1 -0
- package/dist/template/implementations/view_id_all_select.template.js +31 -0
- package/dist/{templates → template/implementations}/view_id_async_select.template.d.ts +3 -3
- package/dist/template/implementations/view_id_async_select.template.d.ts.map +1 -0
- package/dist/template/implementations/view_id_async_select.template.js +105 -0
- package/dist/{templates → template/implementations}/view_list.template.d.ts +5 -13
- package/dist/template/implementations/view_list.template.d.ts.map +1 -0
- package/dist/template/implementations/view_list.template.js +465 -0
- package/dist/{templates → template/implementations}/view_list_columns.template.d.ts +3 -3
- package/dist/template/implementations/view_list_columns.template.d.ts.map +1 -0
- package/dist/template/implementations/view_list_columns.template.js +49 -0
- package/dist/{templates → template/implementations}/view_search_input.template.d.ts +3 -3
- package/dist/template/implementations/view_search_input.template.d.ts.map +1 -0
- package/dist/template/implementations/view_search_input.template.js +64 -0
- package/dist/template/index.d.ts +5 -0
- package/dist/template/index.d.ts.map +1 -0
- package/dist/template/index.js +6 -0
- package/dist/template/template.d.ts +39 -0
- package/dist/template/template.d.ts.map +1 -0
- package/dist/template/template.js +47 -0
- package/dist/template/zod-converter.d.ts +18 -0
- package/dist/template/zod-converter.d.ts.map +1 -0
- package/dist/template/zod-converter.js +166 -0
- package/dist/testing/_relation-graph.js +80 -2
- package/dist/testing/fixture-manager.d.ts.map +1 -1
- package/dist/testing/fixture-manager.js +521 -2
- package/dist/types/types.d.ts +39 -40
- package/dist/types/types.d.ts.map +1 -1
- package/dist/types/types.js +289 -2
- package/dist/typings/knex.d.js +3 -2
- package/dist/utils/async-utils.d.ts +7 -0
- package/dist/utils/async-utils.d.ts.map +1 -1
- package/dist/utils/async-utils.js +57 -2
- package/dist/utils/console-util.d.ts +2 -0
- package/dist/utils/console-util.d.ts.map +1 -0
- package/dist/utils/console-util.js +6 -0
- package/dist/utils/controller.js +26 -2
- package/dist/utils/esm-utils.d.ts +45 -0
- package/dist/utils/esm-utils.d.ts.map +1 -0
- package/dist/utils/esm-utils.js +56 -0
- package/dist/utils/fs-utils.js +17 -2
- package/dist/utils/lodash-able.js +6 -2
- package/dist/utils/model.js +22 -2
- package/dist/utils/path-utils.d.ts +89 -0
- package/dist/utils/path-utils.d.ts.map +1 -0
- package/dist/utils/path-utils.js +60 -0
- package/dist/utils/process-utils.d.ts +13 -0
- package/dist/utils/process-utils.d.ts.map +1 -0
- package/dist/utils/process-utils.js +36 -0
- package/dist/utils/sql-parser.js +35 -2
- package/dist/utils/utils.d.ts +4 -7
- package/dist/utils/utils.d.ts.map +1 -1
- package/dist/utils/utils.js +33 -2
- package/dist/utils/zod-error.d.ts.map +1 -1
- package/dist/utils/zod-error.js +19 -2
- package/package.json +21 -9
- package/src/api/code-converters.ts +2 -2
- package/src/api/config.ts +142 -0
- package/src/api/context.ts +1 -0
- package/src/api/decorators.ts +15 -5
- package/src/api/sonamu.ts +102 -87
- package/src/bin/build-config.ts +2 -1
- package/src/bin/cli-wrapper.ts +10 -3
- package/src/bin/cli.ts +108 -56
- package/src/bin/hot-hook-register.ts +22 -0
- package/src/database/base-model.ts +1 -1
- package/src/database/code-generator.ts +1 -1
- package/src/database/db.ts +53 -60
- package/src/database/puri-wrapper.ts +104 -26
- package/src/database/puri.ts +477 -580
- package/src/database/puri.types.ts +111 -201
- package/src/database/transaction-context.ts +4 -4
- package/src/database/upsert-builder.ts +1 -1
- package/src/entity/entity-manager.ts +19 -15
- package/src/entity/entity.ts +4 -3
- package/src/index.ts +2 -0
- package/src/migration/code-generation.ts +1 -1
- package/src/migration/migration-set.ts +1 -1
- package/src/migration/migrator.ts +23 -152
- package/src/naite/naite.ts +70 -0
- package/src/syncer/api-parser.ts +299 -0
- package/src/syncer/checksum.ts +152 -0
- package/src/syncer/code-generator.ts +202 -0
- package/src/syncer/entity-operations.ts +68 -0
- package/src/syncer/file-patterns.ts +56 -0
- package/src/syncer/index.ts +6 -0
- package/src/syncer/module-loader.ts +125 -0
- package/src/syncer/syncer.ts +363 -1420
- package/src/template/entity-converter.ts +123 -0
- package/src/template/helpers.ts +84 -0
- package/src/{templates → template/implementations}/entity.template.ts +4 -4
- package/src/{templates → template/implementations}/generated.template.ts +9 -9
- package/src/{templates → template/implementations}/generated_http.template.ts +9 -6
- package/src/{templates → template/implementations}/generated_sso.template.ts +7 -7
- package/src/{templates → template/implementations}/init_types.template.ts +4 -4
- package/src/{templates → template/implementations}/model.template.ts +9 -9
- package/src/{templates → template/implementations}/model_test.template.ts +5 -5
- package/src/{templates → template/implementations}/service.template.ts +29 -12
- package/src/{templates → template/implementations}/view_enums_buttonset.template.ts +3 -3
- package/src/{templates → template/implementations}/view_enums_dropdown.template.ts +5 -21
- package/src/{templates → template/implementations}/view_enums_select.template.ts +4 -4
- package/src/{templates → template/implementations}/view_form.template.ts +11 -13
- package/src/{templates → template/implementations}/view_id_all_select.template.ts +3 -3
- package/src/{templates → template/implementations}/view_id_async_select.template.ts +3 -3
- package/src/{templates → template/implementations}/view_list.template.ts +13 -64
- package/src/{templates → template/implementations}/view_list_columns.template.ts +3 -3
- package/src/{templates → template/implementations}/view_search_input.template.ts +3 -3
- package/src/template/index.ts +4 -0
- package/src/template/template.ts +86 -0
- package/src/template/zod-converter.ts +219 -0
- package/src/testing/fixture-manager.ts +8 -1
- package/src/types/types.ts +39 -62
- package/src/utils/async-utils.ts +17 -0
- package/src/utils/console-util.ts +4 -0
- package/src/utils/esm-utils.ts +69 -0
- package/src/utils/path-utils.ts +102 -0
- package/src/utils/process-utils.ts +46 -0
- package/src/utils/sql-parser.ts +1 -1
- package/src/utils/utils.ts +14 -40
- package/src/utils/zod-error.ts +0 -1
- package/dist/api/base-frame.js.map +0 -1
- package/dist/api/caster.js.map +0 -1
- package/dist/api/code-converters.js.map +0 -1
- package/dist/api/context.js.map +0 -1
- package/dist/api/decorators.js.map +0 -1
- package/dist/api/index.js.map +0 -1
- package/dist/api/sonamu.js.map +0 -1
- package/dist/bin/build-config.js.map +0 -1
- package/dist/bin/cli-wrapper.js.map +0 -1
- package/dist/bin/cli.js.map +0 -1
- package/dist/database/_batch_update.js.map +0 -1
- package/dist/database/base-model.js.map +0 -1
- package/dist/database/code-generator.js.map +0 -1
- package/dist/database/db.js.map +0 -1
- package/dist/database/knex-plugins/knex-on-duplicate-update.js.map +0 -1
- package/dist/database/puri-wrapper.js.map +0 -1
- package/dist/database/puri.js.map +0 -1
- package/dist/database/puri.types.js.map +0 -1
- package/dist/database/transaction-context.js.map +0 -1
- package/dist/database/upsert-builder.js.map +0 -1
- package/dist/entity/entity-manager.js.map +0 -1
- package/dist/entity/entity-utils.js.map +0 -1
- package/dist/entity/entity.js.map +0 -1
- package/dist/exceptions/error-handler.js.map +0 -1
- package/dist/exceptions/so-exceptions.js.map +0 -1
- package/dist/file-storage/driver.js.map +0 -1
- package/dist/file-storage/file-storage.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/migration/code-generation.js.map +0 -1
- package/dist/migration/migration-set.js.map +0 -1
- package/dist/migration/migrator.js.map +0 -1
- package/dist/migration/types.js.map +0 -1
- package/dist/stream/index.js.map +0 -1
- package/dist/stream/sse.js.map +0 -1
- package/dist/syncer/index.js.map +0 -1
- package/dist/syncer/syncer.js.map +0 -1
- package/dist/templates/base-template.d.ts +0 -13
- package/dist/templates/base-template.d.ts.map +0 -1
- package/dist/templates/base-template.js +0 -2
- package/dist/templates/base-template.js.map +0 -1
- package/dist/templates/entity.template.d.ts.map +0 -1
- package/dist/templates/entity.template.js +0 -2
- package/dist/templates/entity.template.js.map +0 -1
- package/dist/templates/generated.template.d.ts.map +0 -1
- package/dist/templates/generated.template.js +0 -2
- package/dist/templates/generated.template.js.map +0 -1
- package/dist/templates/generated_http.template.d.ts.map +0 -1
- package/dist/templates/generated_http.template.js +0 -2
- package/dist/templates/generated_http.template.js.map +0 -1
- package/dist/templates/generated_sso.template.d.ts.map +0 -1
- package/dist/templates/generated_sso.template.js +0 -2
- package/dist/templates/generated_sso.template.js.map +0 -1
- package/dist/templates/index.d.ts +0 -2
- package/dist/templates/index.d.ts.map +0 -1
- package/dist/templates/index.js +0 -2
- package/dist/templates/index.js.map +0 -1
- package/dist/templates/init_types.template.d.ts.map +0 -1
- package/dist/templates/init_types.template.js +0 -2
- package/dist/templates/init_types.template.js.map +0 -1
- package/dist/templates/model.template.d.ts +0 -17
- package/dist/templates/model.template.d.ts.map +0 -1
- package/dist/templates/model.template.js +0 -2
- package/dist/templates/model.template.js.map +0 -1
- package/dist/templates/model_test.template.d.ts.map +0 -1
- package/dist/templates/model_test.template.js +0 -2
- package/dist/templates/model_test.template.js.map +0 -1
- package/dist/templates/service.template.d.ts.map +0 -1
- package/dist/templates/service.template.js +0 -2
- package/dist/templates/service.template.js.map +0 -1
- package/dist/templates/view_enums_buttonset.template.d.ts.map +0 -1
- package/dist/templates/view_enums_buttonset.template.js +0 -2
- package/dist/templates/view_enums_buttonset.template.js.map +0 -1
- package/dist/templates/view_enums_dropdown.template.d.ts.map +0 -1
- package/dist/templates/view_enums_dropdown.template.js +0 -2
- package/dist/templates/view_enums_dropdown.template.js.map +0 -1
- package/dist/templates/view_enums_select.template.d.ts.map +0 -1
- package/dist/templates/view_enums_select.template.js +0 -2
- package/dist/templates/view_enums_select.template.js.map +0 -1
- package/dist/templates/view_form.template.d.ts.map +0 -1
- package/dist/templates/view_form.template.js +0 -2
- package/dist/templates/view_form.template.js.map +0 -1
- package/dist/templates/view_id_all_select.template.d.ts.map +0 -1
- package/dist/templates/view_id_all_select.template.js +0 -2
- package/dist/templates/view_id_all_select.template.js.map +0 -1
- package/dist/templates/view_id_async_select.template.d.ts.map +0 -1
- package/dist/templates/view_id_async_select.template.js +0 -2
- package/dist/templates/view_id_async_select.template.js.map +0 -1
- package/dist/templates/view_list.template.d.ts.map +0 -1
- package/dist/templates/view_list.template.js +0 -2
- package/dist/templates/view_list.template.js.map +0 -1
- package/dist/templates/view_list_columns.template.d.ts.map +0 -1
- package/dist/templates/view_list_columns.template.js +0 -2
- package/dist/templates/view_list_columns.template.js.map +0 -1
- package/dist/templates/view_search_input.template.d.ts.map +0 -1
- package/dist/templates/view_search_input.template.js +0 -2
- package/dist/templates/view_search_input.template.js.map +0 -1
- package/dist/testing/_relation-graph.js.map +0 -1
- package/dist/testing/fixture-manager.js.map +0 -1
- package/dist/types/types.js.map +0 -1
- package/dist/typings/knex.d.js.map +0 -1
- package/dist/utils/async-utils.js.map +0 -1
- package/dist/utils/controller.js.map +0 -1
- package/dist/utils/fs-utils.js.map +0 -1
- package/dist/utils/lodash-able.js.map +0 -1
- package/dist/utils/model.js.map +0 -1
- package/dist/utils/sql-parser.js.map +0 -1
- package/dist/utils/utils.js.map +0 -1
- package/dist/utils/zod-error.js.map +0 -1
- package/src/templates/base-template.ts +0 -19
- 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
|
|
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"}
|
package/dist/bin/build-config.js
CHANGED
|
@@ -1,2 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
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
|
package/dist/bin/cli-wrapper.js
CHANGED
|
@@ -1,3 +1,72 @@
|
|
|
1
1
|
#!/usr/bin/env ts-node
|
|
2
|
-
|
|
3
|
-
|
|
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
|
-
|
|
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 @@
|
|
|
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"}
|