Files
goodgo-platform/apps/api/src/modules
Ho Ngoc Hai 05be5f4467 fix(admin): push revenue aggregation to DB with DATE_TRUNC and add 60s cache
- Replace prisma.payment.findMany() with $queryRaw GROUP BY DATE_TRUNC
  to push all aggregation work to the database, avoiding loading all
  payment rows into application memory
- Add simple in-process 60s TTL cache keyed by startDate|endDate|groupBy
  to reduce repeated expensive queries
- Cap date range to 366 days via custom @MaxDateRangeDays validator on RevenueStatsDto.endDate

Closes GOO-26

Co-Authored-By: Paperclip <noreply@paperclip.ing>
2026-04-23 00:05:30 +07:00
..