nestjs-reverse-engineering
Version:
A powerful TypeScript/NestJS library for database reverse engineering, entity generation, and CRUD operations
255 lines • 10.2 kB
JavaScript
;
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var __param = (this && this.__param) || function (paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); }
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.ReverseEngineeringController = void 0;
/* eslint-disable prettier/prettier */
const common_1 = require("@nestjs/common");
const reverse_engineering_service_1 = require("./reverse-engineering.service");
let ReverseEngineeringController = class ReverseEngineeringController {
constructor(reverseEngineeringService) {
this.reverseEngineeringService = reverseEngineeringService;
}
async testConnection() {
return await this.reverseEngineeringService.testConnection();
}
async analyzeSchema() {
return await this.reverseEngineeringService.analyzeSchema();
}
async getTableList() {
return await this.reverseEngineeringService.getTableList();
}
async generateEntities(options) {
try {
await this.reverseEngineeringService.generateEntities(options);
return {
success: true,
message: 'Entities generated successfully',
outputPath: options.outputPath
};
}
catch (error) {
return {
success: false,
message: 'Failed to generate entities',
error: error instanceof Error ? error.message : String(error)
};
}
}
async generateSqlScripts(body) {
try {
const result = await this.reverseEngineeringService.generateSQLScripts(body);
return {
success: true,
message: 'SQL scripts generated successfully',
tableCount: result.tableCount,
outputPath: result.outputPath,
sqlPreview: result.sql.split('\n').slice(0, 20).join('\n') + '\n...'
};
}
catch (error) {
return {
success: false,
message: 'Failed to generate SQL scripts',
error: error instanceof Error ? error.message : String(error)
};
}
}
async generateUIComponents(outputPath) {
try {
await this.reverseEngineeringService.generateUIComponents();
return {
success: true,
message: 'UI components will be generated (feature coming soon)',
outputPath
};
}
catch (error) {
return {
success: false,
message: 'Failed to generate UI components',
error: error instanceof Error ? error.message : String(error)
};
}
}
async scanEntityFiles(entitiesPath) {
try {
const entities = await this.reverseEngineeringService.scanEntityFiles(entitiesPath);
return {
success: true,
count: entities.length,
entities: entities.map(e => ({
className: e.className,
fileName: e.fileName,
filePath: e.filePath
}))
};
}
catch (error) {
return {
success: false,
message: 'Failed to scan entity files',
error: error instanceof Error ? error.message : String(error)
};
}
}
async generateEntityIndex(body) {
try {
await this.reverseEngineeringService.generateEntityIndex(body.entitiesPath);
return {
success: true,
message: 'Entity index generated successfully',
outputPath: body.entitiesPath ? `${body.entitiesPath}/index.ts` : './generated/entities/index.ts'
};
}
catch (error) {
return {
success: false,
message: 'Failed to generate entity index',
error: error instanceof Error ? error.message : String(error)
};
}
}
async exportTableData(body) {
try {
const result = await this.reverseEngineeringService.exportTableData(body);
return {
success: true,
message: 'Table data exported successfully',
...result
};
}
catch (error) {
return {
success: false,
message: 'Failed to export table data',
error: error instanceof Error ? error.message : String(error)
};
}
}
async generateCrudOperations(body) {
try {
const result = await this.reverseEngineeringService.generateCrudOperations(body);
return {
success: true,
message: 'CRUD operations generated successfully',
...result
};
}
catch (error) {
return {
success: false,
message: 'Failed to generate CRUD operations',
error: error instanceof Error ? error.message : String(error)
};
}
}
async generateCrudForTables(body) {
try {
const { tableNames, ...options } = body;
const result = await this.reverseEngineeringService.generateCrudForTables(tableNames, options);
return {
success: true,
message: 'CRUD operations generated successfully for specified tables',
...result
};
}
catch (error) {
return {
success: false,
message: 'Failed to generate CRUD operations for specified tables',
error: error instanceof Error ? error.message : String(error)
};
}
}
};
exports.ReverseEngineeringController = ReverseEngineeringController;
__decorate([
(0, common_1.Get)('test-connection'),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", Promise)
], ReverseEngineeringController.prototype, "testConnection", null);
__decorate([
(0, common_1.Get)('schema'),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", Promise)
], ReverseEngineeringController.prototype, "analyzeSchema", null);
__decorate([
(0, common_1.Get)('tables'),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", Promise)
], ReverseEngineeringController.prototype, "getTableList", null);
__decorate([
(0, common_1.Post)('generate-entities'),
__param(0, (0, common_1.Body)()),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], ReverseEngineeringController.prototype, "generateEntities", null);
__decorate([
(0, common_1.Post)('generate-sql'),
__param(0, (0, common_1.Body)()),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], ReverseEngineeringController.prototype, "generateSqlScripts", null);
__decorate([
(0, common_1.Post)('generate-ui'),
__param(0, (0, common_1.Query)('outputPath')),
__metadata("design:type", Function),
__metadata("design:paramtypes", [String]),
__metadata("design:returntype", Promise)
], ReverseEngineeringController.prototype, "generateUIComponents", null);
__decorate([
(0, common_1.Get)('entity-files'),
__param(0, (0, common_1.Query)('entitiesPath')),
__metadata("design:type", Function),
__metadata("design:paramtypes", [String]),
__metadata("design:returntype", Promise)
], ReverseEngineeringController.prototype, "scanEntityFiles", null);
__decorate([
(0, common_1.Post)('generate-index'),
__param(0, (0, common_1.Body)()),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], ReverseEngineeringController.prototype, "generateEntityIndex", null);
__decorate([
(0, common_1.Post)('export-data'),
__param(0, (0, common_1.Body)()),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], ReverseEngineeringController.prototype, "exportTableData", null);
__decorate([
(0, common_1.Post)('generate-crud'),
__param(0, (0, common_1.Body)()),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], ReverseEngineeringController.prototype, "generateCrudOperations", null);
__decorate([
(0, common_1.Post)('generate-crud-for-tables'),
__param(0, (0, common_1.Body)()),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], ReverseEngineeringController.prototype, "generateCrudForTables", null);
exports.ReverseEngineeringController = ReverseEngineeringController = __decorate([
(0, common_1.Controller)('reverse-engineering'),
__metadata("design:paramtypes", [reverse_engineering_service_1.ReverseEngineeringService])
], ReverseEngineeringController);
//# sourceMappingURL=reverse-engineering.controller.js.map