feature(api): override user-agent information
This commit is contained in:
@@ -19,7 +19,7 @@ export async function updateProfile(
|
||||
const projectId = request.projectId;
|
||||
const ip = getClientIp(request)!;
|
||||
const ua = request.headers['user-agent']!;
|
||||
const uaInfo = parseUserAgent(ua);
|
||||
const uaInfo = parseUserAgent(ua, properties);
|
||||
const geo = await parseIp(ip);
|
||||
|
||||
await upsertProfile({
|
||||
|
||||
@@ -273,7 +273,7 @@ async function identify({
|
||||
geo: GeoLocation;
|
||||
ua?: string;
|
||||
}) {
|
||||
const uaInfo = parseUserAgent(ua);
|
||||
const uaInfo = parseUserAgent(ua, payload.properties);
|
||||
await upsertProfile({
|
||||
...payload,
|
||||
id: payload.profileId,
|
||||
|
||||
@@ -59,7 +59,7 @@ export async function incomingEvent(job: Job<EventsQueuePayloadIncomingEvent>) {
|
||||
const userAgent = headers['user-agent'];
|
||||
const sdkName = headers['openpanel-sdk-name'];
|
||||
const sdkVersion = headers['openpanel-sdk-version'];
|
||||
const uaInfo = parseUserAgent(userAgent);
|
||||
const uaInfo = parseUserAgent(userAgent, properties);
|
||||
|
||||
const baseEvent = {
|
||||
name: body.name,
|
||||
@@ -121,7 +121,7 @@ export async function incomingEvent(job: Job<EventsQueuePayloadIncomingEvent>) {
|
||||
referrer: sessionEnd.payload?.referrer,
|
||||
referrerName: sessionEnd.payload?.referrerName,
|
||||
referrerType: sessionEnd.payload?.referrerType,
|
||||
});
|
||||
}) as IServiceCreateEventPayload
|
||||
|
||||
if (sessionEnd.notFound) {
|
||||
await createSessionEnd({ payload });
|
||||
|
||||
@@ -68,7 +68,10 @@ const parse = (ua: string): UAParser.IResult => {
|
||||
return res;
|
||||
};
|
||||
|
||||
export function parseUserAgent(ua?: string | null) {
|
||||
export function parseUserAgent(
|
||||
ua?: string | null,
|
||||
overrides?: Record<string, unknown>,
|
||||
) {
|
||||
if (!ua) return parsedServerUa;
|
||||
const res = parse(ua);
|
||||
|
||||
@@ -77,13 +80,13 @@ export function parseUserAgent(ua?: string | null) {
|
||||
}
|
||||
|
||||
return {
|
||||
os: res.os.name,
|
||||
osVersion: res.os.version,
|
||||
browser: res.browser.name,
|
||||
browserVersion: res.browser.version,
|
||||
device: res.device.type ?? getDevice(ua),
|
||||
brand: res.device.vendor,
|
||||
model: res.device.model,
|
||||
os: overrides?.__os || res.os.name,
|
||||
osVersion: overrides?.__osVersion || res.os.version,
|
||||
browser: overrides?.__browser || res.browser.name,
|
||||
browserVersion: overrides?.__browserVersion || res.browser.version,
|
||||
device: overrides?.__device || res.device.type || getDevice(ua),
|
||||
brand: overrides?.__brand || res.device.vendor,
|
||||
model: overrides?.__model || res.device.model,
|
||||
isServer: false,
|
||||
} as const;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user