import { Injectable, Inject } from "@nestjs/common"; import { PrismaService } from "../common/prisma/prisma.service"; import { Logger } from "nestjs-pino"; @Injectable() export class SimUsageStoreService { constructor( private readonly prisma: PrismaService, @Inject(Logger) private readonly logger: Logger ) {} private normalizeDate(date?: Date): Date { const d = date ? new Date(date) : new Date(); // strip time to YYYY-MM-DD const iso = d.toISOString().split("T")[0]; return new Date(iso + "T00:00:00.000Z"); } async upsertToday(account: string, usageMb: number, date?: Date): Promise { const day = this.normalizeDate(date); try { await (this.prisma as any).simUsageDaily.upsert({ where: { account_date: { account, date: day } as any }, update: { usageMb }, create: { account, date: day, usageMb }, }); } catch (e: any) { this.logger.error("Failed to upsert daily usage", { account, error: e?.message }); } } async getLastNDays( account: string, days = 30 ): Promise> { const end = this.normalizeDate(); const start = new Date(end); start.setUTCDate(end.getUTCDate() - (days - 1)); const rows = (await (this.prisma as any).simUsageDaily.findMany({ where: { account, date: { gte: start, lte: end } }, orderBy: { date: "desc" }, })) as Array<{ date: Date; usageMb: number }>; return rows.map(r => ({ date: r.date.toISOString().split("T")[0], usageMb: r.usageMb })); } async cleanupPreviousMonths(): Promise { const now = new Date(); const firstOfMonth = new Date(Date.UTC(now.getUTCFullYear(), now.getUTCMonth(), 1)); const result = await (this.prisma as any).simUsageDaily.deleteMany({ where: { date: { lt: firstOfMonth } }, }); return result.count; } }