mirror of
https://github.com/umami-software/umami.git
synced 2026-02-04 04:37:11 +01:00
64 lines
2 KiB
TypeScript
64 lines
2 KiB
TypeScript
import JSZip from 'jszip';
|
|
import Papa from 'papaparse';
|
|
import { z } from 'zod';
|
|
import { getQueryFilters, parseRequest } from '@/lib/request';
|
|
import { json, unauthorized } from '@/lib/response';
|
|
import { dateRangeParams, pagingParams } from '@/lib/schema';
|
|
import { canViewWebsite } from '@/permissions';
|
|
import { getEventMetrics, getPageviewMetrics, getSessionMetrics } from '@/queries/sql';
|
|
|
|
export async function GET(
|
|
request: Request,
|
|
{ params }: { params: Promise<{ websiteId: string }> },
|
|
) {
|
|
const schema = z.object({
|
|
...dateRangeParams,
|
|
...pagingParams,
|
|
});
|
|
|
|
const { auth, query, error } = await parseRequest(request, schema);
|
|
|
|
if (error) {
|
|
return error();
|
|
}
|
|
|
|
const { websiteId } = await params;
|
|
|
|
if (!(await canViewWebsite(auth, websiteId))) {
|
|
return unauthorized();
|
|
}
|
|
|
|
const filters = await getQueryFilters(query, websiteId);
|
|
|
|
const [events, pages, referrers, browsers, os, devices, countries] = await Promise.all([
|
|
getEventMetrics(websiteId, { type: 'event' }, filters),
|
|
getPageviewMetrics(websiteId, { type: 'path' }, filters),
|
|
getPageviewMetrics(websiteId, { type: 'referrer' }, filters),
|
|
getSessionMetrics(websiteId, { type: 'browser' }, filters),
|
|
getSessionMetrics(websiteId, { type: 'os' }, filters),
|
|
getSessionMetrics(websiteId, { type: 'device' }, filters),
|
|
getSessionMetrics(websiteId, { type: 'country' }, filters),
|
|
]);
|
|
|
|
const zip = new JSZip();
|
|
|
|
const parse = (data: any) => {
|
|
return Papa.unparse(data, {
|
|
header: true,
|
|
skipEmptyLines: true,
|
|
});
|
|
};
|
|
|
|
zip.file('events.csv', parse(events));
|
|
zip.file('pages.csv', parse(pages));
|
|
zip.file('referrers.csv', parse(referrers));
|
|
zip.file('browsers.csv', parse(browsers));
|
|
zip.file('os.csv', parse(os));
|
|
zip.file('devices.csv', parse(devices));
|
|
zip.file('countries.csv', parse(countries));
|
|
|
|
const content = await zip.generateAsync({ type: 'nodebuffer' });
|
|
const base64 = content.toString('base64');
|
|
|
|
return json({ zip: base64 });
|
|
}
|