Files
whyrating/packages/analytics/web/src/providers/google-analytics/server.ts
2026-02-04 01:55:00 +01:00

37 lines
943 B
TypeScript

import { randomUUID } from "crypto";
import { logger } from "@turbostarter/shared/logger";
import { env } from "./env";
import type {
AllowedPropertyValues,
AnalyticsProviderServerStrategy,
} from "@turbostarter/analytics";
const postEvent = async (
event: string,
data?: Record<string, AllowedPropertyValues>,
) => {
const response = await fetch(
`https://www.google-analytics.com/mp/collect?measurement_id=${env.NEXT_PUBLIC_GOOGLE_ANALYTICS_MEASUREMENT_ID}&api_secret=${env.GOOGLE_ANALYTICS_SECRET}`,
{
method: "POST",
body: JSON.stringify({
client_id: data?.clientId ?? randomUUID(),
events: [{ name: event, params: data }],
}),
},
);
if (!response.ok) {
logger.error("Failed to post event to Google Analytics: ", response);
}
};
export const { track } = {
track: (event, data) => {
void postEvent(event, data);
},
} satisfies AnalyticsProviderServerStrategy;