umami/pages/api/websites/[id]/pageviews.ts

101 lines
2.1 KiB
TypeScript
Raw Normal View History

import { NextApiRequestQueryBody, WebsitePageviews } from 'lib/types';
import { canViewWebsite } from 'lib/auth';
import { useAuth, useCors } from 'lib/middleware';
import moment from 'moment-timezone';
import { NextApiResponse } from 'next';
import { badRequest, methodNotAllowed, ok, unauthorized } from 'next-basics';
2022-07-12 23:14:36 +02:00
import { getPageviewStats } from 'queries';
2020-07-26 09:12:42 +02:00
2020-09-13 10:38:14 +02:00
const unitTypes = ['year', 'month', 'hour', 'day'];
2020-08-01 04:05:14 +02:00
export interface WebsitePageviewRequestQuery {
id: string;
websiteId: string;
start_at: number;
end_at: number;
unit: string;
tz: string;
url?: string;
referrer?: string;
os?: string;
browser?: string;
device?: string;
country?: string;
}
export default async (
req: NextApiRequestQueryBody<WebsitePageviewRequestQuery>,
res: NextApiResponse<WebsitePageviews>,
) => {
2022-10-12 22:11:44 +02:00
await useCors(req, res);
await useAuth(req, res);
2022-04-04 09:33:20 +02:00
const {
id: websiteId,
start_at,
end_at,
unit,
tz,
url,
referrer,
os,
browser,
device,
country,
} = req.query;
2022-12-13 20:27:55 +01:00
const { user, shareToken } = req.auth;
const userId = user?.id;
const shared = shareToken?.websiteId === websiteId;
2022-10-12 22:11:44 +02:00
if (req.method === 'GET') {
2022-12-13 20:27:55 +01:00
const canView = await canViewWebsite(userId, websiteId);
if (!canView && !shared) {
return unauthorized(res);
2020-09-11 22:49:43 +02:00
}
2020-09-11 22:49:43 +02:00
const startDate = new Date(+start_at);
const endDate = new Date(+end_at);
2020-07-30 09:06:29 +02:00
if (!moment.tz.zone(tz) || !unitTypes.includes(unit)) {
return badRequest(res);
}
2020-10-09 08:26:05 +02:00
const [pageviews, sessions] = await Promise.all([
2022-10-11 02:01:48 +02:00
getPageviewStats(websiteId, {
startDate,
endDate,
2022-09-28 02:18:16 +02:00
timezone: tz,
2022-09-12 18:55:34 +02:00
unit,
count: '*',
filters: {
url,
referrer,
os,
browser,
device,
country,
},
2022-04-10 12:51:43 +02:00
}),
2022-10-11 02:01:48 +02:00
getPageviewStats(websiteId, {
startDate,
endDate,
2022-09-28 02:18:16 +02:00
timezone: tz,
2022-09-12 18:55:34 +02:00
unit,
2023-01-12 20:29:37 +01:00
count: 'distinct website_event.',
2022-09-12 18:55:34 +02:00
filters: {
url,
os,
browser,
device,
country,
},
2021-11-22 07:00:14 +01:00
}),
2020-09-11 22:49:43 +02:00
]);
2020-10-09 08:26:05 +02:00
return ok(res, { pageviews, sessions });
2020-09-11 22:49:43 +02:00
}
2020-07-28 08:52:14 +02:00
2020-09-11 22:49:43 +02:00
return methodNotAllowed(res);
2020-07-26 09:12:42 +02:00
};