sonamu 0.6.0 → 0.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.swcrc.project-default +18 -0
- package/bin/cli.js +24 -0
- package/dist/ai/agents/agent.d.ts +11 -0
- package/dist/ai/agents/agent.d.ts.map +1 -0
- package/dist/ai/agents/agent.js +65 -0
- package/dist/ai/agents/index.d.ts +3 -0
- package/dist/ai/agents/index.d.ts.map +1 -0
- package/dist/ai/agents/index.js +4 -0
- package/dist/ai/agents/types.d.ts +43 -0
- package/dist/ai/agents/types.d.ts.map +1 -0
- package/dist/ai/agents/types.js +3 -0
- package/dist/ai/index.d.ts +2 -0
- package/dist/ai/index.d.ts.map +1 -0
- package/dist/ai/index.js +3 -0
- package/dist/ai/providers/rtzr/api.d.ts +22 -0
- package/dist/ai/providers/rtzr/api.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/api.js +28 -0
- package/dist/ai/providers/rtzr/error.d.ts +18 -0
- package/dist/ai/providers/rtzr/error.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/error.js +29 -0
- package/dist/ai/providers/rtzr/index.d.ts +5 -0
- package/dist/ai/providers/rtzr/index.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/index.js +6 -0
- package/dist/ai/providers/rtzr/model.d.ts +52 -0
- package/dist/ai/providers/rtzr/model.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/model.js +137 -0
- package/dist/ai/providers/rtzr/options.d.ts +7 -0
- package/dist/ai/providers/rtzr/options.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/options.js +47 -0
- package/dist/ai/providers/rtzr/provider.d.ts +18 -0
- package/dist/ai/providers/rtzr/provider.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/provider.js +54 -0
- package/dist/ai/providers/rtzr/utils.d.ts +19 -0
- package/dist/ai/providers/rtzr/utils.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/utils.js +88 -0
- package/dist/api/base-frame.d.ts +2 -2
- package/dist/api/base-frame.d.ts.map +1 -1
- package/dist/api/base-frame.js +2 -1
- package/dist/api/caster.d.ts.map +1 -1
- package/dist/api/caster.js +6 -1
- package/dist/api/code-converters.d.ts +58 -14
- package/dist/api/code-converters.d.ts.map +1 -1
- package/dist/api/code-converters.js +178 -409
- package/dist/api/config.d.ts +27 -13
- package/dist/api/config.d.ts.map +1 -1
- package/dist/api/config.js +19 -26
- package/dist/api/context.d.ts +4 -3
- package/dist/api/context.d.ts.map +1 -1
- package/dist/api/context.js +1 -1
- package/dist/api/decorators.d.ts +20 -6
- package/dist/api/decorators.d.ts.map +1 -1
- package/dist/api/decorators.js +111 -18
- package/dist/api/index.d.ts +2 -2
- package/dist/api/index.d.ts.map +1 -1
- package/dist/api/index.js +3 -3
- package/dist/api/sonamu.d.ts +7 -7
- package/dist/api/sonamu.d.ts.map +1 -1
- package/dist/api/sonamu.js +83 -51
- package/dist/api/validator.d.ts +6 -0
- package/dist/api/validator.d.ts.map +1 -0
- package/dist/api/validator.js +81 -0
- package/dist/bin/build-config.d.ts +5 -1
- package/dist/bin/build-config.d.ts.map +1 -1
- package/dist/bin/build-config.js +5 -2
- package/dist/bin/cli.js +165 -64
- package/dist/bin/loader-register.d.ts +2 -0
- package/dist/bin/loader-register.d.ts.map +1 -0
- package/dist/bin/loader-register.js +34 -0
- package/dist/database/_batch_update.d.ts +5 -3
- package/dist/database/_batch_update.d.ts.map +1 -1
- package/dist/database/_batch_update.js +30 -13
- package/dist/database/base-model.d.ts +96 -10
- package/dist/database/base-model.d.ts.map +1 -1
- package/dist/database/base-model.js +232 -89
- package/dist/database/base-model.types.d.ts +93 -0
- package/dist/database/base-model.types.d.ts.map +1 -0
- package/dist/database/base-model.types.js +10 -0
- package/dist/database/code-generator.d.ts +1 -1
- package/dist/database/code-generator.d.ts.map +1 -1
- package/dist/database/code-generator.js +11 -10
- package/dist/database/db.d.ts +5 -6
- package/dist/database/db.d.ts.map +1 -1
- package/dist/database/db.js +22 -25
- package/dist/database/puri-subset.test-d.js +81 -0
- package/dist/database/puri-subset.types.d.ts +123 -0
- package/dist/database/puri-subset.types.d.ts.map +1 -0
- package/dist/database/puri-subset.types.js +16 -0
- package/dist/database/puri-wrapper.d.ts +13 -11
- package/dist/database/puri-wrapper.d.ts.map +1 -1
- package/dist/database/puri-wrapper.js +2 -2
- package/dist/database/puri.d.ts +25 -14
- package/dist/database/puri.d.ts.map +1 -1
- package/dist/database/puri.js +83 -21
- package/dist/database/puri.types.d.ts +21 -7
- package/dist/database/puri.types.d.ts.map +1 -1
- package/dist/database/puri.types.js +4 -1
- package/dist/database/transaction-context.d.ts +1 -1
- package/dist/database/transaction-context.d.ts.map +1 -1
- package/dist/database/transaction-context.js +1 -1
- package/dist/database/upsert-builder.d.ts +9 -3
- package/dist/database/upsert-builder.d.ts.map +1 -1
- package/dist/database/upsert-builder.js +228 -78
- package/dist/entity/entity-manager.d.ts +165 -2
- package/dist/entity/entity-manager.d.ts.map +1 -1
- package/dist/entity/entity-manager.js +26 -10
- package/dist/entity/entity.d.ts +5 -3
- package/dist/entity/entity.d.ts.map +1 -1
- package/dist/entity/entity.js +153 -54
- package/dist/exceptions/error-handler.d.ts +1 -1
- package/dist/exceptions/error-handler.d.ts.map +1 -1
- package/dist/exceptions/error-handler.js +1 -1
- package/dist/exceptions/so-exceptions.d.ts +1 -1
- package/dist/exceptions/so-exceptions.d.ts.map +1 -1
- package/dist/exceptions/so-exceptions.js +1 -1
- package/dist/file-storage/driver.d.ts +1 -1
- package/dist/file-storage/driver.d.ts.map +1 -1
- package/dist/file-storage/driver.js +1 -1
- package/dist/file-storage/file-storage.js +2 -2
- package/dist/index.d.ts +18 -11
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +19 -13
- package/dist/migration/code-generation.d.ts +1 -1
- package/dist/migration/code-generation.d.ts.map +1 -1
- package/dist/migration/code-generation.js +123 -67
- package/dist/migration/migration-set.d.ts +2 -10
- package/dist/migration/migration-set.d.ts.map +1 -1
- package/dist/migration/migration-set.js +67 -218
- package/dist/migration/migrator.d.ts +24 -73
- package/dist/migration/migrator.d.ts.map +1 -1
- package/dist/migration/migrator.js +121 -301
- package/dist/migration/postgresql-schema-reader.d.ts +51 -0
- package/dist/migration/postgresql-schema-reader.d.ts.map +1 -0
- package/dist/migration/postgresql-schema-reader.js +245 -0
- package/dist/migration/types.d.ts +6 -38
- package/dist/migration/types.d.ts.map +1 -1
- package/dist/migration/types.js +1 -1
- package/dist/naite/messaging-types.d.ts +43 -0
- package/dist/naite/messaging-types.d.ts.map +1 -0
- package/dist/naite/messaging-types.js +7 -0
- package/dist/naite/naite-reporter.d.ts +41 -0
- package/dist/naite/naite-reporter.d.ts.map +1 -0
- package/dist/naite/naite-reporter.js +102 -0
- package/dist/naite/naite.d.ts +91 -8
- package/dist/naite/naite.d.ts.map +1 -1
- package/dist/naite/naite.js +285 -41
- package/dist/stream/sse.d.ts +2 -2
- package/dist/stream/sse.d.ts.map +1 -1
- package/dist/stream/sse.js +1 -1
- package/dist/syncer/api-parser.d.ts +3 -13
- package/dist/syncer/api-parser.d.ts.map +1 -1
- package/dist/syncer/api-parser.js +67 -56
- package/dist/syncer/checksum.d.ts +2 -2
- package/dist/syncer/checksum.d.ts.map +1 -1
- package/dist/syncer/checksum.js +11 -11
- package/dist/syncer/code-generator.d.ts +3 -3
- package/dist/syncer/code-generator.d.ts.map +1 -1
- package/dist/syncer/code-generator.js +37 -17
- package/dist/syncer/entity-operations.d.ts +2 -2
- package/dist/syncer/entity-operations.d.ts.map +1 -1
- package/dist/syncer/entity-operations.js +9 -8
- package/dist/syncer/file-patterns.d.ts +1 -1
- package/dist/syncer/file-patterns.d.ts.map +1 -1
- package/dist/syncer/file-patterns.js +1 -1
- package/dist/syncer/index.d.ts +4 -4
- package/dist/syncer/index.d.ts.map +1 -1
- package/dist/syncer/index.js +5 -5
- package/dist/syncer/module-loader.d.ts +4 -4
- package/dist/syncer/module-loader.d.ts.map +1 -1
- package/dist/syncer/module-loader.js +17 -12
- package/dist/syncer/syncer.d.ts +31 -24
- package/dist/syncer/syncer.d.ts.map +1 -1
- package/dist/syncer/syncer.js +92 -45
- package/dist/template/entity-converter.d.ts +1 -1
- package/dist/template/entity-converter.d.ts.map +1 -1
- package/dist/template/entity-converter.js +15 -8
- package/dist/template/helpers.d.ts +2 -2
- package/dist/template/helpers.d.ts.map +1 -1
- package/dist/template/helpers.js +3 -3
- package/dist/template/implementations/entity.template.d.ts +2 -2
- package/dist/template/implementations/entity.template.d.ts.map +1 -1
- package/dist/template/implementations/entity.template.js +4 -5
- package/dist/template/implementations/generated.template.d.ts +2 -3
- package/dist/template/implementations/generated.template.d.ts.map +1 -1
- package/dist/template/implementations/generated.template.js +46 -29
- package/dist/template/implementations/generated_http.template.d.ts +2 -3
- package/dist/template/implementations/generated_http.template.d.ts.map +1 -1
- package/dist/template/implementations/generated_http.template.js +9 -9
- package/dist/template/implementations/generated_sso.template.d.ts +3 -4
- package/dist/template/implementations/generated_sso.template.d.ts.map +1 -1
- package/dist/template/implementations/generated_sso.template.js +54 -25
- package/dist/template/implementations/init_types.template.d.ts +2 -2
- package/dist/template/implementations/init_types.template.d.ts.map +1 -1
- package/dist/template/implementations/init_types.template.js +2 -2
- package/dist/template/implementations/model.template.d.ts +2 -2
- package/dist/template/implementations/model.template.d.ts.map +1 -1
- package/dist/template/implementations/model.template.js +47 -37
- package/dist/template/implementations/model_test.template.d.ts +2 -2
- package/dist/template/implementations/model_test.template.d.ts.map +1 -1
- package/dist/template/implementations/model_test.template.js +2 -2
- package/dist/template/implementations/service.template.d.ts +4 -4
- package/dist/template/implementations/service.template.d.ts.map +1 -1
- package/dist/template/implementations/service.template.js +24 -16
- package/dist/template/implementations/view_enums_buttonset.template.d.ts +2 -2
- package/dist/template/implementations/view_enums_buttonset.template.d.ts.map +1 -1
- package/dist/template/implementations/view_enums_buttonset.template.js +1 -1
- package/dist/template/implementations/view_enums_dropdown.template.d.ts +2 -2
- package/dist/template/implementations/view_enums_dropdown.template.d.ts.map +1 -1
- package/dist/template/implementations/view_enums_dropdown.template.js +2 -2
- package/dist/template/implementations/view_enums_select.template.d.ts +2 -2
- package/dist/template/implementations/view_enums_select.template.d.ts.map +1 -1
- package/dist/template/implementations/view_enums_select.template.js +2 -2
- package/dist/template/implementations/view_form.template.d.ts +2 -2
- package/dist/template/implementations/view_form.template.d.ts.map +1 -1
- package/dist/template/implementations/view_form.template.js +4 -4
- package/dist/template/implementations/view_id_all_select.template.d.ts +2 -2
- package/dist/template/implementations/view_id_all_select.template.d.ts.map +1 -1
- package/dist/template/implementations/view_id_all_select.template.js +1 -1
- package/dist/template/implementations/view_id_async_select.template.d.ts +2 -2
- package/dist/template/implementations/view_id_async_select.template.d.ts.map +1 -1
- package/dist/template/implementations/view_id_async_select.template.js +1 -1
- package/dist/template/implementations/view_list.template.d.ts +2 -2
- package/dist/template/implementations/view_list.template.d.ts.map +1 -1
- package/dist/template/implementations/view_list.template.js +29 -19
- package/dist/template/implementations/view_list_columns.template.d.ts +3 -3
- package/dist/template/implementations/view_list_columns.template.d.ts.map +1 -1
- package/dist/template/implementations/view_list_columns.template.js +1 -1
- package/dist/template/implementations/view_search_input.template.d.ts +2 -2
- package/dist/template/implementations/view_search_input.template.d.ts.map +1 -1
- package/dist/template/implementations/view_search_input.template.js +1 -1
- package/dist/template/index.d.ts +4 -2
- package/dist/template/index.d.ts.map +1 -1
- package/dist/template/index.js +5 -3
- package/dist/template/template-manager.d.ts +56 -0
- package/dist/template/template-manager.d.ts.map +1 -0
- package/dist/template/template-manager.js +125 -0
- package/dist/template/template-types.d.ts +16 -0
- package/dist/template/template-types.d.ts.map +1 -0
- package/dist/template/template-types.js +7 -0
- package/dist/template/template.d.ts +12 -2
- package/dist/template/template.d.ts.map +1 -1
- package/dist/template/template.js +19 -6
- package/dist/template/zod-converter.d.ts +40 -7
- package/dist/template/zod-converter.d.ts.map +1 -1
- package/dist/template/zod-converter.js +341 -58
- package/dist/testing/_relation-graph.d.ts +1 -1
- package/dist/testing/_relation-graph.d.ts.map +1 -1
- package/dist/testing/_relation-graph.js +12 -3
- package/dist/testing/fixture-manager.d.ts +42 -11
- package/dist/testing/fixture-manager.d.ts.map +1 -1
- package/dist/testing/fixture-manager.js +338 -236
- package/dist/types/types.d.ts +709 -104
- package/dist/types/types.d.ts.map +1 -1
- package/dist/types/types.js +309 -52
- package/dist/typings/knex.d.js +2 -2
- package/dist/utils/async-utils.d.ts.map +1 -1
- package/dist/utils/async-utils.js +3 -3
- package/dist/utils/console-util.js +1 -1
- package/dist/utils/controller.d.ts +1 -0
- package/dist/utils/controller.d.ts.map +1 -1
- package/dist/utils/controller.js +4 -1
- package/dist/utils/esm-utils.d.ts +0 -6
- package/dist/utils/esm-utils.d.ts.map +1 -1
- package/dist/utils/esm-utils.js +2 -9
- package/dist/utils/formatter.d.ts +3 -0
- package/dist/utils/formatter.d.ts.map +1 -0
- package/dist/utils/formatter.js +110 -0
- package/dist/utils/fs-utils.d.ts +1 -1
- package/dist/utils/fs-utils.d.ts.map +1 -1
- package/dist/utils/fs-utils.js +1 -1
- package/dist/utils/lodash-able.d.ts.map +1 -1
- package/dist/utils/lodash-able.js +1 -1
- package/dist/utils/object-utils.d.ts +44 -0
- package/dist/utils/object-utils.d.ts.map +1 -0
- package/dist/utils/object-utils.js +191 -0
- package/dist/utils/path-utils.d.ts +1 -1
- package/dist/utils/path-utils.d.ts.map +1 -1
- package/dist/utils/path-utils.js +3 -3
- package/dist/utils/process-utils.js +1 -1
- package/dist/utils/sql-parser.d.ts +5 -1
- package/dist/utils/sql-parser.d.ts.map +1 -1
- package/dist/utils/sql-parser.js +14 -3
- package/dist/utils/type-utils.d.ts +23 -0
- package/dist/utils/type-utils.d.ts.map +1 -0
- package/dist/utils/type-utils.js +45 -0
- package/dist/utils/utils.d.ts +7 -1
- package/dist/utils/utils.d.ts.map +1 -1
- package/dist/utils/utils.js +44 -5
- package/dist/utils/zod-error.d.ts +1 -1
- package/dist/utils/zod-error.d.ts.map +1 -1
- package/dist/utils/zod-error.js +1 -1
- package/package.json +54 -29
- package/src/ai/agents/agent.ts +87 -0
- package/src/ai/agents/index.ts +2 -0
- package/src/ai/agents/types.ts +47 -0
- package/src/ai/index.ts +1 -0
- package/src/ai/providers/rtzr/api.ts +37 -0
- package/src/ai/providers/rtzr/error.ts +34 -0
- package/src/ai/providers/rtzr/index.ts +4 -0
- package/src/ai/providers/rtzr/model.ts +201 -0
- package/src/ai/providers/rtzr/options.ts +49 -0
- package/src/ai/providers/rtzr/provider.ts +91 -0
- package/src/ai/providers/rtzr/utils.ts +127 -0
- package/src/api/base-frame.ts +4 -2
- package/src/api/caster.ts +17 -23
- package/src/api/code-converters.ts +176 -533
- package/src/api/config.ts +39 -56
- package/src/api/context.ts +7 -18
- package/src/api/decorators.ts +175 -46
- package/src/api/index.ts +2 -2
- package/src/api/sonamu.ts +133 -124
- package/src/api/validator.ts +83 -0
- package/src/bin/build-config.ts +7 -1
- package/src/bin/cli.ts +192 -110
- package/src/bin/loader-register.ts +38 -0
- package/src/database/_batch_update.ts +46 -31
- package/src/database/base-model.ts +390 -182
- package/src/database/base-model.types.ts +155 -0
- package/src/database/code-generator.ts +13 -32
- package/src/database/db.ts +36 -50
- package/src/database/puri-subset.test-d.ts +471 -0
- package/src/database/puri-subset.types.ts +195 -0
- package/src/database/puri-wrapper.ts +58 -67
- package/src/database/puri.ts +182 -126
- package/src/database/puri.types.ts +64 -31
- package/src/database/transaction-context.ts +1 -1
- package/src/database/upsert-builder.ts +262 -132
- package/src/entity/entity-manager.ts +36 -28
- package/src/entity/entity.ts +330 -249
- package/src/exceptions/error-handler.ts +3 -3
- package/src/exceptions/so-exceptions.ts +11 -11
- package/src/file-storage/driver.ts +5 -5
- package/src/file-storage/file-storage.ts +2 -2
- package/src/index.ts +18 -12
- package/src/migration/code-generation.ts +185 -172
- package/src/migration/migration-set.ts +80 -293
- package/src/migration/migrator.ts +182 -425
- package/src/migration/mysql-schema-reader.ts.txt +272 -0
- package/src/migration/postgresql-schema-reader.ts +310 -0
- package/src/migration/types.ts +6 -39
- package/src/naite/messaging-types.ts +51 -0
- package/src/naite/naite-reporter.ts +128 -0
- package/src/naite/naite.ts +378 -33
- package/src/shared/web.shared.ts.txt +20 -24
- package/src/stream/sse.ts +5 -5
- package/src/syncer/api-parser.ts +52 -69
- package/src/syncer/checksum.ts +25 -37
- package/src/syncer/code-generator.ts +58 -62
- package/src/syncer/entity-operations.ts +12 -15
- package/src/syncer/file-patterns.ts +2 -2
- package/src/syncer/index.ts +4 -4
- package/src/syncer/module-loader.ts +28 -25
- package/src/syncer/syncer.ts +155 -162
- package/src/template/entity-converter.ts +18 -27
- package/src/template/helpers.ts +8 -11
- package/src/template/implementations/entity.template.ts +6 -6
- package/src/template/implementations/generated.template.ts +99 -99
- package/src/template/implementations/generated_http.template.ts +21 -54
- package/src/template/implementations/generated_sso.template.ts +78 -65
- package/src/template/implementations/init_types.template.ts +4 -6
- package/src/template/implementations/model.template.ts +47 -38
- package/src/template/implementations/model_test.template.ts +3 -3
- package/src/template/implementations/service.template.ts +56 -80
- package/src/template/implementations/view_enums_buttonset.template.ts +2 -2
- package/src/template/implementations/view_enums_dropdown.template.ts +4 -4
- package/src/template/implementations/view_enums_select.template.ts +3 -3
- package/src/template/implementations/view_form.template.ts +34 -75
- package/src/template/implementations/view_id_all_select.template.ts +2 -2
- package/src/template/implementations/view_id_async_select.template.ts +9 -23
- package/src/template/implementations/view_list.template.ts +54 -95
- package/src/template/implementations/view_list_columns.template.ts +4 -10
- package/src/template/implementations/view_search_input.template.ts +2 -2
- package/src/template/index.ts +4 -2
- package/src/template/template-manager.ts +166 -0
- package/src/template/template-types.ts +16 -0
- package/src/template/template.ts +29 -10
- package/src/template/zod-converter.ts +407 -101
- package/src/testing/_relation-graph.ts +18 -11
- package/src/testing/fixture-manager.ts +468 -362
- package/src/types/types.ts +516 -248
- package/src/typings/knex.d.ts +7 -9
- package/src/utils/async-utils.ts +8 -12
- package/src/utils/console-util.ts +1 -1
- package/src/utils/controller.ts +3 -0
- package/src/utils/esm-utils.ts +8 -18
- package/src/utils/formatter.ts +109 -0
- package/src/utils/fs-utils.ts +1 -1
- package/src/utils/lodash-able.ts +1 -4
- package/src/utils/object-utils.ts +217 -0
- package/src/utils/path-utils.ts +3 -6
- package/src/utils/process-utils.ts +1 -1
- package/src/utils/sql-parser.ts +23 -5
- package/src/utils/type-utils.ts +83 -0
- package/src/utils/utils.ts +58 -9
- package/src/utils/zod-error.ts +3 -3
- package/dist/bin/cli-wrapper.d.ts +0 -3
- package/dist/bin/cli-wrapper.d.ts.map +0 -1
- package/dist/bin/cli-wrapper.js +0 -72
- package/dist/database/knex-plugins/knex-on-duplicate-update.d.ts +0 -2
- package/dist/database/knex-plugins/knex-on-duplicate-update.d.ts.map +0 -1
- package/dist/database/knex-plugins/knex-on-duplicate-update.js +0 -39
- package/dist/entity/entity-utils.d.ts +0 -61
- package/dist/entity/entity-utils.d.ts.map +0 -1
- package/dist/entity/entity-utils.js +0 -210
- package/src/bin/cli-wrapper.ts +0 -82
- package/src/database/knex-plugins/knex-on-duplicate-update.ts +0 -45
- package/src/entity/entity-utils.ts +0 -291
|
@@ -1,11 +1,13 @@
|
|
|
1
|
-
import * as _ from "lodash-es";
|
|
2
|
-
import prettier from "prettier";
|
|
3
1
|
import equal from "fast-deep-equal";
|
|
2
|
+
import { alphabetical, diff, fork, omit } from "radashi";
|
|
3
|
+
import { Naite } from "../index.js";
|
|
4
|
+
import { formatCode } from "../utils/formatter.js";
|
|
5
|
+
import { differenceWith, intersectionBy } from "../utils/utils.js";
|
|
4
6
|
/**
|
|
5
7
|
* 테이블 생성하는 케이스 - 컬럼/인덱스 생성
|
|
6
8
|
*/ async function generateCreateCode_ColumnAndIndexes(table, columns, indexes) {
|
|
7
9
|
// fulltext index 분리
|
|
8
|
-
const [ngramIndexes, standardIndexes] =
|
|
10
|
+
const [ngramIndexes, standardIndexes] = fork(indexes, (i)=>i.type === "fulltext" && i.parser === "ngram");
|
|
9
11
|
// 컬럼, 인덱스 처리
|
|
10
12
|
const lines = [
|
|
11
13
|
'import { Knex } from "knex";',
|
|
@@ -30,9 +32,7 @@ import equal from "fast-deep-equal";
|
|
|
30
32
|
table,
|
|
31
33
|
type: "normal",
|
|
32
34
|
title: `create__${table}`,
|
|
33
|
-
formatted:
|
|
34
|
-
parser: "typescript"
|
|
35
|
-
})
|
|
35
|
+
formatted: formatCode(lines.join("\n"), "typescript", `src/migration/${table}.ts`)
|
|
36
36
|
};
|
|
37
37
|
}
|
|
38
38
|
/**
|
|
@@ -43,21 +43,37 @@ import equal from "fast-deep-equal";
|
|
|
43
43
|
if (column.name === "id") {
|
|
44
44
|
return `table.increments().primary();`;
|
|
45
45
|
}
|
|
46
|
-
//
|
|
47
|
-
if (column.type
|
|
48
|
-
|
|
46
|
+
// 배열 타입 처리
|
|
47
|
+
if (column.type.endsWith("[]")) {
|
|
48
|
+
const elementType = column.type.slice(0, -2); // "integer[]" -> "integer"
|
|
49
|
+
const pgType = getPgArrayType(column, elementType);
|
|
50
|
+
chains.push(`specificType('${column.name}', '${pgType}')`);
|
|
51
|
+
} else if (column.type === "numberOrNumeric") {
|
|
52
|
+
// number
|
|
53
|
+
if (column.numberType === "real") {
|
|
54
|
+
chains.push(`float('${column.name}')`);
|
|
55
|
+
} else if (column.numberType === "double precision") {
|
|
56
|
+
chains.push(`double('${column.name}')`);
|
|
57
|
+
} else if ((column.numberType ?? "numeric") === "numeric") {
|
|
58
|
+
chains.push(`decimal('${column.name}', ${column.precision}, ${column.scale})`);
|
|
59
|
+
}
|
|
60
|
+
} else if (column.type === "string") {
|
|
61
|
+
// string
|
|
62
|
+
if (column.length !== undefined) {
|
|
63
|
+
chains.push(`string('${column.name}', ${column.length})`);
|
|
64
|
+
} else {
|
|
65
|
+
chains.push(`text('${column.name}')`);
|
|
66
|
+
}
|
|
67
|
+
} else if (column.type === "date") {
|
|
68
|
+
// date
|
|
69
|
+
chains.push(`timestamp('${column.name}', { useTz: true })`);
|
|
70
|
+
} else if (column.type === "json") {
|
|
71
|
+
// json
|
|
72
|
+
chains.push(`jsonb('${column.name}')`);
|
|
49
73
|
} else {
|
|
50
74
|
// type, length
|
|
51
|
-
let columnType = column.type;
|
|
52
75
|
let extraType;
|
|
53
|
-
|
|
54
|
-
extraType = columnType;
|
|
55
|
-
columnType = "text";
|
|
56
|
-
}
|
|
57
|
-
chains.push(`${columnType}('${column.name}'${column.length ? `, ${column.length}` : ""}${extraType ? `, '${extraType}'` : ""})`);
|
|
58
|
-
}
|
|
59
|
-
if (column.unsigned) {
|
|
60
|
-
chains.push("unsigned()");
|
|
76
|
+
chains.push(`${column.type}('${column.name}'${column.length ? `, ${column.length}` : ""}${extraType ? `, '${extraType}'` : ""})`);
|
|
61
77
|
}
|
|
62
78
|
// nullable
|
|
63
79
|
chains.push(column.nullable ? "nullable()" : "notNullable()");
|
|
@@ -72,6 +88,23 @@ import equal from "fast-deep-equal";
|
|
|
72
88
|
return `table.${chains.join(".")};`;
|
|
73
89
|
});
|
|
74
90
|
}
|
|
91
|
+
function getPgArrayType(column, elementType) {
|
|
92
|
+
if (elementType === "numberOrNumeric") {
|
|
93
|
+
if (column.numberType === "real") return "real[]";
|
|
94
|
+
if (column.numberType === "double precision") return "double precision[]";
|
|
95
|
+
return `numeric(${column.precision}, ${column.scale})[]`;
|
|
96
|
+
}
|
|
97
|
+
if (elementType === "string") {
|
|
98
|
+
return column.length ? `varchar(${column.length})[]` : "text[]";
|
|
99
|
+
}
|
|
100
|
+
if (elementType === "date") return "timestamptz[]";
|
|
101
|
+
if (elementType === "integer") return "integer[]";
|
|
102
|
+
if (elementType === "bigInteger") return "bigint[]";
|
|
103
|
+
if (elementType === "boolean") return "boolean[]";
|
|
104
|
+
if (elementType === "uuid") return "uuid[]";
|
|
105
|
+
if (elementType === "enum") return "text[]";
|
|
106
|
+
throw new Error(`Unknown array element type: ${elementType}`);
|
|
107
|
+
}
|
|
75
108
|
/**
|
|
76
109
|
* 개별 인덱스 정의 생성
|
|
77
110
|
*/ function genIndexDefinition(index, table) {
|
|
@@ -120,9 +153,7 @@ import equal from "fast-deep-equal";
|
|
|
120
153
|
table,
|
|
121
154
|
type: "foreign",
|
|
122
155
|
title: `foreign__${table}__${foreignKeysString}`,
|
|
123
|
-
formatted:
|
|
124
|
-
parser: "typescript"
|
|
125
|
-
})
|
|
156
|
+
formatted: formatCode(lines.join("\n"), "typescript", `src/migration/${table}.ts`)
|
|
126
157
|
}
|
|
127
158
|
];
|
|
128
159
|
}
|
|
@@ -162,9 +193,29 @@ import equal from "fast-deep-equal";
|
|
|
162
193
|
// 인덱스의 add, drop 여부 확인
|
|
163
194
|
const alterIndexesTo = getAlterIndexesTo(entityIndexes, dbIndexes);
|
|
164
195
|
// fulltext index 분리
|
|
165
|
-
const [ngramIndexes, standardIndexes] =
|
|
196
|
+
const [ngramIndexes, standardIndexes] = fork(alterIndexesTo.add, (i)=>i.type === "fulltext" && i.parser === "ngram");
|
|
166
197
|
// 인덱스가 삭제되는 경우, 컬럼과 같이 삭제된 케이스에는 drop에서 제외해야함!
|
|
167
198
|
const indexNeedsToDrop = alterIndexesTo.drop.filter((index)=>index.columns.every((colName)=>alterColumnsTo.drop.map((col)=>col.name).includes(colName)) === false);
|
|
199
|
+
// 빈 코드 생성 방지
|
|
200
|
+
if (alterColumnLinesTo.add.up.length === 0 && alterColumnLinesTo.drop.up.length === 0 && alterColumnLinesTo.alter.up.length === 0 && standardIndexes.length === 0 && indexNeedsToDrop.length === 0) {
|
|
201
|
+
Naite.t("migrator:generateAlterCode_ColumnAndIndexes:emptyCodeGenerationError", {
|
|
202
|
+
entityColumns,
|
|
203
|
+
dbColumns,
|
|
204
|
+
entityIndexes,
|
|
205
|
+
dbIndexes
|
|
206
|
+
});
|
|
207
|
+
// throw new Error("컬럼/인덱스 변경 코드 생성 오류");
|
|
208
|
+
}
|
|
209
|
+
Naite.t("migrator:generateAlterCode_ColumnAndIndexes:debug", {
|
|
210
|
+
"alterColumnsTo.add.length": alterColumnsTo.add.length,
|
|
211
|
+
"alterColumnsTo.drop.length": alterColumnsTo.drop.length,
|
|
212
|
+
"alterColumnsTo.alter.length": alterColumnsTo.alter.length,
|
|
213
|
+
"alterIndexesTo.add.length": alterIndexesTo.add.length,
|
|
214
|
+
"alterIndexesTo.drop.length": alterIndexesTo.drop.length,
|
|
215
|
+
"standardIndexes.length": standardIndexes.length,
|
|
216
|
+
"indexNeedsToDrop.length": indexNeedsToDrop.length
|
|
217
|
+
});
|
|
218
|
+
// Naite.t("migrator:generateAlterCode_ColumnAndIndexes:alterColumnsTo", alterColumnsTo);
|
|
168
219
|
const lines = [
|
|
169
220
|
'import { Knex } from "knex";',
|
|
170
221
|
"",
|
|
@@ -195,9 +246,7 @@ import equal from "fast-deep-equal";
|
|
|
195
246
|
"});",
|
|
196
247
|
"}"
|
|
197
248
|
];
|
|
198
|
-
const formatted =
|
|
199
|
-
parser: "typescript"
|
|
200
|
-
});
|
|
249
|
+
const formatted = formatCode(lines.join("\n"), "typescript", `src/migration/${table}.ts`);
|
|
201
250
|
const title = [
|
|
202
251
|
"alter",
|
|
203
252
|
table,
|
|
@@ -232,8 +281,8 @@ import equal from "fast-deep-equal";
|
|
|
232
281
|
};
|
|
233
282
|
// 컬럼명 기준 비교
|
|
234
283
|
const extraColumns = {
|
|
235
|
-
db:
|
|
236
|
-
entity:
|
|
284
|
+
db: diff(dbColumns, entityColumns, (col)=>col.name),
|
|
285
|
+
entity: diff(entityColumns, dbColumns, (col)=>col.name)
|
|
237
286
|
};
|
|
238
287
|
if (extraColumns.entity.length > 0) {
|
|
239
288
|
columnsTo.add = columnsTo.add.concat(extraColumns.entity);
|
|
@@ -242,15 +291,15 @@ import equal from "fast-deep-equal";
|
|
|
242
291
|
columnsTo.drop = columnsTo.drop.concat(extraColumns.db);
|
|
243
292
|
}
|
|
244
293
|
// 동일 컬럼명의 세부 필드 비교
|
|
245
|
-
const sameDbColumns =
|
|
246
|
-
const sameMdColumns =
|
|
247
|
-
columnsTo.alter =
|
|
294
|
+
const sameDbColumns = intersectionBy(dbColumns, entityColumns, (col)=>col.name);
|
|
295
|
+
const sameMdColumns = intersectionBy(entityColumns, dbColumns, (col)=>col.name);
|
|
296
|
+
columnsTo.alter = differenceWith(sameDbColumns, sameMdColumns, (a, b)=>equal(a, b));
|
|
248
297
|
return columnsTo;
|
|
249
298
|
}
|
|
250
299
|
/**
|
|
251
300
|
* 추출된 컬럼들을 기준으로 각각 라인 생성
|
|
252
301
|
*/ function getAlterColumnLinesTo(columnsTo, entityColumns, table, dbForeigns) {
|
|
253
|
-
|
|
302
|
+
const linesTo = {
|
|
254
303
|
add: {
|
|
255
304
|
up: [],
|
|
256
305
|
down: []
|
|
@@ -301,17 +350,17 @@ import equal from "fast-deep-equal";
|
|
|
301
350
|
]
|
|
302
351
|
};
|
|
303
352
|
linesTo.alter = columnsTo.alter.reduce((r, dbColumn)=>{
|
|
304
|
-
const entityColumn = entityColumns.find((col)=>col.name
|
|
353
|
+
const entityColumn = entityColumns.find((col)=>col.name === dbColumn.name);
|
|
305
354
|
if (entityColumn === undefined) {
|
|
306
355
|
return r;
|
|
307
356
|
}
|
|
308
357
|
// 컬럼 변경사항
|
|
309
|
-
const columnDiffUp =
|
|
358
|
+
const columnDiffUp = diff(genColumnDefinitions([
|
|
310
359
|
entityColumn
|
|
311
360
|
]), genColumnDefinitions([
|
|
312
361
|
dbColumn
|
|
313
362
|
]));
|
|
314
|
-
const columnDiffDown =
|
|
363
|
+
const columnDiffDown = diff(genColumnDefinitions([
|
|
315
364
|
dbColumn
|
|
316
365
|
]), genColumnDefinitions([
|
|
317
366
|
entityColumn
|
|
@@ -320,12 +369,12 @@ import equal from "fast-deep-equal";
|
|
|
320
369
|
r.up = [
|
|
321
370
|
...r.up,
|
|
322
371
|
"// alter column",
|
|
323
|
-
...columnDiffUp.map((l)
|
|
372
|
+
...columnDiffUp.map((l)=>`${l.replace(";", "")}.alter();`)
|
|
324
373
|
];
|
|
325
374
|
r.down = [
|
|
326
375
|
...r.down,
|
|
327
376
|
"// rollback - alter column",
|
|
328
|
-
...columnDiffDown.map((l)
|
|
377
|
+
...columnDiffDown.map((l)=>`${l.replace(";", "")}.alter();`)
|
|
329
378
|
];
|
|
330
379
|
}
|
|
331
380
|
return r;
|
|
@@ -339,16 +388,16 @@ import equal from "fast-deep-equal";
|
|
|
339
388
|
* 인덱스의 add, drop 여부 확인
|
|
340
389
|
*/ function getAlterIndexesTo(entityIndexes, dbIndexes) {
|
|
341
390
|
// 인덱스 비교
|
|
342
|
-
|
|
391
|
+
const indexesTo = {
|
|
343
392
|
add: [],
|
|
344
393
|
drop: []
|
|
345
394
|
};
|
|
346
395
|
const extraIndexes = {
|
|
347
|
-
db:
|
|
396
|
+
db: diff(dbIndexes, entityIndexes, (col)=>[
|
|
348
397
|
col.type,
|
|
349
398
|
col.columns.join("-")
|
|
350
399
|
].join("//")),
|
|
351
|
-
entity:
|
|
400
|
+
entity: diff(entityIndexes, dbIndexes, (col)=>[
|
|
352
401
|
col.type,
|
|
353
402
|
col.columns.join("-")
|
|
354
403
|
].join("//"))
|
|
@@ -425,6 +474,14 @@ import equal from "fast-deep-equal";
|
|
|
425
474
|
if (!hasLines) {
|
|
426
475
|
return [];
|
|
427
476
|
}
|
|
477
|
+
if (linesTo.add.up.length === 0 && linesTo.drop.up.length === 0 && linesTo.alterSrc.up.length === 0 && linesTo.alterDst.up.length === 0) {
|
|
478
|
+
Naite.t("migrator:generateAlterCode_Foreigns:fkChangeCodeGenerationError", {
|
|
479
|
+
table,
|
|
480
|
+
entityForeigns,
|
|
481
|
+
dbForeigns
|
|
482
|
+
});
|
|
483
|
+
throw new Error("FK 변경 코드 생성 오류");
|
|
484
|
+
}
|
|
428
485
|
const lines = [
|
|
429
486
|
'import { Knex } from "knex";',
|
|
430
487
|
"",
|
|
@@ -446,9 +503,7 @@ import equal from "fast-deep-equal";
|
|
|
446
503
|
"})",
|
|
447
504
|
"}"
|
|
448
505
|
];
|
|
449
|
-
const formatted =
|
|
450
|
-
parser: "typescript"
|
|
451
|
-
});
|
|
506
|
+
const formatted = formatCode(lines.join("\n"), "typescript", `src/migration/${table}.ts`);
|
|
452
507
|
const title = [
|
|
453
508
|
"alter",
|
|
454
509
|
table,
|
|
@@ -481,26 +536,27 @@ import equal from "fast-deep-equal";
|
|
|
481
536
|
*/ export async function generateAlterCode(entitySet, dbSet) {
|
|
482
537
|
const replaceColumnDefaultTo = (col)=>{
|
|
483
538
|
// float인 경우 기본값을 0으로 지정하는 경우 "0.00"으로 변환되는 케이스 대응
|
|
484
|
-
if (col.type === "float" && col.defaultTo && String(col.defaultTo).includes('"') === false) {
|
|
485
|
-
|
|
486
|
-
}
|
|
487
|
-
// string인 경우 기본값이 빈 스트링인 경우 대응
|
|
488
|
-
if (col.type === "string" && col.defaultTo === "") {
|
|
489
|
-
|
|
490
|
-
}
|
|
491
|
-
// boolean인 경우 기본값 정규화 (MySQL에서는 TINYINT(1)로 저장되므로 0 또는 1로 정규화)
|
|
492
|
-
// TODO: db.ts에 typeCase 설정 확인하여 처리하도록 수정 필요
|
|
493
|
-
if (col.type === "boolean" && col.defaultTo !== undefined) {
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
}
|
|
539
|
+
// if (col.type === "float" && col.defaultTo && String(col.defaultTo).includes('"') === false) {
|
|
540
|
+
// col.defaultTo = `"${Number(col.defaultTo).toFixed(col.scale ?? 2)}"`;
|
|
541
|
+
// }
|
|
542
|
+
// // string인 경우 기본값이 빈 스트링인 경우 대응
|
|
543
|
+
// if (col.type === "string" && col.defaultTo === "") {
|
|
544
|
+
// col.defaultTo = '""';
|
|
545
|
+
// }
|
|
546
|
+
// // boolean인 경우 기본값 정규화 (MySQL에서는 TINYINT(1)로 저장되므로 0 또는 1로 정규화)
|
|
547
|
+
// // TODO: db.ts에 typeCase 설정 확인하여 처리하도록 수정 필요
|
|
548
|
+
// if (col.type === "boolean" && col.defaultTo !== undefined) {
|
|
549
|
+
// if (col.defaultTo === "0" || col.defaultTo.toLowerCase() === "false") {
|
|
550
|
+
// col.defaultTo = "0";
|
|
551
|
+
// } else if (col.defaultTo === "1" || col.defaultTo.toLowerCase() === "true") {
|
|
552
|
+
// col.defaultTo = "1";
|
|
553
|
+
// }
|
|
554
|
+
// }
|
|
555
|
+
// FIXME: 일단 MySQL 상황에서 발생했던 이슈의 workaround 이므로 Pg에서 재확인 후 대응 추가
|
|
500
556
|
return col;
|
|
501
557
|
};
|
|
502
|
-
const entityColumns =
|
|
503
|
-
const dbColumns =
|
|
558
|
+
const entityColumns = alphabetical(entitySet.columns, (a)=>a.name).map(replaceColumnDefaultTo);
|
|
559
|
+
const dbColumns = alphabetical(dbSet.columns, (a)=>a.name).map(replaceColumnDefaultTo);
|
|
504
560
|
/* 디버깅용 코드, 특정 컬럼에서 불일치 발생할 때 확인
|
|
505
561
|
const entityColumn = entitySet.columns.find(
|
|
506
562
|
(col) => col.name === "price_krw"
|
|
@@ -509,11 +565,11 @@ import equal from "fast-deep-equal";
|
|
|
509
565
|
(col) => col.name === "price_krw"
|
|
510
566
|
);
|
|
511
567
|
console.debug({ entityColumn, dbColumn });
|
|
512
|
-
*/ const entityIndexes =
|
|
568
|
+
*/ const entityIndexes = alphabetical(entitySet.indexes, (a)=>[
|
|
513
569
|
a.type,
|
|
514
570
|
...a.columns.sort((c1, c2)=>c1 > c2 ? 1 : -1)
|
|
515
571
|
].join("-"));
|
|
516
|
-
const dbIndexes =
|
|
572
|
+
const dbIndexes = alphabetical(dbSet.indexes, (a)=>[
|
|
517
573
|
a.type,
|
|
518
574
|
...a.columns.sort((c1, c2)=>c1 > c2 ? 1 : -1)
|
|
519
575
|
].join("-"));
|
|
@@ -526,20 +582,20 @@ import equal from "fast-deep-equal";
|
|
|
526
582
|
onDelete: onDelete === "RESTRICT" ? "NO ACTION" : onDelete
|
|
527
583
|
};
|
|
528
584
|
};
|
|
529
|
-
const entityForeigns =
|
|
585
|
+
const entityForeigns = alphabetical(entitySet.foreigns, (a)=>[
|
|
530
586
|
a.to,
|
|
531
587
|
...a.columns
|
|
532
588
|
].join("-")).map((f)=>replaceNoActionOnMySQL(f));
|
|
533
|
-
const dbForeigns =
|
|
589
|
+
const dbForeigns = alphabetical(dbSet.foreigns, (a)=>[
|
|
534
590
|
a.to,
|
|
535
591
|
...a.columns
|
|
536
592
|
].join("-")).map((f)=>replaceNoActionOnMySQL(f));
|
|
537
593
|
// 삭제될 컬럼 목록 계산
|
|
538
|
-
const droppingColumns =
|
|
594
|
+
const droppingColumns = diff(dbColumns, entityColumns, (col)=>col.name);
|
|
539
595
|
const alterCodes = [];
|
|
540
596
|
// 1. columnsAndIndexes 처리
|
|
541
597
|
const isEqualColumns = equal(entityColumns, dbColumns);
|
|
542
|
-
const isEqualIndexes = equal(entityIndexes.map((index)=>
|
|
598
|
+
const isEqualIndexes = equal(entityIndexes.map((index)=>omit(index, [
|
|
543
599
|
"parser"
|
|
544
600
|
])), dbIndexes);
|
|
545
601
|
if (!isEqualColumns || !isEqualIndexes) {
|
|
@@ -555,4 +611,4 @@ import equal from "fast-deep-equal";
|
|
|
555
611
|
return alterCodes.filter((alterCode)=>alterCode !== null).flat();
|
|
556
612
|
}
|
|
557
613
|
|
|
558
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/migration/code-generation.ts"],"sourcesContent":["import * as _ from \"lodash-es\";\nimport prettier from \"prettier\";\nimport equal from \"fast-deep-equal\";\nimport {\n  GenMigrationCode,\n  MigrationColumn,\n  MigrationForeign,\n  MigrationIndex,\n  MigrationSet,\n} from \"../types/types\";\n\n/**\n * 테이블 생성하는 케이스 - 컬럼/인덱스 생성\n */\nasync function generateCreateCode_ColumnAndIndexes(\n  table: string,\n  columns: MigrationColumn[],\n  indexes: MigrationIndex[]\n): Promise<GenMigrationCode> {\n  // fulltext index 분리\n  const [ngramIndexes, standardIndexes] = _.partition(\n    indexes,\n    (i) => i.type === \"fulltext\" && i.parser === \"ngram\"\n  );\n\n  // 컬럼, 인덱스 처리\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `await knex.schema.createTable(\"${table}\", (table) => {`,\n    \"// columns\",\n    ...genColumnDefinitions(columns),\n    \"\",\n    \"// indexes\",\n    ...standardIndexes.map((index) => genIndexDefinition(index, table)),\n    \"});\",\n    // ngram은 knex.raw로 처리하므로 createTable 밖에서 실행\n    ...ngramIndexes.map((index) => genIndexDefinition(index, table)),\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    ` return knex.schema.dropTable(\"${table}\");`,\n    \"}\",\n  ];\n  return {\n    table,\n    type: \"normal\",\n    title: `create__${table}`,\n    formatted: await prettier.format(lines.join(\"\\n\"), {\n      parser: \"typescript\",\n    }),\n  };\n}\n\n/**\n * MigrationColumn[] 읽어서 컬럼 정의하는 구문 생성\n */\nfunction genColumnDefinitions(columns: MigrationColumn[]): string[] {\n  return columns.map((column) => {\n    const chains: string[] = [];\n    if (column.name === \"id\") {\n      return `table.increments().primary();`;\n    }\n\n    // FIXME: float(M,D) deprecated -> decimal(M,D) 이용하도록 하고, float/double 처리 추가\n    if (column.type === \"float\" || column.type === \"decimal\") {\n      chains.push(\n        `${column.type}('${column.name}', ${column.precision}, ${column.scale})`\n      );\n    } else {\n      // type, length\n      let columnType = column.type;\n      let extraType: string | undefined;\n      if (columnType.includes(\"text\") && columnType !== \"text\") {\n        extraType = columnType;\n        columnType = \"text\";\n      }\n      chains.push(\n        `${columnType}('${column.name}'${\n          column.length ? `, ${column.length}` : \"\"\n        }${extraType ? `, '${extraType}'` : \"\"})`\n      );\n    }\n    if (column.unsigned) {\n      chains.push(\"unsigned()\");\n    }\n\n    // nullable\n    chains.push(column.nullable ? \"nullable()\" : \"notNullable()\");\n\n    // defaultTo\n    if (column.defaultTo !== undefined) {\n      if (\n        typeof column.defaultTo === \"string\" &&\n        column.defaultTo.startsWith(`\"`)\n      ) {\n        chains.push(`defaultTo(${column.defaultTo})`);\n      } else {\n        chains.push(`defaultTo(knex.raw('${column.defaultTo}'))`);\n      }\n    }\n\n    return `table.${chains.join(\".\")};`;\n  });\n}\n\n/**\n * 개별 인덱스 정의 생성\n */\nfunction genIndexDefinition(index: MigrationIndex, table: string) {\n  const methodMap = {\n    index: \"index\",\n    fulltext: \"index\",\n    unique: \"unique\",\n  };\n\n  if (index.type === \"fulltext\" && index.parser === \"ngram\") {\n    const indexName = `${table}_${index.columns.join(\"_\")}_index`;\n    return `await knex.raw(\\`ALTER TABLE ${table} ADD FULLTEXT INDEX ${indexName} (${index.columns.join(\n      \", \"\n    )}) WITH PARSER ngram\\`);`;\n  }\n\n  return `table.${methodMap[index.type]}([${index.columns\n    .map((col) => `'${col}'`)\n    .join(\",\")}]${index.type === \"fulltext\" ? \", undefined, 'FULLTEXT'\" : \"\"})`;\n}\n\n/**\n * 테이블 생성하는 케이스 - FK 생성\n */\nasync function generateCreateCode_Foreign(\n  table: string,\n  foreigns: MigrationForeign[]\n): Promise<GenMigrationCode[]> {\n  if (foreigns.length === 0) {\n    return [];\n  }\n\n  const { up, down } = genForeignDefinitions(table, foreigns);\n  if (up.length === 0 && down.length === 0) {\n    console.log(\"fk 가 뭔가 다릅니다\");\n    return [];\n  }\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    \"// create fk\",\n    ...up,\n    \"});\",\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    \"// drop fk\",\n    ...down,\n    \"});\",\n    \"}\",\n  ];\n\n  const foreignKeysString = foreigns\n    .map((foreign) => foreign.columns.join(\"_\"))\n    .join(\"_\");\n  return [\n    {\n      table,\n      type: \"foreign\",\n      title: `foreign__${table}__${foreignKeysString}`,\n      formatted: await prettier.format(lines.join(\"\\n\"), {\n        parser: \"typescript\",\n      }),\n    },\n  ];\n}\n\n/**\n * MigrationForeign[] 읽어서 외부키 constraint 정의하는 구문 생성\n */\nfunction genForeignDefinitions(\n  table: string,\n  foreigns: MigrationForeign[]\n): { up: string[]; down: string[] } {\n  return foreigns.reduce(\n    (r, foreign) => {\n      const columnsStringQuote = foreign.columns\n        .map((col) => `'${col.replace(`${table}.`, \"\")}'`)\n        .join(\",\");\n      r.up.push(\n        `table.foreign('${foreign.columns.join(\",\")}')\n            .references('${foreign.to}')\n            .onUpdate('${foreign.onUpdate}')\n            .onDelete('${foreign.onDelete}')`\n      );\n      r.down.push(`table.dropForeign([${columnsStringQuote}])`);\n      return r;\n    },\n    {\n      up: [] as string[],\n      down: [] as string[],\n    }\n  );\n}\n\n/**\n * 테이블 변경 케이스 - 컬럼/인덱스 변경\n */\nasync function generateAlterCode_ColumnAndIndexes(\n  table: string,\n  entityColumns: MigrationColumn[],\n  entityIndexes: MigrationIndex[],\n  dbColumns: MigrationColumn[],\n  dbIndexes: MigrationIndex[],\n  dbForeigns: MigrationForeign[]\n): Promise<GenMigrationCode[]> {\n  /*\n    세부 비교 후 다른점 찾아서 코드 생성\n\n    1. 컬럼갯수 다름: MD에 있으나, DB에 없다면 추가\n    2. 컬럼갯수 다름: MD에 없으나, DB에 있다면 삭제\n    3. 그외 컬럼(컬럼 갯수가 동일하거나, 다른 경우 동일한 컬럼끼리) => alter\n    4. 다른거 다 동일하고 index만 변경되는 경우\n\n    ** 컬럼명을 변경하는 경우는 따로 핸들링하지 않음\n    => drop/add 형태의 마이그레이션 코드가 생성되는데, 수동으로 rename 코드로 수정하여 처리\n  */\n\n  // 각 컬럼 이름 기준으로 add, drop, alter 여부 확인\n  const alterColumnsTo = getAlterColumnsTo(entityColumns, dbColumns);\n\n  // 추출된 컬럼들을 기준으로 각각 라인 생성\n  const alterColumnLinesTo = getAlterColumnLinesTo(\n    alterColumnsTo,\n    entityColumns,\n    table,\n    dbForeigns\n  );\n\n  // 인덱스의 add, drop 여부 확인\n  const alterIndexesTo = getAlterIndexesTo(entityIndexes, dbIndexes);\n\n  // fulltext index 분리\n  const [ngramIndexes, standardIndexes] = _.partition(\n    alterIndexesTo.add,\n    (i) => i.type === \"fulltext\" && i.parser === \"ngram\"\n  );\n\n  // 인덱스가 삭제되는 경우, 컬럼과 같이 삭제된 케이스에는 drop에서 제외해야함!\n  const indexNeedsToDrop = alterIndexesTo.drop.filter(\n    (index) =>\n      index.columns.every((colName) =>\n        alterColumnsTo.drop.map((col) => col.name).includes(colName)\n      ) === false\n  );\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `await knex.schema.alterTable(\"${table}\", (table) => {`,\n    // 1. add column\n    ...(alterColumnsTo.add.length > 0 ? alterColumnLinesTo.add.up : []),\n    // 2. drop column\n    ...(alterColumnsTo.drop.length > 0 ? alterColumnLinesTo.drop.up : []),\n    // 3. alter column\n    ...(alterColumnsTo.alter.length > 0 ? alterColumnLinesTo.alter.up : []),\n    // 4. add index\n    ...standardIndexes.map((index) => genIndexDefinition(index, table)),\n    // 5. drop index\n    ...indexNeedsToDrop.map(genIndexDropDefinition),\n    \"});\",\n    // ngram은 knex.raw로 처리하므로 alterTable 밖에서 실행\n    ...ngramIndexes.map((index) => genIndexDefinition(index, table)),\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...(alterColumnsTo.add.length > 0 ? alterColumnLinesTo.add.down : []),\n    ...(alterColumnsTo.drop.length > 0 ? alterColumnLinesTo.drop.down : []),\n    ...(alterColumnsTo.alter.length > 0 ? alterColumnLinesTo.alter.down : []),\n    ...alterIndexesTo.add\n      .filter(\n        (index) =>\n          index.columns.every((colName) =>\n            alterColumnsTo.add.map((col) => col.name).includes(colName)\n          ) === false\n      )\n      .map(genIndexDropDefinition),\n    ...indexNeedsToDrop.map((index) => genIndexDefinition(index, table)),\n    \"});\",\n    \"}\",\n  ];\n\n  const formatted = await prettier.format(lines.join(\"\\n\"), {\n    parser: \"typescript\",\n  });\n\n  const title = [\n    \"alter\",\n    table,\n    ...([\"add\", \"drop\", \"alter\"] as const)\n      .map((action) => {\n        const len = alterColumnsTo[action].length;\n        if (len > 0) {\n          return action + len;\n        }\n        return null;\n      })\n      .filter((part) => part !== null),\n  ].join(\"_\");\n\n  return [\n    {\n      table,\n      title,\n      formatted,\n      type: \"normal\",\n    },\n  ];\n}\n\n/**\n * 각 컬럼 이름 기준으로 add, drop, alter 여부 확인\n */\nfunction getAlterColumnsTo(\n  entityColumns: MigrationColumn[],\n  dbColumns: MigrationColumn[]\n) {\n  const columnsTo = {\n    add: [] as MigrationColumn[],\n    drop: [] as MigrationColumn[],\n    alter: [] as MigrationColumn[],\n  };\n\n  // 컬럼명 기준 비교\n  const extraColumns = {\n    db: _.differenceBy(dbColumns, entityColumns, (col) => col.name),\n    entity: _.differenceBy(entityColumns, dbColumns, (col) => col.name),\n  };\n  if (extraColumns.entity.length > 0) {\n    columnsTo.add = columnsTo.add.concat(extraColumns.entity);\n  }\n  if (extraColumns.db.length > 0) {\n    columnsTo.drop = columnsTo.drop.concat(extraColumns.db);\n  }\n\n  // 동일 컬럼명의 세부 필드 비교\n  const sameDbColumns = _.intersectionBy(\n    dbColumns,\n    entityColumns,\n    (col) => col.name\n  );\n  const sameMdColumns = _.intersectionBy(\n    entityColumns,\n    dbColumns,\n    (col) => col.name\n  );\n  columnsTo.alter = _.differenceWith(sameDbColumns, sameMdColumns, (a, b) =>\n    equal(a, b)\n  );\n\n  return columnsTo;\n}\n\n/**\n * 추출된 컬럼들을 기준으로 각각 라인 생성\n */\nfunction getAlterColumnLinesTo(\n  columnsTo: ReturnType<typeof getAlterColumnsTo>,\n  entityColumns: MigrationColumn[],\n  table: string,\n  dbForeigns: MigrationForeign[]\n) {\n  let linesTo = {\n    add: {\n      up: [] as string[],\n      down: [] as string[],\n    },\n    drop: {\n      up: [] as string[],\n      down: [] as string[],\n    },\n    alter: {\n      up: [] as string[],\n      down: [] as string[],\n    },\n  };\n\n  linesTo.add = {\n    up: [\"// add\", ...genColumnDefinitions(columnsTo.add)],\n    down: [\n      \"// rollback - add\",\n      `table.dropColumns(${columnsTo.add\n        .map((col) => `'${col.name}'`)\n        .join(\", \")})`,\n    ],\n  };\n\n  // drop할 컬럼에 걸린 FK 찾기\n  const dropColumnNames = columnsTo.drop.map((col) => col.name);\n  const fkToDropBeforeColumn = dbForeigns.filter((fk) =>\n    fk.columns.some((col) => dropColumnNames.includes(col))\n  );\n\n  const dropFkLines = fkToDropBeforeColumn.map((fk) => {\n    const columnsStringQuote = fk.columns.map((col) => `'${col}'`).join(\",\");\n    return `table.dropForeign([${columnsStringQuote}])`;\n  });\n\n  const restoreFkLines = genForeignDefinitions(table, fkToDropBeforeColumn).up;\n\n  linesTo.drop = {\n    up: [\n      ...(dropFkLines.length > 0\n        ? [\"// drop foreign keys on columns to be dropped\", ...dropFkLines]\n        : []),\n      \"// drop columns\",\n      `table.dropColumns(${columnsTo.drop\n        .map((col) => `'${col.name}'`)\n        .join(\", \")})`,\n    ],\n    down: [\n      \"// rollback - drop columns\",\n      ...genColumnDefinitions(columnsTo.drop),\n      ...(restoreFkLines.length > 0\n        ? [\"// restore foreign keys\", ...restoreFkLines]\n        : []),\n    ],\n  };\n  linesTo.alter = columnsTo.alter.reduce(\n    (r, dbColumn) => {\n      const entityColumn = entityColumns.find(\n        (col) => col.name == dbColumn.name\n      );\n      if (entityColumn === undefined) {\n        return r;\n      }\n\n      // 컬럼 변경사항\n      const columnDiffUp = _.difference(\n        genColumnDefinitions([entityColumn]),\n        genColumnDefinitions([dbColumn])\n      );\n      const columnDiffDown = _.difference(\n        genColumnDefinitions([dbColumn]),\n        genColumnDefinitions([entityColumn])\n      );\n      if (columnDiffUp.length > 0) {\n        r.up = [\n          ...r.up,\n          \"// alter column\",\n          ...columnDiffUp.map((l) => l.replace(\";\", \"\") + \".alter();\"),\n        ];\n        r.down = [\n          ...r.down,\n          \"// rollback - alter column\",\n          ...columnDiffDown.map((l) => l.replace(\";\", \"\") + \".alter();\"),\n        ];\n      }\n\n      return r;\n    },\n    {\n      up: [] as string[],\n      down: [] as string[],\n    }\n  );\n\n  return linesTo;\n}\n\n/**\n * 인덱스의 add, drop 여부 확인\n */\nfunction getAlterIndexesTo(\n  entityIndexes: MigrationIndex[],\n  dbIndexes: MigrationIndex[]\n) {\n  // 인덱스 비교\n  let indexesTo = {\n    add: [] as MigrationIndex[],\n    drop: [] as MigrationIndex[],\n  };\n  const extraIndexes = {\n    db: _.differenceBy(dbIndexes, entityIndexes, (col) =>\n      [col.type, col.columns.join(\"-\")].join(\"//\")\n    ),\n    entity: _.differenceBy(entityIndexes, dbIndexes, (col) =>\n      [col.type, col.columns.join(\"-\")].join(\"//\")\n    ),\n  };\n  if (extraIndexes.entity.length > 0) {\n    indexesTo.add = indexesTo.add.concat(extraIndexes.entity);\n  }\n  if (extraIndexes.db.length > 0) {\n    indexesTo.drop = indexesTo.drop.concat(extraIndexes.db);\n  }\n\n  return indexesTo;\n}\n\n/**\n * 인덱스 삭제 정의 생성\n */\nfunction genIndexDropDefinition(index: MigrationIndex) {\n  const methodMap = {\n    index: \"Index\",\n    fulltext: \"Index\",\n    unique: \"Unique\",\n  };\n\n  return `table.drop${methodMap[index.type]}([${index.columns\n    .map((columnName) => `'${columnName}'`)\n    .join(\",\")}])`;\n}\n\n/**\n * 테이블 변경 케이스 - Foreign Key 변경\n */\nasync function generateAlterCode_Foreigns(\n  table: string,\n  entityForeigns: MigrationForeign[],\n  dbForeigns: MigrationForeign[],\n  droppingColumns: MigrationColumn[] = []\n): Promise<GenMigrationCode[]> {\n  // console.log({ entityForeigns, dbForeigns });\n\n  const getKey = (mf: MigrationForeign): string => {\n    return [mf.columns.join(\"-\"), mf.to].join(\"///\");\n  };\n\n  // 삭제될 컬럼명 목록\n  const droppingColumnNames = droppingColumns.map((col) => col.name);\n\n  const fkTo = entityForeigns.reduce(\n    (result, entityF) => {\n      const matchingDbF = dbForeigns.find(\n        (dbF) => getKey(entityF) === getKey(dbF)\n      );\n      if (!matchingDbF) {\n        result.add.push(entityF);\n        return result;\n      }\n\n      if (equal(entityF, matchingDbF) === false) {\n        result.alterSrc.push(matchingDbF);\n        result.alterDst.push(entityF);\n        return result;\n      }\n      return result;\n    },\n    {\n      add: [] as MigrationForeign[],\n      drop: [] as MigrationForeign[],\n      alterSrc: [] as MigrationForeign[],\n      alterDst: [] as MigrationForeign[],\n    }\n  );\n\n  // dbForeigns에는 있지만 entityForeigns에는 없는 경우 (삭제된 FK)\n  // 단, 삭제될 컬럼의 FK는 제외 (generateAlterCode_ColumnAndIndexes에서 처리)\n  dbForeigns.forEach((dbF) => {\n    const matchingEntityF = entityForeigns.find(\n      (entityF) => getKey(entityF) === getKey(dbF)\n    );\n    if (!matchingEntityF) {\n      // 이 FK의 컬럼이 삭제될 컬럼 목록에 있는지 확인\n      const isColumnDropping = dbF.columns.some((col) =>\n        droppingColumnNames.includes(col)\n      );\n      // 컬럼이 삭제되지 않는 경우에만 FK drop 목록에 추가\n      if (!isColumnDropping) {\n        fkTo.drop.push(dbF);\n      }\n    }\n  });\n\n  const linesTo = {\n    add: genForeignDefinitions(table, fkTo.add),\n    drop: genForeignDefinitions(table, fkTo.drop),\n    alterSrc: genForeignDefinitions(table, fkTo.alterSrc),\n    alterDst: genForeignDefinitions(table, fkTo.alterDst),\n  };\n\n  // drop fk columns인 경우(생성될 코드 없는 경우) 패스\n  const hasLines = Object.values(linesTo).some(\n    (l) => l.up.length > 0 || l.down.length > 0\n  );\n  if (!hasLines) {\n    return [];\n  }\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...linesTo.drop.down,\n    ...linesTo.add.up,\n    ...linesTo.alterSrc.down,\n    ...linesTo.alterDst.up,\n    \"})\",\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...linesTo.add.down,\n    ...linesTo.alterDst.down,\n    ...linesTo.alterSrc.up,\n    ...linesTo.drop.up,\n    \"})\",\n    \"}\",\n  ];\n\n  const formatted = await prettier.format(lines.join(\"\\n\"), {\n    parser: \"typescript\",\n  });\n\n  const title = [\n    \"alter\",\n    table,\n    \"foreigns\",\n    // TODO 바뀌는 부분\n  ].join(\"_\");\n\n  return [\n    {\n      table,\n      title,\n      formatted,\n      type: \"normal\",\n    },\n  ];\n}\n\n/**\n * 주어진 EntitySet을 기반으로 테이블 CREATE 마이그레이션 코드를 생성합니다.\n * @param entitySet\n * @returns CREATE 마이그레이션 코드\n */\nexport async function generateCreateCode(\n  entitySet: MigrationSet\n): Promise<GenMigrationCode[]> {\n  return [\n    await generateCreateCode_ColumnAndIndexes(\n      entitySet.table,\n      entitySet.columns,\n      entitySet.indexes\n    ),\n    ...(await generateCreateCode_Foreign(entitySet.table, entitySet.foreigns)),\n  ];\n}\n\n/**\n * 주어진 entitySet을 목표로, dbSet을 현 상황으로 하여 테이블 ALTER 마이그레이션 코드를 생성합니다.\n * @param entitySet 현 상황의 MigrationSet\n * @param dbSet 목표 상황의 MigrationSet\n * @returns ALTER 마이그레이션 코드\n */\nexport async function generateAlterCode(\n  entitySet: MigrationSet,\n  dbSet: MigrationSet\n): Promise<GenMigrationCode[]> {\n  const replaceColumnDefaultTo = (col: MigrationColumn) => {\n    // float인 경우 기본값을 0으로 지정하는 경우 \"0.00\"으로 변환되는 케이스 대응\n    if (\n      col.type === \"float\" &&\n      col.defaultTo &&\n      String(col.defaultTo).includes('\"') === false\n    ) {\n      col.defaultTo = `\"${Number(col.defaultTo).toFixed(col.scale ?? 2)}\"`;\n    }\n    // string인 경우 기본값이 빈 스트링인 경우 대응\n    if (col.type === \"string\" && col.defaultTo === \"\") {\n      col.defaultTo = '\"\"';\n    }\n    // boolean인 경우 기본값 정규화 (MySQL에서는 TINYINT(1)로 저장되므로 0 또는 1로 정규화)\n    // TODO: db.ts에 typeCase 설정 확인하여 처리하도록 수정 필요\n    if (col.type === \"boolean\" && col.defaultTo !== undefined) {\n      if (col.defaultTo === \"0\" || col.defaultTo.toLowerCase() === \"false\") {\n        col.defaultTo = \"0\";\n      } else if (col.defaultTo === \"1\" || col.defaultTo.toLowerCase() === \"true\") {\n        col.defaultTo = \"1\";\n      }\n    }\n    return col;\n  };\n  const entityColumns = _.sortBy(entitySet.columns, (a) => a.name).map(\n    replaceColumnDefaultTo\n  );\n  const dbColumns = _.sortBy(dbSet.columns, (a) => a.name).map(\n    replaceColumnDefaultTo\n  );\n\n  /* 디버깅용 코드, 특정 컬럼에서 불일치 발생할 때 확인\n        const entityColumn = entitySet.columns.find(\n          (col) => col.name === \"price_krw\"\n        );\n        const dbColumn = dbSet.columns.find(\n          (col) => col.name === \"price_krw\"\n        );\n        console.debug({ entityColumn, dbColumn });\n         */\n\n  const entityIndexes = _.sortBy(entitySet.indexes, (a) =>\n    [a.type, ...a.columns.sort((c1, c2) => (c1 > c2 ? 1 : -1))].join(\"-\")\n  );\n  const dbIndexes = _.sortBy(dbSet.indexes, (a) =>\n    [a.type, ...a.columns.sort((c1, c2) => (c1 > c2 ? 1 : -1))].join(\"-\")\n  );\n\n  const replaceNoActionOnMySQL = (f: MigrationForeign) => {\n    // MySQL에서 RESTRICT와 NO ACTION은 동일함\n    const { onDelete, onUpdate } = f;\n    return {\n      ...f,\n      onUpdate: onUpdate === \"RESTRICT\" ? \"NO ACTION\" : onUpdate,\n      onDelete: onDelete === \"RESTRICT\" ? \"NO ACTION\" : onDelete,\n    };\n  };\n\n  const entityForeigns = _.sortBy(entitySet.foreigns, (a) =>\n    [a.to, ...a.columns].join(\"-\")\n  ).map((f) => replaceNoActionOnMySQL(f));\n  const dbForeigns = _.sortBy(dbSet.foreigns, (a) =>\n    [a.to, ...a.columns].join(\"-\")\n  ).map((f) => replaceNoActionOnMySQL(f));\n\n  // 삭제될 컬럼 목록 계산\n  const droppingColumns = _.differenceBy(\n    dbColumns,\n    entityColumns,\n    (col) => col.name\n  );\n\n  const alterCodes: (GenMigrationCode | GenMigrationCode[] | null)[] = [];\n\n  // 1. columnsAndIndexes 처리\n  const isEqualColumns = equal(entityColumns, dbColumns);\n  const isEqualIndexes = equal(\n    entityIndexes.map((index) => _.omit(index, [\"parser\"])),\n    dbIndexes\n  );\n  if (!isEqualColumns || !isEqualIndexes) {\n    alterCodes.push(\n      await generateAlterCode_ColumnAndIndexes(\n        entitySet.table,\n        entityColumns,\n        entityIndexes,\n        dbColumns,\n        dbIndexes,\n        dbSet.foreigns\n      )\n    );\n  }\n\n  // 2. foreigns 처리 (삭제될 컬럼 정보 전달)\n  if (equal(entityForeigns, dbForeigns) === false) {\n    alterCodes.push(\n      await generateAlterCode_Foreigns(\n        entitySet.table,\n        entityForeigns,\n        dbForeigns,\n        droppingColumns\n      )\n    );\n  }\n\n  if (alterCodes.every((alterCode) => alterCode === null)) {\n    return [];\n  }\n\n  return alterCodes.filter((alterCode) => alterCode !== null).flat();\n}\n"],"names":["_","prettier","equal","generateCreateCode_ColumnAndIndexes","table","columns","indexes","ngramIndexes","standardIndexes","partition","i","type","parser","lines","genColumnDefinitions","map","index","genIndexDefinition","title","formatted","format","join","column","chains","name","push","precision","scale","columnType","extraType","includes","length","unsigned","nullable","defaultTo","undefined","startsWith","methodMap","fulltext","unique","indexName","col","generateCreateCode_Foreign","foreigns","up","down","genForeignDefinitions","console","log","foreignKeysString","foreign","reduce","r","columnsStringQuote","replace","to","onUpdate","onDelete","generateAlterCode_ColumnAndIndexes","entityColumns","entityIndexes","dbColumns","dbIndexes","dbForeigns","alterColumnsTo","getAlterColumnsTo","alterColumnLinesTo","getAlterColumnLinesTo","alterIndexesTo","getAlterIndexesTo","add","indexNeedsToDrop","drop","filter","every","colName","alter","genIndexDropDefinition","action","len","part","columnsTo","extraColumns","db","differenceBy","entity","concat","sameDbColumns","intersectionBy","sameMdColumns","differenceWith","a","b","linesTo","dropColumnNames","fkToDropBeforeColumn","fk","some","dropFkLines","restoreFkLines","dbColumn","entityColumn","find","columnDiffUp","difference","columnDiffDown","l","indexesTo","extraIndexes","columnName","generateAlterCode_Foreigns","entityForeigns","droppingColumns","getKey","mf","droppingColumnNames","fkTo","result","entityF","matchingDbF","dbF","alterSrc","alterDst","forEach","matchingEntityF","isColumnDropping","hasLines","Object","values","generateCreateCode","entitySet","generateAlterCode","dbSet","replaceColumnDefaultTo","String","Number","toFixed","toLowerCase","sortBy","sort","c1","c2","replaceNoActionOnMySQL","f","alterCodes","isEqualColumns","isEqualIndexes","omit","alterCode","flat"],"mappings":"AAAA,YAAYA,OAAO,YAAY;AAC/B,OAAOC,cAAc,WAAW;AAChC,OAAOC,WAAW,kBAAkB;AASpC;;CAEC,GACD,eAAeC,oCACbC,KAAa,EACbC,OAA0B,EAC1BC,OAAyB;IAEzB,oBAAoB;IACpB,MAAM,CAACC,cAAcC,gBAAgB,GAAGR,EAAES,SAAS,CACjDH,SACA,CAACI,IAAMA,EAAEC,IAAI,KAAK,cAAcD,EAAEE,MAAM,KAAK;IAG/C,aAAa;IACb,MAAMC,QAAkB;QACtB;QACA;QACA;QACA,CAAC,+BAA+B,EAAET,MAAM,eAAe,CAAC;QACxD;WACGU,qBAAqBT;QACxB;QACA;WACGG,gBAAgBO,GAAG,CAAC,CAACC,QAAUC,mBAAmBD,OAAOZ;QAC5D;QACA,4CAA4C;WACzCG,aAAaQ,GAAG,CAAC,CAACC,QAAUC,mBAAmBD,OAAOZ;QACzD;QACA;QACA;QACA,CAAC,+BAA+B,EAAEA,MAAM,GAAG,CAAC;QAC5C;KACD;IACD,OAAO;QACLA;QACAO,MAAM;QACNO,OAAO,CAAC,QAAQ,EAAEd,OAAO;QACzBe,WAAW,MAAMlB,SAASmB,MAAM,CAACP,MAAMQ,IAAI,CAAC,OAAO;YACjDT,QAAQ;QACV;IACF;AACF;AAEA;;CAEC,GACD,SAASE,qBAAqBT,OAA0B;IACtD,OAAOA,QAAQU,GAAG,CAAC,CAACO;QAClB,MAAMC,SAAmB,EAAE;QAC3B,IAAID,OAAOE,IAAI,KAAK,MAAM;YACxB,OAAO,CAAC,6BAA6B,CAAC;QACxC;QAEA,4EAA4E;QAC5E,IAAIF,OAAOX,IAAI,KAAK,WAAWW,OAAOX,IAAI,KAAK,WAAW;YACxDY,OAAOE,IAAI,CACT,GAAGH,OAAOX,IAAI,CAAC,EAAE,EAAEW,OAAOE,IAAI,CAAC,GAAG,EAAEF,OAAOI,SAAS,CAAC,EAAE,EAAEJ,OAAOK,KAAK,CAAC,CAAC,CAAC;QAE5E,OAAO;YACL,eAAe;YACf,IAAIC,aAAaN,OAAOX,IAAI;YAC5B,IAAIkB;YACJ,IAAID,WAAWE,QAAQ,CAAC,WAAWF,eAAe,QAAQ;gBACxDC,YAAYD;gBACZA,aAAa;YACf;YACAL,OAAOE,IAAI,CACT,GAAGG,WAAW,EAAE,EAAEN,OAAOE,IAAI,CAAC,CAAC,EAC7BF,OAAOS,MAAM,GAAG,CAAC,EAAE,EAAET,OAAOS,MAAM,EAAE,GAAG,KACtCF,YAAY,CAAC,GAAG,EAAEA,UAAU,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;QAE7C;QACA,IAAIP,OAAOU,QAAQ,EAAE;YACnBT,OAAOE,IAAI,CAAC;QACd;QAEA,WAAW;QACXF,OAAOE,IAAI,CAACH,OAAOW,QAAQ,GAAG,eAAe;QAE7C,YAAY;QACZ,IAAIX,OAAOY,SAAS,KAAKC,WAAW;YAClC,IACE,OAAOb,OAAOY,SAAS,KAAK,YAC5BZ,OAAOY,SAAS,CAACE,UAAU,CAAC,CAAC,CAAC,CAAC,GAC/B;gBACAb,OAAOE,IAAI,CAAC,CAAC,UAAU,EAAEH,OAAOY,SAAS,CAAC,CAAC,CAAC;YAC9C,OAAO;gBACLX,OAAOE,IAAI,CAAC,CAAC,oBAAoB,EAAEH,OAAOY,SAAS,CAAC,GAAG,CAAC;YAC1D;QACF;QAEA,OAAO,CAAC,MAAM,EAAEX,OAAOF,IAAI,CAAC,KAAK,CAAC,CAAC;IACrC;AACF;AAEA;;CAEC,GACD,SAASJ,mBAAmBD,KAAqB,EAAEZ,KAAa;IAC9D,MAAMiC,YAAY;QAChBrB,OAAO;QACPsB,UAAU;QACVC,QAAQ;IACV;IAEA,IAAIvB,MAAML,IAAI,KAAK,cAAcK,MAAMJ,MAAM,KAAK,SAAS;QACzD,MAAM4B,YAAY,GAAGpC,MAAM,CAAC,EAAEY,MAAMX,OAAO,CAACgB,IAAI,CAAC,KAAK,MAAM,CAAC;QAC7D,OAAO,CAAC,6BAA6B,EAAEjB,MAAM,oBAAoB,EAAEoC,UAAU,EAAE,EAAExB,MAAMX,OAAO,CAACgB,IAAI,CACjG,MACA,uBAAuB,CAAC;IAC5B;IAEA,OAAO,CAAC,MAAM,EAAEgB,SAAS,CAACrB,MAAML,IAAI,CAAC,CAAC,EAAE,EAAEK,MAAMX,OAAO,CACpDU,GAAG,CAAC,CAAC0B,MAAQ,CAAC,CAAC,EAAEA,IAAI,CAAC,CAAC,EACvBpB,IAAI,CAAC,KAAK,CAAC,EAAEL,MAAML,IAAI,KAAK,aAAa,4BAA4B,GAAG,CAAC,CAAC;AAC/E;AAEA;;CAEC,GACD,eAAe+B,2BACbtC,KAAa,EACbuC,QAA4B;IAE5B,IAAIA,SAASZ,MAAM,KAAK,GAAG;QACzB,OAAO,EAAE;IACX;IAEA,MAAM,EAAEa,EAAE,EAAEC,IAAI,EAAE,GAAGC,sBAAsB1C,OAAOuC;IAClD,IAAIC,GAAGb,MAAM,KAAK,KAAKc,KAAKd,MAAM,KAAK,GAAG;QACxCgB,QAAQC,GAAG,CAAC;QACZ,OAAO,EAAE;IACX;IAEA,MAAMnC,QAAkB;QACtB;QACA;QACA;QACA,CAAC,+BAA+B,EAAET,MAAM,eAAe,CAAC;QACxD;WACGwC;QACH;QACA;QACA;QACA;QACA,CAAC,+BAA+B,EAAExC,MAAM,eAAe,CAAC;QACxD;WACGyC;QACH;QACA;KACD;IAED,MAAMI,oBAAoBN,SACvB5B,GAAG,CAAC,CAACmC,UAAYA,QAAQ7C,OAAO,CAACgB,IAAI,CAAC,MACtCA,IAAI,CAAC;IACR,OAAO;QACL;YACEjB;YACAO,MAAM;YACNO,OAAO,CAAC,SAAS,EAAEd,MAAM,EAAE,EAAE6C,mBAAmB;YAChD9B,WAAW,MAAMlB,SAASmB,MAAM,CAACP,MAAMQ,IAAI,CAAC,OAAO;gBACjDT,QAAQ;YACV;QACF;KACD;AACH;AAEA;;CAEC,GACD,SAASkC,sBACP1C,KAAa,EACbuC,QAA4B;IAE5B,OAAOA,SAASQ,MAAM,CACpB,CAACC,GAAGF;QACF,MAAMG,qBAAqBH,QAAQ7C,OAAO,CACvCU,GAAG,CAAC,CAAC0B,MAAQ,CAAC,CAAC,EAAEA,IAAIa,OAAO,CAAC,GAAGlD,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAChDiB,IAAI,CAAC;QACR+B,EAAER,EAAE,CAACnB,IAAI,CACP,CAAC,eAAe,EAAEyB,QAAQ7C,OAAO,CAACgB,IAAI,CAAC,KAAK;yBAC3B,EAAE6B,QAAQK,EAAE,CAAC;uBACf,EAAEL,QAAQM,QAAQ,CAAC;uBACnB,EAAEN,QAAQO,QAAQ,CAAC,EAAE,CAAC;QAEvCL,EAAEP,IAAI,CAACpB,IAAI,CAAC,CAAC,mBAAmB,EAAE4B,mBAAmB,EAAE,CAAC;QACxD,OAAOD;IACT,GACA;QACER,IAAI,EAAE;QACNC,MAAM,EAAE;IACV;AAEJ;AAEA;;CAEC,GACD,eAAea,mCACbtD,KAAa,EACbuD,aAAgC,EAChCC,aAA+B,EAC/BC,SAA4B,EAC5BC,SAA2B,EAC3BC,UAA8B;IAE9B;;;;;;;;;;EAUA,GAEA,sCAAsC;IACtC,MAAMC,iBAAiBC,kBAAkBN,eAAeE;IAExD,yBAAyB;IACzB,MAAMK,qBAAqBC,sBACzBH,gBACAL,eACAvD,OACA2D;IAGF,uBAAuB;IACvB,MAAMK,iBAAiBC,kBAAkBT,eAAeE;IAExD,oBAAoB;IACpB,MAAM,CAACvD,cAAcC,gBAAgB,GAAGR,EAAES,SAAS,CACjD2D,eAAeE,GAAG,EAClB,CAAC5D,IAAMA,EAAEC,IAAI,KAAK,cAAcD,EAAEE,MAAM,KAAK;IAG/C,+CAA+C;IAC/C,MAAM2D,mBAAmBH,eAAeI,IAAI,CAACC,MAAM,CACjD,CAACzD,QACCA,MAAMX,OAAO,CAACqE,KAAK,CAAC,CAACC,UACnBX,eAAeQ,IAAI,CAACzD,GAAG,CAAC,CAAC0B,MAAQA,IAAIjB,IAAI,EAAEM,QAAQ,CAAC6C,cAChD;IAGV,MAAM9D,QAAkB;QACtB;QACA;QACA;QACA,CAAC,8BAA8B,EAAET,MAAM,eAAe,CAAC;QACvD,gBAAgB;WACZ4D,eAAeM,GAAG,CAACvC,MAAM,GAAG,IAAImC,mBAAmBI,GAAG,CAAC1B,EAAE,GAAG,EAAE;QAClE,iBAAiB;WACboB,eAAeQ,IAAI,CAACzC,MAAM,GAAG,IAAImC,mBAAmBM,IAAI,CAAC5B,EAAE,GAAG,EAAE;QACpE,kBAAkB;WACdoB,eAAeY,KAAK,CAAC7C,MAAM,GAAG,IAAImC,mBAAmBU,KAAK,CAAChC,EAAE,GAAG,EAAE;QACtE,eAAe;WACZpC,gBAAgBO,GAAG,CAAC,CAACC,QAAUC,mBAAmBD,OAAOZ;QAC5D,gBAAgB;WACbmE,iBAAiBxD,GAAG,CAAC8D;QACxB;QACA,2CAA2C;WACxCtE,aAAaQ,GAAG,CAAC,CAACC,QAAUC,mBAAmBD,OAAOZ;QACzD;QACA;QACA;QACA,CAAC,+BAA+B,EAAEA,MAAM,eAAe,CAAC;WACpD4D,eAAeM,GAAG,CAACvC,MAAM,GAAG,IAAImC,mBAAmBI,GAAG,CAACzB,IAAI,GAAG,EAAE;WAChEmB,eAAeQ,IAAI,CAACzC,MAAM,GAAG,IAAImC,mBAAmBM,IAAI,CAAC3B,IAAI,GAAG,EAAE;WAClEmB,eAAeY,KAAK,CAAC7C,MAAM,GAAG,IAAImC,mBAAmBU,KAAK,CAAC/B,IAAI,GAAG,EAAE;WACrEuB,eAAeE,GAAG,CAClBG,MAAM,CACL,CAACzD,QACCA,MAAMX,OAAO,CAACqE,KAAK,CAAC,CAACC,UACnBX,eAAeM,GAAG,CAACvD,GAAG,CAAC,CAAC0B,MAAQA,IAAIjB,IAAI,EAAEM,QAAQ,CAAC6C,cAC/C,OAET5D,GAAG,CAAC8D;WACJN,iBAAiBxD,GAAG,CAAC,CAACC,QAAUC,mBAAmBD,OAAOZ;QAC7D;QACA;KACD;IAED,MAAMe,YAAY,MAAMlB,SAASmB,MAAM,CAACP,MAAMQ,IAAI,CAAC,OAAO;QACxDT,QAAQ;IACV;IAEA,MAAMM,QAAQ;QACZ;QACAd;WACG,AAAC;YAAC;YAAO;YAAQ;SAAQ,CACzBW,GAAG,CAAC,CAAC+D;YACJ,MAAMC,MAAMf,cAAc,CAACc,OAAO,CAAC/C,MAAM;YACzC,IAAIgD,MAAM,GAAG;gBACX,OAAOD,SAASC;YAClB;YACA,OAAO;QACT,GACCN,MAAM,CAAC,CAACO,OAASA,SAAS;KAC9B,CAAC3D,IAAI,CAAC;IAEP,OAAO;QACL;YACEjB;YACAc;YACAC;YACAR,MAAM;QACR;KACD;AACH;AAEA;;CAEC,GACD,SAASsD,kBACPN,aAAgC,EAChCE,SAA4B;IAE5B,MAAMoB,YAAY;QAChBX,KAAK,EAAE;QACPE,MAAM,EAAE;QACRI,OAAO,EAAE;IACX;IAEA,YAAY;IACZ,MAAMM,eAAe;QACnBC,IAAInF,EAAEoF,YAAY,CAACvB,WAAWF,eAAe,CAAClB,MAAQA,IAAIjB,IAAI;QAC9D6D,QAAQrF,EAAEoF,YAAY,CAACzB,eAAeE,WAAW,CAACpB,MAAQA,IAAIjB,IAAI;IACpE;IACA,IAAI0D,aAAaG,MAAM,CAACtD,MAAM,GAAG,GAAG;QAClCkD,UAAUX,GAAG,GAAGW,UAAUX,GAAG,CAACgB,MAAM,CAACJ,aAAaG,MAAM;IAC1D;IACA,IAAIH,aAAaC,EAAE,CAACpD,MAAM,GAAG,GAAG;QAC9BkD,UAAUT,IAAI,GAAGS,UAAUT,IAAI,CAACc,MAAM,CAACJ,aAAaC,EAAE;IACxD;IAEA,mBAAmB;IACnB,MAAMI,gBAAgBvF,EAAEwF,cAAc,CACpC3B,WACAF,eACA,CAAClB,MAAQA,IAAIjB,IAAI;IAEnB,MAAMiE,gBAAgBzF,EAAEwF,cAAc,CACpC7B,eACAE,WACA,CAACpB,MAAQA,IAAIjB,IAAI;IAEnByD,UAAUL,KAAK,GAAG5E,EAAE0F,cAAc,CAACH,eAAeE,eAAe,CAACE,GAAGC,IACnE1F,MAAMyF,GAAGC;IAGX,OAAOX;AACT;AAEA;;CAEC,GACD,SAASd,sBACPc,SAA+C,EAC/CtB,aAAgC,EAChCvD,KAAa,EACb2D,UAA8B;IAE9B,IAAI8B,UAAU;QACZvB,KAAK;YACH1B,IAAI,EAAE;YACNC,MAAM,EAAE;QACV;QACA2B,MAAM;YACJ5B,IAAI,EAAE;YACNC,MAAM,EAAE;QACV;QACA+B,OAAO;YACLhC,IAAI,EAAE;YACNC,MAAM,EAAE;QACV;IACF;IAEAgD,QAAQvB,GAAG,GAAG;QACZ1B,IAAI;YAAC;eAAa9B,qBAAqBmE,UAAUX,GAAG;SAAE;QACtDzB,MAAM;YACJ;YACA,CAAC,kBAAkB,EAAEoC,UAAUX,GAAG,CAC/BvD,GAAG,CAAC,CAAC0B,MAAQ,CAAC,CAAC,EAAEA,IAAIjB,IAAI,CAAC,CAAC,CAAC,EAC5BH,IAAI,CAAC,MAAM,CAAC,CAAC;SACjB;IACH;IAEA,qBAAqB;IACrB,MAAMyE,kBAAkBb,UAAUT,IAAI,CAACzD,GAAG,CAAC,CAAC0B,MAAQA,IAAIjB,IAAI;IAC5D,MAAMuE,uBAAuBhC,WAAWU,MAAM,CAAC,CAACuB,KAC9CA,GAAG3F,OAAO,CAAC4F,IAAI,CAAC,CAACxD,MAAQqD,gBAAgBhE,QAAQ,CAACW;IAGpD,MAAMyD,cAAcH,qBAAqBhF,GAAG,CAAC,CAACiF;QAC5C,MAAM3C,qBAAqB2C,GAAG3F,OAAO,CAACU,GAAG,CAAC,CAAC0B,MAAQ,CAAC,CAAC,EAAEA,IAAI,CAAC,CAAC,EAAEpB,IAAI,CAAC;QACpE,OAAO,CAAC,mBAAmB,EAAEgC,mBAAmB,EAAE,CAAC;IACrD;IAEA,MAAM8C,iBAAiBrD,sBAAsB1C,OAAO2F,sBAAsBnD,EAAE;IAE5EiD,QAAQrB,IAAI,GAAG;QACb5B,IAAI;eACEsD,YAAYnE,MAAM,GAAG,IACrB;gBAAC;mBAAoDmE;aAAY,GACjE,EAAE;YACN;YACA,CAAC,kBAAkB,EAAEjB,UAAUT,IAAI,CAChCzD,GAAG,CAAC,CAAC0B,MAAQ,CAAC,CAAC,EAAEA,IAAIjB,IAAI,CAAC,CAAC,CAAC,EAC5BH,IAAI,CAAC,MAAM,CAAC,CAAC;SACjB;QACDwB,MAAM;YACJ;eACG/B,qBAAqBmE,UAAUT,IAAI;eAClC2B,eAAepE,MAAM,GAAG,IACxB;gBAAC;mBAA8BoE;aAAe,GAC9C,EAAE;SACP;IACH;IACAN,QAAQjB,KAAK,GAAGK,UAAUL,KAAK,CAACzB,MAAM,CACpC,CAACC,GAAGgD;QACF,MAAMC,eAAe1C,cAAc2C,IAAI,CACrC,CAAC7D,MAAQA,IAAIjB,IAAI,IAAI4E,SAAS5E,IAAI;QAEpC,IAAI6E,iBAAiBlE,WAAW;YAC9B,OAAOiB;QACT;QAEA,UAAU;QACV,MAAMmD,eAAevG,EAAEwG,UAAU,CAC/B1F,qBAAqB;YAACuF;SAAa,GACnCvF,qBAAqB;YAACsF;SAAS;QAEjC,MAAMK,iBAAiBzG,EAAEwG,UAAU,CACjC1F,qBAAqB;YAACsF;SAAS,GAC/BtF,qBAAqB;YAACuF;SAAa;QAErC,IAAIE,aAAaxE,MAAM,GAAG,GAAG;YAC3BqB,EAAER,EAAE,GAAG;mBACFQ,EAAER,EAAE;gBACP;mBACG2D,aAAaxF,GAAG,CAAC,CAAC2F,IAAMA,EAAEpD,OAAO,CAAC,KAAK,MAAM;aACjD;YACDF,EAAEP,IAAI,GAAG;mBACJO,EAAEP,IAAI;gBACT;mBACG4D,eAAe1F,GAAG,CAAC,CAAC2F,IAAMA,EAAEpD,OAAO,CAAC,KAAK,MAAM;aACnD;QACH;QAEA,OAAOF;IACT,GACA;QACER,IAAI,EAAE;QACNC,MAAM,EAAE;IACV;IAGF,OAAOgD;AACT;AAEA;;CAEC,GACD,SAASxB,kBACPT,aAA+B,EAC/BE,SAA2B;IAE3B,SAAS;IACT,IAAI6C,YAAY;QACdrC,KAAK,EAAE;QACPE,MAAM,EAAE;IACV;IACA,MAAMoC,eAAe;QACnBzB,IAAInF,EAAEoF,YAAY,CAACtB,WAAWF,eAAe,CAACnB,MAC5C;gBAACA,IAAI9B,IAAI;gBAAE8B,IAAIpC,OAAO,CAACgB,IAAI,CAAC;aAAK,CAACA,IAAI,CAAC;QAEzCgE,QAAQrF,EAAEoF,YAAY,CAACxB,eAAeE,WAAW,CAACrB,MAChD;gBAACA,IAAI9B,IAAI;gBAAE8B,IAAIpC,OAAO,CAACgB,IAAI,CAAC;aAAK,CAACA,IAAI,CAAC;IAE3C;IACA,IAAIuF,aAAavB,MAAM,CAACtD,MAAM,GAAG,GAAG;QAClC4E,UAAUrC,GAAG,GAAGqC,UAAUrC,GAAG,CAACgB,MAAM,CAACsB,aAAavB,MAAM;IAC1D;IACA,IAAIuB,aAAazB,EAAE,CAACpD,MAAM,GAAG,GAAG;QAC9B4E,UAAUnC,IAAI,GAAGmC,UAAUnC,IAAI,CAACc,MAAM,CAACsB,aAAazB,EAAE;IACxD;IAEA,OAAOwB;AACT;AAEA;;CAEC,GACD,SAAS9B,uBAAuB7D,KAAqB;IACnD,MAAMqB,YAAY;QAChBrB,OAAO;QACPsB,UAAU;QACVC,QAAQ;IACV;IAEA,OAAO,CAAC,UAAU,EAAEF,SAAS,CAACrB,MAAML,IAAI,CAAC,CAAC,EAAE,EAAEK,MAAMX,OAAO,CACxDU,GAAG,CAAC,CAAC8F,aAAe,CAAC,CAAC,EAAEA,WAAW,CAAC,CAAC,EACrCxF,IAAI,CAAC,KAAK,EAAE,CAAC;AAClB;AAEA;;CAEC,GACD,eAAeyF,2BACb1G,KAAa,EACb2G,cAAkC,EAClChD,UAA8B,EAC9BiD,kBAAqC,EAAE;IAEvC,+CAA+C;IAE/C,MAAMC,SAAS,CAACC;QACd,OAAO;YAACA,GAAG7G,OAAO,CAACgB,IAAI,CAAC;YAAM6F,GAAG3D,EAAE;SAAC,CAAClC,IAAI,CAAC;IAC5C;IAEA,aAAa;IACb,MAAM8F,sBAAsBH,gBAAgBjG,GAAG,CAAC,CAAC0B,MAAQA,IAAIjB,IAAI;IAEjE,MAAM4F,OAAOL,eAAe5D,MAAM,CAChC,CAACkE,QAAQC;QACP,MAAMC,cAAcxD,WAAWuC,IAAI,CACjC,CAACkB,MAAQP,OAAOK,aAAaL,OAAOO;QAEtC,IAAI,CAACD,aAAa;YAChBF,OAAO/C,GAAG,CAAC7C,IAAI,CAAC6F;YAChB,OAAOD;QACT;QAEA,IAAInH,MAAMoH,SAASC,iBAAiB,OAAO;YACzCF,OAAOI,QAAQ,CAAChG,IAAI,CAAC8F;YACrBF,OAAOK,QAAQ,CAACjG,IAAI,CAAC6F;YACrB,OAAOD;QACT;QACA,OAAOA;IACT,GACA;QACE/C,KAAK,EAAE;QACPE,MAAM,EAAE;QACRiD,UAAU,EAAE;QACZC,UAAU,EAAE;IACd;IAGF,mDAAmD;IACnD,8DAA8D;IAC9D3D,WAAW4D,OAAO,CAAC,CAACH;QAClB,MAAMI,kBAAkBb,eAAeT,IAAI,CACzC,CAACgB,UAAYL,OAAOK,aAAaL,OAAOO;QAE1C,IAAI,CAACI,iBAAiB;YACpB,8BAA8B;YAC9B,MAAMC,mBAAmBL,IAAInH,OAAO,CAAC4F,IAAI,CAAC,CAACxD,MACzC0E,oBAAoBrF,QAAQ,CAACW;YAE/B,kCAAkC;YAClC,IAAI,CAACoF,kBAAkB;gBACrBT,KAAK5C,IAAI,CAAC/C,IAAI,CAAC+F;YACjB;QACF;IACF;IAEA,MAAM3B,UAAU;QACdvB,KAAKxB,sBAAsB1C,OAAOgH,KAAK9C,GAAG;QAC1CE,MAAM1B,sBAAsB1C,OAAOgH,KAAK5C,IAAI;QAC5CiD,UAAU3E,sBAAsB1C,OAAOgH,KAAKK,QAAQ;QACpDC,UAAU5E,sBAAsB1C,OAAOgH,KAAKM,QAAQ;IACtD;IAEA,uCAAuC;IACvC,MAAMI,WAAWC,OAAOC,MAAM,CAACnC,SAASI,IAAI,CAC1C,CAACS,IAAMA,EAAE9D,EAAE,CAACb,MAAM,GAAG,KAAK2E,EAAE7D,IAAI,CAACd,MAAM,GAAG;IAE5C,IAAI,CAAC+F,UAAU;QACb,OAAO,EAAE;IACX;IAEA,MAAMjH,QAAkB;QACtB;QACA;QACA;QACA,CAAC,+BAA+B,EAAET,MAAM,eAAe,CAAC;WACrDyF,QAAQrB,IAAI,CAAC3B,IAAI;WACjBgD,QAAQvB,GAAG,CAAC1B,EAAE;WACdiD,QAAQ4B,QAAQ,CAAC5E,IAAI;WACrBgD,QAAQ6B,QAAQ,CAAC9E,EAAE;QACtB;QACA;QACA;QACA;QACA,CAAC,+BAA+B,EAAExC,MAAM,eAAe,CAAC;WACrDyF,QAAQvB,GAAG,CAACzB,IAAI;WAChBgD,QAAQ6B,QAAQ,CAAC7E,IAAI;WACrBgD,QAAQ4B,QAAQ,CAAC7E,EAAE;WACnBiD,QAAQrB,IAAI,CAAC5B,EAAE;QAClB;QACA;KACD;IAED,MAAMzB,YAAY,MAAMlB,SAASmB,MAAM,CAACP,MAAMQ,IAAI,CAAC,OAAO;QACxDT,QAAQ;IACV;IAEA,MAAMM,QAAQ;QACZ;QACAd;QACA;KAED,CAACiB,IAAI,CAAC;IAEP,OAAO;QACL;YACEjB;YACAc;YACAC;YACAR,MAAM;QACR;KACD;AACH;AAEA;;;;CAIC,GACD,OAAO,eAAesH,mBACpBC,SAAuB;IAEvB,OAAO;QACL,MAAM/H,oCACJ+H,UAAU9H,KAAK,EACf8H,UAAU7H,OAAO,EACjB6H,UAAU5H,OAAO;WAEf,MAAMoC,2BAA2BwF,UAAU9H,KAAK,EAAE8H,UAAUvF,QAAQ;KACzE;AACH;AAEA;;;;;CAKC,GACD,OAAO,eAAewF,kBACpBD,SAAuB,EACvBE,KAAmB;IAEnB,MAAMC,yBAAyB,CAAC5F;QAC9B,kDAAkD;QAClD,IACEA,IAAI9B,IAAI,KAAK,WACb8B,IAAIP,SAAS,IACboG,OAAO7F,IAAIP,SAAS,EAAEJ,QAAQ,CAAC,SAAS,OACxC;YACAW,IAAIP,SAAS,GAAG,CAAC,CAAC,EAAEqG,OAAO9F,IAAIP,SAAS,EAAEsG,OAAO,CAAC/F,IAAId,KAAK,IAAI,GAAG,CAAC,CAAC;QACtE;QACA,+BAA+B;QAC/B,IAAIc,IAAI9B,IAAI,KAAK,YAAY8B,IAAIP,SAAS,KAAK,IAAI;YACjDO,IAAIP,SAAS,GAAG;QAClB;QACA,+DAA+D;QAC/D,4CAA4C;QAC5C,IAAIO,IAAI9B,IAAI,KAAK,aAAa8B,IAAIP,SAAS,KAAKC,WAAW;YACzD,IAAIM,IAAIP,SAAS,KAAK,OAAOO,IAAIP,SAAS,CAACuG,WAAW,OAAO,SAAS;gBACpEhG,IAAIP,SAAS,GAAG;YAClB,OAAO,IAAIO,IAAIP,SAAS,KAAK,OAAOO,IAAIP,SAAS,CAACuG,WAAW,OAAO,QAAQ;gBAC1EhG,IAAIP,SAAS,GAAG;YAClB;QACF;QACA,OAAOO;IACT;IACA,MAAMkB,gBAAgB3D,EAAE0I,MAAM,CAACR,UAAU7H,OAAO,EAAE,CAACsF,IAAMA,EAAEnE,IAAI,EAAET,GAAG,CAClEsH;IAEF,MAAMxE,YAAY7D,EAAE0I,MAAM,CAACN,MAAM/H,OAAO,EAAE,CAACsF,IAAMA,EAAEnE,IAAI,EAAET,GAAG,CAC1DsH;IAGF;;;;;;;;SAQO,GAEP,MAAMzE,gBAAgB5D,EAAE0I,MAAM,CAACR,UAAU5H,OAAO,EAAE,CAACqF,IACjD;YAACA,EAAEhF,IAAI;eAAKgF,EAAEtF,OAAO,CAACsI,IAAI,CAAC,CAACC,IAAIC,KAAQD,KAAKC,KAAK,IAAI,CAAC;SAAI,CAACxH,IAAI,CAAC;IAEnE,MAAMyC,YAAY9D,EAAE0I,MAAM,CAACN,MAAM9H,OAAO,EAAE,CAACqF,IACzC;YAACA,EAAEhF,IAAI;eAAKgF,EAAEtF,OAAO,CAACsI,IAAI,CAAC,CAACC,IAAIC,KAAQD,KAAKC,KAAK,IAAI,CAAC;SAAI,CAACxH,IAAI,CAAC;IAGnE,MAAMyH,yBAAyB,CAACC;QAC9B,mCAAmC;QACnC,MAAM,EAAEtF,QAAQ,EAAED,QAAQ,EAAE,GAAGuF;QAC/B,OAAO;YACL,GAAGA,CAAC;YACJvF,UAAUA,aAAa,aAAa,cAAcA;YAClDC,UAAUA,aAAa,aAAa,cAAcA;QACpD;IACF;IAEA,MAAMsD,iBAAiB/G,EAAE0I,MAAM,CAACR,UAAUvF,QAAQ,EAAE,CAACgD,IACnD;YAACA,EAAEpC,EAAE;eAAKoC,EAAEtF,OAAO;SAAC,CAACgB,IAAI,CAAC,MAC1BN,GAAG,CAAC,CAACgI,IAAMD,uBAAuBC;IACpC,MAAMhF,aAAa/D,EAAE0I,MAAM,CAACN,MAAMzF,QAAQ,EAAE,CAACgD,IAC3C;YAACA,EAAEpC,EAAE;eAAKoC,EAAEtF,OAAO;SAAC,CAACgB,IAAI,CAAC,MAC1BN,GAAG,CAAC,CAACgI,IAAMD,uBAAuBC;IAEpC,eAAe;IACf,MAAM/B,kBAAkBhH,EAAEoF,YAAY,CACpCvB,WACAF,eACA,CAAClB,MAAQA,IAAIjB,IAAI;IAGnB,MAAMwH,aAA+D,EAAE;IAEvE,0BAA0B;IAC1B,MAAMC,iBAAiB/I,MAAMyD,eAAeE;IAC5C,MAAMqF,iBAAiBhJ,MACrB0D,cAAc7C,GAAG,CAAC,CAACC,QAAUhB,EAAEmJ,IAAI,CAACnI,OAAO;YAAC;SAAS,IACrD8C;IAEF,IAAI,CAACmF,kBAAkB,CAACC,gBAAgB;QACtCF,WAAWvH,IAAI,CACb,MAAMiC,mCACJwE,UAAU9H,KAAK,EACfuD,eACAC,eACAC,WACAC,WACAsE,MAAMzF,QAAQ;IAGpB;IAEA,gCAAgC;IAChC,IAAIzC,MAAM6G,gBAAgBhD,gBAAgB,OAAO;QAC/CiF,WAAWvH,IAAI,CACb,MAAMqF,2BACJoB,UAAU9H,KAAK,EACf2G,gBACAhD,YACAiD;IAGN;IAEA,IAAIgC,WAAWtE,KAAK,CAAC,CAAC0E,YAAcA,cAAc,OAAO;QACvD,OAAO,EAAE;IACX;IAEA,OAAOJ,WAAWvE,MAAM,CAAC,CAAC2E,YAAcA,cAAc,MAAMC,IAAI;AAClE"}
|
|
614
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/migration/code-generation.ts"],"sourcesContent":["import equal from \"fast-deep-equal\";\nimport { alphabetical, diff, fork, omit } from \"radashi\";\nimport { Naite } from \"..\";\nimport type {\n  GenMigrationCode,\n  MigrationColumn,\n  MigrationForeign,\n  MigrationIndex,\n  MigrationSet,\n} from \"../types/types\";\nimport { formatCode } from \"../utils/formatter\";\nimport { differenceWith, intersectionBy } from \"../utils/utils\";\n\n/**\n * 테이블 생성하는 케이스 - 컬럼/인덱스 생성\n */\nasync function generateCreateCode_ColumnAndIndexes(\n  table: string,\n  columns: MigrationColumn[],\n  indexes: MigrationIndex[],\n): Promise<GenMigrationCode> {\n  // fulltext index 분리\n  const [ngramIndexes, standardIndexes] = fork(\n    indexes,\n    (i) => i.type === \"fulltext\" && i.parser === \"ngram\",\n  );\n\n  // 컬럼, 인덱스 처리\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `await knex.schema.createTable(\"${table}\", (table) => {`,\n    \"// columns\",\n    ...genColumnDefinitions(columns),\n    \"\",\n    \"// indexes\",\n    ...standardIndexes.map((index) => genIndexDefinition(index, table)),\n    \"});\",\n    // ngram은 knex.raw로 처리하므로 createTable 밖에서 실행\n    ...ngramIndexes.map((index) => genIndexDefinition(index, table)),\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    ` return knex.schema.dropTable(\"${table}\");`,\n    \"}\",\n  ];\n  return {\n    table,\n    type: \"normal\",\n    title: `create__${table}`,\n    formatted: formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`),\n  };\n}\n\n/**\n * MigrationColumn[] 읽어서 컬럼 정의하는 구문 생성\n */\nfunction genColumnDefinitions(columns: MigrationColumn[]): string[] {\n  return columns.map((column) => {\n    const chains: string[] = [];\n    if (column.name === \"id\") {\n      return `table.increments().primary();`;\n    }\n\n    // 배열 타입 처리\n    if (column.type.endsWith(\"[]\")) {\n      const elementType = column.type.slice(0, -2); // \"integer[]\" -> \"integer\"\n      const pgType = getPgArrayType(column, elementType);\n      chains.push(`specificType('${column.name}', '${pgType}')`);\n    } else if (column.type === \"numberOrNumeric\") {\n      // number\n      if (column.numberType === \"real\") {\n        chains.push(`float('${column.name}')`);\n      } else if (column.numberType === \"double precision\") {\n        chains.push(`double('${column.name}')`);\n      } else if ((column.numberType ?? \"numeric\") === \"numeric\") {\n        chains.push(`decimal('${column.name}', ${column.precision}, ${column.scale})`);\n      }\n    } else if (column.type === \"string\") {\n      // string\n      if (column.length !== undefined) {\n        chains.push(`string('${column.name}', ${column.length})`);\n      } else {\n        chains.push(`text('${column.name}')`);\n      }\n    } else if (column.type === \"date\") {\n      // date\n      chains.push(`timestamp('${column.name}', { useTz: true })`);\n    } else if (column.type === \"json\") {\n      // json\n      chains.push(`jsonb('${column.name}')`);\n    } else {\n      // type, length\n      let extraType: string | undefined;\n      chains.push(\n        `${column.type}('${column.name}'${\n          column.length ? `, ${column.length}` : \"\"\n        }${extraType ? `, '${extraType}'` : \"\"})`,\n      );\n    }\n\n    // nullable\n    chains.push(column.nullable ? \"nullable()\" : \"notNullable()\");\n\n    // defaultTo\n    if (column.defaultTo !== undefined) {\n      if (typeof column.defaultTo === \"string\" && column.defaultTo.startsWith(`\"`)) {\n        chains.push(`defaultTo(${column.defaultTo})`);\n      } else {\n        chains.push(`defaultTo(knex.raw('${column.defaultTo}'))`);\n      }\n    }\n\n    return `table.${chains.join(\".\")};`;\n  });\n}\n\nfunction getPgArrayType(column: MigrationColumn, elementType: string): string {\n  if (elementType === \"numberOrNumeric\") {\n    if (column.numberType === \"real\") return \"real[]\";\n    if (column.numberType === \"double precision\") return \"double precision[]\";\n    return `numeric(${column.precision}, ${column.scale})[]`;\n  }\n  if (elementType === \"string\") {\n    return column.length ? `varchar(${column.length})[]` : \"text[]\";\n  }\n  if (elementType === \"date\") return \"timestamptz[]\";\n  if (elementType === \"integer\") return \"integer[]\";\n  if (elementType === \"bigInteger\") return \"bigint[]\";\n  if (elementType === \"boolean\") return \"boolean[]\";\n  if (elementType === \"uuid\") return \"uuid[]\";\n  if (elementType === \"enum\") return \"text[]\";\n\n  throw new Error(`Unknown array element type: ${elementType}`);\n}\n\n/**\n * 개별 인덱스 정의 생성\n */\nfunction genIndexDefinition(index: MigrationIndex, table: string) {\n  const methodMap = {\n    index: \"index\",\n    fulltext: \"index\",\n    unique: \"unique\",\n  };\n\n  if (index.type === \"fulltext\" && index.parser === \"ngram\") {\n    const indexName = `${table}_${index.columns.join(\"_\")}_index`;\n    return `await knex.raw(\\`ALTER TABLE ${table} ADD FULLTEXT INDEX ${indexName} (${index.columns.join(\n      \", \",\n    )}) WITH PARSER ngram\\`);`;\n  }\n\n  return `table.${methodMap[index.type]}([${index.columns\n    .map((col) => `'${col}'`)\n    .join(\",\")}]${index.type === \"fulltext\" ? \", undefined, 'FULLTEXT'\" : \"\"})`;\n}\n\n/**\n * 테이블 생성하는 케이스 - FK 생성\n */\nasync function generateCreateCode_Foreign(\n  table: string,\n  foreigns: MigrationForeign[],\n): Promise<GenMigrationCode[]> {\n  if (foreigns.length === 0) {\n    return [];\n  }\n\n  const { up, down } = genForeignDefinitions(table, foreigns);\n  if (up.length === 0 && down.length === 0) {\n    console.log(\"fk 가 뭔가 다릅니다\");\n    return [];\n  }\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    \"// create fk\",\n    ...up,\n    \"});\",\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    \"// drop fk\",\n    ...down,\n    \"});\",\n    \"}\",\n  ];\n\n  const foreignKeysString = foreigns.map((foreign) => foreign.columns.join(\"_\")).join(\"_\");\n  return [\n    {\n      table,\n      type: \"foreign\",\n      title: `foreign__${table}__${foreignKeysString}`,\n      formatted: formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`),\n    },\n  ];\n}\n\n/**\n * MigrationForeign[] 읽어서 외부키 constraint 정의하는 구문 생성\n */\nfunction genForeignDefinitions(\n  table: string,\n  foreigns: MigrationForeign[],\n): { up: string[]; down: string[] } {\n  return foreigns.reduce(\n    (r, foreign) => {\n      const columnsStringQuote = foreign.columns\n        .map((col) => `'${col.replace(`${table}.`, \"\")}'`)\n        .join(\",\");\n      r.up.push(\n        `table.foreign('${foreign.columns.join(\",\")}')\n            .references('${foreign.to}')\n            .onUpdate('${foreign.onUpdate}')\n            .onDelete('${foreign.onDelete}')`,\n      );\n      r.down.push(`table.dropForeign([${columnsStringQuote}])`);\n      return r;\n    },\n    {\n      up: [] as string[],\n      down: [] as string[],\n    },\n  );\n}\n\n/**\n * 테이블 변경 케이스 - 컬럼/인덱스 변경\n */\nasync function generateAlterCode_ColumnAndIndexes(\n  table: string,\n  entityColumns: MigrationColumn[],\n  entityIndexes: MigrationIndex[],\n  dbColumns: MigrationColumn[],\n  dbIndexes: MigrationIndex[],\n  dbForeigns: MigrationForeign[],\n): Promise<GenMigrationCode[]> {\n  /*\n    세부 비교 후 다른점 찾아서 코드 생성\n\n    1. 컬럼갯수 다름: MD에 있으나, DB에 없다면 추가\n    2. 컬럼갯수 다름: MD에 없으나, DB에 있다면 삭제\n    3. 그외 컬럼(컬럼 갯수가 동일하거나, 다른 경우 동일한 컬럼끼리) => alter\n    4. 다른거 다 동일하고 index만 변경되는 경우\n\n    ** 컬럼명을 변경하는 경우는 따로 핸들링하지 않음\n    => drop/add 형태의 마이그레이션 코드가 생성되는데, 수동으로 rename 코드로 수정하여 처리\n  */\n\n  // 각 컬럼 이름 기준으로 add, drop, alter 여부 확인\n  const alterColumnsTo = getAlterColumnsTo(entityColumns, dbColumns);\n\n  // 추출된 컬럼들을 기준으로 각각 라인 생성\n  const alterColumnLinesTo = getAlterColumnLinesTo(\n    alterColumnsTo,\n    entityColumns,\n    table,\n    dbForeigns,\n  );\n\n  // 인덱스의 add, drop 여부 확인\n  const alterIndexesTo = getAlterIndexesTo(entityIndexes, dbIndexes);\n\n  // fulltext index 분리\n  const [ngramIndexes, standardIndexes] = fork(\n    alterIndexesTo.add,\n    (i) => i.type === \"fulltext\" && i.parser === \"ngram\",\n  );\n\n  // 인덱스가 삭제되는 경우, 컬럼과 같이 삭제된 케이스에는 drop에서 제외해야함!\n  const indexNeedsToDrop = alterIndexesTo.drop.filter(\n    (index) =>\n      index.columns.every((colName) =>\n        alterColumnsTo.drop.map((col) => col.name).includes(colName),\n      ) === false,\n  );\n\n  // 빈 코드 생성 방지\n  if (\n    alterColumnLinesTo.add.up.length === 0 &&\n    alterColumnLinesTo.drop.up.length === 0 &&\n    alterColumnLinesTo.alter.up.length === 0 &&\n    standardIndexes.length === 0 &&\n    indexNeedsToDrop.length === 0\n  ) {\n    Naite.t(\"migrator:generateAlterCode_ColumnAndIndexes:emptyCodeGenerationError\", {\n      entityColumns,\n      dbColumns,\n      entityIndexes,\n      dbIndexes,\n    });\n    // throw new Error(\"컬럼/인덱스 변경 코드 생성 오류\");\n  }\n  Naite.t(\"migrator:generateAlterCode_ColumnAndIndexes:debug\", {\n    \"alterColumnsTo.add.length\": alterColumnsTo.add.length,\n    \"alterColumnsTo.drop.length\": alterColumnsTo.drop.length,\n    \"alterColumnsTo.alter.length\": alterColumnsTo.alter.length,\n    \"alterIndexesTo.add.length\": alterIndexesTo.add.length,\n    \"alterIndexesTo.drop.length\": alterIndexesTo.drop.length,\n    \"standardIndexes.length\": standardIndexes.length,\n    \"indexNeedsToDrop.length\": indexNeedsToDrop.length,\n  });\n  // Naite.t(\"migrator:generateAlterCode_ColumnAndIndexes:alterColumnsTo\", alterColumnsTo);\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `await knex.schema.alterTable(\"${table}\", (table) => {`,\n    // 1. add column\n    ...(alterColumnsTo.add.length > 0 ? alterColumnLinesTo.add.up : []),\n    // 2. drop column\n    ...(alterColumnsTo.drop.length > 0 ? alterColumnLinesTo.drop.up : []),\n    // 3. alter column\n    ...(alterColumnsTo.alter.length > 0 ? alterColumnLinesTo.alter.up : []),\n    // 4. add index\n    ...standardIndexes.map((index) => genIndexDefinition(index, table)),\n    // 5. drop index\n    ...indexNeedsToDrop.map(genIndexDropDefinition),\n    \"});\",\n    // ngram은 knex.raw로 처리하므로 alterTable 밖에서 실행\n    ...ngramIndexes.map((index) => genIndexDefinition(index, table)),\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...(alterColumnsTo.add.length > 0 ? alterColumnLinesTo.add.down : []),\n    ...(alterColumnsTo.drop.length > 0 ? alterColumnLinesTo.drop.down : []),\n    ...(alterColumnsTo.alter.length > 0 ? alterColumnLinesTo.alter.down : []),\n    ...alterIndexesTo.add\n      .filter(\n        (index) =>\n          index.columns.every((colName) =>\n            alterColumnsTo.add.map((col) => col.name).includes(colName),\n          ) === false,\n      )\n      .map(genIndexDropDefinition),\n    ...indexNeedsToDrop.map((index) => genIndexDefinition(index, table)),\n    \"});\",\n    \"}\",\n  ];\n\n  const formatted = formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`);\n  const title = [\n    \"alter\",\n    table,\n    ...([\"add\", \"drop\", \"alter\"] as const)\n      .map((action) => {\n        const len = alterColumnsTo[action].length;\n        if (len > 0) {\n          return action + len;\n        }\n        return null;\n      })\n      .filter((part) => part !== null),\n  ].join(\"_\");\n\n  return [\n    {\n      table,\n      title,\n      formatted,\n      type: \"normal\",\n    },\n  ];\n}\n\n/**\n * 각 컬럼 이름 기준으로 add, drop, alter 여부 확인\n */\nfunction getAlterColumnsTo(entityColumns: MigrationColumn[], dbColumns: MigrationColumn[]) {\n  const columnsTo = {\n    add: [] as MigrationColumn[],\n    drop: [] as MigrationColumn[],\n    alter: [] as MigrationColumn[],\n  };\n\n  // 컬럼명 기준 비교\n  const extraColumns = {\n    db: diff(dbColumns, entityColumns, (col) => col.name),\n    entity: diff(entityColumns, dbColumns, (col) => col.name),\n  };\n  if (extraColumns.entity.length > 0) {\n    columnsTo.add = columnsTo.add.concat(extraColumns.entity);\n  }\n  if (extraColumns.db.length > 0) {\n    columnsTo.drop = columnsTo.drop.concat(extraColumns.db);\n  }\n\n  // 동일 컬럼명의 세부 필드 비교\n  const sameDbColumns = intersectionBy(dbColumns, entityColumns, (col) => col.name);\n  const sameMdColumns = intersectionBy(entityColumns, dbColumns, (col) => col.name);\n  columnsTo.alter = differenceWith(sameDbColumns, sameMdColumns, (a, b) => equal(a, b));\n\n  return columnsTo;\n}\n\n/**\n * 추출된 컬럼들을 기준으로 각각 라인 생성\n */\nfunction getAlterColumnLinesTo(\n  columnsTo: ReturnType<typeof getAlterColumnsTo>,\n  entityColumns: MigrationColumn[],\n  table: string,\n  dbForeigns: MigrationForeign[],\n) {\n  const linesTo = {\n    add: {\n      up: [] as string[],\n      down: [] as string[],\n    },\n    drop: {\n      up: [] as string[],\n      down: [] as string[],\n    },\n    alter: {\n      up: [] as string[],\n      down: [] as string[],\n    },\n  };\n\n  linesTo.add = {\n    up: [\"// add\", ...genColumnDefinitions(columnsTo.add)],\n    down: [\n      \"// rollback - add\",\n      `table.dropColumns(${columnsTo.add.map((col) => `'${col.name}'`).join(\", \")})`,\n    ],\n  };\n\n  // drop할 컬럼에 걸린 FK 찾기\n  const dropColumnNames = columnsTo.drop.map((col) => col.name);\n  const fkToDropBeforeColumn = dbForeigns.filter((fk) =>\n    fk.columns.some((col) => dropColumnNames.includes(col)),\n  );\n\n  const dropFkLines = fkToDropBeforeColumn.map((fk) => {\n    const columnsStringQuote = fk.columns.map((col) => `'${col}'`).join(\",\");\n    return `table.dropForeign([${columnsStringQuote}])`;\n  });\n\n  const restoreFkLines = genForeignDefinitions(table, fkToDropBeforeColumn).up;\n\n  linesTo.drop = {\n    up: [\n      ...(dropFkLines.length > 0\n        ? [\"// drop foreign keys on columns to be dropped\", ...dropFkLines]\n        : []),\n      \"// drop columns\",\n      `table.dropColumns(${columnsTo.drop.map((col) => `'${col.name}'`).join(\", \")})`,\n    ],\n    down: [\n      \"// rollback - drop columns\",\n      ...genColumnDefinitions(columnsTo.drop),\n      ...(restoreFkLines.length > 0 ? [\"// restore foreign keys\", ...restoreFkLines] : []),\n    ],\n  };\n  linesTo.alter = columnsTo.alter.reduce(\n    (r, dbColumn) => {\n      const entityColumn = entityColumns.find((col) => col.name === dbColumn.name);\n      if (entityColumn === undefined) {\n        return r;\n      }\n\n      // 컬럼 변경사항\n      const columnDiffUp = diff(\n        genColumnDefinitions([entityColumn]),\n        genColumnDefinitions([dbColumn]),\n      );\n      const columnDiffDown = diff(\n        genColumnDefinitions([dbColumn]),\n        genColumnDefinitions([entityColumn]),\n      );\n      if (columnDiffUp.length > 0) {\n        r.up = [\n          ...r.up,\n          \"// alter column\",\n          ...columnDiffUp.map((l) => `${l.replace(\";\", \"\")}.alter();`),\n        ];\n        r.down = [\n          ...r.down,\n          \"// rollback - alter column\",\n          ...columnDiffDown.map((l) => `${l.replace(\";\", \"\")}.alter();`),\n        ];\n      }\n\n      return r;\n    },\n    {\n      up: [] as string[],\n      down: [] as string[],\n    },\n  );\n\n  return linesTo;\n}\n\n/**\n * 인덱스의 add, drop 여부 확인\n */\nfunction getAlterIndexesTo(entityIndexes: MigrationIndex[], dbIndexes: MigrationIndex[]) {\n  // 인덱스 비교\n  const indexesTo = {\n    add: [] as MigrationIndex[],\n    drop: [] as MigrationIndex[],\n  };\n  const extraIndexes = {\n    db: diff(dbIndexes, entityIndexes, (col) => [col.type, col.columns.join(\"-\")].join(\"//\")),\n    entity: diff(entityIndexes, dbIndexes, (col) => [col.type, col.columns.join(\"-\")].join(\"//\")),\n  };\n  if (extraIndexes.entity.length > 0) {\n    indexesTo.add = indexesTo.add.concat(extraIndexes.entity);\n  }\n  if (extraIndexes.db.length > 0) {\n    indexesTo.drop = indexesTo.drop.concat(extraIndexes.db);\n  }\n\n  return indexesTo;\n}\n\n/**\n * 인덱스 삭제 정의 생성\n */\nfunction genIndexDropDefinition(index: MigrationIndex) {\n  const methodMap = {\n    index: \"Index\",\n    fulltext: \"Index\",\n    unique: \"Unique\",\n  };\n\n  return `table.drop${methodMap[index.type]}([${index.columns\n    .map((columnName) => `'${columnName}'`)\n    .join(\",\")}])`;\n}\n\n/**\n * 테이블 변경 케이스 - Foreign Key 변경\n */\nasync function generateAlterCode_Foreigns(\n  table: string,\n  entityForeigns: MigrationForeign[],\n  dbForeigns: MigrationForeign[],\n  droppingColumns: MigrationColumn[] = [],\n): Promise<GenMigrationCode[]> {\n  // console.log({ entityForeigns, dbForeigns });\n\n  const getKey = (mf: MigrationForeign): string => {\n    return [mf.columns.join(\"-\"), mf.to].join(\"///\");\n  };\n\n  // 삭제될 컬럼명 목록\n  const droppingColumnNames = droppingColumns.map((col) => col.name);\n\n  const fkTo = entityForeigns.reduce(\n    (result, entityF) => {\n      const matchingDbF = dbForeigns.find((dbF) => getKey(entityF) === getKey(dbF));\n      if (!matchingDbF) {\n        result.add.push(entityF);\n        return result;\n      }\n\n      if (equal(entityF, matchingDbF) === false) {\n        result.alterSrc.push(matchingDbF);\n        result.alterDst.push(entityF);\n        return result;\n      }\n      return result;\n    },\n    {\n      add: [] as MigrationForeign[],\n      drop: [] as MigrationForeign[],\n      alterSrc: [] as MigrationForeign[],\n      alterDst: [] as MigrationForeign[],\n    },\n  );\n\n  // dbForeigns에는 있지만 entityForeigns에는 없는 경우 (삭제된 FK)\n  // 단, 삭제될 컬럼의 FK는 제외 (generateAlterCode_ColumnAndIndexes에서 처리)\n  dbForeigns.forEach((dbF) => {\n    const matchingEntityF = entityForeigns.find((entityF) => getKey(entityF) === getKey(dbF));\n    if (!matchingEntityF) {\n      // 이 FK의 컬럼이 삭제될 컬럼 목록에 있는지 확인\n      const isColumnDropping = dbF.columns.some((col) => droppingColumnNames.includes(col));\n      // 컬럼이 삭제되지 않는 경우에만 FK drop 목록에 추가\n      if (!isColumnDropping) {\n        fkTo.drop.push(dbF);\n      }\n    }\n  });\n\n  const linesTo = {\n    add: genForeignDefinitions(table, fkTo.add),\n    drop: genForeignDefinitions(table, fkTo.drop),\n    alterSrc: genForeignDefinitions(table, fkTo.alterSrc),\n    alterDst: genForeignDefinitions(table, fkTo.alterDst),\n  };\n\n  // drop fk columns인 경우(생성될 코드 없는 경우) 패스\n  const hasLines = Object.values(linesTo).some((l) => l.up.length > 0 || l.down.length > 0);\n  if (!hasLines) {\n    return [];\n  }\n\n  if (\n    linesTo.add.up.length === 0 &&\n    linesTo.drop.up.length === 0 &&\n    linesTo.alterSrc.up.length === 0 &&\n    linesTo.alterDst.up.length === 0\n  ) {\n    Naite.t(\"migrator:generateAlterCode_Foreigns:fkChangeCodeGenerationError\", {\n      table,\n      entityForeigns,\n      dbForeigns,\n    });\n    throw new Error(\"FK 변경 코드 생성 오류\");\n  }\n\n  const lines: string[] = [\n    'import { Knex } from \"knex\";',\n    \"\",\n    \"export async function up(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...linesTo.drop.down,\n    ...linesTo.add.up,\n    ...linesTo.alterSrc.down,\n    ...linesTo.alterDst.up,\n    \"})\",\n    \"}\",\n    \"\",\n    \"export async function down(knex: Knex): Promise<void> {\",\n    `return knex.schema.alterTable(\"${table}\", (table) => {`,\n    ...linesTo.add.down,\n    ...linesTo.alterDst.down,\n    ...linesTo.alterSrc.up,\n    ...linesTo.drop.up,\n    \"})\",\n    \"}\",\n  ];\n\n  const formatted = formatCode(lines.join(\"\\n\"), \"typescript\", `src/migration/${table}.ts`);\n  const title = [\n    \"alter\",\n    table,\n    \"foreigns\",\n    // TODO 바뀌는 부분\n  ].join(\"_\");\n\n  return [\n    {\n      table,\n      title,\n      formatted,\n      type: \"normal\",\n    },\n  ];\n}\n\n/**\n * 주어진 EntitySet을 기반으로 테이블 CREATE 마이그레이션 코드를 생성합니다.\n * @param entitySet\n * @returns CREATE 마이그레이션 코드\n */\nexport async function generateCreateCode(entitySet: MigrationSet): Promise<GenMigrationCode[]> {\n  return [\n    await generateCreateCode_ColumnAndIndexes(\n      entitySet.table,\n      entitySet.columns,\n      entitySet.indexes,\n    ),\n    ...(await generateCreateCode_Foreign(entitySet.table, entitySet.foreigns)),\n  ];\n}\n\n/**\n * 주어진 entitySet을 목표로, dbSet을 현 상황으로 하여 테이블 ALTER 마이그레이션 코드를 생성합니다.\n * @param entitySet 현 상황의 MigrationSet\n * @param dbSet 목표 상황의 MigrationSet\n * @returns ALTER 마이그레이션 코드\n */\nexport async function generateAlterCode(\n  entitySet: MigrationSet,\n  dbSet: MigrationSet,\n): Promise<GenMigrationCode[]> {\n  const replaceColumnDefaultTo = (col: MigrationColumn) => {\n    // float인 경우 기본값을 0으로 지정하는 경우 \"0.00\"으로 변환되는 케이스 대응\n    // if (col.type === \"float\" && col.defaultTo && String(col.defaultTo).includes('\"') === false) {\n    //   col.defaultTo = `\"${Number(col.defaultTo).toFixed(col.scale ?? 2)}\"`;\n    // }\n    // // string인 경우 기본값이 빈 스트링인 경우 대응\n    // if (col.type === \"string\" && col.defaultTo === \"\") {\n    //   col.defaultTo = '\"\"';\n    // }\n    // // boolean인 경우 기본값 정규화 (MySQL에서는 TINYINT(1)로 저장되므로 0 또는 1로 정규화)\n    // // TODO: db.ts에 typeCase 설정 확인하여 처리하도록 수정 필요\n    // if (col.type === \"boolean\" && col.defaultTo !== undefined) {\n    //   if (col.defaultTo === \"0\" || col.defaultTo.toLowerCase() === \"false\") {\n    //     col.defaultTo = \"0\";\n    //   } else if (col.defaultTo === \"1\" || col.defaultTo.toLowerCase() === \"true\") {\n    //     col.defaultTo = \"1\";\n    //   }\n    // }\n\n    // FIXME: 일단 MySQL 상황에서 발생했던 이슈의 workaround 이므로 Pg에서 재확인 후 대응 추가\n    return col;\n  };\n  const entityColumns = alphabetical(entitySet.columns, (a) => a.name).map(replaceColumnDefaultTo);\n  const dbColumns = alphabetical(dbSet.columns, (a) => a.name).map(replaceColumnDefaultTo);\n\n  /* 디버깅용 코드, 특정 컬럼에서 불일치 발생할 때 확인\n        const entityColumn = entitySet.columns.find(\n          (col) => col.name === \"price_krw\"\n        );\n        const dbColumn = dbSet.columns.find(\n          (col) => col.name === \"price_krw\"\n        );\n        console.debug({ entityColumn, dbColumn });\n         */\n\n  const entityIndexes = alphabetical(entitySet.indexes, (a) =>\n    [a.type, ...a.columns.sort((c1, c2) => (c1 > c2 ? 1 : -1))].join(\"-\"),\n  );\n  const dbIndexes = alphabetical(dbSet.indexes, (a) =>\n    [a.type, ...a.columns.sort((c1, c2) => (c1 > c2 ? 1 : -1))].join(\"-\"),\n  );\n\n  const replaceNoActionOnMySQL = (f: MigrationForeign) => {\n    // MySQL에서 RESTRICT와 NO ACTION은 동일함\n    const { onDelete, onUpdate } = f;\n    return {\n      ...f,\n      onUpdate: onUpdate === \"RESTRICT\" ? \"NO ACTION\" : onUpdate,\n      onDelete: onDelete === \"RESTRICT\" ? \"NO ACTION\" : onDelete,\n    };\n  };\n\n  const entityForeigns = alphabetical(entitySet.foreigns, (a) =>\n    [a.to, ...a.columns].join(\"-\"),\n  ).map((f) => replaceNoActionOnMySQL(f));\n  const dbForeigns = alphabetical(dbSet.foreigns, (a) => [a.to, ...a.columns].join(\"-\")).map((f) =>\n    replaceNoActionOnMySQL(f),\n  );\n\n  // 삭제될 컬럼 목록 계산\n  const droppingColumns = diff(dbColumns, entityColumns, (col) => col.name);\n\n  const alterCodes: (GenMigrationCode | GenMigrationCode[] | null)[] = [];\n\n  // 1. columnsAndIndexes 처리\n  const isEqualColumns = equal(entityColumns, dbColumns);\n  const isEqualIndexes = equal(\n    entityIndexes.map((index) => omit(index, [\"parser\"])),\n    dbIndexes,\n  );\n  if (!isEqualColumns || !isEqualIndexes) {\n    alterCodes.push(\n      await generateAlterCode_ColumnAndIndexes(\n        entitySet.table,\n        entityColumns,\n        entityIndexes,\n        dbColumns,\n        dbIndexes,\n        dbSet.foreigns,\n      ),\n    );\n  }\n\n  // 2. foreigns 처리 (삭제될 컬럼 정보 전달)\n  if (equal(entityForeigns, dbForeigns) === false) {\n    alterCodes.push(\n      await generateAlterCode_Foreigns(\n        entitySet.table,\n        entityForeigns,\n        dbForeigns,\n        droppingColumns,\n      ),\n    );\n  }\n\n  if (alterCodes.every((alterCode) => alterCode === null)) {\n    return [];\n  }\n\n  return alterCodes.filter((alterCode) => alterCode !== null).flat();\n}\n"],"names":["equal","alphabetical","diff","fork","omit","Naite","formatCode","differenceWith","intersectionBy","generateCreateCode_ColumnAndIndexes","table","columns","indexes","ngramIndexes","standardIndexes","i","type","parser","lines","genColumnDefinitions","map","index","genIndexDefinition","title","formatted","join","column","chains","name","endsWith","elementType","slice","pgType","getPgArrayType","push","numberType","precision","scale","length","undefined","extraType","nullable","defaultTo","startsWith","Error","methodMap","fulltext","unique","indexName","col","generateCreateCode_Foreign","foreigns","up","down","genForeignDefinitions","console","log","foreignKeysString","foreign","reduce","r","columnsStringQuote","replace","to","onUpdate","onDelete","generateAlterCode_ColumnAndIndexes","entityColumns","entityIndexes","dbColumns","dbIndexes","dbForeigns","alterColumnsTo","getAlterColumnsTo","alterColumnLinesTo","getAlterColumnLinesTo","alterIndexesTo","getAlterIndexesTo","add","indexNeedsToDrop","drop","filter","every","colName","includes","alter","t","genIndexDropDefinition","action","len","part","columnsTo","extraColumns","db","entity","concat","sameDbColumns","sameMdColumns","a","b","linesTo","dropColumnNames","fkToDropBeforeColumn","fk","some","dropFkLines","restoreFkLines","dbColumn","entityColumn","find","columnDiffUp","columnDiffDown","l","indexesTo","extraIndexes","columnName","generateAlterCode_Foreigns","entityForeigns","droppingColumns","getKey","mf","droppingColumnNames","fkTo","result","entityF","matchingDbF","dbF","alterSrc","alterDst","forEach","matchingEntityF","isColumnDropping","hasLines","Object","values","generateCreateCode","entitySet","generateAlterCode","dbSet","replaceColumnDefaultTo","sort","c1","c2","replaceNoActionOnMySQL","f","alterCodes","isEqualColumns","isEqualIndexes","alterCode","flat"],"mappings":"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"}
|
|
@@ -1,13 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { MigrationSet, MigrationSetAndJoinTable } from "../types/types";
|
|
4
|
-
/**
|
|
5
|
-
* DB에서 테이블 정보를 읽어서 MigrationSet을 만들어옵니다.
|
|
6
|
-
* @param compareDB Knex 인스턴스
|
|
7
|
-
* @param table 테이블 이름
|
|
8
|
-
* @returns MigrationSet 객체
|
|
9
|
-
*/
|
|
10
|
-
export declare function getMigrationSetFromDB(compareDB: Knex, table: string): Promise<MigrationSet | null>;
|
|
1
|
+
import type { Entity } from "../entity/entity";
|
|
2
|
+
import { type MigrationSetAndJoinTable } from "../types/types";
|
|
11
3
|
/**
|
|
12
4
|
* Entity를 읽어서 MigrationSetAndJoinTable을 만들어옵니다.
|
|
13
5
|
* @param entity Entity 객체
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migration-set.d.ts","sourceRoot":"","sources":["../../src/migration/migration-set.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"migration-set.d.ts","sourceRoot":"","sources":["../../src/migration/migration-set.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE/C,OAAO,EAgBL,KAAK,wBAAwB,EAC9B,MAAM,gBAAgB,CAAC;AAGxB;;;;GAIG;AACH,wBAAgB,yBAAyB,CAAC,MAAM,EAAE,MAAM,GAAG,wBAAwB,CAiKlF"}
|