@codemastersolutions/db-utility 0.0.17 → 0.0.19
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/README.es.md +45 -3
- package/README.md +38 -3
- package/README.pt-BR.md +37 -2
- package/dist/database/connectors/MssqlConnector.d.ts.map +1 -1
- package/dist/database/connectors/MssqlConnector.js +8 -0
- package/dist/database/connectors/MssqlConnector.js.map +1 -1
- package/dist/generators/MongooseGenerator.d.ts.map +1 -1
- package/dist/generators/MongooseGenerator.js +3 -1
- package/dist/generators/MongooseGenerator.js.map +1 -1
- package/dist/generators/PrismaGenerator.d.ts.map +1 -1
- package/dist/generators/PrismaGenerator.js +3 -1
- package/dist/generators/PrismaGenerator.js.map +1 -1
- package/dist/generators/SequelizeGenerator.d.ts +1 -0
- package/dist/generators/SequelizeGenerator.d.ts.map +1 -1
- package/dist/generators/SequelizeGenerator.js +18 -10
- package/dist/generators/SequelizeGenerator.js.map +1 -1
- package/dist/generators/TypeORMGenerator.d.ts +1 -0
- package/dist/generators/TypeORMGenerator.d.ts.map +1 -1
- package/dist/generators/TypeORMGenerator.js +48 -25
- package/dist/generators/TypeORMGenerator.js.map +1 -1
- package/dist/introspection/IntrospectionLogger.d.ts.map +1 -1
- package/dist/introspection/IntrospectionLogger.js +4 -0
- package/dist/introspection/IntrospectionLogger.js.map +1 -1
- package/dist/introspection/MssqlIntrospector.d.ts.map +1 -1
- package/dist/introspection/MssqlIntrospector.js +7 -1
- package/dist/introspection/MssqlIntrospector.js.map +1 -1
- package/dist/testing/runners/TypeORMRunner.d.ts.map +1 -1
- package/dist/testing/runners/TypeORMRunner.js +11 -1
- package/dist/testing/runners/TypeORMRunner.js.map +1 -1
- package/dist/types/introspection.d.ts +1 -0
- package/dist/types/introspection.d.ts.map +1 -1
- package/dist/utils/IndexUtils.d.ts +19 -0
- package/dist/utils/IndexUtils.d.ts.map +1 -0
- package/dist/utils/IndexUtils.js +28 -0
- package/dist/utils/IndexUtils.js.map +1 -0
- package/package.json +9 -1
package/README.es.md
CHANGED
|
@@ -14,8 +14,8 @@ DbUtility es una utilidad poderosa para manipular bases de datos Microsoft SQL S
|
|
|
14
14
|
- **Soporte Multi-Base de Datos**: Conéctese a Microsoft SQL Server, MySQL y PostgreSQL utilizando controladores oficiales (`mssql`, `mysql2`, `pg`).
|
|
15
15
|
- **Configuración Flexible**: Detalles de conexión a través de CLI, `.env`, archivos de configuración JSON.
|
|
16
16
|
- **Introspección**: Analice su base de datos para listar tablas, vistas, procedimientos almacenados, funciones y disparadores.
|
|
17
|
-
- **Exportación de Modelos**: Exporte tablas de base de datos a modelos de Sequelize, TypeORM y
|
|
18
|
-
- **Generación de Migraciones**: Cree migraciones a partir de tablas existentes en la base de datos para Sequelize
|
|
17
|
+
- **Exportación de Modelos**: Exporte tablas de base de datos a modelos de Sequelize, TypeORM, Prisma y Mongoose.
|
|
18
|
+
- **Generación de Migraciones**: Cree migraciones de esquema y datos a partir de tablas existentes en la base de datos para Sequelize y TypeORM.
|
|
19
19
|
|
|
20
20
|
## Instalación
|
|
21
21
|
|
|
@@ -25,6 +25,41 @@ npm install @codemastersolutions/db-utility
|
|
|
25
25
|
npm install -g @codemastersolutions/db-utility
|
|
26
26
|
```
|
|
27
27
|
|
|
28
|
+
## Pruebas de Integracion MSSQL
|
|
29
|
+
|
|
30
|
+
DbUtility incluye pruebas de integracion opt-in para Microsoft SQL Server que validan los runners reales de migracion contra un contenedor Docker.
|
|
31
|
+
|
|
32
|
+
Actualmente, estas pruebas cubren:
|
|
33
|
+
|
|
34
|
+
- migraciones Sequelize con columnas de texto largas en MSSQL
|
|
35
|
+
- migraciones TypeORM con columnas de texto largas en MSSQL
|
|
36
|
+
- inserciones reales de valores con mas de 4000 caracteres sin errores de tamano de parametro
|
|
37
|
+
|
|
38
|
+
Prerequisitos:
|
|
39
|
+
|
|
40
|
+
- Docker instalado y disponible en su `PATH`
|
|
41
|
+
- Dependencias de desarrollo instaladas con `pnpm install`
|
|
42
|
+
|
|
43
|
+
Scripts disponibles:
|
|
44
|
+
|
|
45
|
+
```bash
|
|
46
|
+
# Ejecuta las dos suites de integracion MSSQL
|
|
47
|
+
pnpm run test:integration:mssql
|
|
48
|
+
|
|
49
|
+
# Ejecuta solo la integracion Sequelize + MSSQL
|
|
50
|
+
pnpm run test:integration:mssql:sequelize
|
|
51
|
+
|
|
52
|
+
# Ejecuta solo la integracion TypeORM + MSSQL
|
|
53
|
+
pnpm run test:integration:mssql:typeorm
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
Notas:
|
|
57
|
+
|
|
58
|
+
- Estos scripts activan automaticamente `DBUTILITY_RUN_DOCKER_INTEGRATION=1`.
|
|
59
|
+
- Usan `cross-env`, por lo que los mismos comandos funcionan en macOS, Linux y Windows.
|
|
60
|
+
- Se mantienen separados de `pnpm test` para conservar la suite predeterminada rapida.
|
|
61
|
+
- Las pruebas levantan contenedores reales de SQL Server y pueden tardar mas que las pruebas unitarias.
|
|
62
|
+
|
|
28
63
|
## Uso de Internet
|
|
29
64
|
|
|
30
65
|
Esta librería utiliza su conexión a internet para buscar actualizaciones en el registro npm. Esta verificación se realiza automáticamente (predeterminado: diariamente) cuando ejecuta un comando de la CLI.
|
|
@@ -136,7 +171,8 @@ La opción `dataTables` permite especificar qué tablas deben tener sus datos ex
|
|
|
136
171
|
"permisos",
|
|
137
172
|
{
|
|
138
173
|
"table": "usuarios",
|
|
139
|
-
"where": "activo = 1 AND creado_en > '2023-01-01'"
|
|
174
|
+
"where": "activo = 1 AND creado_en > '2023-01-01'",
|
|
175
|
+
"disableIdentity": true
|
|
140
176
|
},
|
|
141
177
|
{
|
|
142
178
|
"table": "registros",
|
|
@@ -145,6 +181,12 @@ La opción `dataTables` permite especificar qué tablas deben tener sus datos ex
|
|
|
145
181
|
]
|
|
146
182
|
```
|
|
147
183
|
|
|
184
|
+
La opción `disableIdentity` (predeterminado: `false`) permite insertar valores explícitos en columnas auto-increment/identity. Esto es útil cuando desea preservar los IDs originales de la base de datos de origen.
|
|
185
|
+
|
|
186
|
+
- **MSSQL**: Envuelve las inserciones con `SET IDENTITY_INSERT [Table] ON/OFF`.
|
|
187
|
+
- **PostgreSQL**: Reinicia el valor de la secuencia después de la inserción usando `setval` para evitar fallos en inserciones posteriores.
|
|
188
|
+
- **Otras Bases de Datos (MySQL, SQLite)**: Incluye la columna identity en el payload de inserción (normalmente actualizan el contador auto-incremental automáticamente).
|
|
189
|
+
|
|
148
190
|
### Múltiples Conexiones
|
|
149
191
|
|
|
150
192
|
Puede definir múltiples conexiones dentro de la propiedad `connections` y utilizarlas en la CLI con el flag `--conn <nombre>`.
|
package/README.md
CHANGED
|
@@ -14,8 +14,8 @@ DbUtility is a powerful utility for manipulating Microsoft SQL Server, MySQL, an
|
|
|
14
14
|
- **Multi-Database Support**: Connect to Microsoft SQL Server, MySQL, and PostgreSQL using official drivers (`mssql`, `mysql2`, `pg`).
|
|
15
15
|
- **Flexible Configuration**: Connection details via CLI, `.env`, JSON configuration files.
|
|
16
16
|
- **Introspection**: Analyze your database to list tables, views, stored procedures, functions, and triggers.
|
|
17
|
-
- **Model Export**: Export database tables to Sequelize, TypeORM, and
|
|
18
|
-
- **Migration Generation**: Create migrations from existing database tables for Sequelize
|
|
17
|
+
- **Model Export**: Export database tables to Sequelize, TypeORM, Prisma, and Mongoose models.
|
|
18
|
+
- **Migration Generation**: Create schema and data migrations from existing database tables for Sequelize and TypeORM.
|
|
19
19
|
|
|
20
20
|
## Installation
|
|
21
21
|
|
|
@@ -25,6 +25,41 @@ npm install @codemastersolutions/db-utility
|
|
|
25
25
|
npm install -g @codemastersolutions/db-utility
|
|
26
26
|
```
|
|
27
27
|
|
|
28
|
+
## MSSQL Integration Tests
|
|
29
|
+
|
|
30
|
+
DbUtility includes opt-in integration tests for Microsoft SQL Server that validate the real migration runners against a Docker container.
|
|
31
|
+
|
|
32
|
+
These tests currently cover:
|
|
33
|
+
|
|
34
|
+
- Sequelize migrations with long MSSQL string columns
|
|
35
|
+
- TypeORM migrations with long MSSQL string columns
|
|
36
|
+
- Real inserts of values longer than 4000 characters without parameter size errors
|
|
37
|
+
|
|
38
|
+
Prerequisites:
|
|
39
|
+
|
|
40
|
+
- Docker installed and available in your `PATH`
|
|
41
|
+
- Development dependencies installed with `pnpm install`
|
|
42
|
+
|
|
43
|
+
Available scripts:
|
|
44
|
+
|
|
45
|
+
```bash
|
|
46
|
+
# Run both MSSQL integration suites
|
|
47
|
+
pnpm run test:integration:mssql
|
|
48
|
+
|
|
49
|
+
# Run only Sequelize + MSSQL integration
|
|
50
|
+
pnpm run test:integration:mssql:sequelize
|
|
51
|
+
|
|
52
|
+
# Run only TypeORM + MSSQL integration
|
|
53
|
+
pnpm run test:integration:mssql:typeorm
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
Notes:
|
|
57
|
+
|
|
58
|
+
- These scripts automatically enable `DBUTILITY_RUN_DOCKER_INTEGRATION=1`.
|
|
59
|
+
- They use `cross-env`, so the same commands work on macOS, Linux, and Windows.
|
|
60
|
+
- They are intentionally separate from `pnpm test` to keep the default test suite fast.
|
|
61
|
+
- The tests start real SQL Server containers and may take longer than unit tests.
|
|
62
|
+
|
|
28
63
|
## Internet Usage
|
|
29
64
|
|
|
30
65
|
This library uses your internet connection to check for updates on the npm registry. This check is performed automatically (default: daily) when you execute a CLI command.
|
|
@@ -70,7 +105,7 @@ The configuration file allows you to define CLI language, output directories, na
|
|
|
70
105
|
"outputDir": "db-utility-migrations",
|
|
71
106
|
"fileNamePattern": "timestamp-prefix",
|
|
72
107
|
"data": true,
|
|
73
|
-
"dataTables": ["users", { "table": "
|
|
108
|
+
"dataTables": ["users", { "table": "logs", "where": "level = 'ERROR'" }],
|
|
74
109
|
"backup": true
|
|
75
110
|
},
|
|
76
111
|
"connection": {
|
package/README.pt-BR.md
CHANGED
|
@@ -14,8 +14,8 @@ DbUtility é um utilitário poderoso para manipulação de bancos de dados Micro
|
|
|
14
14
|
- **Suporte Multi-Banco**: Conecte-se ao Microsoft SQL Server, MySQL e PostgreSQL usando drivers oficiais (`mssql`, `mysql2`, `pg`).
|
|
15
15
|
- **Configuração Flexível**: Detalhes de conexão via CLI, `.env`, arquivos de configuração JSON.
|
|
16
16
|
- **Introspecção**: Analise seu banco de dados para listar tabelas, views, stored procedures, funções e triggers.
|
|
17
|
-
- **Exportação de Models**: Exporte tabelas do banco de dados para models do Sequelize, TypeORM
|
|
18
|
-
- **Geração de Migrations**: Crie migrations a partir de tabelas existentes no banco de dados para Sequelize
|
|
17
|
+
- **Exportação de Models**: Exporte tabelas do banco de dados para models do Sequelize, TypeORM, Prisma e Mongoose.
|
|
18
|
+
- **Geração de Migrations**: Crie migrations de esquema e dados a partir de tabelas existentes no banco de dados para Sequelize e TypeORM.
|
|
19
19
|
|
|
20
20
|
## Instalação
|
|
21
21
|
|
|
@@ -25,6 +25,41 @@ npm install @codemastersolutions/db-utility
|
|
|
25
25
|
npm install -g @codemastersolutions/db-utility
|
|
26
26
|
```
|
|
27
27
|
|
|
28
|
+
## Testes de Integração MSSQL
|
|
29
|
+
|
|
30
|
+
O DbUtility inclui testes de integração opt-in para Microsoft SQL Server que validam os runners reais de migration contra um container Docker.
|
|
31
|
+
|
|
32
|
+
Atualmente, esses testes cobrem:
|
|
33
|
+
|
|
34
|
+
- migrations Sequelize com colunas de string longa no MSSQL
|
|
35
|
+
- migrations TypeORM com colunas de string longa no MSSQL
|
|
36
|
+
- inserções reais de valores com mais de 4000 caracteres sem erro de tamanho de parâmetro
|
|
37
|
+
|
|
38
|
+
Pré-requisitos:
|
|
39
|
+
|
|
40
|
+
- Docker instalado e disponível no seu `PATH`
|
|
41
|
+
- Dependências de desenvolvimento instaladas com `pnpm install`
|
|
42
|
+
|
|
43
|
+
Scripts disponíveis:
|
|
44
|
+
|
|
45
|
+
```bash
|
|
46
|
+
# Executa as duas suítes de integração MSSQL
|
|
47
|
+
pnpm run test:integration:mssql
|
|
48
|
+
|
|
49
|
+
# Executa apenas a integração Sequelize + MSSQL
|
|
50
|
+
pnpm run test:integration:mssql:sequelize
|
|
51
|
+
|
|
52
|
+
# Executa apenas a integração TypeORM + MSSQL
|
|
53
|
+
pnpm run test:integration:mssql:typeorm
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
Observações:
|
|
57
|
+
|
|
58
|
+
- Esses scripts ativam automaticamente `DBUTILITY_RUN_DOCKER_INTEGRATION=1`.
|
|
59
|
+
- Eles usam `cross-env`, então os mesmos comandos funcionam em macOS, Linux e Windows.
|
|
60
|
+
- Eles ficam separados de `pnpm test` para manter a suíte padrão rápida.
|
|
61
|
+
- Os testes sobem containers reais do SQL Server e podem demorar mais do que os testes unitários.
|
|
62
|
+
|
|
28
63
|
## Uso de Internet
|
|
29
64
|
|
|
30
65
|
Esta biblioteca utiliza sua conexão com a internet para verificar atualizações no registro npm. Esta verificação é realizada automaticamente (padrão: diariamente) quando você executa um comando da CLI.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MssqlConnector.d.ts","sourceRoot":"","sources":["../../../src/database/connectors/MssqlConnector.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,cAAc,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAGxF,qBAAa,cAAe,YAAW,kBAAkB;IACvD,OAAO,CAAC,IAAI,CAA+B;IAC3C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAiB;gBAE5B,MAAM,EAAE,cAAc;IAI5B,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAmCxB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAO3B,KAAK,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,EAAE,OAAO,CAAC,EAAE,YAAY,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"MssqlConnector.d.ts","sourceRoot":"","sources":["../../../src/database/connectors/MssqlConnector.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,cAAc,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAGxF,qBAAa,cAAe,YAAW,kBAAkB;IACvD,OAAO,CAAC,IAAI,CAA+B;IAC3C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAiB;gBAE5B,MAAM,EAAE,cAAc;IAI5B,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAmCxB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAO3B,KAAK,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,EAAE,OAAO,CAAC,EAAE,YAAY,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IA+B/E,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IAK/B,UAAU,IAAI,OAAO,CAAC,MAAM,CAAC;CAMpC"}
|
|
@@ -61,6 +61,14 @@ class MssqlConnector {
|
|
|
61
61
|
const request = this.pool.request();
|
|
62
62
|
if (params) {
|
|
63
63
|
params.forEach((param, index) => {
|
|
64
|
+
if (typeof param === 'string' && param.length > 4000) {
|
|
65
|
+
request.input(`param${index}`, (0, mssql_1.NVarChar)(mssql_1.MAX), param);
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
if (param instanceof Uint8Array && param.byteLength > 8000) {
|
|
69
|
+
request.input(`param${index}`, (0, mssql_1.VarBinary)(mssql_1.MAX), param);
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
64
72
|
request.input(`param${index}`, param);
|
|
65
73
|
});
|
|
66
74
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MssqlConnector.js","sourceRoot":"","sources":["../../../src/database/connectors/MssqlConnector.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"MssqlConnector.js","sourceRoot":"","sources":["../../../src/database/connectors/MssqlConnector.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MongooseGenerator.d.ts","sourceRoot":"","sources":["../../src/generators/MongooseGenerator.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,cAAc,EACf,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"MongooseGenerator.d.ts","sourceRoot":"","sources":["../../src/generators/MongooseGenerator.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,cAAc,EACf,MAAM,wBAAwB,CAAC;AAGhC,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAElE,qBAAa,iBAAkB,YAAW,eAAe;IACjD,QAAQ,CAAC,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;IAwChE,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,SAAS;IAQjB,OAAO,CAAC,uBAAuB;IAkB/B,OAAO,CAAC,eAAe;IAQvB,OAAO,CAAC,0BAA0B;CAsBnC"}
|
|
@@ -2,11 +2,13 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.MongooseGenerator = void 0;
|
|
4
4
|
const DefaultValueUtils_1 = require("../utils/DefaultValueUtils");
|
|
5
|
+
const IndexUtils_1 = require("../utils/IndexUtils");
|
|
5
6
|
class MongooseGenerator {
|
|
6
7
|
async generate(schema) {
|
|
7
8
|
const files = [];
|
|
8
9
|
for (const table of schema.tables) {
|
|
9
10
|
const className = this.formatModelName(table.name);
|
|
11
|
+
const indexes = (0, IndexUtils_1.getGeneratableIndexes)(table.indexes);
|
|
10
12
|
const content = `import { Schema, model, Document } from 'mongoose';
|
|
11
13
|
|
|
12
14
|
export interface I${className} extends Document {
|
|
@@ -20,7 +22,7 @@ ${table.columns.map((c) => this.generateFieldDefinition(c)).join(',\n')}
|
|
|
20
22
|
collection: '${table.name}'
|
|
21
23
|
});
|
|
22
24
|
|
|
23
|
-
${
|
|
25
|
+
${indexes
|
|
24
26
|
.filter((idx) => !idx.isPrimary)
|
|
25
27
|
.map((idx) => `${className}Schema.index({ ${idx.columns
|
|
26
28
|
.map((c) => `${c}: 1`)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MongooseGenerator.js","sourceRoot":"","sources":["../../src/generators/MongooseGenerator.ts"],"names":[],"mappings":";;;AAIA,kEAA8F;
|
|
1
|
+
{"version":3,"file":"MongooseGenerator.js","sourceRoot":"","sources":["../../src/generators/MongooseGenerator.ts"],"names":[],"mappings":";;;AAIA,kEAA8F;AAC9F,oDAA4D;AAG5D,MAAa,iBAAiB;IAC5B,KAAK,CAAC,QAAQ,CAAC,MAAsB;QACnC,MAAM,KAAK,GAAoB,EAAE,CAAC;QAElC,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;YAClC,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACnD,MAAM,OAAO,GAAG,IAAA,kCAAqB,EAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACrD,MAAM,OAAO,GAAG;;oBAEF,SAAS;EAC3B,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;;;QAG5E,SAAS,wBAAwB,SAAS;EAChD,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;;;iBAGtD,KAAK,CAAC,IAAI;;;EAGzB,OAAO;iBACN,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC;iBAC/B,GAAG,CACF,CAAC,GAAG,EAAE,EAAE,CACN,GAAG,SAAS,kBAAkB,GAAG,CAAC,OAAO;iBACtC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC;iBACrB,IAAI,CAAC,IAAI,CAAC,gBAAgB,GAAG,CAAC,IAAI,cAAc,GAAG,CAAC,QAAQ,MAAM,CACxE;iBACA,IAAI,CAAC,IAAI,CAAC;;eAEE,SAAS,aAAa,SAAS,MAAM,SAAS,MAAM,SAAS;CAC3E,CAAC;YACI,KAAK,CAAC,IAAI,CAAC;gBACT,QAAQ,EAAE,GAAG,SAAS,KAAK;gBAC3B,OAAO;aACR,CAAC,CAAC;QACL,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,eAAe,CAAC,IAAY;QAClC,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACtD,CAAC;IAEO,SAAS,CAAC,QAAgB;QAChC,MAAM,KAAK,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;QACrC,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC;YAAE,OAAO,QAAQ,CAAC;QACnG,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC;YAAE,OAAO,SAAS,CAAC;QAC7C,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC;YAAE,OAAO,MAAM,CAAC;QACpE,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEO,uBAAuB,CAAC,GAAmB;QACjD,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAChD,MAAM,KAAK,GAAG,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC;QAEpC,IAAI,CAAC,GAAG,CAAC,UAAU;YAAE,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QAItD,IAAI,GAAG,CAAC,UAAU,IAAI,GAAG,CAAC,YAAY,KAAK,IAAI,IAAI,GAAG,CAAC,YAAY,KAAK,SAAS,EAAE,CAAC;YAClF,MAAM,YAAY,GAAG,IAAI,CAAC,0BAA0B,CAAC,GAAG,CAAC,CAAC;YAC1D,IAAI,YAAY,KAAK,IAAI,EAAE,CAAC;gBAC1B,KAAK,CAAC,IAAI,CAAC,gBAAgB,YAAY,EAAE,CAAC,CAAC;YAC7C,CAAC;QACH,CAAC;QAED,OAAO,KAAK,GAAG,CAAC,IAAI,QAAQ,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC;IACvD,CAAC;IAEO,eAAe,CAAC,QAAgB;QACtC,MAAM,KAAK,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;QACrC,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC;YAAE,OAAO,QAAQ,CAAC;QACnG,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC;YAAE,OAAO,SAAS,CAAC;QAC7C,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC;YAAE,OAAO,MAAM,CAAC;QACpE,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEO,0BAA0B,CAAC,GAAmB;QACpD,MAAM,cAAc,GAAG,IAAA,2CAAuB,EAC5C,GAAG,CAAC,YAAY,IAAI,EAAE,EACtB,IAAA,2CAAuB,EAAC,GAAG,CAAC,QAAQ,CAAC,CACtC,CAAC;QAEF,QAAQ,cAAc,CAAC,IAAI,EAAE,CAAC;YAC5B,KAAK,OAAO;gBACV,OAAO,IAAI,CAAC;YACd,KAAK,QAAQ;gBACX,OAAO,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YAC9C,KAAK,QAAQ;gBACX,OAAO,cAAc,CAAC,KAAK,CAAC;YAC9B,KAAK,SAAS;gBACZ,OAAO,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC;YACjD,KAAK,UAAU;gBACb,OAAO,UAAU,CAAC;YACpB,KAAK,YAAY;gBACf,OAAO,IAAI,CAAC;QAChB,CAAC;IACH,CAAC;CAEF;AArGD,8CAqGC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PrismaGenerator.d.ts","sourceRoot":"","sources":["../../src/generators/PrismaGenerator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,cAAc,EAAE,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"PrismaGenerator.d.ts","sourceRoot":"","sources":["../../src/generators/PrismaGenerator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAGxE,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAElE,qBAAa,eAAgB,YAAW,eAAe;IAC/C,QAAQ,CAAC,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;IAsDhE,OAAO,CAAC,eAAe;IAKvB,OAAO,CAAC,OAAO;IAWf,OAAO,CAAC,YAAY;IAiCpB,OAAO,CAAC,wBAAwB;CAsBjC"}
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.PrismaGenerator = void 0;
|
|
4
4
|
const DefaultValueUtils_1 = require("../utils/DefaultValueUtils");
|
|
5
|
+
const IndexUtils_1 = require("../utils/IndexUtils");
|
|
5
6
|
class PrismaGenerator {
|
|
6
7
|
async generate(schema) {
|
|
7
8
|
const lines = [];
|
|
@@ -15,13 +16,14 @@ class PrismaGenerator {
|
|
|
15
16
|
lines.push('}');
|
|
16
17
|
lines.push('');
|
|
17
18
|
for (const table of schema.tables) {
|
|
19
|
+
const indexes = (0, IndexUtils_1.getGeneratableIndexes)(table.indexes);
|
|
18
20
|
lines.push(`model ${this.formatModelName(table.name)} {`);
|
|
19
21
|
for (const col of table.columns) {
|
|
20
22
|
const type = this.mapType(col.dataType);
|
|
21
23
|
const modifiers = this.getModifiers(col);
|
|
22
24
|
lines.push(` ${col.name} ${type}${modifiers}`);
|
|
23
25
|
}
|
|
24
|
-
for (const idx of
|
|
26
|
+
for (const idx of indexes) {
|
|
25
27
|
const cols = idx.columns.join(', ');
|
|
26
28
|
if (idx.isPrimary) {
|
|
27
29
|
lines.push(` @@id([${cols}], map: "${idx.name}")`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PrismaGenerator.js","sourceRoot":"","sources":["../../src/generators/PrismaGenerator.ts"],"names":[],"mappings":";;;AACA,kEAA8F;
|
|
1
|
+
{"version":3,"file":"PrismaGenerator.js","sourceRoot":"","sources":["../../src/generators/PrismaGenerator.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,6 +6,7 @@ export declare class SequelizeGenerator implements SchemaGenerator, MigrationGen
|
|
|
6
6
|
generateDataMigrations(data: TableData[]): Promise<GeneratedFile[]>;
|
|
7
7
|
private formatModelName;
|
|
8
8
|
private mapType;
|
|
9
|
+
private mapStringType;
|
|
9
10
|
private generateColumnDefinition;
|
|
10
11
|
private generateMigrationColumn;
|
|
11
12
|
private formatSequelizeDefaultValue;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SequelizeGenerator.d.ts","sourceRoot":"","sources":["../../src/generators/SequelizeGenerator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,cAAc,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"SequelizeGenerator.d.ts","sourceRoot":"","sources":["../../src/generators/SequelizeGenerator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,cAAc,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAKnF,OAAO,EACL,sBAAsB,EACtB,aAAa,EACb,kBAAkB,EAClB,eAAe,EAChB,MAAM,kBAAkB,CAAC;AAE1B,qBAAa,kBACX,YAAW,eAAe,EAAE,kBAAkB,EAAE,sBAAsB;IAEhE,QAAQ,CAAC,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;IA6C1D,kBAAkB,CAAC,MAAM,EAAE,cAAc,EAAE,IAAI,CAAC,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;IAsNxF,sBAAsB,CAAC,IAAI,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;IAwGzE,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,OAAO;IAqDf,OAAO,CAAC,aAAa;IAarB,OAAO,CAAC,wBAAwB;IAehC,OAAO,CAAC,uBAAuB;IAmB/B,OAAO,CAAC,2BAA2B;CAqBpC"}
|
|
@@ -3,12 +3,14 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.SequelizeGenerator = void 0;
|
|
4
4
|
const DataUtils_1 = require("../utils/DataUtils");
|
|
5
5
|
const DefaultValueUtils_1 = require("../utils/DefaultValueUtils");
|
|
6
|
+
const IndexUtils_1 = require("../utils/IndexUtils");
|
|
6
7
|
const topologicalSort_1 = require("../utils/topologicalSort");
|
|
7
8
|
class SequelizeGenerator {
|
|
8
9
|
async generate(schema) {
|
|
9
10
|
const files = [];
|
|
10
11
|
for (const table of schema.tables) {
|
|
11
12
|
const className = this.formatModelName(table.name);
|
|
13
|
+
const indexes = (0, IndexUtils_1.getGeneratableIndexes)(table.indexes);
|
|
12
14
|
const content = `import { Model, DataTypes, Sequelize } from 'sequelize';
|
|
13
15
|
|
|
14
16
|
export class ${className} extends Model {}
|
|
@@ -23,7 +25,7 @@ ${table.columns.map((c) => this.generateColumnDefinition(c)).join(',\n')}
|
|
|
23
25
|
tableName: '${table.name}',
|
|
24
26
|
timestamps: false,
|
|
25
27
|
indexes: [
|
|
26
|
-
${
|
|
28
|
+
${indexes
|
|
27
29
|
.filter((idx) => !idx.isPrimary)
|
|
28
30
|
.map((idx) => ` { name: '${idx.name}', fields: ['${idx.columns.join("','")}'], unique: ${idx.isUnique} }`)
|
|
29
31
|
.join(',\n')}
|
|
@@ -54,12 +56,13 @@ ${table.indexes
|
|
|
54
56
|
const migrationName = `${timestamp}${paddedCounter}-create-${table.name}.js`;
|
|
55
57
|
const tableData = data?.find((d) => d.tableName.toLowerCase() === table.name.toLowerCase());
|
|
56
58
|
const hasAutoIncrement = table.columns.some((c) => c.isAutoIncrement);
|
|
59
|
+
const indexes = (0, IndexUtils_1.getGeneratableIndexes)(table.indexes);
|
|
57
60
|
const createTablePart = `await queryInterface.createTable('${table.name}', {
|
|
58
61
|
${table.columns.map((c) => this.generateMigrationColumn(c, !hasAutoIncrement, false)).join(',\n')}
|
|
59
62
|
});`;
|
|
60
63
|
const pkConstraintsPart = hasAutoIncrement
|
|
61
64
|
? ''
|
|
62
|
-
:
|
|
65
|
+
: indexes
|
|
63
66
|
.filter((idx) => idx.isPrimary)
|
|
64
67
|
.map((idx) => `await queryInterface.addConstraint('${table.name}', {
|
|
65
68
|
fields: ['${idx.columns.join("','")}'],
|
|
@@ -67,7 +70,7 @@ ${table.columns.map((c) => this.generateMigrationColumn(c, !hasAutoIncrement, fa
|
|
|
67
70
|
name: '${idx.name}'
|
|
68
71
|
});`)
|
|
69
72
|
.join('\n ');
|
|
70
|
-
const indexesPart =
|
|
73
|
+
const indexesPart = indexes
|
|
71
74
|
.filter((idx) => !idx.isPrimary)
|
|
72
75
|
.map((idx) => `await queryInterface.addIndex('${table.name}', ['${idx.columns.join("','")}'], { name: '${idx.name}', unique: ${idx.isUnique} });`)
|
|
73
76
|
.join('\n ');
|
|
@@ -354,19 +357,24 @@ module.exports = {
|
|
|
354
357
|
lower.includes('image') ||
|
|
355
358
|
lower.includes('xml'))
|
|
356
359
|
return 'DataTypes.TEXT';
|
|
357
|
-
if (lower.includes('char'))
|
|
358
|
-
|
|
359
|
-
return 'DataTypes.TEXT';
|
|
360
|
-
if (col.maxLength && col.maxLength > 0)
|
|
361
|
-
return `DataTypes.STRING(${col.maxLength})`;
|
|
362
|
-
return 'DataTypes.STRING';
|
|
363
|
-
}
|
|
360
|
+
if (lower.includes('char'))
|
|
361
|
+
return this.mapStringType(col);
|
|
364
362
|
if (lower.includes('binary') || lower.includes('blob'))
|
|
365
363
|
return 'DataTypes.BLOB';
|
|
366
364
|
if (lower.includes('uuid') || lower.includes('guid'))
|
|
367
365
|
return 'DataTypes.UUID';
|
|
368
366
|
return 'DataTypes.STRING';
|
|
369
367
|
}
|
|
368
|
+
mapStringType(col) {
|
|
369
|
+
if (col.maxLength === -1)
|
|
370
|
+
return 'DataTypes.TEXT';
|
|
371
|
+
if (col.maxLength && col.maxLength > 4000) {
|
|
372
|
+
return 'DataTypes.TEXT';
|
|
373
|
+
}
|
|
374
|
+
if (col.maxLength && col.maxLength > 0)
|
|
375
|
+
return `DataTypes.STRING(${col.maxLength})`;
|
|
376
|
+
return 'DataTypes.STRING';
|
|
377
|
+
}
|
|
370
378
|
generateColumnDefinition(col) {
|
|
371
379
|
const type = this.mapType(col);
|
|
372
380
|
const parts = [` type: ${type}`];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SequelizeGenerator.js","sourceRoot":"","sources":["../../src/generators/SequelizeGenerator.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"SequelizeGenerator.js","sourceRoot":"","sources":["../../src/generators/SequelizeGenerator.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,6 +6,7 @@ export declare class TypeORMGenerator implements SchemaGenerator, MigrationGener
|
|
|
6
6
|
generateDataMigrations(data: TableData[]): Promise<GeneratedFile[]>;
|
|
7
7
|
private formatModelName;
|
|
8
8
|
private mapType;
|
|
9
|
+
private withLength;
|
|
9
10
|
private generateColumnDefinition;
|
|
10
11
|
private generateMigrationColumn;
|
|
11
12
|
private formatTypeOrmDefaultValue;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TypeORMGenerator.d.ts","sourceRoot":"","sources":["../../src/generators/TypeORMGenerator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,cAAc,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"TypeORMGenerator.d.ts","sourceRoot":"","sources":["../../src/generators/TypeORMGenerator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,cAAc,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAKnF,OAAO,EACL,sBAAsB,EACtB,aAAa,EACb,kBAAkB,EAClB,eAAe,EAChB,MAAM,kBAAkB,CAAC;AAE1B,qBAAa,gBACX,YAAW,eAAe,EAAE,kBAAkB,EAAE,sBAAsB;IAEhE,QAAQ,CAAC,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;IA+B1D,kBAAkB,CAAC,MAAM,EAAE,cAAc,EAAE,IAAI,CAAC,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;IAsIxF,sBAAsB,CAAC,IAAI,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;IA4DzE,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,OAAO;IAqCf,OAAO,CAAC,UAAU;IAYlB,OAAO,CAAC,wBAAwB;IAiBhC,OAAO,CAAC,uBAAuB;IAmB/B,OAAO,CAAC,yBAAyB;CAqBlC"}
|
|
@@ -3,16 +3,18 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.TypeORMGenerator = void 0;
|
|
4
4
|
const DataUtils_1 = require("../utils/DataUtils");
|
|
5
5
|
const DefaultValueUtils_1 = require("../utils/DefaultValueUtils");
|
|
6
|
+
const IndexUtils_1 = require("../utils/IndexUtils");
|
|
6
7
|
const topologicalSort_1 = require("../utils/topologicalSort");
|
|
7
8
|
class TypeORMGenerator {
|
|
8
9
|
async generate(schema) {
|
|
9
10
|
const files = [];
|
|
10
11
|
for (const table of schema.tables) {
|
|
11
12
|
const className = this.formatModelName(table.name);
|
|
13
|
+
const indexes = (0, IndexUtils_1.getGeneratableIndexes)(table.indexes);
|
|
12
14
|
const content = `import { Entity, PrimaryColumn, Column, Index } from 'typeorm';
|
|
13
15
|
|
|
14
16
|
@Entity('${table.name}')
|
|
15
|
-
${
|
|
17
|
+
${indexes
|
|
16
18
|
.filter((idx) => !idx.isPrimary)
|
|
17
19
|
.map((idx) => `@Index('${idx.name}', ['${idx.columns.join("', '")}']${idx.isUnique ? ', { unique: true }' : ''})`)
|
|
18
20
|
.join('\n')}
|
|
@@ -36,7 +38,8 @@ ${table.columns.map((c) => this.generateColumnDefinition(c)).join('\n')}
|
|
|
36
38
|
counter++;
|
|
37
39
|
const migrationName = `Create${this.formatModelName(table.name)}${timestamp + counter}`;
|
|
38
40
|
const fileName = `${timestamp + counter}-${migrationName}.ts`;
|
|
39
|
-
const
|
|
41
|
+
const indexes = (0, IndexUtils_1.getGeneratableIndexes)(table.indexes);
|
|
42
|
+
const pkIndex = indexes.find((idx) => idx.isPrimary);
|
|
40
43
|
const pkName = pkIndex ? pkIndex.name : undefined;
|
|
41
44
|
const content = `import { MigrationInterface, QueryRunner, Table, TableIndex, TableForeignKey } from 'typeorm';
|
|
42
45
|
|
|
@@ -61,7 +64,7 @@ ${table.foreignKeys
|
|
|
61
64
|
],
|
|
62
65
|
}), true);
|
|
63
66
|
|
|
64
|
-
${
|
|
67
|
+
${indexes
|
|
65
68
|
.filter((idx) => !idx.isPrimary)
|
|
66
69
|
.map((idx) => ` await queryRunner.createIndex('${table.name}', new TableIndex({
|
|
67
70
|
name: '${idx.name}',
|
|
@@ -192,26 +195,51 @@ export class ${migrationName} implements MigrationInterface {
|
|
|
192
195
|
formatModelName(name) {
|
|
193
196
|
return name.charAt(0).toUpperCase() + name.slice(1);
|
|
194
197
|
}
|
|
195
|
-
mapType(
|
|
196
|
-
const lower = dataType.toLowerCase();
|
|
198
|
+
mapType(col) {
|
|
199
|
+
const lower = col.dataType.toLowerCase();
|
|
197
200
|
if (lower.includes('int'))
|
|
198
|
-
return 'int';
|
|
199
|
-
if (lower.includes('char') || lower.includes('text'))
|
|
200
|
-
return 'varchar';
|
|
201
|
+
return { type: 'int', tsType: 'number' };
|
|
201
202
|
if (lower.includes('bool'))
|
|
202
|
-
return 'boolean';
|
|
203
|
+
return { type: 'boolean', tsType: 'boolean' };
|
|
203
204
|
if (lower.includes('date') || lower.includes('time'))
|
|
204
|
-
return 'timestamp';
|
|
205
|
+
return { type: 'timestamp', tsType: 'Date' };
|
|
205
206
|
if (lower.includes('float') || lower.includes('double'))
|
|
206
|
-
return 'float';
|
|
207
|
-
|
|
207
|
+
return { type: 'float', tsType: 'number' };
|
|
208
|
+
if (lower.includes('decimal') || lower.includes('numeric'))
|
|
209
|
+
return { type: 'decimal', tsType: 'number' };
|
|
210
|
+
if (lower.includes('text') ||
|
|
211
|
+
lower.includes('ntext') ||
|
|
212
|
+
lower.includes('xml') ||
|
|
213
|
+
col.maxLength === -1) {
|
|
214
|
+
return { type: 'text', tsType: 'string' };
|
|
215
|
+
}
|
|
216
|
+
if (lower.includes('nvarchar')) {
|
|
217
|
+
return this.withLength('nvarchar', col.maxLength, 'string');
|
|
218
|
+
}
|
|
219
|
+
if (lower.includes('nchar')) {
|
|
220
|
+
return this.withLength('nchar', col.maxLength, 'string');
|
|
221
|
+
}
|
|
222
|
+
if (lower.includes('varchar')) {
|
|
223
|
+
return this.withLength('varchar', col.maxLength, 'string');
|
|
224
|
+
}
|
|
225
|
+
if (lower.includes('char')) {
|
|
226
|
+
return this.withLength('char', col.maxLength, 'string');
|
|
227
|
+
}
|
|
228
|
+
return { type: 'varchar', tsType: 'string' };
|
|
229
|
+
}
|
|
230
|
+
withLength(type, maxLength, tsType) {
|
|
231
|
+
if (maxLength && maxLength > 0) {
|
|
232
|
+
return { type, length: String(maxLength), tsType };
|
|
233
|
+
}
|
|
234
|
+
return { type, tsType };
|
|
208
235
|
}
|
|
209
236
|
generateColumnDefinition(col) {
|
|
210
|
-
const
|
|
237
|
+
const mappedType = this.mapType(col);
|
|
211
238
|
const decorator = col.isPrimaryKey ? '@PrimaryColumn' : '@Column';
|
|
212
239
|
const options = [];
|
|
213
|
-
|
|
214
|
-
|
|
240
|
+
options.push(`type: '${mappedType.type}'`);
|
|
241
|
+
if (mappedType.length)
|
|
242
|
+
options.push(`length: '${mappedType.length}'`);
|
|
215
243
|
if (col.isNullable)
|
|
216
244
|
options.push('nullable: true');
|
|
217
245
|
if (col.isUnique)
|
|
@@ -219,19 +247,12 @@ export class ${migrationName} implements MigrationInterface {
|
|
|
219
247
|
if (col.hasDefault && col.defaultValue !== null && col.defaultValue !== undefined) {
|
|
220
248
|
options.push(`default: ${this.formatTypeOrmDefaultValue(col)}`);
|
|
221
249
|
}
|
|
222
|
-
let tsType = 'string';
|
|
223
|
-
if (type === 'int' || type === 'float')
|
|
224
|
-
tsType = 'number';
|
|
225
|
-
if (type === 'boolean')
|
|
226
|
-
tsType = 'boolean';
|
|
227
|
-
if (type === 'timestamp')
|
|
228
|
-
tsType = 'Date';
|
|
229
250
|
return ` ${decorator}({ ${options.join(', ')} })
|
|
230
|
-
${col.name}${col.isNullable ? '?' : ''}: ${tsType};`;
|
|
251
|
+
${col.name}${col.isNullable ? '?' : ''}: ${mappedType.tsType};`;
|
|
231
252
|
}
|
|
232
253
|
generateMigrationColumn(col) {
|
|
233
|
-
const
|
|
234
|
-
const parts = [` name: '${col.name}'`, ` type: '${type}'`];
|
|
254
|
+
const mappedType = this.mapType(col);
|
|
255
|
+
const parts = [` name: '${col.name}'`, ` type: '${mappedType.type}'`];
|
|
235
256
|
if (col.isPrimaryKey)
|
|
236
257
|
parts.push(' isPrimary: true');
|
|
237
258
|
if (col.isAutoIncrement)
|
|
@@ -240,6 +261,8 @@ export class ${migrationName} implements MigrationInterface {
|
|
|
240
261
|
parts.push(' isNullable: true');
|
|
241
262
|
if (col.isUnique)
|
|
242
263
|
parts.push(' isUnique: true');
|
|
264
|
+
if (mappedType.length)
|
|
265
|
+
parts.push(` length: '${mappedType.length}'`);
|
|
243
266
|
if (col.hasDefault && col.defaultValue !== null && col.defaultValue !== undefined) {
|
|
244
267
|
parts.push(` default: ${this.formatTypeOrmDefaultValue(col)}`);
|
|
245
268
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TypeORMGenerator.js","sourceRoot":"","sources":["../../src/generators/TypeORMGenerator.ts"],"names":[],"mappings":";;;AACA,kDAAgE;AAChE,kEAA8F;AAC9F,8DAA2D;AAQ3D,MAAa,gBAAgB;IAG3B,KAAK,CAAC,QAAQ,CAAC,MAAsB;QACnC,MAAM,KAAK,GAAoB,EAAE,CAAC;QAElC,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;YAClC,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACnD,MAAM,OAAO,GAAG;;WAEX,KAAK,CAAC,IAAI;EACnB,
|
|
1
|
+
{"version":3,"file":"TypeORMGenerator.js","sourceRoot":"","sources":["../../src/generators/TypeORMGenerator.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"IntrospectionLogger.d.ts","sourceRoot":"","sources":["../../src/introspection/IntrospectionLogger.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"IntrospectionLogger.d.ts","sourceRoot":"","sources":["../../src/introspection/IntrospectionLogger.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAGxD,qBAAa,mBAAmB;IAC9B,MAAM,CAAC,SAAS,CACd,QAAQ,EAAE,cAAc,EACxB,MAAM,EAAE,cAAc,EACtB,OAAO,EAAE,MAAM,EACf,SAAS,CAAC,EAAE,SAAS,GACpB,MAAM;CA6BV"}
|
|
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.IntrospectionLogger = void 0;
|
|
4
4
|
const node_fs_1 = require("node:fs");
|
|
5
5
|
const node_path_1 = require("node:path");
|
|
6
|
+
const IndexUtils_1 = require("../utils/IndexUtils");
|
|
6
7
|
class IntrospectionLogger {
|
|
7
8
|
static logSchema(dbConfig, schema, baseDir, appConfig) {
|
|
8
9
|
const rootDirName = appConfig ? appConfig.introspection.outputDir : 'db-utility-introspect';
|
|
@@ -13,6 +14,7 @@ class IntrospectionLogger {
|
|
|
13
14
|
(0, node_fs_1.mkdirSync)(runDir, { recursive: true });
|
|
14
15
|
const schemaPath = (0, node_path_1.join)(runDir, 'schema.json');
|
|
15
16
|
const metadataPath = (0, node_path_1.join)(runDir, 'metadata.json');
|
|
17
|
+
const limits = (0, IndexUtils_1.analyzeSchemaLimits)(schema);
|
|
16
18
|
const metadata = {
|
|
17
19
|
type: dbConfig.type,
|
|
18
20
|
host: dbConfig.host,
|
|
@@ -20,6 +22,8 @@ class IntrospectionLogger {
|
|
|
20
22
|
database: dbConfig.database,
|
|
21
23
|
executedAt: new Date().toISOString(),
|
|
22
24
|
tablesCount: schema.tables.length,
|
|
25
|
+
tablesOver32Columns: limits.tablesOverColumnLimit,
|
|
26
|
+
indexesOver32KeyColumns: limits.indexesOverKeyColumnLimit,
|
|
23
27
|
};
|
|
24
28
|
(0, node_fs_1.writeFileSync)(schemaPath, JSON.stringify(schema, null, 2), 'utf-8');
|
|
25
29
|
(0, node_fs_1.writeFileSync)(metadataPath, JSON.stringify(metadata, null, 2), 'utf-8');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"IntrospectionLogger.js","sourceRoot":"","sources":["../../src/introspection/IntrospectionLogger.ts"],"names":[],"mappings":";;;AAAA,qCAAmD;AACnD,yCAAiC;
|
|
1
|
+
{"version":3,"file":"IntrospectionLogger.js","sourceRoot":"","sources":["../../src/introspection/IntrospectionLogger.ts"],"names":[],"mappings":";;;AAAA,qCAAmD;AACnD,yCAAiC;AAIjC,oDAA0D;AAE1D,MAAa,mBAAmB;IAC9B,MAAM,CAAC,SAAS,CACd,QAAwB,EACxB,MAAsB,EACtB,OAAe,EACf,SAAqB;QAErB,MAAM,WAAW,GAAG,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,CAAC,uBAAuB,CAAC;QAC5F,MAAM,OAAO,GAAG,IAAA,gBAAI,EAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAC3C,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QACjE,MAAM,OAAO,GAAG,OAAO,SAAS,EAAE,CAAC;QACnC,MAAM,MAAM,GAAG,IAAA,gBAAI,EAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QAEtC,IAAA,mBAAS,EAAC,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAEvC,MAAM,UAAU,GAAG,IAAA,gBAAI,EAAC,MAAM,EAAE,aAAa,CAAC,CAAC;QAC/C,MAAM,YAAY,GAAG,IAAA,gBAAI,EAAC,MAAM,EAAE,eAAe,CAAC,CAAC;QACnD,MAAM,MAAM,GAAG,IAAA,gCAAmB,EAAC,MAAM,CAAC,CAAC;QAE3C,MAAM,QAAQ,GAAG;YACf,IAAI,EAAE,QAAQ,CAAC,IAAI;YACnB,IAAI,EAAE,QAAQ,CAAC,IAAI;YACnB,IAAI,EAAE,QAAQ,CAAC,IAAI;YACnB,QAAQ,EAAE,QAAQ,CAAC,QAAQ;YAC3B,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACpC,WAAW,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM;YACjC,mBAAmB,EAAE,MAAM,CAAC,qBAAqB;YACjD,uBAAuB,EAAE,MAAM,CAAC,yBAAyB;SAC1D,CAAC;QAEF,IAAA,uBAAa,EAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;QACpE,IAAA,uBAAa,EAAC,YAAY,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;QAExE,OAAO,MAAM,CAAC;IAChB,CAAC;CACF;AAnCD,kDAmCC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MssqlIntrospector.d.ts","sourceRoot":"","sources":["../../src/introspection/MssqlIntrospector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAEL,cAAc,EAIf,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"MssqlIntrospector.d.ts","sourceRoot":"","sources":["../../src/introspection/MssqlIntrospector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAEL,cAAc,EAIf,MAAM,wBAAwB,CAAC;AA4ChC,qBAAa,iBAAkB,SAAQ,gBAAgB;IAC/C,gBAAgB,IAAI,OAAO,CAAC,cAAc,CAAC;YAkHnC,UAAU;YAWV,WAAW;YAmBX,eAAe;YAef,WAAW;YA0BX,eAAe;IA+B7B,OAAO,CAAC,qBAAqB;CAG9B"}
|
|
@@ -53,6 +53,7 @@ class MssqlIntrospector extends Introspector_1.BaseIntrospector {
|
|
|
53
53
|
indexMap.set(key, {
|
|
54
54
|
name: i.index_name,
|
|
55
55
|
columns: [],
|
|
56
|
+
includedColumns: [],
|
|
56
57
|
isUnique: i.is_unique,
|
|
57
58
|
isPrimary: i.is_primary,
|
|
58
59
|
});
|
|
@@ -60,6 +61,10 @@ class MssqlIntrospector extends Introspector_1.BaseIntrospector {
|
|
|
60
61
|
const entry = indexMap.get(key);
|
|
61
62
|
if (!entry)
|
|
62
63
|
return;
|
|
64
|
+
if (i.is_included_column || i.key_ordinal === 0) {
|
|
65
|
+
entry.includedColumns?.push(i.column_name);
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
63
68
|
entry.columns.push(i.column_name);
|
|
64
69
|
});
|
|
65
70
|
indexMap.forEach((idx, key) => {
|
|
@@ -146,7 +151,8 @@ class MssqlIntrospector extends Introspector_1.BaseIntrospector {
|
|
|
146
151
|
ind.is_unique,
|
|
147
152
|
ind.is_primary_key AS is_primary,
|
|
148
153
|
col.name AS column_name,
|
|
149
|
-
ic.key_ordinal
|
|
154
|
+
ic.key_ordinal,
|
|
155
|
+
ic.is_included_column
|
|
150
156
|
FROM sys.indexes ind
|
|
151
157
|
INNER JOIN sys.index_columns ic
|
|
152
158
|
ON ind.object_id = ic.object_id
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MssqlIntrospector.js","sourceRoot":"","sources":["../../src/introspection/MssqlIntrospector.ts"],"names":[],"mappings":";;;AAAA,iDAAkD;AAQlD,kEAAsE;
|
|
1
|
+
{"version":3,"file":"MssqlIntrospector.js","sourceRoot":"","sources":["../../src/introspection/MssqlIntrospector.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TypeORMRunner.d.ts","sourceRoot":"","sources":["../../../src/testing/runners/TypeORMRunner.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAIpD,qBAAa,aAAc,YAAW,eAAe;IACnD,OAAO,CAAC,OAAO,CAAC,CAAS;gBAEb,OAAO,CAAC,EAAE,MAAM;IAItB,GAAG,CAAC,aAAa,EAAE,MAAM,EAAE,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"TypeORMRunner.d.ts","sourceRoot":"","sources":["../../../src/testing/runners/TypeORMRunner.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAIpD,qBAAa,aAAc,YAAW,eAAe;IACnD,OAAO,CAAC,OAAO,CAAC,CAAS;gBAEb,OAAO,CAAC,EAAE,MAAM;IAItB,GAAG,CAAC,aAAa,EAAE,MAAM,EAAE,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;CAuGxE"}
|
|
@@ -42,6 +42,16 @@ class TypeORMRunner {
|
|
|
42
42
|
catch {
|
|
43
43
|
console.warn('ts-node not found. If your migrations are in TypeScript, they might fail to load.');
|
|
44
44
|
}
|
|
45
|
+
const extra = config.type === 'mssql'
|
|
46
|
+
? {
|
|
47
|
+
options: {
|
|
48
|
+
encrypt: !!config.ssl,
|
|
49
|
+
trustServerCertificate: !config.ssl,
|
|
50
|
+
},
|
|
51
|
+
}
|
|
52
|
+
: config.ssl
|
|
53
|
+
? { ssl: { rejectUnauthorized: false } }
|
|
54
|
+
: undefined;
|
|
45
55
|
const dataSource = new DataSourceClass({
|
|
46
56
|
type: config.type,
|
|
47
57
|
host: config.host,
|
|
@@ -54,7 +64,7 @@ class TypeORMRunner {
|
|
|
54
64
|
entities: [],
|
|
55
65
|
migrations: [],
|
|
56
66
|
ssl: config.ssl ? { rejectUnauthorized: false } : false,
|
|
57
|
-
extra
|
|
67
|
+
extra,
|
|
58
68
|
});
|
|
59
69
|
try {
|
|
60
70
|
await dataSource.initialize();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TypeORMRunner.js","sourceRoot":"","sources":["../../../src/testing/runners/TypeORMRunner.ts"],"names":[],"mappings":";;;AAAA,yCAAiC;AACjC,qCAAsC;AACtC,6CAA4C;AAI5C,MAAM,YAAY,GAAG,IAAA,2BAAa,EAAC,UAAU,CAAC,CAAC;AAE/C,MAAa,aAAa;IAChB,OAAO,CAAU;IAEzB,YAAY,OAAgB;QAC1B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,aAAqB,EAAE,MAAsB;QACrD,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;QAC1B,IAAI,eAAe,CAAC;QAEpB,IAAI,CAAC;YACH,IAAI,UAAU,CAAC;YACf,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACjB,UAAU,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC1C,CAAC;iBAAM,CAAC;gBAEN,IAAI,CAAC;oBACH,UAAU,GAAG,YAAY,CAAC,IAAA,gBAAI,EAAC,GAAG,EAAE,cAAc,EAAE,SAAS,CAAC,CAAC,CAAC;gBAClE,CAAC;gBAAC,MAAM,CAAC;oBACP,UAAU,GAAG,YAAY,CAAC,SAAS,CAAC,CAAC;gBACvC,CAAC;YACH,CAAC;YACD,eAAe,GAAG,UAAU,CAAC,UAAU,CAAC;QAC1C,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,IAAI,KAAK,CAAC,yEAAyE,CAAC,CAAC;QAC7F,CAAC;QAGD,IAAI,CAAC;YACH,YAAY,CAAC,IAAA,gBAAI,EAAC,GAAG,EAAE,cAAc,EAAE,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC;gBAC1D,aAAa,EAAE,IAAI;gBACnB,eAAe,EAAE;oBACf,MAAM,EAAE,UAAU;iBACnB;aACF,CAAC,CAAC;QACL,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,IAAI,CACV,mFAAmF,CACpF,CAAC;QACJ,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,eAAe,CAAC;YACrC,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,WAAW,EAAE,KAAK;YAClB,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,EAAE;YACZ,UAAU,EAAE,EAAE;YACd,GAAG,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,KAAK;YACvD,KAAK
|
|
1
|
+
{"version":3,"file":"TypeORMRunner.js","sourceRoot":"","sources":["../../../src/testing/runners/TypeORMRunner.ts"],"names":[],"mappings":";;;AAAA,yCAAiC;AACjC,qCAAsC;AACtC,6CAA4C;AAI5C,MAAM,YAAY,GAAG,IAAA,2BAAa,EAAC,UAAU,CAAC,CAAC;AAE/C,MAAa,aAAa;IAChB,OAAO,CAAU;IAEzB,YAAY,OAAgB;QAC1B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,aAAqB,EAAE,MAAsB;QACrD,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;QAC1B,IAAI,eAAe,CAAC;QAEpB,IAAI,CAAC;YACH,IAAI,UAAU,CAAC;YACf,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACjB,UAAU,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC1C,CAAC;iBAAM,CAAC;gBAEN,IAAI,CAAC;oBACH,UAAU,GAAG,YAAY,CAAC,IAAA,gBAAI,EAAC,GAAG,EAAE,cAAc,EAAE,SAAS,CAAC,CAAC,CAAC;gBAClE,CAAC;gBAAC,MAAM,CAAC;oBACP,UAAU,GAAG,YAAY,CAAC,SAAS,CAAC,CAAC;gBACvC,CAAC;YACH,CAAC;YACD,eAAe,GAAG,UAAU,CAAC,UAAU,CAAC;QAC1C,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,IAAI,KAAK,CAAC,yEAAyE,CAAC,CAAC;QAC7F,CAAC;QAGD,IAAI,CAAC;YACH,YAAY,CAAC,IAAA,gBAAI,EAAC,GAAG,EAAE,cAAc,EAAE,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC;gBAC1D,aAAa,EAAE,IAAI;gBACnB,eAAe,EAAE;oBACf,MAAM,EAAE,UAAU;iBACnB;aACF,CAAC,CAAC;QACL,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,IAAI,CACV,mFAAmF,CACpF,CAAC;QACJ,CAAC;QAED,MAAM,KAAK,GACT,MAAM,CAAC,IAAI,KAAK,OAAO;YACrB,CAAC,CAAC;gBACE,OAAO,EAAE;oBACP,OAAO,EAAE,CAAC,CAAC,MAAM,CAAC,GAAG;oBACrB,sBAAsB,EAAE,CAAC,MAAM,CAAC,GAAG;iBACpC;aACF;YACH,CAAC,CAAC,MAAM,CAAC,GAAG;gBACV,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,kBAAkB,EAAE,KAAK,EAAE,EAAE;gBACxC,CAAC,CAAC,SAAS,CAAC;QAElB,MAAM,UAAU,GAAG,IAAI,eAAe,CAAC;YACrC,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,WAAW,EAAE,KAAK;YAClB,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,EAAE;YACZ,UAAU,EAAE,EAAE;YACd,GAAG,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,KAAK;YACvD,KAAK;SACN,CAAC,CAAC;QAEH,IAAI,CAAC;YACH,MAAM,UAAU,CAAC,UAAU,EAAE,CAAC;YAC9B,MAAM,WAAW,GAAG,UAAU,CAAC,iBAAiB,EAAE,CAAC;YACnD,MAAM,WAAW,CAAC,OAAO,EAAE,CAAC;YAE5B,MAAM,KAAK,GAAG,IAAA,qBAAW,EAAC,aAAa,CAAC;iBACrC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;iBACrD,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBAEb,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACxC,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACxC,OAAO,KAAK,GAAG,KAAK,CAAC;YACvB,CAAC,CAAC,CAAC;YAEL,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;gBACzB,OAAO,CAAC,GAAG,CAAC,sBAAsB,IAAI,EAAE,CAAC,CAAC;gBAC1C,MAAM,aAAa,GAAG,IAAA,gBAAI,EAAC,aAAa,EAAE,IAAI,CAAC,CAAC;gBAGhD,MAAM,eAAe,GAAG,YAAY,CAAC,aAAa,CAAC,CAAC;gBAIpD,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;gBAC1C,MAAM,cAAc,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;gBAEhD,IAAI,OAAO,cAAc,KAAK,UAAU,EAAE,CAAC;oBACzC,MAAM,QAAQ,GAAG,IAAI,cAAc,EAAE,CAAC;oBACtC,IAAI,QAAQ,CAAC,EAAE,EAAE,CAAC;wBAChB,MAAM,QAAQ,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC;oBACjC,CAAC;gBACH,CAAC;YACH,CAAC;YAED,MAAM,WAAW,CAAC,OAAO,EAAE,CAAC;QAC9B,CAAC;gBAAS,CAAC;YACT,IAAI,UAAU,CAAC,aAAa,EAAE,CAAC;gBAC7B,MAAM,UAAU,CAAC,OAAO,EAAE,CAAC;YAC7B,CAAC;QACH,CAAC;IACH,CAAC;CACF;AA9GD,sCA8GC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"introspection.d.ts","sourceRoot":"","sources":["../../src/types/introspection.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,OAAO,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,YAAY,EAAE,OAAO,CAAC;IACtB,QAAQ,EAAE,OAAO,CAAC;IAClB,eAAe,EAAE,OAAO,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,gBAAgB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC9B;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,QAAQ,EAAE,OAAO,CAAC;IAClB,SAAS,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,kBAAkB;IACjC,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,eAAe,EAAE,MAAM,CAAC;IACxB,iBAAiB,EAAE,MAAM,EAAE,CAAC;IAC5B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,OAAO,EAAE,aAAa,EAAE,CAAC;IACzB,WAAW,EAAE,kBAAkB,EAAE,CAAC;CACnC;AAED,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,aAAa,EAAE,CAAC;CACzB;AAED,MAAM,WAAW,SAAS;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,CAAC;IAC5B,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B"}
|
|
1
|
+
{"version":3,"file":"introspection.d.ts","sourceRoot":"","sources":["../../src/types/introspection.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,OAAO,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,YAAY,EAAE,OAAO,CAAC;IACtB,QAAQ,EAAE,OAAO,CAAC;IAClB,eAAe,EAAE,OAAO,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,gBAAgB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC9B;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAC3B,QAAQ,EAAE,OAAO,CAAC;IAClB,SAAS,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,kBAAkB;IACjC,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,eAAe,EAAE,MAAM,CAAC;IACxB,iBAAiB,EAAE,MAAM,EAAE,CAAC;IAC5B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,OAAO,EAAE,aAAa,EAAE,CAAC;IACzB,WAAW,EAAE,kBAAkB,EAAE,CAAC;CACnC;AAED,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,aAAa,EAAE,CAAC;CACzB;AAED,MAAM,WAAW,SAAS;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,CAAC;IAC5B,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { DatabaseSchema, IndexMetadata } from '../types/introspection';
|
|
2
|
+
export declare const INDEX_KEY_COLUMN_LIMIT = 32;
|
|
3
|
+
export interface WideTableInfo {
|
|
4
|
+
tableName: string;
|
|
5
|
+
columnCount: number;
|
|
6
|
+
}
|
|
7
|
+
export interface OversizedIndexInfo {
|
|
8
|
+
tableName: string;
|
|
9
|
+
indexName: string;
|
|
10
|
+
keyColumnCount: number;
|
|
11
|
+
columns: string[];
|
|
12
|
+
}
|
|
13
|
+
export interface SchemaLimitAnalysis {
|
|
14
|
+
tablesOverColumnLimit: WideTableInfo[];
|
|
15
|
+
indexesOverKeyColumnLimit: OversizedIndexInfo[];
|
|
16
|
+
}
|
|
17
|
+
export declare function getGeneratableIndexes(indexes: IndexMetadata[], maxKeyColumns?: number): IndexMetadata[];
|
|
18
|
+
export declare function analyzeSchemaLimits(schema: DatabaseSchema, maxKeyColumns?: number): SchemaLimitAnalysis;
|
|
19
|
+
//# sourceMappingURL=IndexUtils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IndexUtils.d.ts","sourceRoot":"","sources":["../../src/utils/IndexUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAEvE,eAAO,MAAM,sBAAsB,KAAK,CAAC;AAEzC,MAAM,WAAW,aAAa;IAC5B,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,kBAAkB;IACjC,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;IACvB,OAAO,EAAE,MAAM,EAAE,CAAC;CACnB;AAED,MAAM,WAAW,mBAAmB;IAClC,qBAAqB,EAAE,aAAa,EAAE,CAAC;IACvC,yBAAyB,EAAE,kBAAkB,EAAE,CAAC;CACjD;AAED,wBAAgB,qBAAqB,CACnC,OAAO,EAAE,aAAa,EAAE,EACxB,aAAa,SAAyB,GACrC,aAAa,EAAE,CAEjB;AAED,wBAAgB,mBAAmB,CACjC,MAAM,EAAE,cAAc,EACtB,aAAa,SAAyB,GACrC,mBAAmB,CAmBrB"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.INDEX_KEY_COLUMN_LIMIT = void 0;
|
|
4
|
+
exports.getGeneratableIndexes = getGeneratableIndexes;
|
|
5
|
+
exports.analyzeSchemaLimits = analyzeSchemaLimits;
|
|
6
|
+
exports.INDEX_KEY_COLUMN_LIMIT = 32;
|
|
7
|
+
function getGeneratableIndexes(indexes, maxKeyColumns = exports.INDEX_KEY_COLUMN_LIMIT) {
|
|
8
|
+
return indexes.filter((index) => index.columns.length > 0 && index.columns.length <= maxKeyColumns);
|
|
9
|
+
}
|
|
10
|
+
function analyzeSchemaLimits(schema, maxKeyColumns = exports.INDEX_KEY_COLUMN_LIMIT) {
|
|
11
|
+
return {
|
|
12
|
+
tablesOverColumnLimit: schema.tables
|
|
13
|
+
.filter((table) => table.columns.length > maxKeyColumns)
|
|
14
|
+
.map((table) => ({
|
|
15
|
+
tableName: table.name,
|
|
16
|
+
columnCount: table.columns.length,
|
|
17
|
+
})),
|
|
18
|
+
indexesOverKeyColumnLimit: schema.tables.flatMap((table) => table.indexes
|
|
19
|
+
.filter((index) => index.columns.length > maxKeyColumns)
|
|
20
|
+
.map((index) => ({
|
|
21
|
+
tableName: table.name,
|
|
22
|
+
indexName: index.name,
|
|
23
|
+
keyColumnCount: index.columns.length,
|
|
24
|
+
columns: index.columns,
|
|
25
|
+
}))),
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=IndexUtils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IndexUtils.js","sourceRoot":"","sources":["../../src/utils/IndexUtils.ts"],"names":[],"mappings":";;;AAqBA,sDAKC;AAED,kDAsBC;AAhDY,QAAA,sBAAsB,GAAG,EAAE,CAAC;AAmBzC,SAAgB,qBAAqB,CACnC,OAAwB,EACxB,aAAa,GAAG,8BAAsB;IAEtC,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,IAAI,aAAa,CAAC,CAAC;AACtG,CAAC;AAED,SAAgB,mBAAmB,CACjC,MAAsB,EACtB,aAAa,GAAG,8BAAsB;IAEtC,OAAO;QACL,qBAAqB,EAAE,MAAM,CAAC,MAAM;aACjC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC;aACvD,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YACf,SAAS,EAAE,KAAK,CAAC,IAAI;YACrB,WAAW,EAAE,KAAK,CAAC,OAAO,CAAC,MAAM;SAClC,CAAC,CAAC;QACL,yBAAyB,EAAE,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,CACzD,KAAK,CAAC,OAAO;aACV,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC;aACvD,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YACf,SAAS,EAAE,KAAK,CAAC,IAAI;YACrB,SAAS,EAAE,KAAK,CAAC,IAAI;YACrB,cAAc,EAAE,KAAK,CAAC,OAAO,CAAC,MAAM;YACpC,OAAO,EAAE,KAAK,CAAC,OAAO;SACvB,CAAC,CAAC,CACN;KACF,CAAC;AACJ,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@codemastersolutions/db-utility",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.19",
|
|
4
4
|
"description": "Database utility for migrations, seeders, factories, introspection and more...",
|
|
5
5
|
"files": [
|
|
6
6
|
"dist",
|
|
@@ -61,9 +61,14 @@
|
|
|
61
61
|
"@typescript-eslint/eslint-plugin": "^8.53.0",
|
|
62
62
|
"@typescript-eslint/parser": "^8.53.0",
|
|
63
63
|
"@vitest/coverage-v8": "^4.0.17",
|
|
64
|
+
"cross-env": "^10.1.0",
|
|
64
65
|
"eslint": "^9.39.2",
|
|
65
66
|
"globals": "^17.0.0",
|
|
66
67
|
"prettier": "^3.7.4",
|
|
68
|
+
"sequelize": "^6.37.8",
|
|
69
|
+
"tedious": "^19.2.1",
|
|
70
|
+
"ts-node": "^10.9.2",
|
|
71
|
+
"typeorm": "^1.0.0",
|
|
67
72
|
"typescript": "^5.9.3",
|
|
68
73
|
"vitest": "^4.0.17"
|
|
69
74
|
},
|
|
@@ -72,6 +77,9 @@
|
|
|
72
77
|
"test": "vitest run",
|
|
73
78
|
"test:watch": "vitest",
|
|
74
79
|
"test:coverage": "vitest run --coverage",
|
|
80
|
+
"test:integration:mssql": "cross-env DBUTILITY_RUN_DOCKER_INTEGRATION=1 vitest run tests/integration/testing/SequelizeMssqlLongString.test.ts tests/integration/testing/TypeormMssqlLongString.test.ts",
|
|
81
|
+
"test:integration:mssql:sequelize": "cross-env DBUTILITY_RUN_DOCKER_INTEGRATION=1 vitest run tests/integration/testing/SequelizeMssqlLongString.test.ts",
|
|
82
|
+
"test:integration:mssql:typeorm": "cross-env DBUTILITY_RUN_DOCKER_INTEGRATION=1 vitest run tests/integration/testing/TypeormMssqlLongString.test.ts",
|
|
75
83
|
"lint": "eslint 'src/**/*.ts'",
|
|
76
84
|
"format": "prettier --write \"src/**/*.ts\" \"tests/**/*.ts\""
|
|
77
85
|
}
|