From f2cad917183844e59c2ab40699b097da3d18fa23 Mon Sep 17 00:00:00 2001 From: Arnaud Roland Date: Wed, 4 Sep 2024 15:12:49 +0200 Subject: [PATCH] profile: prevent undefined identifier on identify --- src/modules/profile.ts | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/src/modules/profile.ts b/src/modules/profile.ts index b9267ad..87093d9 100644 --- a/src/modules/profile.ts +++ b/src/modules/profile.ts @@ -13,6 +13,13 @@ export class ProfileModule implements BatchSDK.ProfileModule { } identify(identifier: string | null): void { + if (typeof identifier === 'undefined') { + writeBatchLog( + false, + "BatchProfile - Identifier cannot be undefined, please use explicit null if you want to logout. Aborting." + ); + return; + } sendToBridge(null, Profile.Identify, [{ custom_user_id: identifier }]); } @@ -39,18 +46,18 @@ export class ProfileModule implements BatchSDK.ProfileModule { if (typeof location !== "object") { writeBatchLog( false, - "BatchUser - Invalid trackLocation argument. Skipping." + "BatchProfile - Invalid trackLocation argument. Skipping." ); return; } if (typeof location.latitude !== "number" || isNaN(location.latitude)) { - writeBatchLog(false, "BatchUser - Invalid latitude. Skipping."); + writeBatchLog(false, "BatchProfile - Invalid latitude. Skipping."); return; } if (typeof location.longitude !== "number" || isNaN(location.longitude)) { - writeBatchLog(false, "BatchUser - Invalid longitude. Skipping."); + writeBatchLog(false, "BatchProfile - Invalid longitude. Skipping."); return; } @@ -58,12 +65,12 @@ export class ProfileModule implements BatchSDK.ProfileModule { location.precision && (typeof location.precision !== "number" || isNaN(location.precision)) ) { - writeBatchLog(false, "BatchUser - Invalid precision. Skipping."); + writeBatchLog(false, "BatchProfile - Invalid precision. Skipping."); return; } if (location.date && !(location.date instanceof Date)) { - writeBatchLog(false, "BatchUser - Invalid date. Skipping."); + writeBatchLog(false, "BatchProfile - Invalid date. Skipping."); return; }