import { getUserProjectFromId } from "~/server/LIVE_DEMO_DATA"; import { VisitModel } from "@schema/metrics/VisitSchema"; import { DATA_EXPIRE_TIME, Redis } from "~/server/services/CacheService"; export type DevicesAggregated = { _id: string, count: number } export default defineEventHandler(async event => { const project_id = getRequestProjectId(event); if (!project_id) return; const user = getRequestUser(event); const project = await getUserProjectFromId(project_id, user); if (!project) return; const limit = getRequestHeader(event, 'x-query-limit'); const numLimit = parseInt(limit || '10'); const from = getRequestHeader(event, 'x-from'); const to = getRequestHeader(event, 'x-to'); if (!from || !to) return setResponseStatus(event, 400, 'x-from and x-to headers missing'); return await Redis.useCache({ key: `devices:${project_id}:${numLimit}:${from}:${to}`, exp: DATA_EXPIRE_TIME }, async () => { const devices: DevicesAggregated[] = await VisitModel.aggregate([ { $match: { project_id: project._id, device: { $ne: null }, created_at: { $gte: new Date(from), $lte: new Date(to) } }, }, { $group: { _id: "$device", count: { $sum: 1, } } }, { $sort: { count: -1 } }, { $limit: numLimit } ]); return devices; }); });