Files
litlyx/dashboard/server/api/project/generate_csv.ts
2025-02-14 16:13:06 +01:00

112 lines
2.7 KiB
TypeScript

import { UserModel } from "@schema/UserSchema";
import { VisitModel } from "@schema/metrics/VisitSchema";
import { EventModel } from "~/shared/schema/metrics/EventSchema";
const { SELFHOSTED } = useRuntimeConfig();
export default defineEventHandler(async event => {
const data = await getRequestDataOld(event, { requireSchema: false });
if (!data) return;
const { project, project_id, user } = data;
if (SELFHOSTED.toString() !== 'TRUE' && SELFHOSTED.toString() !== 'true') {
const PREMIUM_TYPE = project.premium_type;
if (PREMIUM_TYPE === 0) return setResponseStatus(event, 400, 'Project not premium');
}
const { mode, slice } = getQuery(event);
let timeSub = 1000 * 60 * 60 * 24;
if (slice == '0') {
timeSub = 1000 * 60 * 60 * 24
} else if (slice == '1') {
timeSub = 1000 * 60 * 60 * 24 * 7
} else if (slice == '2') {
timeSub = 1000 * 60 * 60 * 24 * 7 * 30
} else if (slice == '3') {
timeSub = 1000 * 60 * 60 * 24 * 7 * 30 * 12 * 2
}
if (mode === 'visits') {
const visistsReportData = await VisitModel.find({
project_id,
created_at: {
$gt: Date.now() - timeSub
}
});
const csvHeader = [
"browser",
"os",
"continent",
"country",
"device",
"website",
"page",
"referrer",
"created_at",
];
const lines: any[] = [];
visistsReportData.forEach(line => lines.push(line.toJSON()));
const result = csvHeader.join(',') + '\n' + lines.map(element => {
const content: string[] = [];
for (const key of csvHeader) {
content.push(element[key]);
}
return content.join(',');
}).join('\n');
return result;
} else if (mode === 'events') {
const eventsReportData = await EventModel.find({
project_id,
created_at: {
$gt: Date.now() - timeSub
}
});
const csvHeader = [
"name",
"session",
"metadata",
"website",
"created_at",
];
const lines: any[] = [];
eventsReportData.forEach(line => lines.push(line.toJSON()));
const result = csvHeader.join(',') + '\n' + lines.map(element => {
const content: string[] = [];
for (const key of csvHeader) {
content.push(element[key]);
}
return content.join(',');
}).join('\n');
return result;
} else {
return '';
}
});