mirror of
https://github.com/Litlyx/litlyx
synced 2025-12-10 15:58:38 +01:00
53 lines
1.5 KiB
TypeScript
53 lines
1.5 KiB
TypeScript
|
|
import { getUserProjectFromId } from "~/server/LIVE_DEMO_DATA";
|
|
import { VisitModel } from "@schema/metrics/VisitSchema";
|
|
import { DATA_EXPIRE_TIME, Redis } from "~/server/services/CacheService";
|
|
|
|
|
|
export type VisitsWebsiteAggregated = {
|
|
_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: `websites:${project_id}:${numLimit}`,
|
|
exp: DATA_EXPIRE_TIME
|
|
}, async () => {
|
|
const websites: VisitsWebsiteAggregated[] = await VisitModel.aggregate([
|
|
{
|
|
$match: {
|
|
project_id: project._id,
|
|
created_at: {
|
|
$gte: new Date(from),
|
|
$lte: new Date(to)
|
|
}
|
|
},
|
|
},
|
|
{ $group: { _id: "$website", count: { $sum: 1, } } },
|
|
{ $sort: { count: -1 } },
|
|
{ $limit: numLimit }
|
|
]);
|
|
|
|
return websites;
|
|
});
|
|
|
|
|
|
}); |