nestjs-ddd-cli 2.2.1 → 3.2.1
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.md +247 -408
- package/ddd.schema.json +111 -0
- package/dist/commands/aggregate-validator.d.ts +9 -0
- package/dist/commands/aggregate-validator.js +953 -0
- package/dist/commands/aggregate-validator.js.map +1 -0
- package/dist/commands/ai-assist.d.ts +8 -0
- package/dist/commands/ai-assist.js +337 -0
- package/dist/commands/ai-assist.js.map +1 -0
- package/dist/commands/api-contracts.d.ts +9 -0
- package/dist/commands/api-contracts.js +1368 -0
- package/dist/commands/api-contracts.js.map +1 -0
- package/dist/commands/api-docs.d.ts +8 -0
- package/dist/commands/api-docs.js +408 -0
- package/dist/commands/api-docs.js.map +1 -0
- package/dist/commands/api-versioning.d.ts +11 -0
- package/dist/commands/api-versioning.js +643 -0
- package/dist/commands/api-versioning.js.map +1 -0
- package/dist/commands/audit-logging.d.ts +9 -0
- package/dist/commands/audit-logging.js +1129 -0
- package/dist/commands/audit-logging.js.map +1 -0
- package/dist/commands/batch-generate.d.ts +10 -0
- package/dist/commands/batch-generate.js +405 -0
- package/dist/commands/batch-generate.js.map +1 -0
- package/dist/commands/caching-strategies.d.ts +9 -0
- package/dist/commands/caching-strategies.js +874 -0
- package/dist/commands/caching-strategies.js.map +1 -0
- package/dist/commands/code-analyzer.d.ts +42 -0
- package/dist/commands/code-analyzer.js +474 -0
- package/dist/commands/code-analyzer.js.map +1 -0
- package/dist/commands/database-seeding.d.ts +6 -0
- package/dist/commands/database-seeding.js +621 -0
- package/dist/commands/database-seeding.js.map +1 -0
- package/dist/commands/db-optimization.d.ts +7 -0
- package/dist/commands/db-optimization.js +687 -0
- package/dist/commands/db-optimization.js.map +1 -0
- package/dist/commands/dependency-graph.d.ts +6 -0
- package/dist/commands/dependency-graph.js +329 -0
- package/dist/commands/dependency-graph.js.map +1 -0
- package/dist/commands/doctor-enhanced.d.ts +22 -0
- package/dist/commands/doctor-enhanced.js +543 -0
- package/dist/commands/doctor-enhanced.js.map +1 -0
- package/dist/commands/doctor.d.ts +4 -0
- package/dist/commands/doctor.js +151 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/env-manager.d.ts +6 -0
- package/dist/commands/env-manager.js +419 -0
- package/dist/commands/env-manager.js.map +1 -0
- package/dist/commands/event-sourcing-full.d.ts +10 -0
- package/dist/commands/event-sourcing-full.js +1107 -0
- package/dist/commands/event-sourcing-full.js.map +1 -0
- package/dist/commands/feature-flags.d.ts +9 -0
- package/dist/commands/feature-flags.js +824 -0
- package/dist/commands/feature-flags.js.map +1 -0
- package/dist/commands/filter-dsl.d.ts +10 -0
- package/dist/commands/filter-dsl.js +1407 -0
- package/dist/commands/filter-dsl.js.map +1 -0
- package/dist/commands/generate-all.js +485 -32
- package/dist/commands/generate-all.js.map +1 -1
- package/dist/commands/generate-deployment.d.ts +8 -0
- package/dist/commands/generate-deployment.js +746 -0
- package/dist/commands/generate-deployment.js.map +1 -0
- package/dist/commands/generate-domain-service.d.ts +14 -0
- package/dist/commands/generate-domain-service.js +796 -0
- package/dist/commands/generate-domain-service.js.map +1 -0
- package/dist/commands/generate-entity.js +82 -24
- package/dist/commands/generate-entity.js.map +1 -1
- package/dist/commands/generate-from-schema.d.ts +56 -0
- package/dist/commands/generate-from-schema.js +222 -0
- package/dist/commands/generate-from-schema.js.map +1 -0
- package/dist/commands/generate-orchestrator.d.ts +14 -0
- package/dist/commands/generate-orchestrator.js +887 -0
- package/dist/commands/generate-orchestrator.js.map +1 -0
- package/dist/commands/generate-repository.d.ts +14 -0
- package/dist/commands/generate-repository.js +1019 -0
- package/dist/commands/generate-repository.js.map +1 -0
- package/dist/commands/generate-shared.d.ts +4 -0
- package/dist/commands/generate-shared.js +388 -0
- package/dist/commands/generate-shared.js.map +1 -0
- package/dist/commands/generate-value-object.d.ts +32 -0
- package/dist/commands/generate-value-object.js +700 -0
- package/dist/commands/generate-value-object.js.map +1 -0
- package/dist/commands/graphql-subscriptions.d.ts +6 -0
- package/dist/commands/graphql-subscriptions.js +607 -0
- package/dist/commands/graphql-subscriptions.js.map +1 -0
- package/dist/commands/graphql-types.d.ts +5 -0
- package/dist/commands/graphql-types.js +423 -0
- package/dist/commands/graphql-types.js.map +1 -0
- package/dist/commands/health-probes-advanced.d.ts +6 -0
- package/dist/commands/health-probes-advanced.js +655 -0
- package/dist/commands/health-probes-advanced.js.map +1 -0
- package/dist/commands/i18n-setup.d.ts +10 -0
- package/dist/commands/i18n-setup.js +677 -0
- package/dist/commands/i18n-setup.js.map +1 -0
- package/dist/commands/init-config.d.ts +6 -0
- package/dist/commands/init-config.js +370 -0
- package/dist/commands/init-config.js.map +1 -0
- package/dist/commands/init-project.js +56 -6
- package/dist/commands/init-project.js.map +1 -1
- package/dist/commands/interactive-scaffold.d.ts +5 -0
- package/dist/commands/interactive-scaffold.js +271 -0
- package/dist/commands/interactive-scaffold.js.map +1 -0
- package/dist/commands/metrics-prometheus.d.ts +6 -0
- package/dist/commands/metrics-prometheus.js +681 -0
- package/dist/commands/metrics-prometheus.js.map +1 -0
- package/dist/commands/migration-engine.d.ts +6 -0
- package/dist/commands/migration-engine.js +446 -0
- package/dist/commands/migration-engine.js.map +1 -0
- package/dist/commands/migration.d.ts +12 -0
- package/dist/commands/migration.js +484 -0
- package/dist/commands/migration.js.map +1 -0
- package/dist/commands/monorepo.d.ts +8 -0
- package/dist/commands/monorepo.js +483 -0
- package/dist/commands/monorepo.js.map +1 -0
- package/dist/commands/multi-database.d.ts +5 -0
- package/dist/commands/multi-database.js +439 -0
- package/dist/commands/multi-database.js.map +1 -0
- package/dist/commands/observability-tracing.d.ts +10 -0
- package/dist/commands/observability-tracing.js +740 -0
- package/dist/commands/observability-tracing.js.map +1 -0
- package/dist/commands/openapi-export.d.ts +8 -0
- package/dist/commands/openapi-export.js +359 -0
- package/dist/commands/openapi-export.js.map +1 -0
- package/dist/commands/perf-analyzer.d.ts +8 -0
- package/dist/commands/perf-analyzer.js +423 -0
- package/dist/commands/perf-analyzer.js.map +1 -0
- package/dist/commands/rate-limiting.d.ts +10 -0
- package/dist/commands/rate-limiting.js +953 -0
- package/dist/commands/rate-limiting.js.map +1 -0
- package/dist/commands/recipe-plugin.d.ts +56 -0
- package/dist/commands/recipe-plugin.js +315 -0
- package/dist/commands/recipe-plugin.js.map +1 -0
- package/dist/commands/recipe.d.ts +6 -0
- package/dist/commands/recipe.js +3941 -0
- package/dist/commands/recipe.js.map +1 -0
- package/dist/commands/recipes/elasticsearch.recipe.d.ts +1 -0
- package/dist/commands/recipes/elasticsearch.recipe.js +761 -0
- package/dist/commands/recipes/elasticsearch.recipe.js.map +1 -0
- package/dist/commands/recipes/event-sourcing.recipe.d.ts +1 -0
- package/dist/commands/recipes/event-sourcing.recipe.js +889 -0
- package/dist/commands/recipes/event-sourcing.recipe.js.map +1 -0
- package/dist/commands/recipes/index.d.ts +7 -0
- package/dist/commands/recipes/index.js +24 -0
- package/dist/commands/recipes/index.js.map +1 -0
- package/dist/commands/recipes/message-queue.recipe.d.ts +1 -0
- package/dist/commands/recipes/message-queue.recipe.js +706 -0
- package/dist/commands/recipes/message-queue.recipe.js.map +1 -0
- package/dist/commands/recipes/middleware.recipe.d.ts +1 -0
- package/dist/commands/recipes/middleware.recipe.js +383 -0
- package/dist/commands/recipes/middleware.recipe.js.map +1 -0
- package/dist/commands/recipes/multi-tenancy.recipe.d.ts +1 -0
- package/dist/commands/recipes/multi-tenancy.recipe.js +520 -0
- package/dist/commands/recipes/multi-tenancy.recipe.js.map +1 -0
- package/dist/commands/recipes/oauth2.recipe.d.ts +1 -0
- package/dist/commands/recipes/oauth2.recipe.js +472 -0
- package/dist/commands/recipes/oauth2.recipe.js.map +1 -0
- package/dist/commands/recipes/websocket.recipe.d.ts +1 -0
- package/dist/commands/recipes/websocket.recipe.js +453 -0
- package/dist/commands/recipes/websocket.recipe.js.map +1 -0
- package/dist/commands/resilience-patterns.d.ts +13 -0
- package/dist/commands/resilience-patterns.js +1029 -0
- package/dist/commands/resilience-patterns.js.map +1 -0
- package/dist/commands/security-patterns.d.ts +11 -0
- package/dist/commands/security-patterns.js +2233 -0
- package/dist/commands/security-patterns.js.map +1 -0
- package/dist/commands/template-debug.d.ts +27 -0
- package/dist/commands/template-debug.js +388 -0
- package/dist/commands/template-debug.js.map +1 -0
- package/dist/commands/test-factory-full.d.ts +9 -0
- package/dist/commands/test-factory-full.js +1570 -0
- package/dist/commands/test-factory-full.js.map +1 -0
- package/dist/commands/test-scaffold.d.ts +7 -0
- package/dist/commands/test-scaffold.js +621 -0
- package/dist/commands/test-scaffold.js.map +1 -0
- package/dist/index.js +1088 -0
- package/dist/index.js.map +1 -1
- package/dist/templates/ai-context/CLAUDE.md.hbs +158 -0
- package/dist/templates/ai-context/conventions.md.hbs +154 -0
- package/dist/templates/command/create-command.hbs +6 -14
- package/dist/templates/command/delete-command.hbs +19 -0
- package/dist/templates/command/update-command.hbs +24 -0
- package/dist/templates/controller/controller.hbs +64 -17
- package/dist/templates/dto/create-dto.hbs +29 -5
- package/dist/templates/dto/filter-dto.hbs +52 -0
- package/dist/templates/dto/filter-query.dto.hbs +148 -0
- package/dist/templates/dto/paginated-response.dto.hbs +29 -0
- package/dist/templates/dto/pagination-query.dto.hbs +30 -0
- package/dist/templates/dto/response-dto.hbs +38 -0
- package/dist/templates/dto/update-dto.hbs +11 -0
- package/dist/templates/entity/entity.hbs +32 -1
- package/dist/templates/event/domain-event.hbs +33 -7
- package/dist/templates/event/event-handler.hbs +40 -0
- package/dist/templates/exception/base-exceptions.hbs +69 -0
- package/dist/templates/exception/entity-not-found.exception.hbs +7 -0
- package/dist/templates/mapper/mapper.hbs +49 -24
- package/dist/templates/module/module.hbs +34 -10
- package/dist/templates/orm-entity/orm-entity.hbs +63 -12
- package/dist/templates/prisma/prisma-mapper.hbs +71 -0
- package/dist/templates/prisma/prisma-repository.hbs +114 -0
- package/dist/templates/prisma/prisma-schema.hbs +20 -0
- package/dist/templates/prisma/prisma-service.hbs +51 -0
- package/dist/templates/query/get-all.query.hbs +50 -0
- package/dist/templates/query/get-by-id.query.hbs +31 -0
- package/dist/templates/repository/repository.hbs +55 -13
- package/dist/templates/resolver/graphql-input.hbs +54 -0
- package/dist/templates/resolver/graphql-type.hbs +58 -0
- package/dist/templates/resolver/pagination-args.hbs +33 -0
- package/dist/templates/resolver/resolver.hbs +62 -0
- package/dist/templates/shared/prisma-query-builder.util.hbs +189 -0
- package/dist/templates/shared/query-builder.util.hbs +218 -0
- package/dist/templates/test/controller.spec.hbs +124 -0
- package/dist/templates/test/repository.spec.hbs +158 -0
- package/dist/templates/test/usecase.spec.hbs +116 -0
- package/dist/templates/usecase/create-usecase.hbs +19 -7
- package/dist/templates/usecase/delete-usecase.hbs +17 -0
- package/dist/templates/usecase/update-usecase.hbs +31 -0
- package/dist/utils/config.utils.d.ts +45 -0
- package/dist/utils/config.utils.js +211 -0
- package/dist/utils/config.utils.js.map +1 -0
- package/dist/utils/error.utils.d.ts +145 -0
- package/dist/utils/error.utils.js +422 -0
- package/dist/utils/error.utils.js.map +1 -0
- package/dist/utils/field.utils.d.ts +54 -0
- package/dist/utils/field.utils.js +389 -0
- package/dist/utils/field.utils.js.map +1 -0
- package/dist/utils/file.utils.d.ts +19 -8
- package/dist/utils/file.utils.js +135 -4
- package/dist/utils/file.utils.js.map +1 -1
- package/dist/utils/idempotency.utils.d.ts +123 -0
- package/dist/utils/idempotency.utils.js +444 -0
- package/dist/utils/idempotency.utils.js.map +1 -0
- package/dist/utils/naming.utils.js +24 -5
- package/dist/utils/naming.utils.js.map +1 -1
- package/dist/utils/performance.utils.d.ts +37 -0
- package/dist/utils/performance.utils.js +158 -0
- package/dist/utils/performance.utils.js.map +1 -0
- package/dist/utils/relation.utils.d.ts +92 -0
- package/dist/utils/relation.utils.js +388 -0
- package/dist/utils/relation.utils.js.map +1 -0
- package/dist/utils/rollback.utils.d.ts +49 -0
- package/dist/utils/rollback.utils.js +306 -0
- package/dist/utils/rollback.utils.js.map +1 -0
- package/dist/utils/schema.utils.d.ts +123 -0
- package/dist/utils/schema.utils.js +419 -0
- package/dist/utils/schema.utils.js.map +1 -0
- package/dist/utils/security.utils.d.ts +57 -0
- package/dist/utils/security.utils.js +315 -0
- package/dist/utils/security.utils.js.map +1 -0
- package/dist/utils/template-engine.utils.d.ts +80 -0
- package/dist/utils/template-engine.utils.js +463 -0
- package/dist/utils/template-engine.utils.js.map +1 -0
- package/dist/utils/validation-registry.utils.d.ts +160 -0
- package/dist/utils/validation-registry.utils.js +526 -0
- package/dist/utils/validation-registry.utils.js.map +1 -0
- package/package.json +3 -1
|
@@ -0,0 +1,484 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.createMigration = createMigration;
|
|
40
|
+
exports.generateMigrationFromEntity = generateMigrationFromEntity;
|
|
41
|
+
const fs = __importStar(require("fs"));
|
|
42
|
+
const path = __importStar(require("path"));
|
|
43
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
44
|
+
const file_utils_1 = require("../utils/file.utils");
|
|
45
|
+
async function createMigration(basePath, options) {
|
|
46
|
+
const orm = options.orm || 'typeorm';
|
|
47
|
+
const timestamp = Date.now();
|
|
48
|
+
const migrationName = options.name.replace(/[^a-zA-Z0-9]/g, '_');
|
|
49
|
+
console.log(chalk_1.default.bold.blue(`\n📦 Creating ${orm} migration: ${migrationName}\n`));
|
|
50
|
+
if (orm === 'typeorm') {
|
|
51
|
+
await createTypeOrmMigration(basePath, migrationName, timestamp, options.path);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
await createPrismaMigration(basePath, migrationName, timestamp, options.path);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
async function createTypeOrmMigration(basePath, name, timestamp, customPath) {
|
|
58
|
+
const migrationsPath = customPath || path.join(basePath, 'src/database/migrations');
|
|
59
|
+
await (0, file_utils_1.ensureDir)(migrationsPath);
|
|
60
|
+
const className = `${toPascalCase(name)}${timestamp}`;
|
|
61
|
+
const fileName = `${timestamp}-${name}.ts`;
|
|
62
|
+
const content = `import { MigrationInterface, QueryRunner, Table, TableIndex, TableForeignKey } from "typeorm";
|
|
63
|
+
|
|
64
|
+
export class ${className} implements MigrationInterface {
|
|
65
|
+
name = '${className}';
|
|
66
|
+
|
|
67
|
+
public async up(queryRunner: QueryRunner): Promise<void> {
|
|
68
|
+
// TODO: Add your migration logic here
|
|
69
|
+
// Examples:
|
|
70
|
+
|
|
71
|
+
// Create table
|
|
72
|
+
// await queryRunner.createTable(
|
|
73
|
+
// new Table({
|
|
74
|
+
// name: "example",
|
|
75
|
+
// columns: [
|
|
76
|
+
// { name: "id", type: "uuid", isPrimary: true, generationStrategy: "uuid", default: "uuid_generate_v4()" },
|
|
77
|
+
// { name: "name", type: "varchar", length: "255" },
|
|
78
|
+
// { name: "created_at", type: "timestamp", default: "CURRENT_TIMESTAMP" },
|
|
79
|
+
// { name: "updated_at", type: "timestamp", default: "CURRENT_TIMESTAMP" },
|
|
80
|
+
// ],
|
|
81
|
+
// }),
|
|
82
|
+
// true
|
|
83
|
+
// );
|
|
84
|
+
|
|
85
|
+
// Add column
|
|
86
|
+
// await queryRunner.query(\`ALTER TABLE "example" ADD COLUMN "new_column" varchar(255)\`);
|
|
87
|
+
|
|
88
|
+
// Create index
|
|
89
|
+
// await queryRunner.createIndex("example", new TableIndex({ columnNames: ["name"] }));
|
|
90
|
+
|
|
91
|
+
// Add foreign key
|
|
92
|
+
// await queryRunner.createForeignKey(
|
|
93
|
+
// "example",
|
|
94
|
+
// new TableForeignKey({
|
|
95
|
+
// columnNames: ["user_id"],
|
|
96
|
+
// referencedColumnNames: ["id"],
|
|
97
|
+
// referencedTableName: "users",
|
|
98
|
+
// onDelete: "CASCADE",
|
|
99
|
+
// })
|
|
100
|
+
// );
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
public async down(queryRunner: QueryRunner): Promise<void> {
|
|
104
|
+
// TODO: Add your rollback logic here (reverse of up)
|
|
105
|
+
// await queryRunner.dropTable("example");
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
`;
|
|
109
|
+
await (0, file_utils_1.writeFile)(path.join(migrationsPath, fileName), content);
|
|
110
|
+
console.log(chalk_1.default.green(`✓ Created migration: ${fileName}`));
|
|
111
|
+
console.log(chalk_1.default.gray(` Path: ${migrationsPath}`));
|
|
112
|
+
}
|
|
113
|
+
async function createPrismaMigration(basePath, name, timestamp, customPath) {
|
|
114
|
+
const migrationsPath = customPath || path.join(basePath, 'prisma/migrations');
|
|
115
|
+
const migrationDir = path.join(migrationsPath, `${timestamp}_${name}`);
|
|
116
|
+
await (0, file_utils_1.ensureDir)(migrationDir);
|
|
117
|
+
const content = `-- Migration: ${name}
|
|
118
|
+
-- Created at: ${new Date(timestamp).toISOString()}
|
|
119
|
+
|
|
120
|
+
-- TODO: Add your SQL migration here
|
|
121
|
+
-- Examples:
|
|
122
|
+
|
|
123
|
+
-- Create table
|
|
124
|
+
-- CREATE TABLE "example" (
|
|
125
|
+
-- "id" UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
126
|
+
-- "name" VARCHAR(255) NOT NULL,
|
|
127
|
+
-- "created_at" TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
128
|
+
-- "updated_at" TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
|
|
129
|
+
-- );
|
|
130
|
+
|
|
131
|
+
-- Add column
|
|
132
|
+
-- ALTER TABLE "example" ADD COLUMN "new_column" VARCHAR(255);
|
|
133
|
+
|
|
134
|
+
-- Create index
|
|
135
|
+
-- CREATE INDEX "example_name_idx" ON "example"("name");
|
|
136
|
+
|
|
137
|
+
-- Add foreign key
|
|
138
|
+
-- ALTER TABLE "example"
|
|
139
|
+
-- ADD CONSTRAINT "example_user_id_fkey"
|
|
140
|
+
-- FOREIGN KEY ("user_id") REFERENCES "users"("id")
|
|
141
|
+
-- ON DELETE CASCADE;
|
|
142
|
+
`;
|
|
143
|
+
await (0, file_utils_1.writeFile)(path.join(migrationDir, 'migration.sql'), content);
|
|
144
|
+
console.log(chalk_1.default.green(`✓ Created Prisma migration: ${timestamp}_${name}`));
|
|
145
|
+
console.log(chalk_1.default.gray(` Path: ${migrationDir}`));
|
|
146
|
+
}
|
|
147
|
+
async function generateMigrationFromEntity(basePath, options) {
|
|
148
|
+
const orm = options.orm || 'typeorm';
|
|
149
|
+
const modulePath = path.join(basePath, 'src/modules', options.module);
|
|
150
|
+
if (!fs.existsSync(modulePath)) {
|
|
151
|
+
console.log(chalk_1.default.red(`❌ Module "${options.module}" not found.`));
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
console.log(chalk_1.default.bold.blue(`\n📦 Generating migration from ${options.module} entities...\n`));
|
|
155
|
+
// Find entity files
|
|
156
|
+
const entityFiles = findEntityFiles(modulePath);
|
|
157
|
+
if (entityFiles.length === 0) {
|
|
158
|
+
console.log(chalk_1.default.yellow('⚠️ No entity files found in module.'));
|
|
159
|
+
return;
|
|
160
|
+
}
|
|
161
|
+
// Parse entities
|
|
162
|
+
const tables = [];
|
|
163
|
+
for (const file of entityFiles) {
|
|
164
|
+
const table = parseEntityFile(file);
|
|
165
|
+
if (table) {
|
|
166
|
+
tables.push(table);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
if (tables.length === 0) {
|
|
170
|
+
console.log(chalk_1.default.yellow('⚠️ No valid entities found.'));
|
|
171
|
+
return;
|
|
172
|
+
}
|
|
173
|
+
// Generate migration
|
|
174
|
+
const timestamp = Date.now();
|
|
175
|
+
const migrationName = `create_${options.module}_tables`;
|
|
176
|
+
if (orm === 'typeorm') {
|
|
177
|
+
await generateTypeOrmMigration(basePath, tables, migrationName, timestamp);
|
|
178
|
+
}
|
|
179
|
+
else {
|
|
180
|
+
await generatePrismaMigration(basePath, tables, migrationName, timestamp);
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
function findEntityFiles(modulePath) {
|
|
184
|
+
const files = [];
|
|
185
|
+
function scan(dir) {
|
|
186
|
+
if (!fs.existsSync(dir))
|
|
187
|
+
return;
|
|
188
|
+
const entries = fs.readdirSync(dir, { withFileTypes: true });
|
|
189
|
+
for (const entry of entries) {
|
|
190
|
+
const fullPath = path.join(dir, entry.name);
|
|
191
|
+
if (entry.isDirectory()) {
|
|
192
|
+
scan(fullPath);
|
|
193
|
+
}
|
|
194
|
+
else if (entry.name.endsWith('.entity.ts')) {
|
|
195
|
+
files.push(fullPath);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
scan(modulePath);
|
|
200
|
+
return files;
|
|
201
|
+
}
|
|
202
|
+
function parseEntityFile(filePath) {
|
|
203
|
+
const content = fs.readFileSync(filePath, 'utf-8');
|
|
204
|
+
// Extract table name
|
|
205
|
+
const tableMatch = content.match(/@Entity\(\s*['"]?([^'")\s]+)?['"]?\s*\)/);
|
|
206
|
+
const className = content.match(/export\s+class\s+(\w+)/);
|
|
207
|
+
if (!className)
|
|
208
|
+
return null;
|
|
209
|
+
const tableName = tableMatch?.[1] || toSnakeCase(className[1].replace(/Entity$/, ''));
|
|
210
|
+
const columns = [];
|
|
211
|
+
const indexes = [];
|
|
212
|
+
// Parse columns
|
|
213
|
+
const columnRegex = /@(?:PrimaryGeneratedColumn|PrimaryColumn|Column|CreateDateColumn|UpdateDateColumn|DeleteDateColumn)\s*\(([^)]*)\)\s*(\w+)(?:\?)?:\s*(\w+)/g;
|
|
214
|
+
let match;
|
|
215
|
+
while ((match = columnRegex.exec(content)) !== null) {
|
|
216
|
+
const decorator = match[0];
|
|
217
|
+
const options = match[1];
|
|
218
|
+
const propName = match[2];
|
|
219
|
+
const propType = match[3];
|
|
220
|
+
const column = {
|
|
221
|
+
name: toSnakeCase(propName),
|
|
222
|
+
type: mapTypeToSql(propType, options),
|
|
223
|
+
nullable: options.includes('nullable: true') || decorator.includes('?:'),
|
|
224
|
+
primary: decorator.includes('Primary'),
|
|
225
|
+
unique: options.includes('unique: true'),
|
|
226
|
+
};
|
|
227
|
+
if (options.includes('default:')) {
|
|
228
|
+
const defaultMatch = options.match(/default:\s*['"]?([^'",}]+)['"]?/);
|
|
229
|
+
if (defaultMatch) {
|
|
230
|
+
column.default = defaultMatch[1];
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
columns.push(column);
|
|
234
|
+
}
|
|
235
|
+
// Parse relations for foreign keys
|
|
236
|
+
const relationRegex = /@(?:ManyToOne|OneToOne)\s*\([^)]*\)\s*(?:@JoinColumn\(\s*\{[^}]*name:\s*['"](\w+)['"][^}]*\}\s*\))?\s*(\w+)/g;
|
|
237
|
+
while ((match = relationRegex.exec(content)) !== null) {
|
|
238
|
+
const fkColumn = match[1] || `${toSnakeCase(match[2])}_id`;
|
|
239
|
+
const relatedEntity = match[2];
|
|
240
|
+
// Add foreign key column if not already present
|
|
241
|
+
if (!columns.find(c => c.name === fkColumn)) {
|
|
242
|
+
columns.push({
|
|
243
|
+
name: fkColumn,
|
|
244
|
+
type: 'uuid',
|
|
245
|
+
nullable: true,
|
|
246
|
+
primary: false,
|
|
247
|
+
unique: false,
|
|
248
|
+
references: {
|
|
249
|
+
table: toSnakeCase(relatedEntity),
|
|
250
|
+
column: 'id',
|
|
251
|
+
},
|
|
252
|
+
});
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
// Parse indexes
|
|
256
|
+
const indexMatch = content.match(/@Index\(\s*\[([^\]]+)\]/g);
|
|
257
|
+
if (indexMatch) {
|
|
258
|
+
for (const idx of indexMatch) {
|
|
259
|
+
const cols = idx.match(/['"](\w+)['"]/g);
|
|
260
|
+
if (cols) {
|
|
261
|
+
indexes.push({
|
|
262
|
+
columns: cols.map(c => c.replace(/['"]/g, '')),
|
|
263
|
+
unique: idx.includes('unique: true'),
|
|
264
|
+
});
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
// Add default columns if missing
|
|
269
|
+
if (!columns.find(c => c.name === 'id')) {
|
|
270
|
+
columns.unshift({
|
|
271
|
+
name: 'id',
|
|
272
|
+
type: 'uuid',
|
|
273
|
+
nullable: false,
|
|
274
|
+
primary: true,
|
|
275
|
+
unique: true,
|
|
276
|
+
default: 'uuid_generate_v4()',
|
|
277
|
+
});
|
|
278
|
+
}
|
|
279
|
+
if (!columns.find(c => c.name === 'created_at')) {
|
|
280
|
+
columns.push({
|
|
281
|
+
name: 'created_at',
|
|
282
|
+
type: 'timestamp',
|
|
283
|
+
nullable: false,
|
|
284
|
+
primary: false,
|
|
285
|
+
unique: false,
|
|
286
|
+
default: 'CURRENT_TIMESTAMP',
|
|
287
|
+
});
|
|
288
|
+
}
|
|
289
|
+
if (!columns.find(c => c.name === 'updated_at')) {
|
|
290
|
+
columns.push({
|
|
291
|
+
name: 'updated_at',
|
|
292
|
+
type: 'timestamp',
|
|
293
|
+
nullable: false,
|
|
294
|
+
primary: false,
|
|
295
|
+
unique: false,
|
|
296
|
+
default: 'CURRENT_TIMESTAMP',
|
|
297
|
+
});
|
|
298
|
+
}
|
|
299
|
+
return { name: tableName, columns, indexes };
|
|
300
|
+
}
|
|
301
|
+
function mapTypeToSql(tsType, options) {
|
|
302
|
+
const typeMap = {
|
|
303
|
+
'string': 'varchar(255)',
|
|
304
|
+
'number': 'integer',
|
|
305
|
+
'boolean': 'boolean',
|
|
306
|
+
'Date': 'timestamp',
|
|
307
|
+
'bigint': 'bigint',
|
|
308
|
+
'float': 'float',
|
|
309
|
+
'decimal': 'decimal(10,2)',
|
|
310
|
+
};
|
|
311
|
+
// Check for explicit type in decorator options
|
|
312
|
+
const explicitType = options.match(/type:\s*['"](\w+)['"]/);
|
|
313
|
+
if (explicitType) {
|
|
314
|
+
return explicitType[1];
|
|
315
|
+
}
|
|
316
|
+
// Check for length
|
|
317
|
+
const length = options.match(/length:\s*(\d+)/);
|
|
318
|
+
if (length && tsType === 'string') {
|
|
319
|
+
return `varchar(${length[1]})`;
|
|
320
|
+
}
|
|
321
|
+
return typeMap[tsType] || 'varchar(255)';
|
|
322
|
+
}
|
|
323
|
+
async function generateTypeOrmMigration(basePath, tables, name, timestamp) {
|
|
324
|
+
const migrationsPath = path.join(basePath, 'src/database/migrations');
|
|
325
|
+
await (0, file_utils_1.ensureDir)(migrationsPath);
|
|
326
|
+
const className = `${toPascalCase(name)}${timestamp}`;
|
|
327
|
+
const fileName = `${timestamp}-${name}.ts`;
|
|
328
|
+
let upStatements = '';
|
|
329
|
+
let downStatements = '';
|
|
330
|
+
for (const table of tables) {
|
|
331
|
+
// Generate CREATE TABLE
|
|
332
|
+
const columnDefs = table.columns.map(col => {
|
|
333
|
+
let def = `{ name: "${col.name}", type: "${col.type}"`;
|
|
334
|
+
if (col.primary) {
|
|
335
|
+
def += ', isPrimary: true';
|
|
336
|
+
if (col.type === 'uuid') {
|
|
337
|
+
def += ', generationStrategy: "uuid", default: "uuid_generate_v4()"';
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
if (!col.nullable && !col.primary) {
|
|
341
|
+
def += ', isNullable: false';
|
|
342
|
+
}
|
|
343
|
+
else if (col.nullable) {
|
|
344
|
+
def += ', isNullable: true';
|
|
345
|
+
}
|
|
346
|
+
if (col.unique && !col.primary) {
|
|
347
|
+
def += ', isUnique: true';
|
|
348
|
+
}
|
|
349
|
+
if (col.default && !col.primary) {
|
|
350
|
+
def += `, default: "${col.default}"`;
|
|
351
|
+
}
|
|
352
|
+
def += ' }';
|
|
353
|
+
return def;
|
|
354
|
+
});
|
|
355
|
+
upStatements += `
|
|
356
|
+
// Create ${table.name} table
|
|
357
|
+
await queryRunner.createTable(
|
|
358
|
+
new Table({
|
|
359
|
+
name: "${table.name}",
|
|
360
|
+
columns: [
|
|
361
|
+
${columnDefs.join(',\n ')},
|
|
362
|
+
],
|
|
363
|
+
}),
|
|
364
|
+
true
|
|
365
|
+
);
|
|
366
|
+
`;
|
|
367
|
+
// Generate indexes
|
|
368
|
+
for (const index of table.indexes) {
|
|
369
|
+
const indexName = `IDX_${table.name}_${index.columns.join('_')}`;
|
|
370
|
+
upStatements += `
|
|
371
|
+
await queryRunner.createIndex(
|
|
372
|
+
"${table.name}",
|
|
373
|
+
new TableIndex({
|
|
374
|
+
name: "${indexName}",
|
|
375
|
+
columnNames: [${index.columns.map(c => `"${c}"`).join(', ')}],
|
|
376
|
+
${index.unique ? 'isUnique: true,' : ''}
|
|
377
|
+
})
|
|
378
|
+
);
|
|
379
|
+
`;
|
|
380
|
+
}
|
|
381
|
+
// Generate foreign keys
|
|
382
|
+
for (const col of table.columns.filter(c => c.references)) {
|
|
383
|
+
const fkName = `FK_${table.name}_${col.name}`;
|
|
384
|
+
upStatements += `
|
|
385
|
+
await queryRunner.createForeignKey(
|
|
386
|
+
"${table.name}",
|
|
387
|
+
new TableForeignKey({
|
|
388
|
+
name: "${fkName}",
|
|
389
|
+
columnNames: ["${col.name}"],
|
|
390
|
+
referencedColumnNames: ["${col.references.column}"],
|
|
391
|
+
referencedTableName: "${col.references.table}",
|
|
392
|
+
onDelete: "SET NULL",
|
|
393
|
+
})
|
|
394
|
+
);
|
|
395
|
+
`;
|
|
396
|
+
}
|
|
397
|
+
// Generate DROP TABLE for down
|
|
398
|
+
downStatements = `await queryRunner.dropTable("${table.name}", true);\n ` + downStatements;
|
|
399
|
+
}
|
|
400
|
+
const content = `import { MigrationInterface, QueryRunner, Table, TableIndex, TableForeignKey } from "typeorm";
|
|
401
|
+
|
|
402
|
+
export class ${className} implements MigrationInterface {
|
|
403
|
+
name = '${className}';
|
|
404
|
+
|
|
405
|
+
public async up(queryRunner: QueryRunner): Promise<void> {
|
|
406
|
+
// Enable UUID extension
|
|
407
|
+
await queryRunner.query('CREATE EXTENSION IF NOT EXISTS "uuid-ossp"');
|
|
408
|
+
${upStatements}
|
|
409
|
+
}
|
|
410
|
+
|
|
411
|
+
public async down(queryRunner: QueryRunner): Promise<void> {
|
|
412
|
+
${downStatements}
|
|
413
|
+
}
|
|
414
|
+
}
|
|
415
|
+
`;
|
|
416
|
+
await (0, file_utils_1.writeFile)(path.join(migrationsPath, fileName), content);
|
|
417
|
+
console.log(chalk_1.default.green(`✓ Generated migration: ${fileName}`));
|
|
418
|
+
for (const table of tables) {
|
|
419
|
+
console.log(chalk_1.default.gray(` • Table: ${table.name} (${table.columns.length} columns)`));
|
|
420
|
+
}
|
|
421
|
+
}
|
|
422
|
+
async function generatePrismaMigration(basePath, tables, name, timestamp) {
|
|
423
|
+
const migrationsPath = path.join(basePath, 'prisma/migrations');
|
|
424
|
+
const migrationDir = path.join(migrationsPath, `${timestamp}_${name}`);
|
|
425
|
+
await (0, file_utils_1.ensureDir)(migrationDir);
|
|
426
|
+
let upSql = `-- Migration: ${name}\n-- Generated at: ${new Date(timestamp).toISOString()}\n\n`;
|
|
427
|
+
let downSql = `-- Rollback migration: ${name}\n\n`;
|
|
428
|
+
for (const table of tables) {
|
|
429
|
+
// Generate CREATE TABLE
|
|
430
|
+
const columnDefs = table.columns.map(col => {
|
|
431
|
+
let def = ` "${col.name}" ${col.type.toUpperCase()}`;
|
|
432
|
+
if (col.primary) {
|
|
433
|
+
def += ' PRIMARY KEY';
|
|
434
|
+
if (col.default) {
|
|
435
|
+
def += ` DEFAULT ${col.default}`;
|
|
436
|
+
}
|
|
437
|
+
}
|
|
438
|
+
else {
|
|
439
|
+
if (!col.nullable) {
|
|
440
|
+
def += ' NOT NULL';
|
|
441
|
+
}
|
|
442
|
+
if (col.unique) {
|
|
443
|
+
def += ' UNIQUE';
|
|
444
|
+
}
|
|
445
|
+
if (col.default) {
|
|
446
|
+
def += ` DEFAULT ${col.default}`;
|
|
447
|
+
}
|
|
448
|
+
}
|
|
449
|
+
return def;
|
|
450
|
+
});
|
|
451
|
+
upSql += `CREATE TABLE "${table.name}" (\n${columnDefs.join(',\n')}\n);\n\n`;
|
|
452
|
+
// Generate indexes
|
|
453
|
+
for (const index of table.indexes) {
|
|
454
|
+
const indexName = `${table.name}_${index.columns.join('_')}_idx`;
|
|
455
|
+
upSql += `CREATE ${index.unique ? 'UNIQUE ' : ''}INDEX "${indexName}" ON "${table.name}"(${index.columns.map(c => `"${c}"`).join(', ')});\n`;
|
|
456
|
+
}
|
|
457
|
+
// Generate foreign keys
|
|
458
|
+
for (const col of table.columns.filter(c => c.references)) {
|
|
459
|
+
const fkName = `${table.name}_${col.name}_fkey`;
|
|
460
|
+
upSql += `ALTER TABLE "${table.name}" ADD CONSTRAINT "${fkName}" FOREIGN KEY ("${col.name}") REFERENCES "${col.references.table}"("${col.references.column}") ON DELETE SET NULL;\n`;
|
|
461
|
+
}
|
|
462
|
+
upSql += '\n';
|
|
463
|
+
// Generate DROP for down
|
|
464
|
+
downSql += `DROP TABLE IF EXISTS "${table.name}" CASCADE;\n`;
|
|
465
|
+
}
|
|
466
|
+
await (0, file_utils_1.writeFile)(path.join(migrationDir, 'migration.sql'), upSql);
|
|
467
|
+
console.log(chalk_1.default.green(`✓ Generated Prisma migration: ${timestamp}_${name}`));
|
|
468
|
+
for (const table of tables) {
|
|
469
|
+
console.log(chalk_1.default.gray(` • Table: ${table.name} (${table.columns.length} columns)`));
|
|
470
|
+
}
|
|
471
|
+
}
|
|
472
|
+
function toPascalCase(str) {
|
|
473
|
+
return str
|
|
474
|
+
.split(/[-_\s]+/)
|
|
475
|
+
.map(word => word.charAt(0).toUpperCase() + word.slice(1).toLowerCase())
|
|
476
|
+
.join('');
|
|
477
|
+
}
|
|
478
|
+
function toSnakeCase(str) {
|
|
479
|
+
return str
|
|
480
|
+
.replace(/([A-Z])/g, '_$1')
|
|
481
|
+
.toLowerCase()
|
|
482
|
+
.replace(/^_/, '');
|
|
483
|
+
}
|
|
484
|
+
//# sourceMappingURL=migration.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migration.js","sourceRoot":"","sources":["../../src/commands/migration.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export interface MonorepoOptions {
|
|
2
|
+
path?: string;
|
|
3
|
+
packageManager?: 'npm' | 'yarn' | 'pnpm';
|
|
4
|
+
apps?: string[];
|
|
5
|
+
libs?: string[];
|
|
6
|
+
}
|
|
7
|
+
export declare function initMonorepo(projectName: string, options?: MonorepoOptions): Promise<void>;
|
|
8
|
+
export declare function addWorkspace(basePath: string, type: 'app' | 'lib', name: string): Promise<void>;
|