import { EventModel } from "@schema/metrics/EventSchema"; import { Redis } from "~/server/services/CacheService"; import { getRequestDataOld } from "~/server/utils/getRequestData"; export default defineEventHandler(async event => { const data = await getRequestDataOld(event, { requireSchema: false }); if (!data) return; const { pid, from, to, project_id, limit } = data; const cacheKey = `events:${pid}:${limit}:${from}:${to}`; const cacheExp = 60; return await Redis.useCacheV2(cacheKey, cacheExp, async () => { const result = await EventModel.aggregate([ { $match: { project_id, created_at: { $gte: new Date(from), $lte: new Date(to) } } }, { $group: { _id: "$name", count: { $sum: 1, } } }, { $sort: { count: -1 } }, { $limit: limit } ]); return result as { _id: string, count: number }[]; }); });