Sink-UrlShortener/server/api/stats/views.get.ts
2024-05-25 08:09:30 +08:00

30 lines
1003 B
TypeScript

import type { H3Event } from 'h3'
import { z } from 'zod'
import { QuerySchema } from '@/schemas/query'
const { select } = SqlBricks
const unitMap: { [x: string]: string } = {
hour: '%Y-%m-%d %H',
day: '%Y-%m-%d',
}
const ViewsQuerySchema = QuerySchema.extend({
unit: z.string(),
clientTimezone: z.string().default('Etc/UTC'),
})
function query2sql(query: z.infer<typeof ViewsQuerySchema>, event: H3Event): string {
const filter = query2filter(query)
const { dataset } = useRuntimeConfig(event)
const sql = select(`formatDateTime(timestamp, '${unitMap[query.unit]}', '${query.clientTimezone}') as time, SUM(_sample_interval) as visits, COUNT(DISTINCT ${logsMap.ip}) as visitors`).from(dataset).where(filter).groupBy('time').orderBy('time')
appendTimeFilter(sql, query)
return sql.toString()
}
export default eventHandler(async (event) => {
const query = await getValidatedQuery(event, ViewsQuerySchema.parse)
const sql = query2sql(query, event)
return useWAE(event, sql)
})