Convert event-data, events, session-data, sessions routes.

This commit is contained in:
Mike Cao 2025-01-21 20:57:47 -08:00
parent baa3851fb4
commit 7d5556a637
47 changed files with 692 additions and 136 deletions

View file

@ -1,44 +1,35 @@
import { z } from 'zod';
import { canViewWebsite, checkAuth } from 'lib/auth';
import { getRequestFilters, getRequestDateRange, checkRequest } from 'lib/request';
import { unit, timezone } from 'lib/schema';
import { unitParam, timezoneParam, filterParams } from 'lib/schema';
import { getCompareDate } from 'lib/date';
import { badRequest, unauthorized, json } from 'lib/response';
import { getPageviewStats, getSessionStats } from 'queries';
const schema = z.object({
startAt: z.coerce.number(),
endAt: z.coerce.number(),
unit,
timezone,
url: z.string().optional(),
referrer: z.string().optional(),
title: z.string().optional(),
host: z.string().optional(),
os: z.string().optional(),
browser: z.string().optional(),
device: z.string().optional(),
country: z.string().optional(),
region: z.string().optional(),
city: z.string().optional(),
tag: z.string().optional(),
compare: z.string().optional(),
});
export async function GET(
request: Request,
{ params }: { params: Promise<{ websiteId: string }> },
) {
const schema = z.object({
startAt: z.coerce.number().int(),
endAt: z.coerce.number().int(),
unit: unitParam,
timezone: timezoneParam,
compare: z.string().optional(),
...filterParams,
});
const { query, error } = await checkRequest(request, schema);
if (error) {
return badRequest(error);
}
const auth = await checkAuth(request);
const { websiteId } = await params;
const { timezone, compare } = query;
const auth = await checkAuth(request);
if (!auth || !(await canViewWebsite(auth, websiteId))) {
return unauthorized();
}