"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); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.TicketsService = void 0; const common_1 = require("@nestjs/common"); const prisma_service_1 = require("../prisma/prisma.service"); const mail_service_1 = require("../mail/mail.service"); const QRCode = require("qrcode"); let TicketsService = class TicketsService { constructor(prisma, mailService) { this.prisma = prisma; this.mailService = mailService; } async create(createTicketDto) { const event = await this.prisma.event.findUnique({ where: { id: createTicketDto.eventId }, }); if (!event) { throw new common_1.NotFoundException(`Event with ID "${createTicketDto.eventId}" not found`); } const ticket = await this.prisma.ticket.create({ data: createTicketDto, include: { event: true }, }); try { const qrCodeBuffer = await QRCode.toBuffer(ticket.id, { errorCorrectionLevel: 'H', type: 'png', width: 250, color: { dark: '#000000', light: '#FFFFFF', }, }); await this.mailService.sendTicket(ticket.attendeeEmail, ticket.attendeeName, ticket.id, ticket.event.name, qrCodeBuffer); } catch (error) { console.error('Failed to send ticket email:', error); } return ticket; } findAll(eventId) { return this.prisma.ticket.findMany({ where: { eventId }, }); } async resendEmail(id) { const ticket = await this.prisma.ticket.findUnique({ where: { id }, include: { event: true }, }); if (!ticket) { throw new Error('Ticket not found'); } try { const qrCodeBuffer = await QRCode.toBuffer(ticket.id, { errorCorrectionLevel: 'H', type: 'png', width: 250, color: { dark: '#000000', light: '#FFFFFF', }, }); await this.mailService.sendTicket(ticket.attendeeEmail, ticket.attendeeName, ticket.id, ticket.event.name, qrCodeBuffer); return { success: true, message: 'Email resent successfully' }; } catch (error) { console.error('Failed to resend ticket email:', error); throw new Error('Failed to send email'); } } updateStatus(id, status) { return this.prisma.ticket.update({ where: { id }, data: { status }, }); } remove(id) { return this.prisma.ticket.delete({ where: { id }, }); } }; exports.TicketsService = TicketsService; exports.TicketsService = TicketsService = __decorate([ (0, common_1.Injectable)(), __metadata("design:paramtypes", [prisma_service_1.PrismaService, mail_service_1.MailService]) ], TicketsService); //# sourceMappingURL=tickets.service.js.map