umami/src/queries/analytics/events/getEventDataProperties.ts

69 lines
2 KiB
TypeScript
Raw Normal View History

2023-07-11 08:16:17 +00:00
import prisma from 'lib/prisma';
2023-06-03 06:10:59 +00:00
import clickhouse from 'lib/clickhouse';
import { CLICKHOUSE, PRISMA, runQuery } from 'lib/db';
2023-08-16 15:49:22 +00:00
import { QueryFilters, WebsiteEventData } from 'lib/types';
2023-06-03 06:10:59 +00:00
2024-08-09 08:09:54 +00:00
export async function getEventDataProperties(
...args: [websiteId: string, filters: QueryFilters & { propertyName?: string }]
2023-08-16 15:49:22 +00:00
): Promise<WebsiteEventData[]> {
2023-06-03 06:10:59 +00:00
return runQuery({
[PRISMA]: () => relationalQuery(...args),
[CLICKHOUSE]: () => clickhouseQuery(...args),
});
}
2024-08-09 08:09:54 +00:00
async function relationalQuery(
websiteId: string,
filters: QueryFilters & { propertyName?: string },
) {
2023-08-04 20:18:30 +00:00
const { rawQuery, parseFilters } = prisma;
const { filterQuery, params } = await parseFilters(websiteId, filters, {
2024-08-09 08:09:54 +00:00
columns: { propertyName: 'data_key' },
});
2023-06-03 06:10:59 +00:00
return rawQuery(
2023-07-25 06:06:16 +00:00
`
select
website_event.event_name as "eventName",
event_data.data_key as "propertyName",
count(*) as "total"
from event_data
join website_event on website_event.event_id = event_data.website_event_id
where event_data.website_id = {{websiteId::uuid}}
and event_data.created_at between {{startDate}} and {{endDate}}
${filterQuery}
group by website_event.event_name, event_data.data_key
2024-08-14 19:29:47 +00:00
order by 3 desc
2024-02-14 23:13:53 +00:00
limit 500
2023-07-11 08:16:17 +00:00
`,
2023-08-04 20:18:30 +00:00
params,
2023-06-03 06:10:59 +00:00
);
}
2023-09-29 18:00:06 +00:00
async function clickhouseQuery(
websiteId: string,
2024-08-09 08:09:54 +00:00
filters: QueryFilters & { propertyName?: string },
2024-08-14 19:29:47 +00:00
): Promise<{ eventName: string; propertyName: string; total: number }[]> {
2023-08-04 20:18:30 +00:00
const { rawQuery, parseFilters } = clickhouse;
const { filterQuery, params } = await parseFilters(websiteId, filters, {
2024-08-09 08:09:54 +00:00
columns: { propertyName: 'data_key' },
});
2023-06-03 06:10:59 +00:00
return rawQuery(
2023-07-25 06:06:16 +00:00
`
select
2024-08-14 19:29:47 +00:00
event_name as eventName,
2024-08-09 08:09:54 +00:00
data_key as propertyName,
2023-07-25 06:06:16 +00:00
count(*) as total
from event_data
where website_id = {websiteId:UUID}
2023-09-29 18:00:06 +00:00
and created_at between {startDate:DateTime64} and {endDate:DateTime64}
${filterQuery}
2024-08-14 19:29:47 +00:00
group by event_name, data_key
order by 1, 3 desc
2024-02-14 23:13:53 +00:00
limit 500
2023-07-11 08:16:17 +00:00
`,
2023-08-04 20:18:30 +00:00
params,
);
2023-06-03 06:10:59 +00:00
}