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.
- 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.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 +2 -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.js +109 -2
- package/dist/database/puri.d.ts +23 -16
- package/dist/database/puri.d.ts.map +1 -1
- package/dist/database/puri.js +539 -2
- package/dist/database/puri.types.d.ts +8 -3
- package/dist/database/puri.types.d.ts.map +1 -1
- package/dist/database/puri.types.js +3 -2
- 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 -8
- 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 +1 -0
- package/src/api/sonamu.ts +81 -67
- 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 +10 -52
- package/src/database/puri.ts +78 -53
- package/src/database/puri.types.ts +18 -5
- 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 +19 -11
- 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 +38 -61
- 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
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* hot-hook 초기화하는 모듈입니다.
|
|
3
|
+
*
|
|
4
|
+
* 이 파일은 --import 플래그로 프로세스 시작 시 로드되어야 합니다.
|
|
5
|
+
*
|
|
6
|
+
* 환경변수:
|
|
7
|
+
* - API_ROOT_PATH: 사용자 프로젝트의 API 루트 경로
|
|
8
|
+
* - HOT: 'yes'일 때만 hot-hook 활성화
|
|
9
|
+
*/ if (process.env.HOT === "yes" && process.env.API_ROOT_PATH) {
|
|
10
|
+
const { hot } = await import("@sonamu-kit/hot-hook");
|
|
11
|
+
await hot.init({
|
|
12
|
+
rootDirectory: process.env.API_ROOT_PATH,
|
|
13
|
+
boundaries: [
|
|
14
|
+
`./src/**/*.ts`
|
|
15
|
+
]
|
|
16
|
+
});
|
|
17
|
+
console.log("🔥 Hot-hook initialized");
|
|
18
|
+
}
|
|
19
|
+
export { };
|
|
20
|
+
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9iaW4vaG90LWhvb2stcmVnaXN0ZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBob3QtaG9vayDstIjquLDtmZTtlZjripQg66qo65OI7J6F64uI64ukLlxuICpcbiAqIOydtCDtjIzsnbzsnYAgLS1pbXBvcnQg7ZSM656Y6re466GcIO2UhOuhnOyEuOyKpCDsi5zsnpEg7IucIOuhnOuTnOuQmOyWtOyVvCDtlanri4jri6QuXG4gKlxuICog7ZmY6rK967OA7IiYOlxuICogLSBBUElfUk9PVF9QQVRIOiDsgqzsmqnsnpAg7ZSE66Gc7KCd7Yq47J2YIEFQSSDro6jtirgg6rK966GcXG4gKiAtIEhPVDogJ3llcyfsnbwg65WM66eMIGhvdC1ob29rIO2ZnOyEse2ZlFxuICovXG5cbmlmIChwcm9jZXNzLmVudi5IT1QgPT09IFwieWVzXCIgJiYgcHJvY2Vzcy5lbnYuQVBJX1JPT1RfUEFUSCkge1xuICBjb25zdCB7IGhvdCB9ID0gYXdhaXQgaW1wb3J0KFwiQHNvbmFtdS1raXQvaG90LWhvb2tcIik7XG5cbiAgYXdhaXQgaG90LmluaXQoe1xuICAgIHJvb3REaXJlY3Rvcnk6IHByb2Nlc3MuZW52LkFQSV9ST09UX1BBVEgsIC8vIOydtCDsuZzqtazqsIAg7ZSE66Gc7KCd7Yq4IEFQSSDqsr3roZzroZwg7J6YIOyEpOygleuQmOyWtOyVvCDslYTrnpgg67CU7Jq0642U66as6rCAIOyekeuPme2VqeuLiOuLpC5cbiAgICBib3VuZGFyaWVzOiBbYC4vc3JjLyoqLyoudHNgXSwgLy8g7ZSE66Gc7KCd7Yq47J2YIOydtCDsuZzqtazrk6TsnbQg67CU7Jq0642U66as6rCAIOuQqeuLiOuLpC5cbiAgfSk7XG5cbiAgY29uc29sZS5sb2coXCLwn5SlIEhvdC1ob29rIGluaXRpYWxpemVkXCIpO1xufVxuXG5leHBvcnQge307XG4iXSwibmFtZXMiOlsicHJvY2VzcyIsImVudiIsIkhPVCIsIkFQSV9ST09UX1BBVEgiLCJob3QiLCJpbml0Iiwicm9vdERpcmVjdG9yeSIsImJvdW5kYXJpZXMiLCJjb25zb2xlIiwibG9nIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Q0FRQyxHQUVELElBQUlBLFFBQVFDLEdBQUcsQ0FBQ0MsR0FBRyxLQUFLLFNBQVNGLFFBQVFDLEdBQUcsQ0FBQ0UsYUFBYSxFQUFFO0lBQzFELE1BQU0sRUFBRUMsR0FBRyxFQUFFLEdBQUcsTUFBTSxNQUFNLENBQUM7SUFFN0IsTUFBTUEsSUFBSUMsSUFBSSxDQUFDO1FBQ2JDLGVBQWVOLFFBQVFDLEdBQUcsQ0FBQ0UsYUFBYTtRQUN4Q0ksWUFBWTtZQUFDLENBQUMsYUFBYSxDQUFDO1NBQUM7SUFDL0I7SUFFQUMsUUFBUUMsR0FBRyxDQUFDO0FBQ2Q7QUFFQSxXQUFVIn0=
|
|
@@ -1,2 +1,78 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
/*
|
|
2
|
+
아래의 링크에서 참고해서 가져온 소스코드
|
|
3
|
+
https://github.com/knex/knex/issues/5716
|
|
4
|
+
*/ /**
|
|
5
|
+
* Batch update rows in a table. Technically its a patch since it only updates the specified columns. Any omitted columns will not be affected
|
|
6
|
+
* @param db
|
|
7
|
+
* @param tableName
|
|
8
|
+
* @param ids
|
|
9
|
+
* @param rows
|
|
10
|
+
* @param chunkSize
|
|
11
|
+
* @param trx
|
|
12
|
+
*/ export async function batchUpdate(knex, tableName, ids, rows, chunkSize = 50, trx = null) {
|
|
13
|
+
const chunks = [];
|
|
14
|
+
for(let i = 0; i < rows.length; i += chunkSize){
|
|
15
|
+
chunks.push(rows.slice(i, i + chunkSize));
|
|
16
|
+
}
|
|
17
|
+
const executeUpdate = async (chunk, transaction)=>{
|
|
18
|
+
const sql = generateBatchUpdateSQL(knex, tableName, chunk, ids);
|
|
19
|
+
return knex.raw(sql).transacting(transaction);
|
|
20
|
+
};
|
|
21
|
+
if (trx) {
|
|
22
|
+
for (const chunk of chunks){
|
|
23
|
+
await executeUpdate(chunk, trx);
|
|
24
|
+
}
|
|
25
|
+
} else {
|
|
26
|
+
await knex.transaction(async (newTrx)=>{
|
|
27
|
+
for (const chunk of chunks){
|
|
28
|
+
await executeUpdate(chunk, newTrx);
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Generate a set of unique keys in a data array
|
|
35
|
+
*
|
|
36
|
+
* Example:
|
|
37
|
+
* [ { a: 1, b: 2 }, { a: 3, c: 4 } ] => Set([ "a", "b", "c" ])
|
|
38
|
+
* @param data
|
|
39
|
+
*/ function generateKeySetFromData(data) {
|
|
40
|
+
const keySet = new Set();
|
|
41
|
+
for (const row of data){
|
|
42
|
+
for (const key of Object.keys(row)){
|
|
43
|
+
keySet.add(key);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
return keySet;
|
|
47
|
+
}
|
|
48
|
+
function generateBatchUpdateSQL(db, tableName, data, identifiers) {
|
|
49
|
+
const keySet = generateKeySetFromData(data);
|
|
50
|
+
const bindings = [];
|
|
51
|
+
const invalidIdentifiers = identifiers.filter((id)=>!keySet.has(id));
|
|
52
|
+
if (invalidIdentifiers.length > 0) {
|
|
53
|
+
throw new Error(`Invalid identifiers: ${invalidIdentifiers.join(", ")}. Identifiers must exist in the data`);
|
|
54
|
+
}
|
|
55
|
+
const cases = [];
|
|
56
|
+
for (const key of keySet){
|
|
57
|
+
if (identifiers.includes(key)) continue;
|
|
58
|
+
const rows = [];
|
|
59
|
+
for (const row of data){
|
|
60
|
+
if (Object.hasOwnProperty.call(row, key)) {
|
|
61
|
+
const whereClause = identifiers.map((id)=>`\`${id}\` = ?`).join(" AND ");
|
|
62
|
+
rows.push(`WHEN (${whereClause}) THEN ?`);
|
|
63
|
+
bindings.push(...identifiers.map((i)=>row[i]), row[key]);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
const whenThen = rows.join(" ");
|
|
67
|
+
cases.push(`\`${key}\` = CASE ${whenThen} ELSE \`${key}\` END`);
|
|
68
|
+
}
|
|
69
|
+
const whereInClauses = identifiers.map((col)=>`${col} IN (${data.map(()=>"?").join(", ")})`).join(" AND ");
|
|
70
|
+
const whereInBindings = identifiers.flatMap((col)=>data.map((row)=>row[col]));
|
|
71
|
+
const sql = db.raw(`UPDATE \`${tableName}\` SET ${cases.join(", ")} WHERE ${whereInClauses}`, [
|
|
72
|
+
...bindings,
|
|
73
|
+
...whereInBindings
|
|
74
|
+
]);
|
|
75
|
+
return sql.toQuery();
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhYmFzZS9fYmF0Y2hfdXBkYXRlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qXG4gIOyVhOuemOydmCDrp4Htgazsl5DshJwg7LC46rOg7ZW07IScIOqwgOyguOyYqCDshozsiqTsvZTrk5xcbiAgaHR0cHM6Ly9naXRodWIuY29tL2tuZXgva25leC9pc3N1ZXMvNTcxNlxuKi9cblxuaW1wb3J0IHsgS25leCB9IGZyb20gXCJrbmV4XCI7XG5cbmV4cG9ydCB0eXBlIFJvd1dpdGhJZDxJZCBleHRlbmRzIHN0cmluZz4gPSB7XG4gIFtrZXkgaW4gSWRdOiBhbnk7XG59ICYgUmVjb3JkPHN0cmluZywgYW55PjtcblxuLyoqXG4gKiBCYXRjaCB1cGRhdGUgcm93cyBpbiBhIHRhYmxlLiBUZWNobmljYWxseSBpdHMgYSBwYXRjaCBzaW5jZSBpdCBvbmx5IHVwZGF0ZXMgdGhlIHNwZWNpZmllZCBjb2x1bW5zLiBBbnkgb21pdHRlZCBjb2x1bW5zIHdpbGwgbm90IGJlIGFmZmVjdGVkXG4gKiBAcGFyYW0gZGJcbiAqIEBwYXJhbSB0YWJsZU5hbWVcbiAqIEBwYXJhbSBpZHNcbiAqIEBwYXJhbSByb3dzXG4gKiBAcGFyYW0gY2h1bmtTaXplXG4gKiBAcGFyYW0gdHJ4XG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBiYXRjaFVwZGF0ZTxJZCBleHRlbmRzIHN0cmluZz4oXG4gIGtuZXg6IEtuZXgsXG4gIHRhYmxlTmFtZTogc3RyaW5nLFxuICBpZHM6IElkW10sXG4gIHJvd3M6IFJvd1dpdGhJZDxJZD5bXSxcbiAgY2h1bmtTaXplID0gNTAsXG4gIHRyeDogS25leC5UcmFuc2FjdGlvbiB8IG51bGwgPSBudWxsXG4pIHtcbiAgY29uc3QgY2h1bmtzOiBSb3dXaXRoSWQ8SWQ+W11bXSA9IFtdO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IHJvd3MubGVuZ3RoOyBpICs9IGNodW5rU2l6ZSkge1xuICAgIGNodW5rcy5wdXNoKHJvd3Muc2xpY2UoaSwgaSArIGNodW5rU2l6ZSkpO1xuICB9XG5cbiAgY29uc3QgZXhlY3V0ZVVwZGF0ZSA9IGFzeW5jIChcbiAgICBjaHVuazogUm93V2l0aElkPElkPltdLFxuICAgIHRyYW5zYWN0aW9uOiBLbmV4LlRyYW5zYWN0aW9uXG4gICkgPT4ge1xuICAgIGNvbnN0IHNxbCA9IGdlbmVyYXRlQmF0Y2hVcGRhdGVTUUwoa25leCwgdGFibGVOYW1lLCBjaHVuaywgaWRzKTtcbiAgICByZXR1cm4ga25leC5yYXcoc3FsKS50cmFuc2FjdGluZyh0cmFuc2FjdGlvbik7XG4gIH07XG5cbiAgaWYgKHRyeCkge1xuICAgIGZvciAoY29uc3QgY2h1bmsgb2YgY2h1bmtzKSB7XG4gICAgICBhd2FpdCBleGVjdXRlVXBkYXRlKGNodW5rLCB0cngpO1xuICAgIH1cbiAgfSBlbHNlIHtcbiAgICBhd2FpdCBrbmV4LnRyYW5zYWN0aW9uKGFzeW5jIChuZXdUcngpID0+IHtcbiAgICAgIGZvciAoY29uc3QgY2h1bmsgb2YgY2h1bmtzKSB7XG4gICAgICAgIGF3YWl0IGV4ZWN1dGVVcGRhdGUoY2h1bmssIG5ld1RyeCk7XG4gICAgICB9XG4gICAgfSk7XG4gIH1cbn1cblxuLyoqXG4gKiBHZW5lcmF0ZSBhIHNldCBvZiB1bmlxdWUga2V5cyBpbiBhIGRhdGEgYXJyYXlcbiAqXG4gKiBFeGFtcGxlOlxuICogWyB7IGE6IDEsIGI6IDIgfSwgeyBhOiAzLCBjOiA0IH0gXSA9PiBTZXQoWyBcImFcIiwgXCJiXCIsIFwiY1wiIF0pXG4gKiBAcGFyYW0gZGF0YVxuICovXG5mdW5jdGlvbiBnZW5lcmF0ZUtleVNldEZyb21EYXRhKGRhdGE6IFJlY29yZDxzdHJpbmcsIGFueT5bXSkge1xuICBjb25zdCBrZXlTZXQ6IFNldDxzdHJpbmc+ID0gbmV3IFNldCgpO1xuICBmb3IgKGNvbnN0IHJvdyBvZiBkYXRhKSB7XG4gICAgZm9yIChjb25zdCBrZXkgb2YgT2JqZWN0LmtleXMocm93KSkge1xuICAgICAga2V5U2V0LmFkZChrZXkpO1xuICAgIH1cbiAgfVxuICByZXR1cm4ga2V5U2V0O1xufVxuXG5mdW5jdGlvbiBnZW5lcmF0ZUJhdGNoVXBkYXRlU1FMPElkIGV4dGVuZHMgc3RyaW5nPihcbiAgZGI6IEtuZXgsXG4gIHRhYmxlTmFtZTogc3RyaW5nLFxuICBkYXRhOiBSZWNvcmQ8c3RyaW5nLCBhbnk+W10sXG4gIGlkZW50aWZpZXJzOiBJZFtdXG4pIHtcbiAgY29uc3Qga2V5U2V0ID0gZ2VuZXJhdGVLZXlTZXRGcm9tRGF0YShkYXRhKTtcbiAgY29uc3QgYmluZGluZ3MgPSBbXTtcblxuICBjb25zdCBpbnZhbGlkSWRlbnRpZmllcnMgPSBpZGVudGlmaWVycy5maWx0ZXIoKGlkKSA9PiAha2V5U2V0LmhhcyhpZCkpO1xuICBpZiAoaW52YWxpZElkZW50aWZpZXJzLmxlbmd0aCA+IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBgSW52YWxpZCBpZGVudGlmaWVyczogJHtpbnZhbGlkSWRlbnRpZmllcnMuam9pbihcIiwgXCIpfS4gSWRlbnRpZmllcnMgbXVzdCBleGlzdCBpbiB0aGUgZGF0YWBcbiAgICApO1xuICB9XG5cbiAgY29uc3QgY2FzZXMgPSBbXTtcbiAgZm9yIChjb25zdCBrZXkgb2Yga2V5U2V0KSB7XG4gICAgaWYgKGlkZW50aWZpZXJzLmluY2x1ZGVzKGtleSBhcyBJZCkpIGNvbnRpbnVlO1xuXG4gICAgY29uc3Qgcm93cyA9IFtdO1xuICAgIGZvciAoY29uc3Qgcm93IG9mIGRhdGEpIHtcbiAgICAgIGlmIChPYmplY3QuaGFzT3duUHJvcGVydHkuY2FsbChyb3csIGtleSkpIHtcbiAgICAgICAgY29uc3Qgd2hlcmVDbGF1c2UgPSBpZGVudGlmaWVyc1xuICAgICAgICAgIC5tYXAoKGlkKSA9PiBgXFxgJHtpZH1cXGAgPSA/YClcbiAgICAgICAgICAuam9pbihcIiBBTkQgXCIpO1xuICAgICAgICByb3dzLnB1c2goYFdIRU4gKCR7d2hlcmVDbGF1c2V9KSBUSEVOID9gKTtcbiAgICAgICAgYmluZGluZ3MucHVzaCguLi5pZGVudGlmaWVycy5tYXAoKGkpID0+IHJvd1tpXSksIHJvd1trZXldKTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBjb25zdCB3aGVuVGhlbiA9IHJvd3Muam9pbihcIiBcIik7XG4gICAgY2FzZXMucHVzaChgXFxgJHtrZXl9XFxgID0gQ0FTRSAke3doZW5UaGVufSBFTFNFIFxcYCR7a2V5fVxcYCBFTkRgKTtcbiAgfVxuXG4gIGNvbnN0IHdoZXJlSW5DbGF1c2VzID0gaWRlbnRpZmllcnNcbiAgICAubWFwKChjb2wpID0+IGAke2NvbH0gSU4gKCR7ZGF0YS5tYXAoKCkgPT4gXCI/XCIpLmpvaW4oXCIsIFwiKX0pYClcbiAgICAuam9pbihcIiBBTkQgXCIpO1xuXG4gIGNvbnN0IHdoZXJlSW5CaW5kaW5ncyA9IGlkZW50aWZpZXJzLmZsYXRNYXAoKGNvbCkgPT5cbiAgICBkYXRhLm1hcCgocm93KSA9PiByb3dbY29sXSlcbiAgKTtcblxuICBjb25zdCBzcWwgPSBkYi5yYXcoXG4gICAgYFVQREFURSBcXGAke3RhYmxlTmFtZX1cXGAgU0VUICR7Y2FzZXMuam9pbihcIiwgXCIpfSBXSEVSRSAke3doZXJlSW5DbGF1c2VzfWAsXG4gICAgWy4uLmJpbmRpbmdzLCAuLi53aGVyZUluQmluZGluZ3NdXG4gICk7XG5cbiAgcmV0dXJuIHNxbC50b1F1ZXJ5KCk7XG59XG4iXSwibmFtZXMiOlsiYmF0Y2hVcGRhdGUiLCJrbmV4IiwidGFibGVOYW1lIiwiaWRzIiwicm93cyIsImNodW5rU2l6ZSIsInRyeCIsImNodW5rcyIsImkiLCJsZW5ndGgiLCJwdXNoIiwic2xpY2UiLCJleGVjdXRlVXBkYXRlIiwiY2h1bmsiLCJ0cmFuc2FjdGlvbiIsInNxbCIsImdlbmVyYXRlQmF0Y2hVcGRhdGVTUUwiLCJyYXciLCJ0cmFuc2FjdGluZyIsIm5ld1RyeCIsImdlbmVyYXRlS2V5U2V0RnJvbURhdGEiLCJkYXRhIiwia2V5U2V0IiwiU2V0Iiwicm93Iiwia2V5IiwiT2JqZWN0Iiwia2V5cyIsImFkZCIsImRiIiwiaWRlbnRpZmllcnMiLCJiaW5kaW5ncyIsImludmFsaWRJZGVudGlmaWVycyIsImZpbHRlciIsImlkIiwiaGFzIiwiRXJyb3IiLCJqb2luIiwiY2FzZXMiLCJpbmNsdWRlcyIsImhhc093blByb3BlcnR5IiwiY2FsbCIsIndoZXJlQ2xhdXNlIiwibWFwIiwid2hlblRoZW4iLCJ3aGVyZUluQ2xhdXNlcyIsImNvbCIsIndoZXJlSW5CaW5kaW5ncyIsImZsYXRNYXAiLCJ0b1F1ZXJ5Il0sIm1hcHBpbmdzIjoiQUFBQTs7O0FBR0EsR0FRQTs7Ozs7Ozs7Q0FRQyxHQUNELE9BQU8sZUFBZUEsWUFDcEJDLElBQVUsRUFDVkMsU0FBaUIsRUFDakJDLEdBQVMsRUFDVEMsSUFBcUIsRUFDckJDLFlBQVksRUFBRSxFQUNkQyxNQUErQixJQUFJO0lBRW5DLE1BQU1DLFNBQTRCLEVBQUU7SUFDcEMsSUFBSyxJQUFJQyxJQUFJLEdBQUdBLElBQUlKLEtBQUtLLE1BQU0sRUFBRUQsS0FBS0gsVUFBVztRQUMvQ0UsT0FBT0csSUFBSSxDQUFDTixLQUFLTyxLQUFLLENBQUNILEdBQUdBLElBQUlIO0lBQ2hDO0lBRUEsTUFBTU8sZ0JBQWdCLE9BQ3BCQyxPQUNBQztRQUVBLE1BQU1DLE1BQU1DLHVCQUF1QmYsTUFBTUMsV0FBV1csT0FBT1Y7UUFDM0QsT0FBT0YsS0FBS2dCLEdBQUcsQ0FBQ0YsS0FBS0csV0FBVyxDQUFDSjtJQUNuQztJQUVBLElBQUlSLEtBQUs7UUFDUCxLQUFLLE1BQU1PLFNBQVNOLE9BQVE7WUFDMUIsTUFBTUssY0FBY0MsT0FBT1A7UUFDN0I7SUFDRixPQUFPO1FBQ0wsTUFBTUwsS0FBS2EsV0FBVyxDQUFDLE9BQU9LO1lBQzVCLEtBQUssTUFBTU4sU0FBU04sT0FBUTtnQkFDMUIsTUFBTUssY0FBY0MsT0FBT007WUFDN0I7UUFDRjtJQUNGO0FBQ0Y7QUFFQTs7Ozs7O0NBTUMsR0FDRCxTQUFTQyx1QkFBdUJDLElBQTJCO0lBQ3pELE1BQU1DLFNBQXNCLElBQUlDO0lBQ2hDLEtBQUssTUFBTUMsT0FBT0gsS0FBTTtRQUN0QixLQUFLLE1BQU1JLE9BQU9DLE9BQU9DLElBQUksQ0FBQ0gsS0FBTTtZQUNsQ0YsT0FBT00sR0FBRyxDQUFDSDtRQUNiO0lBQ0Y7SUFDQSxPQUFPSDtBQUNUO0FBRUEsU0FBU04sdUJBQ1BhLEVBQVEsRUFDUjNCLFNBQWlCLEVBQ2pCbUIsSUFBMkIsRUFDM0JTLFdBQWlCO0lBRWpCLE1BQU1SLFNBQVNGLHVCQUF1QkM7SUFDdEMsTUFBTVUsV0FBVyxFQUFFO0lBRW5CLE1BQU1DLHFCQUFxQkYsWUFBWUcsTUFBTSxDQUFDLENBQUNDLEtBQU8sQ0FBQ1osT0FBT2EsR0FBRyxDQUFDRDtJQUNsRSxJQUFJRixtQkFBbUJ2QixNQUFNLEdBQUcsR0FBRztRQUNqQyxNQUFNLElBQUkyQixNQUNSLENBQUMscUJBQXFCLEVBQUVKLG1CQUFtQkssSUFBSSxDQUFDLE1BQU0sb0NBQW9DLENBQUM7SUFFL0Y7SUFFQSxNQUFNQyxRQUFRLEVBQUU7SUFDaEIsS0FBSyxNQUFNYixPQUFPSCxPQUFRO1FBQ3hCLElBQUlRLFlBQVlTLFFBQVEsQ0FBQ2QsTUFBWTtRQUVyQyxNQUFNckIsT0FBTyxFQUFFO1FBQ2YsS0FBSyxNQUFNb0IsT0FBT0gsS0FBTTtZQUN0QixJQUFJSyxPQUFPYyxjQUFjLENBQUNDLElBQUksQ0FBQ2pCLEtBQUtDLE1BQU07Z0JBQ3hDLE1BQU1pQixjQUFjWixZQUNqQmEsR0FBRyxDQUFDLENBQUNULEtBQU8sQ0FBQyxFQUFFLEVBQUVBLEdBQUcsTUFBTSxDQUFDLEVBQzNCRyxJQUFJLENBQUM7Z0JBQ1JqQyxLQUFLTSxJQUFJLENBQUMsQ0FBQyxNQUFNLEVBQUVnQyxZQUFZLFFBQVEsQ0FBQztnQkFDeENYLFNBQVNyQixJQUFJLElBQUlvQixZQUFZYSxHQUFHLENBQUMsQ0FBQ25DLElBQU1nQixHQUFHLENBQUNoQixFQUFFLEdBQUdnQixHQUFHLENBQUNDLElBQUk7WUFDM0Q7UUFDRjtRQUVBLE1BQU1tQixXQUFXeEMsS0FBS2lDLElBQUksQ0FBQztRQUMzQkMsTUFBTTVCLElBQUksQ0FBQyxDQUFDLEVBQUUsRUFBRWUsSUFBSSxVQUFVLEVBQUVtQixTQUFTLFFBQVEsRUFBRW5CLElBQUksTUFBTSxDQUFDO0lBQ2hFO0lBRUEsTUFBTW9CLGlCQUFpQmYsWUFDcEJhLEdBQUcsQ0FBQyxDQUFDRyxNQUFRLEdBQUdBLElBQUksS0FBSyxFQUFFekIsS0FBS3NCLEdBQUcsQ0FBQyxJQUFNLEtBQUtOLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUM1REEsSUFBSSxDQUFDO0lBRVIsTUFBTVUsa0JBQWtCakIsWUFBWWtCLE9BQU8sQ0FBQyxDQUFDRixNQUMzQ3pCLEtBQUtzQixHQUFHLENBQUMsQ0FBQ25CLE1BQVFBLEdBQUcsQ0FBQ3NCLElBQUk7SUFHNUIsTUFBTS9CLE1BQU1jLEdBQUdaLEdBQUcsQ0FDaEIsQ0FBQyxTQUFTLEVBQUVmLFVBQVUsT0FBTyxFQUFFb0MsTUFBTUQsSUFBSSxDQUFDLE1BQU0sT0FBTyxFQUFFUSxnQkFBZ0IsRUFDekU7V0FBSWQ7V0FBYWdCO0tBQWdCO0lBR25DLE9BQU9oQyxJQUFJa0MsT0FBTztBQUNwQiJ9
|
|
@@ -1,2 +1,247 @@
|
|
|
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 BaseModel(){return BaseModel},get BaseModelClass(){return BaseModelClass}});var _luxon=require("luxon");var _lodash=require("lodash");var _db=require("./db");var _types=require("../types/types");var _inflection=/*#__PURE__*/_interop_require_default(require("inflection"));var _chalk=/*#__PURE__*/_interop_require_default(require("chalk"));var _upsertbuilder=require("./upsert-builder");var _nodesqlparser=/*#__PURE__*/_interop_require_default(require("node-sql-parser"));var _sqlparser=require("../utils/sql-parser");var _puriwrapper=require("./puri-wrapper");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 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 _class_call_check(instance,Constructor){if(!(instance instanceof Constructor)){throw new TypeError("Cannot call a class as a function")}}function _defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||false;descriptor.configurable=true;if("value"in descriptor)descriptor.writable=true;Object.defineProperty(target,descriptor.key,descriptor)}}function _create_class(Constructor,protoProps,staticProps){if(protoProps)_defineProperties(Constructor.prototype,protoProps);if(staticProps)_defineProperties(Constructor,staticProps);return Constructor}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 _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)}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}}}function _ts_values(o){var s=typeof Symbol==="function"&&Symbol.iterator,m=s&&o[s],i=0;if(m)return m.call(o);if(o&&typeof o.length==="number")return{next:function(){if(o&&i>=o.length)o=void 0;return{value:o&&o[i++],done:!o}}};throw new TypeError(s?"Object is not iterable.":"Symbol.iterator is not defined.")}var BaseModelClass=/*#__PURE__*/function(){"use strict";function BaseModelClass(){_class_call_check(this,BaseModelClass);_define_property(this,"modelName","Unknown")}_create_class(BaseModelClass,[{key:"getDB",value:function getDB(which){return _db.DB.getDB(which)}},{key:"getPuri",value:function getPuri(which){var trx=_db.DB.getTransactionContext().getTransaction(which);if(trx){return trx}var db=this.getDB(which);return new _puriwrapper.PuriWrapper(db,this.getUpsertBuilder())}},{key:"destroy",value:function destroy(){return _async_to_generator(function(){return _ts_generator(this,function(_state){return[2,_db.DB.destroy()]})})()}},{key:"myNow",value:function myNow(timestamp){var dt=timestamp===undefined?_luxon.DateTime.local():_luxon.DateTime.fromSeconds(timestamp);return dt.toFormat("yyyy-MM-dd HH:mm:ss")}},{key:"getInsertedIds",value:function getInsertedIds(wdb,rows,tableName,unqKeyFields){var chunkSize=arguments.length>4&&arguments[4]!==void 0?arguments[4]:500;return _async_to_generator(function(){var unqKeys,whereInField,selectField,chunks,resultIds,_iteratorNormalCompletion,_didIteratorError,_iteratorError,_iterator,_step,_$chunk,dbRows,err;return _ts_generator(this,function(_state){switch(_state.label){case 0:if(!wdb){wdb=this.getDB("w")}if(unqKeyFields.length>1){whereInField=wdb.raw("CONCAT_WS('_', '".concat(unqKeyFields.join(","),"')"));selectField="".concat(whereInField," as tmpUid");unqKeys=rows.map(function(row){return unqKeyFields.map(function(field){return row[field]}).join("_")})}else{whereInField=unqKeyFields[0];selectField=unqKeyFields[0];unqKeys=rows.map(function(row){return row[unqKeyFields[0]]})}chunks=(0,_lodash.chunk)(unqKeys,chunkSize);resultIds=[];_iteratorNormalCompletion=true,_didIteratorError=false,_iteratorError=undefined;_state.label=1;case 1:_state.trys.push([1,6,7,8]);_iterator=chunks[Symbol.iterator]();_state.label=2;case 2:if(!!(_iteratorNormalCompletion=(_step=_iterator.next()).done))return[3,5];_$chunk=_step.value;return[4,wdb(tableName).select("id",wdb.raw(selectField)).whereIn(whereInField,_$chunk)];case 3:dbRows=_state.sent();resultIds=resultIds.concat(dbRows.map(function(dbRow){return parseInt(dbRow.id)}));_state.label=4;case 4:_iteratorNormalCompletion=true;return[3,2];case 5:return[3,8];case 6:err=_state.sent();_didIteratorError=true;_iteratorError=err;return[3,8];case 7:try{if(!_iteratorNormalCompletion&&_iterator.return!=null){_iterator.return()}}finally{if(_didIteratorError){throw _iteratorError}}return[7];case 8:return[2,resultIds]}})}).call(this)}},{key:"useLoaders",value:function useLoaders(db,rows,loaders){return _async_to_generator(function(){var _this,_iteratorNormalCompletion,_didIteratorError,_iteratorError,_this1,_loop,_iterator,_step,err;return _ts_generator(this,function(_state){switch(_state.label){case 0:_this=this;if(loaders.length===0){return[2,rows]}_iteratorNormalCompletion=true,_didIteratorError=false,_iteratorError=undefined;_state.label=1;case 1:_state.trys.push([1,6,7,8]);_loop=function(){var loader,subQ,subRows,toCol,fromIds,idColumn,idColumn1,subRowGroups;return _ts_generator(this,function(_state){switch(_state.label){case 0:loader=_step.value;subQ=void 0;subRows=void 0;toCol=void 0;fromIds=rows.map(function(row){return row[loader.manyJoin.idField]});if(loader.manyJoin.through===undefined){idColumn="".concat(loader.manyJoin.toTable,".").concat(loader.manyJoin.toCol);subQ=db(loader.manyJoin.toTable).whereIn(idColumn,fromIds).select(_to_consumable_array(loader.select).concat([idColumn]));loader.oneJoins.map(function(join){if(join.join=="inner"){subQ.innerJoin("".concat(join.table," as ").concat(join.as),_this.getJoinClause(db,join))}else if(join.join=="outer"){subQ.leftOuterJoin("".concat(join.table," as ").concat(join.as),_this.getJoinClause(db,join))}});toCol=loader.manyJoin.toCol}else{idColumn1="".concat(loader.manyJoin.through.table,".").concat(loader.manyJoin.through.fromCol);subQ=db(loader.manyJoin.through.table).join(loader.manyJoin.toTable,"".concat(loader.manyJoin.through.table,".").concat(loader.manyJoin.through.toCol),"".concat(loader.manyJoin.toTable,".").concat(loader.manyJoin.toCol)).whereIn(idColumn1,fromIds).select((0,_lodash.uniq)(_to_consumable_array(loader.select).concat([idColumn1])));loader.oneJoins.map(function(join){if(join.join=="inner"){subQ.innerJoin("".concat(join.table," as ").concat(join.as),_this.getJoinClause(db,join))}else if(join.join=="outer"){subQ.leftOuterJoin("".concat(join.table," as ").concat(join.as),_this.getJoinClause(db,join))}});toCol=loader.manyJoin.through.fromCol}return[4,subQ];case 1:subRows=_state.sent();if(!loader.loaders)return[3,3];return[4,_this1.useLoaders(db,subRows,loader.loaders)];case 2:subRows=_state.sent();_state.label=3;case 3:subRowGroups=(0,_lodash.groupBy)(subRows,toCol);rows=rows.map(function(row){var _subRowGroups_row_loader_manyJoin_idField;row[loader.as]=((_subRowGroups_row_loader_manyJoin_idField=subRowGroups[row[loader.manyJoin.idField]])!==null&&_subRowGroups_row_loader_manyJoin_idField!==void 0?_subRowGroups_row_loader_manyJoin_idField:[]).map(function(r){return(0,_lodash.omit)(r,toCol)});return row});return[2]}})};_iterator=loaders[Symbol.iterator]();_state.label=2;case 2:if(!!(_iteratorNormalCompletion=(_step=_iterator.next()).done))return[3,5];_this1=this;return[5,_ts_values(_loop())];case 3:_state.sent();_state.label=4;case 4:_iteratorNormalCompletion=true;return[3,2];case 5:return[3,8];case 6:err=_state.sent();_didIteratorError=true;_iteratorError=err;return[3,8];case 7:try{if(!_iteratorNormalCompletion&&_iterator.return!=null){_iterator.return()}}finally{if(_didIteratorError){throw _iteratorError}}return[7];case 8:return[2,rows]}})}).call(this)}},{key:"hydrate",value:function hydrate(rows){var _this=this;return rows.map(function(row){var nestedKeys=Object.keys(row).filter(function(key){return key.includes("__")});var groups=(0,_lodash.groupBy)(nestedKeys,function(key){return key.split("__")[0]});var nullKeys=Object.keys(groups).filter(function(key){return groups[key].length>1&&groups[key].every(function(field){return row[field]===null||Array.isArray(row[field])&&row[field].length===0})});var hydrated=Object.keys(row).reduce(function(r,field){if(!field.includes("__")){if(Array.isArray(row[field])&&(0,_lodash.isObject)(row[field][0])){r[field]=_this.hydrate(row[field]);return r}else{r[field]=row[field];return r}}var parts=field.split("__");var objPath=parts[0]+parts.slice(1).map(function(part){return"[".concat(part,"]")}).join("");(0,_lodash.set)(r,objPath,row[field]&&Array.isArray(row[field])&&(0,_lodash.isObject)(row[field][0])?_this.hydrate(row[field]):row[field]);return r},{});nullKeys.map(function(nullKey){return hydrated[nullKey]=null});return hydrated})}},{key:"runSubsetQuery",value:function runSubsetQuery(_0){return _async_to_generator(function(param){var _this,params,baseTable,subset,subsetQuery,build,afterBuild,debug,_db,optimizeCountQuery,db,_params_queryMode,queryMode,select,virtual,joins,loaders,qb,applyJoinClause,total,rows;return _ts_generator(this,function(_state){switch(_state.label){case 0:_this=this;params=param.params,baseTable=param.baseTable,subset=param.subset,subsetQuery=param.subsetQuery,build=param.build,afterBuild=param.afterBuild,debug=param.debug,_db=param.db,optimizeCountQuery=param.optimizeCountQuery;db=_db!==null&&_db!==void 0?_db:this.getDB(subset.startsWith("A")?"w":"r");baseTable=baseTable!==null&&baseTable!==void 0?baseTable:_inflection.default.pluralize(_inflection.default.underscore(this.modelName));queryMode=(_params_queryMode=params.queryMode)!==null&&_params_queryMode!==void 0?_params_queryMode:params.id!==undefined?"list":"both";select=subsetQuery.select,virtual=subsetQuery.virtual,joins=subsetQuery.joins,loaders=subsetQuery.loaders;qb=build({qb:db.from(baseTable),db:db,select:select,joins:joins,virtual:virtual});applyJoinClause=function(qb,joins){joins.map(function(join){if(join.join=="inner"){qb.innerJoin("".concat(join.table," as ").concat(join.as),_this.getJoinClause(db,join))}else if(join.join=="outer"){qb.leftOuterJoin("".concat(join.table," as ").concat(join.as),_this.getJoinClause(db,join))}})};return[4,function(){return _async_to_generator(function(){var clonedQb,parser,parsedQuery,tables,needToJoin,_afterBuild,processedQb,parsedQuery1,q,countQuery,countRow,_countRow_total;return _ts_generator(this,function(_state){switch(_state.label){case 0:if(queryMode==="list"){return[2,undefined]}clonedQb=qb.clone().clear("order").clear("offset").clear("limit");parser=new _nodesqlparser.default.Parser;if(optimizeCountQuery){parsedQuery=parser.astify(clonedQb.toQuery());tables=(0,_sqlparser.getTableNamesFromWhere)(parsedQuery);needToJoin=(0,_lodash.uniq)(tables.flatMap(function(table){return table.split("__").map(function(t){return _inflection.default.pluralize(t)})}));applyJoinClause(clonedQb,joins.filter(function(j){return needToJoin.includes(j.table)}))}else{applyJoinClause(clonedQb,joins)}processedQb=(_afterBuild=afterBuild===null||afterBuild===void 0?void 0:afterBuild({qb:clonedQb,db:db,select:select,joins:joins,virtual:virtual}))!==null&&_afterBuild!==void 0?_afterBuild:clonedQb;parsedQuery1=parser.astify(processedQb.toQuery());q=Array.isArray(parsedQuery1)?parsedQuery1[0]:parsedQuery1;if(q.type!=="select"){throw new Error("Invalid query")}countQuery=q.distinct!==null?clonedQb.clear("select").select(db.raw("COUNT(DISTINCT `".concat((0,_sqlparser.getTableName)(q.columns[0].expr),"`.`").concat(q.columns[0].expr.column,"`) as total"))).first():clonedQb.clear("select").count("*",{as:"total"}).first();return[4,countQuery];case 1:countRow=_state.sent();if(debug===true||debug==="count"){console.debug("DEBUG: count query",_chalk.default.blue(countQuery.toQuery().toString()))}return[2,(_countRow_total=countRow===null||countRow===void 0?void 0:countRow.total)!==null&&_countRow_total!==void 0?_countRow_total:0]}})})()}()];case 1:total=_state.sent();return[4,function(){return _async_to_generator(function(){var clonedQb,_afterBuild,listQuery,rows;return _ts_generator(this,function(_state){switch(_state.label){case 0:if(queryMode==="count"){return[2,[]]}if(params.num!==0){qb.limit(params.num);qb.offset(params.num*(params.page-1))}clonedQb=qb.clone().select(select);applyJoinClause(clonedQb,joins);listQuery=(_afterBuild=afterBuild===null||afterBuild===void 0?void 0:afterBuild({qb:clonedQb,db:db,select:select,joins:joins,virtual:virtual}))!==null&&_afterBuild!==void 0?_afterBuild:clonedQb;return[4,listQuery];case 1:rows=_state.sent();if(debug===true||debug==="list"){console.debug("DEBUG: list query",_chalk.default.blue(listQuery.toQuery().toString()))}return[4,this.useLoaders(db,rows,loaders)];case 2:rows=_state.sent();rows=this.hydrate(rows);return[2,rows]}})}).call(_this)}()];case 2:rows=_state.sent();return[2,{rows:rows,total:total,subsetQuery:subsetQuery,qb:qb}]}})}).apply(this,arguments)}},{key:"getJoinClause",value:function getJoinClause(db,join){if(!(0,_types.isCustomJoinClause)(join)){return db.raw("".concat(join.from," = ").concat(join.to))}else{return db.raw(join.custom)}}},{key:"getUpsertBuilder",value:function getUpsertBuilder(){return new _upsertbuilder.UpsertBuilder}}]);return BaseModelClass}();var BaseModel=new BaseModelClass;
|
|
2
|
-
|
|
1
|
+
import { DateTime } from "luxon";
|
|
2
|
+
import { chunk, groupBy, isObject, omit, set, uniq } from "lodash-es";
|
|
3
|
+
import { DB } from "./db.js";
|
|
4
|
+
import { isCustomJoinClause } from "../types/types.js";
|
|
5
|
+
import inflection from "inflection";
|
|
6
|
+
import chalk from "chalk";
|
|
7
|
+
import { UpsertBuilder } from "./upsert-builder.js";
|
|
8
|
+
import SqlParser from "node-sql-parser";
|
|
9
|
+
import { getTableName, getTableNamesFromWhere } from "../utils/sql-parser.js";
|
|
10
|
+
import { PuriWrapper } from "./puri-wrapper.js";
|
|
11
|
+
export class BaseModelClass {
|
|
12
|
+
modelName = "Unknown";
|
|
13
|
+
/* DB 인스턴스 get, destroy */ getDB(which) {
|
|
14
|
+
return DB.getDB(which);
|
|
15
|
+
}
|
|
16
|
+
getPuri(which) {
|
|
17
|
+
// 트랜잭션 컨텍스트에서 트랜잭션 획득
|
|
18
|
+
const trx = DB.getTransactionContext().getTransaction(which);
|
|
19
|
+
if (trx) {
|
|
20
|
+
return trx;
|
|
21
|
+
}
|
|
22
|
+
// 트랜잭션이 없으면 새로운 PuriWrapper 반환
|
|
23
|
+
const db = this.getDB(which);
|
|
24
|
+
return new PuriWrapper(db, this.getUpsertBuilder());
|
|
25
|
+
}
|
|
26
|
+
async destroy() {
|
|
27
|
+
return DB.destroy();
|
|
28
|
+
}
|
|
29
|
+
myNow(timestamp) {
|
|
30
|
+
const dt = timestamp === undefined ? DateTime.local() : DateTime.fromSeconds(timestamp);
|
|
31
|
+
return dt.toFormat("yyyy-MM-dd HH:mm:ss");
|
|
32
|
+
}
|
|
33
|
+
async getInsertedIds(wdb, rows, tableName, unqKeyFields, chunkSize = 500) {
|
|
34
|
+
if (!wdb) {
|
|
35
|
+
wdb = this.getDB("w");
|
|
36
|
+
}
|
|
37
|
+
let unqKeys;
|
|
38
|
+
let whereInField, selectField;
|
|
39
|
+
if (unqKeyFields.length > 1) {
|
|
40
|
+
whereInField = wdb.raw(`CONCAT_WS('_', '${unqKeyFields.join(",")}')`);
|
|
41
|
+
selectField = `${whereInField} as tmpUid`;
|
|
42
|
+
unqKeys = rows.map((row)=>unqKeyFields.map((field)=>row[field]).join("_"));
|
|
43
|
+
} else {
|
|
44
|
+
whereInField = unqKeyFields[0];
|
|
45
|
+
selectField = unqKeyFields[0];
|
|
46
|
+
unqKeys = rows.map((row)=>row[unqKeyFields[0]]);
|
|
47
|
+
}
|
|
48
|
+
const chunks = chunk(unqKeys, chunkSize);
|
|
49
|
+
let resultIds = [];
|
|
50
|
+
for (let chunk of chunks){
|
|
51
|
+
const dbRows = await wdb(tableName).select("id", wdb.raw(selectField)).whereIn(whereInField, chunk);
|
|
52
|
+
resultIds = resultIds.concat(dbRows.map((dbRow)=>parseInt(dbRow.id)));
|
|
53
|
+
}
|
|
54
|
+
return resultIds;
|
|
55
|
+
}
|
|
56
|
+
async useLoaders(db, rows, loaders) {
|
|
57
|
+
if (loaders.length === 0) {
|
|
58
|
+
return rows;
|
|
59
|
+
}
|
|
60
|
+
for (let loader of loaders){
|
|
61
|
+
let subQ;
|
|
62
|
+
let subRows;
|
|
63
|
+
let toCol;
|
|
64
|
+
const fromIds = rows.map((row)=>row[loader.manyJoin.idField]);
|
|
65
|
+
if (loader.manyJoin.through === undefined) {
|
|
66
|
+
// HasMany
|
|
67
|
+
const idColumn = `${loader.manyJoin.toTable}.${loader.manyJoin.toCol}`;
|
|
68
|
+
subQ = db(loader.manyJoin.toTable).whereIn(idColumn, fromIds).select([
|
|
69
|
+
...loader.select,
|
|
70
|
+
idColumn
|
|
71
|
+
]);
|
|
72
|
+
// HasMany에서 OneJoin이 있는 경우
|
|
73
|
+
loader.oneJoins.map((join)=>{
|
|
74
|
+
if (join.join == "inner") {
|
|
75
|
+
subQ.innerJoin(`${join.table} as ${join.as}`, this.getJoinClause(db, join));
|
|
76
|
+
} else if (join.join == "outer") {
|
|
77
|
+
subQ.leftOuterJoin(`${join.table} as ${join.as}`, this.getJoinClause(db, join));
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
toCol = loader.manyJoin.toCol;
|
|
81
|
+
} else {
|
|
82
|
+
// ManyToMany
|
|
83
|
+
const idColumn = `${loader.manyJoin.through.table}.${loader.manyJoin.through.fromCol}`;
|
|
84
|
+
subQ = db(loader.manyJoin.through.table).join(loader.manyJoin.toTable, `${loader.manyJoin.through.table}.${loader.manyJoin.through.toCol}`, `${loader.manyJoin.toTable}.${loader.manyJoin.toCol}`).whereIn(idColumn, fromIds).select(uniq([
|
|
85
|
+
...loader.select,
|
|
86
|
+
idColumn
|
|
87
|
+
]));
|
|
88
|
+
// ManyToMany에서 OneJoin이 있는 경우
|
|
89
|
+
loader.oneJoins.map((join)=>{
|
|
90
|
+
if (join.join == "inner") {
|
|
91
|
+
subQ.innerJoin(`${join.table} as ${join.as}`, this.getJoinClause(db, join));
|
|
92
|
+
} else if (join.join == "outer") {
|
|
93
|
+
subQ.leftOuterJoin(`${join.table} as ${join.as}`, this.getJoinClause(db, join));
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
toCol = loader.manyJoin.through.fromCol;
|
|
97
|
+
}
|
|
98
|
+
subRows = await subQ;
|
|
99
|
+
if (loader.loaders) {
|
|
100
|
+
// 추가 -Many 케이스가 있는 경우 recursion 처리
|
|
101
|
+
subRows = await this.useLoaders(db, subRows, loader.loaders);
|
|
102
|
+
}
|
|
103
|
+
// 불러온 row들을 참조ID 기준으로 분류 배치
|
|
104
|
+
const subRowGroups = groupBy(subRows, toCol);
|
|
105
|
+
rows = rows.map((row)=>{
|
|
106
|
+
row[loader.as] = (subRowGroups[row[loader.manyJoin.idField]] ?? []).map((r)=>omit(r, toCol));
|
|
107
|
+
return row;
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
return rows;
|
|
111
|
+
}
|
|
112
|
+
hydrate(rows) {
|
|
113
|
+
return rows.map((row)=>{
|
|
114
|
+
// nullable relation인 경우 관련된 필드가 전부 null로 생성되는 것 방지하는 코드
|
|
115
|
+
const nestedKeys = Object.keys(row).filter((key)=>key.includes("__"));
|
|
116
|
+
const groups = groupBy(nestedKeys, (key)=>key.split("__")[0]);
|
|
117
|
+
const nullKeys = Object.keys(groups).filter((key)=>groups[key].length > 1 && groups[key].every((field)=>row[field] === null || Array.isArray(row[field]) && row[field].length === 0));
|
|
118
|
+
const hydrated = Object.keys(row).reduce((r, field)=>{
|
|
119
|
+
if (!field.includes("__")) {
|
|
120
|
+
if (Array.isArray(row[field]) && isObject(row[field][0])) {
|
|
121
|
+
r[field] = this.hydrate(row[field]);
|
|
122
|
+
return r;
|
|
123
|
+
} else {
|
|
124
|
+
r[field] = row[field];
|
|
125
|
+
return r;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
const parts = field.split("__");
|
|
129
|
+
const objPath = parts[0] + parts.slice(1).map((part)=>`[${part}]`).join("");
|
|
130
|
+
set(r, objPath, row[field] && Array.isArray(row[field]) && isObject(row[field][0]) ? this.hydrate(row[field]) : row[field]);
|
|
131
|
+
return r;
|
|
132
|
+
}, {});
|
|
133
|
+
nullKeys.map((nullKey)=>hydrated[nullKey] = null);
|
|
134
|
+
return hydrated;
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
async runSubsetQuery({ params, baseTable, subset, subsetQuery, build, afterBuild, debug, db: _db, optimizeCountQuery }) {
|
|
138
|
+
const db = _db ?? this.getDB(subset.startsWith("A") ? "w" : "r");
|
|
139
|
+
baseTable = baseTable ?? inflection.pluralize(inflection.underscore(this.modelName));
|
|
140
|
+
const queryMode = params.queryMode ?? (params.id !== undefined ? "list" : "both");
|
|
141
|
+
const { select, virtual, joins, loaders } = subsetQuery;
|
|
142
|
+
const qb = build({
|
|
143
|
+
qb: db.from(baseTable),
|
|
144
|
+
db,
|
|
145
|
+
select,
|
|
146
|
+
joins,
|
|
147
|
+
virtual
|
|
148
|
+
});
|
|
149
|
+
const applyJoinClause = (qb, joins)=>{
|
|
150
|
+
joins.map((join)=>{
|
|
151
|
+
if (join.join == "inner") {
|
|
152
|
+
qb.innerJoin(`${join.table} as ${join.as}`, this.getJoinClause(db, join));
|
|
153
|
+
} else if (join.join == "outer") {
|
|
154
|
+
qb.leftOuterJoin(`${join.table} as ${join.as}`, this.getJoinClause(db, join));
|
|
155
|
+
}
|
|
156
|
+
});
|
|
157
|
+
};
|
|
158
|
+
// countQuery
|
|
159
|
+
const total = await (async ()=>{
|
|
160
|
+
if (queryMode === "list") {
|
|
161
|
+
return undefined;
|
|
162
|
+
}
|
|
163
|
+
const clonedQb = qb.clone().clear("order").clear("offset").clear("limit");
|
|
164
|
+
const parser = new SqlParser.Parser();
|
|
165
|
+
// optmizeCountQuery가 true인 경우 다른 clause에 영향을 주지 않는 모든 join을 제외함
|
|
166
|
+
if (optimizeCountQuery) {
|
|
167
|
+
const parsedQuery = parser.astify(clonedQb.toQuery());
|
|
168
|
+
const tables = getTableNamesFromWhere(parsedQuery);
|
|
169
|
+
// where절에 사용되는 테이블의 조인을 위해 사용되는 테이블
|
|
170
|
+
const needToJoin = uniq(tables.flatMap((table)=>table.split("__").map((t)=>inflection.pluralize(t))));
|
|
171
|
+
applyJoinClause(clonedQb, joins.filter((j)=>needToJoin.includes(j.table)));
|
|
172
|
+
} else {
|
|
173
|
+
applyJoinClause(clonedQb, joins);
|
|
174
|
+
}
|
|
175
|
+
const processedQb = afterBuild?.({
|
|
176
|
+
qb: clonedQb,
|
|
177
|
+
db,
|
|
178
|
+
select,
|
|
179
|
+
joins,
|
|
180
|
+
virtual
|
|
181
|
+
}) ?? clonedQb;
|
|
182
|
+
const parsedQuery = parser.astify(processedQb.toQuery());
|
|
183
|
+
const q = Array.isArray(parsedQuery) ? parsedQuery[0] : parsedQuery;
|
|
184
|
+
if (q.type !== "select") {
|
|
185
|
+
throw new Error("Invalid query");
|
|
186
|
+
}
|
|
187
|
+
const countQuery = q.distinct !== null ? clonedQb.clear("select").select(db.raw(`COUNT(DISTINCT \`${getTableName(q.columns[0].expr)}\`.\`${q.columns[0].expr.column}\`) as total`)).first() : clonedQb.clear("select").count("*", {
|
|
188
|
+
as: "total"
|
|
189
|
+
}).first();
|
|
190
|
+
const countRow = await countQuery;
|
|
191
|
+
// debug: countQuery
|
|
192
|
+
if (debug === true || debug === "count") {
|
|
193
|
+
console.debug("DEBUG: count query", chalk.blue(countQuery.toQuery().toString()));
|
|
194
|
+
}
|
|
195
|
+
return countRow?.total ?? 0;
|
|
196
|
+
})();
|
|
197
|
+
// listQuery
|
|
198
|
+
const rows = await (async ()=>{
|
|
199
|
+
if (queryMode === "count") {
|
|
200
|
+
return [];
|
|
201
|
+
}
|
|
202
|
+
// limit, offset
|
|
203
|
+
if (params.num !== 0) {
|
|
204
|
+
qb.limit(params.num);
|
|
205
|
+
qb.offset(params.num * (params.page - 1));
|
|
206
|
+
}
|
|
207
|
+
// select, rows
|
|
208
|
+
const clonedQb = qb.clone().select(select);
|
|
209
|
+
// join
|
|
210
|
+
applyJoinClause(clonedQb, joins);
|
|
211
|
+
const listQuery = afterBuild?.({
|
|
212
|
+
qb: clonedQb,
|
|
213
|
+
db,
|
|
214
|
+
select,
|
|
215
|
+
joins,
|
|
216
|
+
virtual
|
|
217
|
+
}) ?? clonedQb;
|
|
218
|
+
let rows = await listQuery;
|
|
219
|
+
// debug: listQuery
|
|
220
|
+
if (debug === true || debug === "list") {
|
|
221
|
+
console.debug("DEBUG: list query", chalk.blue(listQuery.toQuery().toString()));
|
|
222
|
+
}
|
|
223
|
+
rows = await this.useLoaders(db, rows, loaders);
|
|
224
|
+
rows = this.hydrate(rows);
|
|
225
|
+
return rows;
|
|
226
|
+
})();
|
|
227
|
+
return {
|
|
228
|
+
rows,
|
|
229
|
+
total,
|
|
230
|
+
subsetQuery,
|
|
231
|
+
qb
|
|
232
|
+
};
|
|
233
|
+
}
|
|
234
|
+
getJoinClause(db, join) {
|
|
235
|
+
if (!isCustomJoinClause(join)) {
|
|
236
|
+
return db.raw(`${join.from} = ${join.to}`);
|
|
237
|
+
} else {
|
|
238
|
+
return db.raw(join.custom);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
getUpsertBuilder() {
|
|
242
|
+
return new UpsertBuilder();
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
export const BaseModel = new BaseModelClass();
|
|
246
|
+
|
|
247
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/database/base-model.ts"],"sourcesContent":["import { DateTime } from \"luxon\";\nimport { Knex } from \"knex\";\nimport { chunk, groupBy, isObject, omit, set, uniq } from \"lodash-es\";\nimport { DBPreset, DB } from \"./db\";\nimport { isCustomJoinClause, type SubsetQuery } from \"../types/types\";\nimport type { BaseListParams } from \"../utils/model\";\nimport inflection from \"inflection\";\nimport chalk from \"chalk\";\nimport { UpsertBuilder } from \"./upsert-builder\";\nimport SqlParser from \"node-sql-parser\";\nimport { getTableName, getTableNamesFromWhere } from \"../utils/sql-parser\";\nimport { PuriWrapper } from \"./puri-wrapper\";\n\nexport class BaseModelClass {\n  public modelName: string = \"Unknown\";\n\n  /* DB 인스턴스 get, destroy */\n  getDB(which: DBPreset): Knex {\n    return DB.getDB(which);\n  }\n\n  getPuri(which: DBPreset): PuriWrapper {\n    // 트랜잭션 컨텍스트에서 트랜잭션 획득\n    const trx = DB.getTransactionContext().getTransaction(which);\n    if (trx) {\n      return trx;\n    }\n\n    // 트랜잭션이 없으면 새로운 PuriWrapper 반환\n    const db = this.getDB(which);\n    return new PuriWrapper(db, this.getUpsertBuilder());\n  }\n\n  async destroy() {\n    return DB.destroy();\n  }\n\n  myNow(timestamp?: number): string {\n    const dt: DateTime =\n      timestamp === undefined\n        ? DateTime.local()\n        : DateTime.fromSeconds(timestamp);\n    return dt.toFormat(\"yyyy-MM-dd HH:mm:ss\");\n  }\n\n  async getInsertedIds(\n    wdb: Knex,\n    rows: any[],\n    tableName: string,\n    unqKeyFields: string[],\n    chunkSize: number = 500\n  ) {\n    if (!wdb) {\n      wdb = this.getDB(\"w\");\n    }\n\n    let unqKeys: string[];\n    let whereInField: any, selectField: string;\n    if (unqKeyFields.length > 1) {\n      whereInField = wdb.raw(`CONCAT_WS('_', '${unqKeyFields.join(\",\")}')`);\n      selectField = `${whereInField} as tmpUid`;\n      unqKeys = rows.map((row) =>\n        unqKeyFields.map((field) => row[field]).join(\"_\")\n      );\n    } else {\n      whereInField = unqKeyFields[0];\n      selectField = unqKeyFields[0];\n      unqKeys = rows.map((row) => row[unqKeyFields[0]]);\n    }\n    const chunks = chunk(unqKeys, chunkSize);\n\n    let resultIds: number[] = [];\n    for (let chunk of chunks) {\n      const dbRows = await wdb(tableName)\n        .select(\"id\", wdb.raw(selectField))\n        .whereIn(whereInField, chunk);\n      resultIds = resultIds.concat(\n        dbRows.map((dbRow: any) => parseInt(dbRow.id))\n      );\n    }\n\n    return resultIds;\n  }\n\n  async useLoaders(db: Knex, rows: any[], loaders: SubsetQuery[\"loaders\"]) {\n    if (loaders.length === 0) {\n      return rows;\n    }\n\n    for (let loader of loaders) {\n      let subQ: any;\n      let subRows: any[];\n      let toCol: string;\n\n      const fromIds = rows.map((row) => row[loader.manyJoin.idField]);\n\n      if (loader.manyJoin.through === undefined) {\n        // HasMany\n        const idColumn = `${loader.manyJoin.toTable}.${loader.manyJoin.toCol}`;\n        subQ = db(loader.manyJoin.toTable)\n          .whereIn(idColumn, fromIds)\n          .select([...loader.select, idColumn]);\n\n        // HasMany에서 OneJoin이 있는 경우\n        loader.oneJoins.map((join) => {\n          if (join.join == \"inner\") {\n            subQ.innerJoin(\n              `${join.table} as ${join.as}`,\n              this.getJoinClause(db, join)\n            );\n          } else if (join.join == \"outer\") {\n            subQ.leftOuterJoin(\n              `${join.table} as ${join.as}`,\n              this.getJoinClause(db, join)\n            );\n          }\n        });\n        toCol = loader.manyJoin.toCol;\n      } else {\n        // ManyToMany\n        const idColumn = `${loader.manyJoin.through.table}.${loader.manyJoin.through.fromCol}`;\n        subQ = db(loader.manyJoin.through.table)\n          .join(\n            loader.manyJoin.toTable,\n            `${loader.manyJoin.through.table}.${loader.manyJoin.through.toCol}`,\n            `${loader.manyJoin.toTable}.${loader.manyJoin.toCol}`\n          )\n          .whereIn(idColumn, fromIds)\n          .select(uniq([...loader.select, idColumn]));\n\n        // ManyToMany에서 OneJoin이 있는 경우\n        loader.oneJoins.map((join) => {\n          if (join.join == \"inner\") {\n            subQ.innerJoin(\n              `${join.table} as ${join.as}`,\n              this.getJoinClause(db, join)\n            );\n          } else if (join.join == \"outer\") {\n            subQ.leftOuterJoin(\n              `${join.table} as ${join.as}`,\n              this.getJoinClause(db, join)\n            );\n          }\n        });\n        toCol = loader.manyJoin.through.fromCol;\n      }\n      subRows = await subQ;\n\n      if (loader.loaders) {\n        // 추가 -Many 케이스가 있는 경우 recursion 처리\n        subRows = await this.useLoaders(db, subRows, loader.loaders);\n      }\n\n      // 불러온 row들을 참조ID 기준으로 분류 배치\n      const subRowGroups = groupBy(subRows, toCol);\n      rows = rows.map((row) => {\n        row[loader.as] = (subRowGroups[row[loader.manyJoin.idField]] ?? []).map(\n          (r) => omit(r, toCol)\n        );\n        return row;\n      });\n    }\n    return rows;\n  }\n\n  hydrate<T>(rows: T[]): T[] {\n    return rows.map((row: any) => {\n      // nullable relation인 경우 관련된 필드가 전부 null로 생성되는 것 방지하는 코드\n      const nestedKeys = Object.keys(row).filter((key) => key.includes(\"__\"));\n      const groups = groupBy(nestedKeys, (key) => key.split(\"__\")[0]);\n      const nullKeys = Object.keys(groups).filter(\n        (key) =>\n          groups[key].length > 1 &&\n          groups[key].every(\n            (field) =>\n              row[field] === null ||\n              (Array.isArray(row[field]) && row[field].length === 0)\n          )\n      );\n\n      const hydrated = Object.keys(row).reduce((r, field) => {\n        if (!field.includes(\"__\")) {\n          if (Array.isArray(row[field]) && isObject(row[field][0])) {\n            r[field] = this.hydrate(row[field]);\n            return r;\n          } else {\n            r[field] = row[field];\n            return r;\n          }\n        }\n\n        const parts = field.split(\"__\");\n        const objPath =\n          parts[0] +\n          parts\n            .slice(1)\n            .map((part) => `[${part}]`)\n            .join(\"\");\n        set(\n          r,\n          objPath,\n          row[field] && Array.isArray(row[field]) && isObject(row[field][0])\n            ? this.hydrate(row[field])\n            : row[field]\n        );\n\n        return r;\n      }, {} as any);\n      nullKeys.map((nullKey) => (hydrated[nullKey] = null));\n\n      return hydrated;\n    });\n  }\n\n  async runSubsetQuery<T extends BaseListParams, U extends string>({\n    params,\n    baseTable,\n    subset,\n    subsetQuery,\n    build,\n    afterBuild,\n    debug,\n    db: _db,\n    optimizeCountQuery,\n  }: {\n    subset: U;\n    params: T;\n    subsetQuery: SubsetQuery;\n    build: (buildParams: {\n      qb: Knex.QueryBuilder;\n      db: Knex;\n      select: (string | Knex.Raw)[];\n      joins: SubsetQuery[\"joins\"];\n      virtual: string[];\n    }) => Knex.QueryBuilder;\n    afterBuild?: (buildParams: {\n      qb: Knex.QueryBuilder;\n      db: Knex;\n      select: (string | Knex.Raw)[];\n      joins: SubsetQuery[\"joins\"];\n      virtual: string[];\n    }) => Knex.QueryBuilder;\n    baseTable?: string;\n    debug?: boolean | \"list\" | \"count\";\n    db?: Knex;\n    optimizeCountQuery?: boolean;\n  }): Promise<{\n    rows: any[];\n    total?: number | undefined;\n    subsetQuery: SubsetQuery;\n    qb: Knex.QueryBuilder;\n  }> {\n    const db = _db ?? this.getDB(subset.startsWith(\"A\") ? \"w\" : \"r\");\n    baseTable =\n      baseTable ?? inflection.pluralize(inflection.underscore(this.modelName));\n    const queryMode =\n      params.queryMode ?? (params.id !== undefined ? \"list\" : \"both\");\n\n    const { select, virtual, joins, loaders } = subsetQuery;\n    const qb = build({\n      qb: db.from(baseTable),\n      db,\n      select,\n      joins,\n      virtual,\n    });\n\n    const applyJoinClause = (\n      qb: Knex.QueryBuilder,\n      joins: SubsetQuery[\"joins\"]\n    ) => {\n      joins.map((join) => {\n        if (join.join == \"inner\") {\n          qb.innerJoin(\n            `${join.table} as ${join.as}`,\n            this.getJoinClause(db, join)\n          );\n        } else if (join.join == \"outer\") {\n          qb.leftOuterJoin(\n            `${join.table} as ${join.as}`,\n            this.getJoinClause(db, join)\n          );\n        }\n      });\n    };\n\n    // countQuery\n    const total = await (async () => {\n      if (queryMode === \"list\") {\n        return undefined;\n      }\n\n      const clonedQb = qb.clone().clear(\"order\").clear(\"offset\").clear(\"limit\");\n      const parser = new SqlParser.Parser();\n\n      // optmizeCountQuery가 true인 경우 다른 clause에 영향을 주지 않는 모든 join을 제외함\n      if (optimizeCountQuery) {\n        const parsedQuery = parser.astify(clonedQb.toQuery());\n        const tables = getTableNamesFromWhere(parsedQuery);\n        // where절에 사용되는 테이블의 조인을 위해 사용되는 테이블\n        const needToJoin = uniq(\n          tables.flatMap((table) =>\n            table.split(\"__\").map((t) => inflection.pluralize(t))\n          )\n        );\n        applyJoinClause(\n          clonedQb,\n          joins.filter((j) => needToJoin.includes(j.table))\n        );\n      } else {\n        applyJoinClause(clonedQb, joins);\n      }\n\n      const processedQb =\n        afterBuild?.({\n          qb: clonedQb,\n          db,\n          select,\n          joins,\n          virtual,\n        }) ?? clonedQb;\n\n      const parsedQuery = parser.astify(processedQb.toQuery());\n      const q = Array.isArray(parsedQuery) ? parsedQuery[0] : parsedQuery;\n      if (q.type !== \"select\") {\n        throw new Error(\"Invalid query\");\n      }\n\n      const countQuery =\n        q.distinct !== null\n          ? clonedQb\n              .clear(\"select\")\n              .select(\n                db.raw(\n                  `COUNT(DISTINCT \\`${getTableName(q.columns[0].expr)}\\`.\\`${q.columns[0].expr.column}\\`) as total`\n                )\n              )\n              .first()\n          : clonedQb.clear(\"select\").count(\"*\", { as: \"total\" }).first();\n      const countRow: { total?: number } = await countQuery;\n\n      // debug: countQuery\n      if (debug === true || debug === \"count\") {\n        console.debug(\n          \"DEBUG: count query\",\n          chalk.blue(countQuery.toQuery().toString())\n        );\n      }\n\n      return countRow?.total ?? 0;\n    })();\n\n    // listQuery\n    const rows = await (async () => {\n      if (queryMode === \"count\") {\n        return [];\n      }\n\n      // limit, offset\n      if (params.num !== 0) {\n        qb.limit(params.num!);\n        qb.offset(params.num! * (params.page! - 1));\n      }\n\n      // select, rows\n      const clonedQb = qb.clone().select(select);\n\n      // join\n      applyJoinClause(clonedQb, joins);\n\n      const listQuery =\n        afterBuild?.({\n          qb: clonedQb,\n          db,\n          select,\n          joins,\n          virtual,\n        }) ?? clonedQb;\n\n      let rows = await listQuery;\n      // debug: listQuery\n      if (debug === true || debug === \"list\") {\n        console.debug(\n          \"DEBUG: list query\",\n          chalk.blue(listQuery.toQuery().toString())\n        );\n      }\n\n      rows = await this.useLoaders(db, rows, loaders);\n      rows = this.hydrate(rows);\n      return rows;\n    })();\n\n    return { rows, total, subsetQuery, qb };\n  }\n\n  getJoinClause(\n    db: Knex<any, unknown>,\n    join: SubsetQuery[\"joins\"][number]\n  ): Knex.Raw<any> {\n    if (!isCustomJoinClause(join)) {\n      return db.raw(`${join.from} = ${join.to}`);\n    } else {\n      return db.raw(join.custom);\n    }\n  }\n\n  getUpsertBuilder(): UpsertBuilder {\n    return new UpsertBuilder();\n  }\n}\nexport const BaseModel = new BaseModelClass();\n"],"names":["DateTime","chunk","groupBy","isObject","omit","set","uniq","DB","isCustomJoinClause","inflection","chalk","UpsertBuilder","SqlParser","getTableName","getTableNamesFromWhere","PuriWrapper","BaseModelClass","modelName","getDB","which","getPuri","trx","getTransactionContext","getTransaction","db","getUpsertBuilder","destroy","myNow","timestamp","dt","undefined","local","fromSeconds","toFormat","getInsertedIds","wdb","rows","tableName","unqKeyFields","chunkSize","unqKeys","whereInField","selectField","length","raw","join","map","row","field","chunks","resultIds","dbRows","select","whereIn","concat","dbRow","parseInt","id","useLoaders","loaders","loader","subQ","subRows","toCol","fromIds","manyJoin","idField","through","idColumn","toTable","oneJoins","innerJoin","table","as","getJoinClause","leftOuterJoin","fromCol","subRowGroups","r","hydrate","nestedKeys","Object","keys","filter","key","includes","groups","split","nullKeys","every","Array","isArray","hydrated","reduce","parts","objPath","slice","part","nullKey","runSubsetQuery","params","baseTable","subset","subsetQuery","build","afterBuild","debug","_db","optimizeCountQuery","startsWith","pluralize","underscore","queryMode","virtual","joins","qb","from","applyJoinClause","total","clonedQb","clone","clear","parser","Parser","parsedQuery","astify","toQuery","tables","needToJoin","flatMap","t","j","processedQb","q","type","Error","countQuery","distinct","columns","expr","column","first","count","countRow","console","blue","toString","num","limit","offset","page","listQuery","to","custom","BaseModel"],"mappings":"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"}
|
|
@@ -1,2 +1,53 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import * as _ from "lodash-es";
|
|
2
|
+
import equal from "fast-deep-equal";
|
|
3
|
+
export class CodeGenerator {
|
|
4
|
+
getAlterColumnsTo(entityColumns, dbColumns) {
|
|
5
|
+
const columnsTo = {
|
|
6
|
+
add: [],
|
|
7
|
+
drop: [],
|
|
8
|
+
alter: []
|
|
9
|
+
};
|
|
10
|
+
// 컬럼명 기준 비교
|
|
11
|
+
const extraColumns = {
|
|
12
|
+
db: _.differenceBy(dbColumns, entityColumns, (col)=>col.name),
|
|
13
|
+
entity: _.differenceBy(entityColumns, dbColumns, (col)=>col.name)
|
|
14
|
+
};
|
|
15
|
+
if (extraColumns.entity.length > 0) {
|
|
16
|
+
columnsTo.add = columnsTo.add.concat(extraColumns.entity);
|
|
17
|
+
}
|
|
18
|
+
if (extraColumns.db.length > 0) {
|
|
19
|
+
columnsTo.drop = columnsTo.drop.concat(extraColumns.db);
|
|
20
|
+
}
|
|
21
|
+
// 동일 컬럼명의 세부 필드 비교
|
|
22
|
+
const sameDbColumns = _.intersectionBy(dbColumns, entityColumns, (col)=>col.name);
|
|
23
|
+
const sameMdColumns = _.intersectionBy(entityColumns, dbColumns, (col)=>col.name);
|
|
24
|
+
columnsTo.alter = _.differenceWith(sameDbColumns, sameMdColumns, (a, b)=>equal(a, b));
|
|
25
|
+
return columnsTo;
|
|
26
|
+
}
|
|
27
|
+
getAlterIndexesTo(entityIndexes, dbIndexes) {
|
|
28
|
+
// 인덱스 비교
|
|
29
|
+
let indexesTo = {
|
|
30
|
+
add: [],
|
|
31
|
+
drop: []
|
|
32
|
+
};
|
|
33
|
+
const extraIndexes = {
|
|
34
|
+
db: _.differenceBy(dbIndexes, entityIndexes, (col)=>[
|
|
35
|
+
col.type,
|
|
36
|
+
col.columns.join("-")
|
|
37
|
+
].join("//")),
|
|
38
|
+
entity: _.differenceBy(entityIndexes, dbIndexes, (col)=>[
|
|
39
|
+
col.type,
|
|
40
|
+
col.columns.join("-")
|
|
41
|
+
].join("//"))
|
|
42
|
+
};
|
|
43
|
+
if (extraIndexes.entity.length > 0) {
|
|
44
|
+
indexesTo.add = indexesTo.add.concat(extraIndexes.entity);
|
|
45
|
+
}
|
|
46
|
+
if (extraIndexes.db.length > 0) {
|
|
47
|
+
indexesTo.drop = indexesTo.drop.concat(extraIndexes.db);
|
|
48
|
+
}
|
|
49
|
+
return indexesTo;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhYmFzZS9jb2RlLWdlbmVyYXRvci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBfIGZyb20gXCJsb2Rhc2gtZXNcIjtcbmltcG9ydCBlcXVhbCBmcm9tIFwiZmFzdC1kZWVwLWVxdWFsXCI7XG5pbXBvcnQgeyBNaWdyYXRpb25Db2x1bW4sIE1pZ3JhdGlvbkluZGV4IH0gZnJvbSBcIi4uL3R5cGVzL3R5cGVzXCI7XG5cbmV4cG9ydCBjbGFzcyBDb2RlR2VuZXJhdG9yIHtcbiAgZ2V0QWx0ZXJDb2x1bW5zVG8oXG4gICAgZW50aXR5Q29sdW1uczogTWlncmF0aW9uQ29sdW1uW10sXG4gICAgZGJDb2x1bW5zOiBNaWdyYXRpb25Db2x1bW5bXVxuICApIHtcbiAgICBjb25zdCBjb2x1bW5zVG8gPSB7XG4gICAgICBhZGQ6IFtdIGFzIE1pZ3JhdGlvbkNvbHVtbltdLFxuICAgICAgZHJvcDogW10gYXMgTWlncmF0aW9uQ29sdW1uW10sXG4gICAgICBhbHRlcjogW10gYXMgTWlncmF0aW9uQ29sdW1uW10sXG4gICAgfTtcblxuICAgIC8vIOy7rOufvOuqhSDquLDspIAg67mE6rWQXG4gICAgY29uc3QgZXh0cmFDb2x1bW5zID0ge1xuICAgICAgZGI6IF8uZGlmZmVyZW5jZUJ5KGRiQ29sdW1ucywgZW50aXR5Q29sdW1ucywgKGNvbCkgPT4gY29sLm5hbWUpLFxuICAgICAgZW50aXR5OiBfLmRpZmZlcmVuY2VCeShlbnRpdHlDb2x1bW5zLCBkYkNvbHVtbnMsIChjb2wpID0+IGNvbC5uYW1lKSxcbiAgICB9O1xuICAgIGlmIChleHRyYUNvbHVtbnMuZW50aXR5Lmxlbmd0aCA+IDApIHtcbiAgICAgIGNvbHVtbnNUby5hZGQgPSBjb2x1bW5zVG8uYWRkLmNvbmNhdChleHRyYUNvbHVtbnMuZW50aXR5KTtcbiAgICB9XG4gICAgaWYgKGV4dHJhQ29sdW1ucy5kYi5sZW5ndGggPiAwKSB7XG4gICAgICBjb2x1bW5zVG8uZHJvcCA9IGNvbHVtbnNUby5kcm9wLmNvbmNhdChleHRyYUNvbHVtbnMuZGIpO1xuICAgIH1cblxuICAgIC8vIOuPmeydvCDsu6zrn7zrqoXsnZgg7IS467aAIO2VhOuTnCDruYTqtZBcbiAgICBjb25zdCBzYW1lRGJDb2x1bW5zID0gXy5pbnRlcnNlY3Rpb25CeShcbiAgICAgIGRiQ29sdW1ucyxcbiAgICAgIGVudGl0eUNvbHVtbnMsXG4gICAgICAoY29sKSA9PiBjb2wubmFtZVxuICAgICk7XG4gICAgY29uc3Qgc2FtZU1kQ29sdW1ucyA9IF8uaW50ZXJzZWN0aW9uQnkoXG4gICAgICBlbnRpdHlDb2x1bW5zLFxuICAgICAgZGJDb2x1bW5zLFxuICAgICAgKGNvbCkgPT4gY29sLm5hbWVcbiAgICApO1xuICAgIGNvbHVtbnNUby5hbHRlciA9IF8uZGlmZmVyZW5jZVdpdGgoc2FtZURiQ29sdW1ucywgc2FtZU1kQ29sdW1ucywgKGEsIGIpID0+XG4gICAgICBlcXVhbChhLCBiKVxuICAgICk7XG5cbiAgICByZXR1cm4gY29sdW1uc1RvO1xuICB9XG5cbiAgZ2V0QWx0ZXJJbmRleGVzVG8oXG4gICAgZW50aXR5SW5kZXhlczogTWlncmF0aW9uSW5kZXhbXSxcbiAgICBkYkluZGV4ZXM6IE1pZ3JhdGlvbkluZGV4W11cbiAgKSB7XG4gICAgLy8g7J24642x7IqkIOu5hOq1kFxuICAgIGxldCBpbmRleGVzVG8gPSB7XG4gICAgICBhZGQ6IFtdIGFzIE1pZ3JhdGlvbkluZGV4W10sXG4gICAgICBkcm9wOiBbXSBhcyBNaWdyYXRpb25JbmRleFtdLFxuICAgIH07XG4gICAgY29uc3QgZXh0cmFJbmRleGVzID0ge1xuICAgICAgZGI6IF8uZGlmZmVyZW5jZUJ5KGRiSW5kZXhlcywgZW50aXR5SW5kZXhlcywgKGNvbCkgPT5cbiAgICAgICAgW2NvbC50eXBlLCBjb2wuY29sdW1ucy5qb2luKFwiLVwiKV0uam9pbihcIi8vXCIpXG4gICAgICApLFxuICAgICAgZW50aXR5OiBfLmRpZmZlcmVuY2VCeShlbnRpdHlJbmRleGVzLCBkYkluZGV4ZXMsIChjb2wpID0+XG4gICAgICAgIFtjb2wudHlwZSwgY29sLmNvbHVtbnMuam9pbihcIi1cIildLmpvaW4oXCIvL1wiKVxuICAgICAgKSxcbiAgICB9O1xuICAgIGlmIChleHRyYUluZGV4ZXMuZW50aXR5Lmxlbmd0aCA+IDApIHtcbiAgICAgIGluZGV4ZXNUby5hZGQgPSBpbmRleGVzVG8uYWRkLmNvbmNhdChleHRyYUluZGV4ZXMuZW50aXR5KTtcbiAgICB9XG4gICAgaWYgKGV4dHJhSW5kZXhlcy5kYi5sZW5ndGggPiAwKSB7XG4gICAgICBpbmRleGVzVG8uZHJvcCA9IGluZGV4ZXNUby5kcm9wLmNvbmNhdChleHRyYUluZGV4ZXMuZGIpO1xuICAgIH1cblxuICAgIHJldHVybiBpbmRleGVzVG87XG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJfIiwiZXF1YWwiLCJDb2RlR2VuZXJhdG9yIiwiZ2V0QWx0ZXJDb2x1bW5zVG8iLCJlbnRpdHlDb2x1bW5zIiwiZGJDb2x1bW5zIiwiY29sdW1uc1RvIiwiYWRkIiwiZHJvcCIsImFsdGVyIiwiZXh0cmFDb2x1bW5zIiwiZGIiLCJkaWZmZXJlbmNlQnkiLCJjb2wiLCJuYW1lIiwiZW50aXR5IiwibGVuZ3RoIiwiY29uY2F0Iiwic2FtZURiQ29sdW1ucyIsImludGVyc2VjdGlvbkJ5Iiwic2FtZU1kQ29sdW1ucyIsImRpZmZlcmVuY2VXaXRoIiwiYSIsImIiLCJnZXRBbHRlckluZGV4ZXNUbyIsImVudGl0eUluZGV4ZXMiLCJkYkluZGV4ZXMiLCJpbmRleGVzVG8iLCJleHRyYUluZGV4ZXMiLCJ0eXBlIiwiY29sdW1ucyIsImpvaW4iXSwibWFwcGluZ3MiOiJBQUFBLFlBQVlBLE9BQU8sWUFBWTtBQUMvQixPQUFPQyxXQUFXLGtCQUFrQjtBQUdwQyxPQUFPLE1BQU1DO0lBQ1hDLGtCQUNFQyxhQUFnQyxFQUNoQ0MsU0FBNEIsRUFDNUI7UUFDQSxNQUFNQyxZQUFZO1lBQ2hCQyxLQUFLLEVBQUU7WUFDUEMsTUFBTSxFQUFFO1lBQ1JDLE9BQU8sRUFBRTtRQUNYO1FBRUEsWUFBWTtRQUNaLE1BQU1DLGVBQWU7WUFDbkJDLElBQUlYLEVBQUVZLFlBQVksQ0FBQ1AsV0FBV0QsZUFBZSxDQUFDUyxNQUFRQSxJQUFJQyxJQUFJO1lBQzlEQyxRQUFRZixFQUFFWSxZQUFZLENBQUNSLGVBQWVDLFdBQVcsQ0FBQ1EsTUFBUUEsSUFBSUMsSUFBSTtRQUNwRTtRQUNBLElBQUlKLGFBQWFLLE1BQU0sQ0FBQ0MsTUFBTSxHQUFHLEdBQUc7WUFDbENWLFVBQVVDLEdBQUcsR0FBR0QsVUFBVUMsR0FBRyxDQUFDVSxNQUFNLENBQUNQLGFBQWFLLE1BQU07UUFDMUQ7UUFDQSxJQUFJTCxhQUFhQyxFQUFFLENBQUNLLE1BQU0sR0FBRyxHQUFHO1lBQzlCVixVQUFVRSxJQUFJLEdBQUdGLFVBQVVFLElBQUksQ0FBQ1MsTUFBTSxDQUFDUCxhQUFhQyxFQUFFO1FBQ3hEO1FBRUEsbUJBQW1CO1FBQ25CLE1BQU1PLGdCQUFnQmxCLEVBQUVtQixjQUFjLENBQ3BDZCxXQUNBRCxlQUNBLENBQUNTLE1BQVFBLElBQUlDLElBQUk7UUFFbkIsTUFBTU0sZ0JBQWdCcEIsRUFBRW1CLGNBQWMsQ0FDcENmLGVBQ0FDLFdBQ0EsQ0FBQ1EsTUFBUUEsSUFBSUMsSUFBSTtRQUVuQlIsVUFBVUcsS0FBSyxHQUFHVCxFQUFFcUIsY0FBYyxDQUFDSCxlQUFlRSxlQUFlLENBQUNFLEdBQUdDLElBQ25FdEIsTUFBTXFCLEdBQUdDO1FBR1gsT0FBT2pCO0lBQ1Q7SUFFQWtCLGtCQUNFQyxhQUErQixFQUMvQkMsU0FBMkIsRUFDM0I7UUFDQSxTQUFTO1FBQ1QsSUFBSUMsWUFBWTtZQUNkcEIsS0FBSyxFQUFFO1lBQ1BDLE1BQU0sRUFBRTtRQUNWO1FBQ0EsTUFBTW9CLGVBQWU7WUFDbkJqQixJQUFJWCxFQUFFWSxZQUFZLENBQUNjLFdBQVdELGVBQWUsQ0FBQ1osTUFDNUM7b0JBQUNBLElBQUlnQixJQUFJO29CQUFFaEIsSUFBSWlCLE9BQU8sQ0FBQ0MsSUFBSSxDQUFDO2lCQUFLLENBQUNBLElBQUksQ0FBQztZQUV6Q2hCLFFBQVFmLEVBQUVZLFlBQVksQ0FBQ2EsZUFBZUMsV0FBVyxDQUFDYixNQUNoRDtvQkFBQ0EsSUFBSWdCLElBQUk7b0JBQUVoQixJQUFJaUIsT0FBTyxDQUFDQyxJQUFJLENBQUM7aUJBQUssQ0FBQ0EsSUFBSSxDQUFDO1FBRTNDO1FBQ0EsSUFBSUgsYUFBYWIsTUFBTSxDQUFDQyxNQUFNLEdBQUcsR0FBRztZQUNsQ1csVUFBVXBCLEdBQUcsR0FBR29CLFVBQVVwQixHQUFHLENBQUNVLE1BQU0sQ0FBQ1csYUFBYWIsTUFBTTtRQUMxRDtRQUNBLElBQUlhLGFBQWFqQixFQUFFLENBQUNLLE1BQU0sR0FBRyxHQUFHO1lBQzlCVyxVQUFVbkIsSUFBSSxHQUFHbUIsVUFBVW5CLElBQUksQ0FBQ1MsTUFBTSxDQUFDVyxhQUFhakIsRUFBRTtRQUN4RDtRQUVBLE9BQU9nQjtJQUNUO0FBQ0YifQ==
|
package/dist/database/db.d.ts
CHANGED
|
@@ -2,20 +2,7 @@ export type DBPreset = "w" | "r";
|
|
|
2
2
|
import { Knex } from "knex";
|
|
3
3
|
import { AsyncLocalStorage } from "async_hooks";
|
|
4
4
|
import { TransactionContext } from "./transaction-context";
|
|
5
|
-
|
|
6
|
-
connection?: Knex.MySql2ConnectionConfig;
|
|
7
|
-
};
|
|
8
|
-
export type SonamuDBBaseConfig = {
|
|
9
|
-
database: string;
|
|
10
|
-
defaultOptions?: MySQLConfig;
|
|
11
|
-
environments?: {
|
|
12
|
-
development?: MySQLConfig;
|
|
13
|
-
development_slave?: MySQLConfig;
|
|
14
|
-
production?: MySQLConfig;
|
|
15
|
-
production_slave?: MySQLConfig;
|
|
16
|
-
remote_fixture?: MySQLConfig;
|
|
17
|
-
};
|
|
18
|
-
};
|
|
5
|
+
import { SonamuConfig } from "../api/config";
|
|
19
6
|
export type SonamuDBConfig = {
|
|
20
7
|
development_master: Knex.Config;
|
|
21
8
|
development_slave: Knex.Config;
|
|
@@ -31,10 +18,9 @@ declare class DBClass {
|
|
|
31
18
|
transactionStorage: AsyncLocalStorage<TransactionContext>;
|
|
32
19
|
runWithTransaction<T>(callback: () => Promise<T>): Promise<T>;
|
|
33
20
|
getTransactionContext(): TransactionContext;
|
|
34
|
-
readKnexfile(): Promise<SonamuDBConfig>;
|
|
35
21
|
getDB(which: DBPreset): Knex;
|
|
36
22
|
destroy(): Promise<void>;
|
|
37
|
-
|
|
23
|
+
generateDBConfig(config: SonamuConfig["database"]): SonamuDBConfig;
|
|
38
24
|
testTransaction: Knex.Transaction | null;
|
|
39
25
|
createTestTransaction(): Promise<Knex.Transaction>;
|
|
40
26
|
clearTestTransaction(): Promise<void>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"db.d.ts","sourceRoot":"","sources":["../../src/database/db.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,GAAG,GAAG,GAAG,CAAC;AACjC,OAAa,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"db.d.ts","sourceRoot":"","sources":["../../src/database/db.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,GAAG,GAAG,GAAG,CAAC;AACjC,OAAa,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAGlC,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAkB,YAAY,EAAE,MAAM,eAAe,CAAC;AAE7D,MAAM,MAAM,cAAc,GAAG;IAC3B,kBAAkB,EAAE,IAAI,CAAC,MAAM,CAAC;IAChC,iBAAiB,EAAE,IAAI,CAAC,MAAM,CAAC;IAC/B,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC;IAClB,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC;IAC3B,cAAc,EAAE,IAAI,CAAC,MAAM,CAAC;IAC5B,iBAAiB,EAAE,IAAI,CAAC,MAAM,CAAC;IAC/B,gBAAgB,EAAE,IAAI,CAAC,MAAM,CAAC;CAC/B,CAAC;AAEF,cAAM,OAAO;IACX,OAAO,CAAC,GAAG,CAAC,CAAO;IACnB,OAAO,CAAC,GAAG,CAAC,CAAO;IAEZ,kBAAkB,wCAA+C;IAEjE,kBAAkB,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAI7D,qBAAqB,IAAI,kBAAkB;IAIlD,KAAK,CAAC,KAAK,EAAE,QAAQ,GAAG,IAAI;IAoDtB,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAWvB,gBAAgB,CAAC,MAAM,EAAE,YAAY,CAAC,UAAU,CAAC,GAAG,cAAc;IAgFlE,eAAe,EAAE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAQ;IACjD,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC;IAKlD,oBAAoB,IAAI,OAAO,CAAC,IAAI,CAAC;CAI5C;AACD,eAAO,MAAM,EAAE,SAAgB,CAAC"}
|