mirror of
https://github.com/Litlyx/litlyx
synced 2025-12-10 07:48:37 +01:00
62 lines
1.7 KiB
TypeScript
62 lines
1.7 KiB
TypeScript
|
|
import { ProjectModel } from "@schema/ProjectSchema";
|
|
import { UserSettingsModel } from "@schema/UserSettings";
|
|
import { EventModel } from '@schema/metrics/EventSchema';
|
|
import { VisitModel } from "@schema/metrics/VisitSchema";
|
|
|
|
|
|
export default defineEventHandler(async event => {
|
|
|
|
const userData = getRequestUser(event);
|
|
if (!userData?.logged) return setResponseStatus(event, 400, 'NotLogged');
|
|
|
|
const currentActiveProject = await UserSettingsModel.findOne({ user_id: userData.id });
|
|
if (!currentActiveProject) return setResponseStatus(event, 400, 'You need to select a project');
|
|
|
|
const project_id = currentActiveProject.active_project_id;
|
|
|
|
const project = await ProjectModel.findById(project_id);
|
|
if (!project) return setResponseStatus(event, 400, 'Project not found');
|
|
|
|
const { mode } = getQuery(event);
|
|
|
|
if (mode === 'visits') {
|
|
|
|
const visistsReportData = await VisitModel.find({
|
|
project_id,
|
|
created_at: {
|
|
$gt: Date.now() - 1000 * 60 * 60 * 24 * 7
|
|
}
|
|
});
|
|
|
|
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 {
|
|
return '';
|
|
}
|
|
|
|
|
|
}); |