"use strict"; 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 AdminBootstrapService_1; Object.defineProperty(exports, "__esModule", { value: true }); exports.AdminBootstrapService = void 0; const common_1 = require("@nestjs/common"); const bcrypt = require("bcryptjs"); const prisma_service_1 = require("../prisma/prisma.service"); const SEED_USERS = [ { username: 'Nadmin', email: 'nadmin@localhost', passwordEnvKey: 'ADMIN_NADMIN_PASSWORD', role: 'admin' }, { username: 'Padmin', email: 'padmin@localhost', passwordEnvKey: 'ADMIN_PADMIN_PASSWORD', role: 'admin' }, { username: 'user1', email: 'user1@localhost', passwordEnvKey: 'SEED_USER1_PASSWORD', role: 'user' }, { username: 'user2', email: 'user2@localhost', passwordEnvKey: 'SEED_USER2_PASSWORD', role: 'user' }, ]; let AdminBootstrapService = AdminBootstrapService_1 = class AdminBootstrapService { constructor(prisma) { this.prisma = prisma; this.logger = new common_1.Logger(AdminBootstrapService_1.name); } async onApplicationBootstrap() { for (const seed of SEED_USERS) { const password = process.env[seed.passwordEnvKey]; if (!password) { this.logger.warn(`${seed.passwordEnvKey} not set — skipping ${seed.username}`); continue; } const existing = await this.prisma.user.findUnique({ where: { username: seed.username } }); if (existing) { if (existing.role !== seed.role) { await this.prisma.user.update({ where: { id: existing.id }, data: { role: seed.role } }); this.logger.log(`Updated role for ${seed.username} → ${seed.role}`); } } else { const passwordHash = await bcrypt.hash(password, 12); await this.prisma.user.create({ data: { username: seed.username, email: seed.email, passwordHash, role: seed.role, }, }); this.logger.log(`Created ${seed.role} user: ${seed.username}`); } } } }; exports.AdminBootstrapService = AdminBootstrapService; exports.AdminBootstrapService = AdminBootstrapService = AdminBootstrapService_1 = __decorate([ (0, common_1.Injectable)(), __metadata("design:paramtypes", [prisma_service_1.PrismaService]) ], AdminBootstrapService); //# sourceMappingURL=admin-bootstrap.service.js.map