add domain wipe

This commit is contained in:
Emily
2024-11-11 16:54:02 +01:00
parent f06d7d78fc
commit 2929b229c4
11 changed files with 440 additions and 5 deletions

View File

@@ -0,0 +1,79 @@
import { VisitModel } from "@schema/metrics/VisitSchema";
import { getRequestData } from "~/server/utils/getRequestData";
export default defineEventHandler(async event => {
const data = await getRequestData(event, { requireSchema: false });
if (!data) return;
const { project_id } = data;
const { domain } = getQuery(event);
try {
const resultData = await VisitModel.aggregate([
{
$match: {
project_id,
website: domain
}
},
{
$group: {
_id: "$session",
count: { $sum: 1 }
}
},
{
$lookup: {
from: "events",
let: { sessionId: "$_id" },
pipeline: [
{ $match: { $expr: { $eq: ["$session", "$$sessionId"] } } },
{ $match: { project_id } },
{ $project: { _id: 1 } }
],
as: "events"
}
},
{
$lookup: {
from: "sessions",
let: { sessionId: "$_id" },
pipeline: [
{ $match: { $expr: { $eq: ["$session", "$$sessionId"] } } },
{ $match: { project_id } },
{ $project: { _id: 1 } }
],
as: "sessions"
}
},
{
$project: {
_id: 1,
count: 1,
"events._id": 1,
"sessions._id": 1
}
}
], { maxTimeMS: 5000 }) as { _id: string, count: number, events: { _id: string }[], sessions: { _id: string }[] }[]
const visits = resultData.reduce((a, e) => a + e.count, 0);
const sessions = resultData.reduce((a, e) => {
const count = e.sessions.length;
return a + count;
}, 0);
const events = resultData.reduce((a, e) => {
const count = e.events.length;
return a + count;
}, 0);
return { visits, sessions, events, error: false, message: '' };
} catch (ex: any) {
return { error: true, message: ex.message.toString(), visits: -1, sessions: -1, events: -1 }
}
});