@magicpixel/rn-mp-client-sdk 1.13.0 → 1.13.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +163 -14
- package/lib/commonjs/common/app-types.js.map +1 -1
- package/lib/commonjs/common/constants.js +11 -2
- package/lib/commonjs/common/constants.js.map +1 -1
- package/lib/commonjs/common/data-store.js +13 -30
- package/lib/commonjs/common/data-store.js.map +1 -1
- package/lib/commonjs/common/deeplink-helper.js +174 -0
- package/lib/commonjs/common/deeplink-helper.js.map +1 -0
- package/lib/commonjs/common/device-info-helper.js +168 -0
- package/lib/commonjs/common/device-info-helper.js.map +1 -0
- package/lib/commonjs/common/event-bus.js +39 -0
- package/lib/commonjs/common/event-bus.js.map +1 -1
- package/lib/commonjs/common/network-service.js +119 -15
- package/lib/commonjs/common/network-service.js.map +1 -1
- package/lib/commonjs/common/reporter.js +75 -14
- package/lib/commonjs/common/reporter.js.map +1 -1
- package/lib/commonjs/common/storage-helper.js +227 -0
- package/lib/commonjs/common/storage-helper.js.map +1 -0
- package/lib/commonjs/common/utils.js +62 -2
- package/lib/commonjs/common/utils.js.map +1 -1
- package/lib/commonjs/eedl/eedl.js +198 -44
- package/lib/commonjs/eedl/eedl.js.map +1 -1
- package/lib/commonjs/index.js +301 -54
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/models/mp-client-sdk.js +17 -10
- package/lib/commonjs/models/mp-client-sdk.js.map +1 -1
- package/lib/commonjs/processors/data-element.processor.js +51 -7
- package/lib/commonjs/processors/data-element.processor.js.map +1 -1
- package/lib/commonjs/processors/visit-id.processor.js +78 -15
- package/lib/commonjs/processors/visit-id.processor.js.map +1 -1
- package/lib/module/common/app-types.js.map +1 -1
- package/lib/module/common/constants.js +11 -2
- package/lib/module/common/constants.js.map +1 -1
- package/lib/module/common/data-store.js +13 -30
- package/lib/module/common/data-store.js.map +1 -1
- package/lib/module/common/deeplink-helper.js +168 -0
- package/lib/module/common/deeplink-helper.js.map +1 -0
- package/lib/module/common/device-info-helper.js +161 -0
- package/lib/module/common/device-info-helper.js.map +1 -0
- package/lib/module/common/event-bus.js +39 -0
- package/lib/module/common/event-bus.js.map +1 -1
- package/lib/module/common/network-service.js +119 -15
- package/lib/module/common/network-service.js.map +1 -1
- package/lib/module/common/reporter.js +76 -14
- package/lib/module/common/reporter.js.map +1 -1
- package/lib/module/common/storage-helper.js +221 -0
- package/lib/module/common/storage-helper.js.map +1 -0
- package/lib/module/common/utils.js +63 -2
- package/lib/module/common/utils.js.map +1 -1
- package/lib/module/eedl/eedl.js +198 -44
- package/lib/module/eedl/eedl.js.map +1 -1
- package/lib/module/index.js +290 -53
- package/lib/module/index.js.map +1 -1
- package/lib/module/models/mp-client-sdk.js +16 -9
- package/lib/module/models/mp-client-sdk.js.map +1 -1
- package/lib/module/processors/data-element.processor.js +51 -7
- package/lib/module/processors/data-element.processor.js.map +1 -1
- package/lib/module/processors/visit-id.processor.js +78 -15
- package/lib/module/processors/visit-id.processor.js.map +1 -1
- package/lib/typescript/{common → src/common}/app-types.d.ts +30 -9
- package/lib/typescript/{common → src/common}/constants.d.ts +0 -1
- package/lib/typescript/{common → src/common}/data-store.d.ts +3 -8
- package/lib/typescript/src/common/deeplink-helper.d.ts +60 -0
- package/lib/typescript/src/common/device-info-helper.d.ts +54 -0
- package/lib/typescript/src/common/event-bus.d.ts +21 -0
- package/lib/typescript/src/common/network-service.d.ts +32 -0
- package/lib/typescript/{common → src/common}/reporter.d.ts +2 -1
- package/lib/typescript/src/common/storage-helper.d.ts +47 -0
- package/lib/typescript/{common → src/common}/utils.d.ts +25 -0
- package/lib/typescript/{eedl → src/eedl}/eedl.d.ts +43 -1
- package/lib/typescript/{index.d.ts → src/index.d.ts} +39 -5
- package/lib/typescript/{models → src/models}/mp-client-sdk.d.ts +7 -0
- package/lib/typescript/src/processors/visit-id.processor.d.ts +23 -0
- package/package.json +25 -36
- package/src/common/app-types.ts +33 -10
- package/src/common/constants.ts +0 -6
- package/src/common/data-store.ts +8 -30
- package/src/common/deeplink-helper.ts +181 -0
- package/src/common/device-info-helper.ts +190 -0
- package/src/common/event-bus.ts +39 -0
- package/src/common/network-service.ts +154 -21
- package/src/common/reporter.ts +97 -16
- package/src/common/storage-helper.ts +260 -0
- package/src/common/utils.ts +63 -2
- package/src/eedl/eedl.ts +225 -51
- package/src/index.tsx +346 -73
- package/src/models/mp-client-sdk.ts +8 -0
- package/src/processors/data-element.processor.ts +85 -7
- package/src/processors/visit-id.processor.ts +92 -22
- package/lib/commonjs/processors/trans-function.processor.js +0 -73
- package/lib/commonjs/processors/trans-function.processor.js.map +0 -1
- package/lib/module/processors/trans-function.processor.js +0 -66
- package/lib/module/processors/trans-function.processor.js.map +0 -1
- package/lib/typescript/common/event-bus.d.ts +0 -6
- package/lib/typescript/common/network-service.d.ts +0 -8
- package/lib/typescript/processors/trans-function.processor.d.ts +0 -12
- package/lib/typescript/processors/visit-id.processor.d.ts +0 -9
- package/src/processors/trans-function.processor.ts +0 -85
- /package/lib/typescript/{common → src/common}/logger.d.ts +0 -0
- /package/lib/typescript/{models → src/models}/geo-api-response.d.ts +0 -0
- /package/lib/typescript/{processors → src/processors}/data-element.processor.d.ts +0 -0
- /package/lib/typescript/{processors → src/processors}/geo-location.processor.d.ts +0 -0
- /package/lib/typescript/{processors → src/processors}/qc.processor.d.ts +0 -0
- /package/lib/typescript/{processors → src/processors}/tag.processor.d.ts +0 -0
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
2
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
|
|
3
|
+
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
4
|
+
/**
|
|
5
|
+
* Storage helper for data element storage duration
|
|
6
|
+
* Handles SESSION (in-memory) and VISITOR (AsyncStorage with 30-day expiry) storage
|
|
7
|
+
*/
|
|
8
|
+
import AsyncStorage from '@react-native-async-storage/async-storage';
|
|
9
|
+
import { DeStorageDuration } from '../models/mp-client-sdk';
|
|
10
|
+
import { Logger } from './logger';
|
|
11
|
+
|
|
12
|
+
// AsyncStorage key for visitor-scoped data elements
|
|
13
|
+
const VISITOR_STORE_KEY = '_mp_de_visitor_store';
|
|
14
|
+
|
|
15
|
+
// 30 days in milliseconds
|
|
16
|
+
const VISITOR_EXPIRY_MS = 30 * 24 * 60 * 60 * 1000;
|
|
17
|
+
|
|
18
|
+
// Interface for stored visitor values (includes timestamp for expiry check)
|
|
19
|
+
|
|
20
|
+
export class StorageHelper {
|
|
21
|
+
/**
|
|
22
|
+
* Initialize the storage helper
|
|
23
|
+
* Loads visitor store from AsyncStorage and cleans expired values
|
|
24
|
+
* Should be called once during SDK initialization
|
|
25
|
+
*/
|
|
26
|
+
static async initialize() {
|
|
27
|
+
if (this.isInitialized) {
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
try {
|
|
31
|
+
// Load visitor store from AsyncStorage
|
|
32
|
+
const storedData = await AsyncStorage.getItem(VISITOR_STORE_KEY);
|
|
33
|
+
if (storedData) {
|
|
34
|
+
this.visitorStoreCache = JSON.parse(storedData);
|
|
35
|
+
Logger.logDbg('StorageHelper: Loaded visitor store with', Object.keys(this.visitorStoreCache).length, 'items');
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
// Clean expired visitor data
|
|
39
|
+
await this.clearExpiredVisitorData();
|
|
40
|
+
this.isInitialized = true;
|
|
41
|
+
Logger.logDbg('StorageHelper: Initialized successfully');
|
|
42
|
+
} catch (err) {
|
|
43
|
+
Logger.logError('StorageHelper: Error initializing', err);
|
|
44
|
+
// Reset to empty state on error
|
|
45
|
+
this.visitorStoreCache = {};
|
|
46
|
+
this.isInitialized = true;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* Clear visitor-scoped values older than 30 days
|
|
52
|
+
*/
|
|
53
|
+
static async clearExpiredVisitorData() {
|
|
54
|
+
try {
|
|
55
|
+
const now = Date.now();
|
|
56
|
+
const keysToRemove = [];
|
|
57
|
+
for (const key of Object.keys(this.visitorStoreCache)) {
|
|
58
|
+
const entry = this.visitorStoreCache[key];
|
|
59
|
+
if (entry && now - entry.timestamp > VISITOR_EXPIRY_MS) {
|
|
60
|
+
keysToRemove.push(key);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
if (keysToRemove.length > 0) {
|
|
64
|
+
for (const key of keysToRemove) {
|
|
65
|
+
delete this.visitorStoreCache[key];
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
// Persist the cleaned store
|
|
69
|
+
await this.persistVisitorStore();
|
|
70
|
+
Logger.logDbg('StorageHelper: Cleared', keysToRemove.length, 'expired visitor values');
|
|
71
|
+
}
|
|
72
|
+
} catch (err) {
|
|
73
|
+
Logger.logError('StorageHelper: Error clearing expired data', err);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
/**
|
|
78
|
+
* Persist the visitor store cache to AsyncStorage
|
|
79
|
+
*/
|
|
80
|
+
static async persistVisitorStore() {
|
|
81
|
+
try {
|
|
82
|
+
await AsyncStorage.setItem(VISITOR_STORE_KEY, JSON.stringify(this.visitorStoreCache));
|
|
83
|
+
} catch (err) {
|
|
84
|
+
Logger.logError('StorageHelper: Error persisting visitor store', err);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
/**
|
|
89
|
+
* Check if a value is defined (not null, undefined, or empty string)
|
|
90
|
+
*/
|
|
91
|
+
static isDefined(value) {
|
|
92
|
+
return value !== null && value !== undefined && value !== '';
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* Store a data element value based on storage duration
|
|
97
|
+
* @param deKey - The data element key
|
|
98
|
+
* @param value - The value to store
|
|
99
|
+
* @param storageDuration - The storage duration type
|
|
100
|
+
*/
|
|
101
|
+
static deStorageDurationSet(deKey, value, storageDuration) {
|
|
102
|
+
try {
|
|
103
|
+
if (!this.isDefined(deKey) || !this.isDefined(value)) {
|
|
104
|
+
// Key and value are required
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
if (!storageDuration) {
|
|
108
|
+
storageDuration = DeStorageDuration.EVENT;
|
|
109
|
+
}
|
|
110
|
+
switch (storageDuration) {
|
|
111
|
+
case DeStorageDuration.SESSION:
|
|
112
|
+
// Store in memory (cleared on app restart)
|
|
113
|
+
this.sessionStore[deKey] = value;
|
|
114
|
+
Logger.logDbg('StorageHelper: Stored SESSION value for', deKey);
|
|
115
|
+
break;
|
|
116
|
+
case DeStorageDuration.VISITOR:
|
|
117
|
+
// Store in AsyncStorage cache with timestamp
|
|
118
|
+
this.visitorStoreCache[deKey] = {
|
|
119
|
+
value: value,
|
|
120
|
+
timestamp: Date.now()
|
|
121
|
+
};
|
|
122
|
+
// Persist to AsyncStorage in background
|
|
123
|
+
this.persistVisitorStore().catch(err => {
|
|
124
|
+
Logger.logError('StorageHelper: Error persisting visitor value', err);
|
|
125
|
+
});
|
|
126
|
+
Logger.logDbg('StorageHelper: Stored VISITOR value for', deKey);
|
|
127
|
+
break;
|
|
128
|
+
case DeStorageDuration.EVENT:
|
|
129
|
+
case DeStorageDuration.NONE:
|
|
130
|
+
default:
|
|
131
|
+
// No persistence needed for EVENT or NONE
|
|
132
|
+
break;
|
|
133
|
+
}
|
|
134
|
+
} catch (err) {
|
|
135
|
+
Logger.logError('StorageHelper: Error in deStorageDurationSet', err);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
/**
|
|
140
|
+
* Retrieve a data element value based on storage duration
|
|
141
|
+
* @param deKey - The data element key
|
|
142
|
+
* @param defaultValue - Default value if not found
|
|
143
|
+
* @param storageDuration - The storage duration type
|
|
144
|
+
* @returns The stored value or default value
|
|
145
|
+
*/
|
|
146
|
+
static deStorageDurationGet(deKey, defaultValue, storageDuration) {
|
|
147
|
+
try {
|
|
148
|
+
if (!this.isDefined(deKey)) {
|
|
149
|
+
return defaultValue;
|
|
150
|
+
}
|
|
151
|
+
if (!storageDuration) {
|
|
152
|
+
storageDuration = DeStorageDuration.EVENT;
|
|
153
|
+
}
|
|
154
|
+
switch (storageDuration) {
|
|
155
|
+
case DeStorageDuration.SESSION:
|
|
156
|
+
{
|
|
157
|
+
// Get from in-memory session store
|
|
158
|
+
const sessionValue = this.sessionStore[deKey];
|
|
159
|
+
if (this.isDefined(sessionValue)) {
|
|
160
|
+
return sessionValue;
|
|
161
|
+
}
|
|
162
|
+
return defaultValue;
|
|
163
|
+
}
|
|
164
|
+
case DeStorageDuration.VISITOR:
|
|
165
|
+
{
|
|
166
|
+
// Get from visitor store cache
|
|
167
|
+
const visitorEntry = this.visitorStoreCache[deKey];
|
|
168
|
+
if (visitorEntry && this.isDefined(visitorEntry.value)) {
|
|
169
|
+
// Check if not expired
|
|
170
|
+
if (Date.now() - visitorEntry.timestamp <= VISITOR_EXPIRY_MS) {
|
|
171
|
+
return visitorEntry.value;
|
|
172
|
+
} else {
|
|
173
|
+
// Value is expired, remove it
|
|
174
|
+
delete this.visitorStoreCache[deKey];
|
|
175
|
+
this.persistVisitorStore().catch(err => {
|
|
176
|
+
Logger.logError('StorageHelper: Error removing expired value', err);
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
return defaultValue;
|
|
181
|
+
}
|
|
182
|
+
case DeStorageDuration.EVENT:
|
|
183
|
+
case DeStorageDuration.NONE:
|
|
184
|
+
default:
|
|
185
|
+
// No retrieval for EVENT or NONE
|
|
186
|
+
return defaultValue;
|
|
187
|
+
}
|
|
188
|
+
} catch (err) {
|
|
189
|
+
Logger.logError('StorageHelper: Error in deStorageDurationGet', err);
|
|
190
|
+
return defaultValue;
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
/**
|
|
195
|
+
* Clear all session-scoped values (called on new session if needed)
|
|
196
|
+
*/
|
|
197
|
+
static clearSessionStore() {
|
|
198
|
+
this.sessionStore = {};
|
|
199
|
+
Logger.logDbg('StorageHelper: Cleared session store');
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
/**
|
|
203
|
+
* Clear all visitor-scoped values
|
|
204
|
+
*/
|
|
205
|
+
static async clearVisitorStore() {
|
|
206
|
+
try {
|
|
207
|
+
this.visitorStoreCache = {};
|
|
208
|
+
await AsyncStorage.removeItem(VISITOR_STORE_KEY);
|
|
209
|
+
Logger.logDbg('StorageHelper: Cleared visitor store');
|
|
210
|
+
} catch (err) {
|
|
211
|
+
Logger.logError('StorageHelper: Error clearing visitor store', err);
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
// In-memory store for SESSION-scoped values (cleared on app restart)
|
|
216
|
+
_defineProperty(StorageHelper, "sessionStore", {});
|
|
217
|
+
// In-memory cache of visitor store (loaded from AsyncStorage on init)
|
|
218
|
+
_defineProperty(StorageHelper, "visitorStoreCache", {});
|
|
219
|
+
// Flag to track if initialized
|
|
220
|
+
_defineProperty(StorageHelper, "isInitialized", false);
|
|
221
|
+
//# sourceMappingURL=storage-helper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["AsyncStorage","DeStorageDuration","Logger","VISITOR_STORE_KEY","VISITOR_EXPIRY_MS","StorageHelper","initialize","isInitialized","storedData","getItem","visitorStoreCache","JSON","parse","logDbg","Object","keys","length","clearExpiredVisitorData","err","logError","now","Date","keysToRemove","key","entry","timestamp","push","persistVisitorStore","setItem","stringify","isDefined","value","undefined","deStorageDurationSet","deKey","storageDuration","EVENT","SESSION","sessionStore","VISITOR","catch","NONE","deStorageDurationGet","defaultValue","sessionValue","visitorEntry","clearSessionStore","clearVisitorStore","removeItem","_defineProperty"],"sources":["storage-helper.ts"],"sourcesContent":["/**\n * Storage helper for data element storage duration\n * Handles SESSION (in-memory) and VISITOR (AsyncStorage with 30-day expiry) storage\n */\nimport AsyncStorage from '@react-native-async-storage/async-storage';\nimport { DeStorageDuration } from '../models/mp-client-sdk';\nimport { Logger } from './logger';\n\n// AsyncStorage key for visitor-scoped data elements\nconst VISITOR_STORE_KEY = '_mp_de_visitor_store';\n\n// 30 days in milliseconds\nconst VISITOR_EXPIRY_MS = 30 * 24 * 60 * 60 * 1000;\n\n// Interface for stored visitor values (includes timestamp for expiry check)\ninterface StoredVisitorValue {\n value: any;\n timestamp: number;\n}\n\nexport class StorageHelper {\n // In-memory store for SESSION-scoped values (cleared on app restart)\n private static sessionStore: Record<string, any> = {};\n\n // In-memory cache of visitor store (loaded from AsyncStorage on init)\n private static visitorStoreCache: Record<string, StoredVisitorValue> = {};\n\n // Flag to track if initialized\n private static isInitialized = false;\n\n /**\n * Initialize the storage helper\n * Loads visitor store from AsyncStorage and cleans expired values\n * Should be called once during SDK initialization\n */\n static async initialize(): Promise<void> {\n if (this.isInitialized) {\n return;\n }\n\n try {\n // Load visitor store from AsyncStorage\n const storedData = await AsyncStorage.getItem(VISITOR_STORE_KEY);\n if (storedData) {\n this.visitorStoreCache = JSON.parse(storedData);\n Logger.logDbg(\n 'StorageHelper: Loaded visitor store with',\n Object.keys(this.visitorStoreCache).length,\n 'items'\n );\n }\n\n // Clean expired visitor data\n await this.clearExpiredVisitorData();\n\n this.isInitialized = true;\n Logger.logDbg('StorageHelper: Initialized successfully');\n } catch (err) {\n Logger.logError('StorageHelper: Error initializing', err);\n // Reset to empty state on error\n this.visitorStoreCache = {};\n this.isInitialized = true;\n }\n }\n\n /**\n * Clear visitor-scoped values older than 30 days\n */\n static async clearExpiredVisitorData(): Promise<void> {\n try {\n const now = Date.now();\n const keysToRemove: string[] = [];\n\n for (const key of Object.keys(this.visitorStoreCache)) {\n const entry = this.visitorStoreCache[key];\n if (entry && now - entry.timestamp > VISITOR_EXPIRY_MS) {\n keysToRemove.push(key);\n }\n }\n\n if (keysToRemove.length > 0) {\n for (const key of keysToRemove) {\n delete this.visitorStoreCache[key];\n }\n\n // Persist the cleaned store\n await this.persistVisitorStore();\n\n Logger.logDbg(\n 'StorageHelper: Cleared',\n keysToRemove.length,\n 'expired visitor values'\n );\n }\n } catch (err) {\n Logger.logError('StorageHelper: Error clearing expired data', err);\n }\n }\n\n /**\n * Persist the visitor store cache to AsyncStorage\n */\n private static async persistVisitorStore(): Promise<void> {\n try {\n await AsyncStorage.setItem(\n VISITOR_STORE_KEY,\n JSON.stringify(this.visitorStoreCache)\n );\n } catch (err) {\n Logger.logError('StorageHelper: Error persisting visitor store', err);\n }\n }\n\n /**\n * Check if a value is defined (not null, undefined, or empty string)\n */\n private static isDefined(value: any): boolean {\n return value !== null && value !== undefined && value !== '';\n }\n\n /**\n * Store a data element value based on storage duration\n * @param deKey - The data element key\n * @param value - The value to store\n * @param storageDuration - The storage duration type\n */\n static deStorageDurationSet(\n deKey: string,\n value: any,\n storageDuration: DeStorageDuration\n ): void {\n try {\n if (!this.isDefined(deKey) || !this.isDefined(value)) {\n // Key and value are required\n return;\n }\n\n if (!storageDuration) {\n storageDuration = DeStorageDuration.EVENT;\n }\n\n switch (storageDuration) {\n case DeStorageDuration.SESSION:\n // Store in memory (cleared on app restart)\n this.sessionStore[deKey] = value;\n Logger.logDbg('StorageHelper: Stored SESSION value for', deKey);\n break;\n\n case DeStorageDuration.VISITOR:\n // Store in AsyncStorage cache with timestamp\n this.visitorStoreCache[deKey] = {\n value: value,\n timestamp: Date.now(),\n };\n // Persist to AsyncStorage in background\n this.persistVisitorStore().catch((err) => {\n Logger.logError(\n 'StorageHelper: Error persisting visitor value',\n err\n );\n });\n Logger.logDbg('StorageHelper: Stored VISITOR value for', deKey);\n break;\n\n case DeStorageDuration.EVENT:\n case DeStorageDuration.NONE:\n default:\n // No persistence needed for EVENT or NONE\n break;\n }\n } catch (err) {\n Logger.logError('StorageHelper: Error in deStorageDurationSet', err);\n }\n }\n\n /**\n * Retrieve a data element value based on storage duration\n * @param deKey - The data element key\n * @param defaultValue - Default value if not found\n * @param storageDuration - The storage duration type\n * @returns The stored value or default value\n */\n static deStorageDurationGet(\n deKey: string,\n defaultValue: any,\n storageDuration: DeStorageDuration\n ): any {\n try {\n if (!this.isDefined(deKey)) {\n return defaultValue;\n }\n\n if (!storageDuration) {\n storageDuration = DeStorageDuration.EVENT;\n }\n\n switch (storageDuration) {\n case DeStorageDuration.SESSION: {\n // Get from in-memory session store\n const sessionValue = this.sessionStore[deKey];\n if (this.isDefined(sessionValue)) {\n return sessionValue;\n }\n return defaultValue;\n }\n\n case DeStorageDuration.VISITOR: {\n // Get from visitor store cache\n const visitorEntry = this.visitorStoreCache[deKey];\n if (visitorEntry && this.isDefined(visitorEntry.value)) {\n // Check if not expired\n if (Date.now() - visitorEntry.timestamp <= VISITOR_EXPIRY_MS) {\n return visitorEntry.value;\n } else {\n // Value is expired, remove it\n delete this.visitorStoreCache[deKey];\n this.persistVisitorStore().catch((err) => {\n Logger.logError(\n 'StorageHelper: Error removing expired value',\n err\n );\n });\n }\n }\n return defaultValue;\n }\n\n case DeStorageDuration.EVENT:\n case DeStorageDuration.NONE:\n default:\n // No retrieval for EVENT or NONE\n return defaultValue;\n }\n } catch (err) {\n Logger.logError('StorageHelper: Error in deStorageDurationGet', err);\n return defaultValue;\n }\n }\n\n /**\n * Clear all session-scoped values (called on new session if needed)\n */\n static clearSessionStore(): void {\n this.sessionStore = {};\n Logger.logDbg('StorageHelper: Cleared session store');\n }\n\n /**\n * Clear all visitor-scoped values\n */\n static async clearVisitorStore(): Promise<void> {\n try {\n this.visitorStoreCache = {};\n await AsyncStorage.removeItem(VISITOR_STORE_KEY);\n Logger.logDbg('StorageHelper: Cleared visitor store');\n } catch (err) {\n Logger.logError('StorageHelper: Error clearing visitor store', err);\n }\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -5,6 +5,10 @@ import { EventBus } from './event-bus';
|
|
|
5
5
|
import { Dimensions } from 'react-native';
|
|
6
6
|
import { URL } from 'react-native-url-polyfill';
|
|
7
7
|
import AsyncStorage from '@react-native-async-storage/async-storage';
|
|
8
|
+
import { ulid } from 'ulid';
|
|
9
|
+
|
|
10
|
+
/** Maximum payload size in bytes (250KB) to prevent DoS attacks */
|
|
11
|
+
const MAX_PAYLOAD_SIZE_BYTES = 250 * 1024;
|
|
8
12
|
export class Utils {
|
|
9
13
|
static triggerEvent(eventName, payload) {
|
|
10
14
|
EventBus.triggerEvent(eventName, payload);
|
|
@@ -111,7 +115,7 @@ export class Utils {
|
|
|
111
115
|
if (tfItem.eTyp === 'URL_ENC') {
|
|
112
116
|
paramValue = encodeURIComponent(paramValue);
|
|
113
117
|
} else if (tfItem.eTyp === 'BASE64') {
|
|
114
|
-
paramValue =
|
|
118
|
+
paramValue = this.toBase64(paramValue);
|
|
115
119
|
}
|
|
116
120
|
}
|
|
117
121
|
}
|
|
@@ -159,8 +163,65 @@ export class Utils {
|
|
|
159
163
|
Logger.logError('Error executing function: ', err);
|
|
160
164
|
}
|
|
161
165
|
}
|
|
166
|
+
|
|
167
|
+
/**
|
|
168
|
+
* Encode string to Base64 - React Native compatible
|
|
169
|
+
* Works with both ASCII and UTF-8 strings
|
|
170
|
+
* @param str String to encode
|
|
171
|
+
* @returns Base64 encoded string
|
|
172
|
+
*/
|
|
173
|
+
static toBase64(str) {
|
|
174
|
+
try {
|
|
175
|
+
// Handle UTF-8 strings properly using encodeURIComponent + unescape trick
|
|
176
|
+
// This works in all JavaScript engines including React Native's Hermes/JSC
|
|
177
|
+
return btoa(unescape(encodeURIComponent(str)));
|
|
178
|
+
} catch (err) {
|
|
179
|
+
Logger.logError('Error encoding to Base64:', err);
|
|
180
|
+
return str; // Return original value if encoding fails
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
/**
|
|
185
|
+
* Encode an object payload to Base64 string
|
|
186
|
+
* @param payload Object to encode
|
|
187
|
+
* @returns Base64 encoded string, or empty string on error
|
|
188
|
+
*/
|
|
189
|
+
static encodeToBase64(payload) {
|
|
190
|
+
try {
|
|
191
|
+
const jsonStr = JSON.stringify(payload);
|
|
192
|
+
return this.toBase64(jsonStr);
|
|
193
|
+
} catch (err) {
|
|
194
|
+
Logger.logError('Error encoding payload to Base64:', err);
|
|
195
|
+
return '';
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
/**
|
|
200
|
+
* Get the size of a payload in bytes
|
|
201
|
+
* @param payload Object to measure
|
|
202
|
+
* @returns Size in bytes
|
|
203
|
+
*/
|
|
204
|
+
static getPayloadSizeBytes(payload) {
|
|
205
|
+
try {
|
|
206
|
+
const jsonStr = JSON.stringify(payload);
|
|
207
|
+
// Use TextEncoder for accurate byte count (handles UTF-8)
|
|
208
|
+
return new TextEncoder().encode(jsonStr).length;
|
|
209
|
+
} catch (err) {
|
|
210
|
+
Logger.logError('Error calculating payload size:', err);
|
|
211
|
+
return 0;
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
/**
|
|
216
|
+
* Check if payload exceeds the maximum allowed size (250KB)
|
|
217
|
+
* @param payload Object to check
|
|
218
|
+
* @returns True if payload is oversized
|
|
219
|
+
*/
|
|
220
|
+
static isPayloadOversized(payload) {
|
|
221
|
+
return this.getPayloadSizeBytes(payload) > MAX_PAYLOAD_SIZE_BYTES;
|
|
222
|
+
}
|
|
162
223
|
static getUniqueID() {
|
|
163
|
-
return
|
|
224
|
+
return ulid();
|
|
164
225
|
}
|
|
165
226
|
|
|
166
227
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["Constants","Logger","flatten","unflatten","EventBus","Dimensions","URL","AsyncStorage","Utils","triggerEvent","eventName","payload","calculateMsp","dim","limit","scale","width","height","_makeUniqueStringArray","input","Set","parseQueryParamsToObject","url","op","trim","length","urlObject","searchParams","forEach","value","name","err","logError","isTablet","get","sleep","delay","Promise","resolve","setTimeout","dtToNum","deviceType","bwToNum","browser","langToNum","language","mergeMaps","toMerge","mapObject","Object","keys","key","applyTransformationResourceParam","paramValue","tf","tfItem","nm","eTyp","encodeURIComponent","Buffer","from","toString","isMatch","toTest","inputs","ignoreCase","fullMatch","isMatched","i","_val","convertToRegex","test","regExpEscape","replace","RegExp","split","map","join","safeExecute","fn","getUniqueID","LARGE_RANDOM_POOL","getHttp","response","fetch","method","headers","ok","Error","status","json","error","getValueFromAsyncStorage","defaultValue","getItem","JSON","parse","setValueToAsyncStorage","setItem","stringify","getSimpleDebugId","prefix","randomNumber","min","max","Math","ceil","random","unFlattenResourceParams","transformMap","item","pId","children","id","push","values","sort","sortAscending","unFlattenObject","obj","object","delimiter","flattenObject","maxDepth","safe"],"sources":["utils.ts"],"sourcesContent":["import { Constants } from './constants';\nimport { Logger } from './logger';\nimport type {\n BaseResourceParamType,\n SdkParamEncodingTransformer,\n TFType,\n} from '../models/mp-client-sdk';\nimport type { MapLike } from './app-types';\nimport { flatten, unflatten } from 'flat';\nimport { EventBus } from './event-bus';\nimport { Dimensions, ScaledSize } from 'react-native';\nimport { URL } from 'react-native-url-polyfill';\nimport AsyncStorage from '@react-native-async-storage/async-storage';\n\nexport class Utils {\n static triggerEvent(eventName: string, payload: any): void {\n EventBus.triggerEvent(eventName, payload);\n }\n\n static calculateMsp(dim: ScaledSize, limit: number): boolean {\n return dim.scale * dim.width >= limit || dim.scale * dim.height >= limit;\n }\n\n static _makeUniqueStringArray(input: string[]): string[] {\n return [...new Set(input)];\n }\n\n static parseQueryParamsToObject(url?: string): Record<string, any> {\n const op: Record<string, any> = {};\n try {\n if (url && url?.trim().length > 0) {\n const urlObject = new URL(url);\n urlObject.searchParams.forEach((value, name) => {\n op[name] = value;\n });\n }\n } catch (err) {\n // TODO: Report error\n Logger.logError('Unable to parse query params', err);\n }\n return op;\n }\n\n static isTablet(): boolean {\n const dim = Dimensions.get('screen');\n return (\n (dim.scale < 2 && this.calculateMsp(dim, 1000)) ||\n (dim.scale >= 2 && this.calculateMsp(dim, 1900))\n );\n }\n\n static sleep(delay = 1000): Promise<void> {\n return new Promise((resolve: (val?: any) => void) => {\n setTimeout(() => {\n return resolve();\n }, delay);\n });\n }\n\n /**\n * deviceTypesMappings = {'1':'Desktop Web','2':'Mobile Web','3':'Tablet','4':'Other'};\n * @param deviceType\n */\n static dtToNum(deviceType: string): number {\n switch (deviceType) {\n case 'desktop':\n return 1;\n case 'mobile':\n return 2;\n case 'tablet':\n return 3;\n default:\n return 4;\n }\n }\n\n /**\n * static browserToOsMappings = {'101': 'ios','102': 'android', '7': 'Other'};\n * @param browser\n */\n static bwToNum(browser: string): number {\n switch (browser) {\n case 'ios':\n return 101;\n case 'android':\n return 102;\n default:\n return 7;\n }\n }\n\n static langToNum(language: string): number {\n if (language === 'en') {\n return 1;\n } else if (language === 'es') {\n return 2;\n } else {\n return 3;\n }\n }\n\n static mergeMaps<T>(\n input: MapLike<T>,\n ...toMerge: Array<MapLike<T>>\n ): MapLike<T> {\n if (!input) {\n input = {} as MapLike<T>;\n }\n for (const mapObject of toMerge) {\n if (mapObject) {\n Object.keys(mapObject).forEach((key: string) => {\n input[key] = mapObject[key];\n });\n }\n }\n return input;\n }\n\n static applyTransformationResourceParam(\n paramValue: string,\n tf: TFType | undefined\n ): any {\n if (!tf || tf.length === 0) {\n return paramValue;\n }\n\n if (typeof paramValue === 'undefined') {\n return paramValue;\n }\n\n // transformers here are expected to be ordered when we get it from the server after build\n for (let tfItem of tf) {\n if (tfItem.nm === 'enc') {\n // only url encode is implemented now\n tfItem = tfItem as SdkParamEncodingTransformer;\n if (tfItem.eTyp === 'URL_ENC') {\n paramValue = encodeURIComponent(paramValue);\n } else if (tfItem.eTyp === 'BASE64') {\n paramValue = Buffer.from(paramValue).toString('base64');\n }\n }\n }\n\n return paramValue;\n }\n\n /**\n * Verifies if the given 'toTest' string exists in any of the input array of strings.\n * By default, this method does a case sensitive match unless specified by the ignoreCase param.\n * @param toTest\n * @param inputs\n * @param ignoreCase - pass a value of 'true' to perform case-insensitive matching.\n * @param fullMatch\n */\n static isMatch(\n toTest: string,\n inputs: string[],\n ignoreCase: boolean,\n fullMatch: boolean\n ): boolean {\n if (!toTest) {\n return false;\n }\n let isMatched = false;\n for (let i = 0; i < inputs.length; i += 1) {\n const _val = inputs[i];\n if (_val) {\n if (this.convertToRegex(_val, ignoreCase, fullMatch).test(toTest)) {\n isMatched = true;\n break;\n }\n }\n }\n return isMatched;\n }\n\n static regExpEscape(input: string): string {\n return input.replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&');\n }\n\n static convertToRegex(\n input: string,\n ignoreCase: boolean,\n fullMatch: boolean\n ): RegExp {\n if (fullMatch) {\n return new RegExp(\n '^' + input.split(/\\*+/).map(this.regExpEscape).join('.*') + '$',\n ignoreCase ? 'i' : ''\n );\n } else {\n return new RegExp(\n input.split(/\\*+/).map(this.regExpEscape).join('.*'),\n ignoreCase ? 'i' : ''\n );\n }\n }\n\n static safeExecute(fn: (payload: any) => any, payload: any): any {\n try {\n return fn(payload);\n } catch (err) {\n Logger.logError('Error executing function: ', err);\n }\n }\n\n static getUniqueID(): string {\n return Constants.LARGE_RANDOM_POOL();\n }\n\n /**\n * Make HTTP GET request - React Native implementation\n * @param url URL to fetch\n * @returns Promise with response data\n */\n static async getHttp<T>(url: string): Promise<T> {\n try {\n const response = await fetch(url, {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json',\n },\n });\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n\n return await response.json();\n } catch (error) {\n Logger.logError('HTTP GET request failed:', error);\n throw error;\n }\n }\n\n /**\n * Get value from AsyncStorage (React Native equivalent of sessionStorage)\n * @param key Storage key\n * @param defaultValue Default value if key not found\n * @returns Promise with stored value or default\n */\n static async getValueFromAsyncStorage<T>(\n key: string,\n defaultValue: T\n ): Promise<T> {\n try {\n const value = await AsyncStorage.getItem(key);\n return value ? JSON.parse(value) : defaultValue;\n } catch (error) {\n Logger.logError('Error getting value from AsyncStorage:', error);\n return defaultValue;\n }\n }\n\n /**\n * Set value to AsyncStorage (React Native equivalent of sessionStorage)\n * @param key Storage key\n * @param value Value to store\n */\n static async setValueToAsyncStorage(key: string, value: any): Promise<void> {\n try {\n await AsyncStorage.setItem(key, JSON.stringify(value));\n } catch (error) {\n Logger.logError('Error setting value to AsyncStorage:', error);\n }\n }\n\n static getSimpleDebugId(prefix?: string): string {\n return `${prefix ?? ''}${this.randomNumber(100000000, 99999999999)}`;\n }\n\n static randomNumber(min: number, max: number): number {\n return Math.ceil(Math.random() * (max - min) + min);\n }\n\n static unFlattenResourceParams<T extends BaseResourceParamType>(\n input: T[]\n ): MapLike<T> {\n if (!input || input.length === 0) {\n return {};\n }\n\n const transformMap: MapLike<T> = {};\n const op: MapLike<T> = {};\n // convert input into a map for quick search O(1)\n for (const item of input) {\n if (item.pId) {\n if (!transformMap[item.pId]) {\n item.children = [];\n transformMap[item.id] = item;\n } else {\n transformMap[item.pId].children.push(item);\n }\n } else {\n item.children = [];\n transformMap[item.id] = item;\n }\n }\n\n // sort children according to child_order inside children if they have any children\n for (const item of Object.values(transformMap)) {\n if (item.children && item.children.length > 0) {\n item.children = item.children.sort(Constants.sortAscending);\n op[item.nm] = item;\n } else {\n op[item.nm] = item;\n }\n }\n\n return op;\n }\n\n static unFlattenObject(obj: any): Record<string, any> {\n if (!obj) {\n return {};\n }\n return unflatten(obj, { object: false, delimiter: '.' });\n }\n\n static flattenObject(obj: any): Record<string, any> {\n if (!obj) {\n return {};\n }\n return flatten(obj, { maxDepth: 5, safe: true });\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["Constants","Logger","flatten","unflatten","EventBus","Dimensions","URL","AsyncStorage","ulid","MAX_PAYLOAD_SIZE_BYTES","Utils","triggerEvent","eventName","payload","calculateMsp","dim","limit","scale","width","height","_makeUniqueStringArray","input","Set","parseQueryParamsToObject","url","op","trim","length","urlObject","searchParams","forEach","value","name","err","logError","isTablet","get","sleep","delay","Promise","resolve","setTimeout","dtToNum","deviceType","bwToNum","browser","langToNum","language","mergeMaps","toMerge","mapObject","Object","keys","key","applyTransformationResourceParam","paramValue","tf","tfItem","nm","eTyp","encodeURIComponent","toBase64","isMatch","toTest","inputs","ignoreCase","fullMatch","isMatched","i","_val","convertToRegex","test","regExpEscape","replace","RegExp","split","map","join","safeExecute","fn","str","btoa","unescape","encodeToBase64","jsonStr","JSON","stringify","getPayloadSizeBytes","TextEncoder","encode","isPayloadOversized","getUniqueID","getHttp","response","fetch","method","headers","ok","Error","status","json","error","getValueFromAsyncStorage","defaultValue","getItem","parse","setValueToAsyncStorage","setItem","getSimpleDebugId","prefix","randomNumber","min","max","Math","ceil","random","unFlattenResourceParams","transformMap","item","pId","children","id","push","values","sort","sortAscending","unFlattenObject","obj","object","delimiter","flattenObject","maxDepth","safe"],"sources":["utils.ts"],"sourcesContent":["import { Constants } from './constants';\nimport { Logger } from './logger';\nimport type {\n BaseResourceParamType,\n SdkParamEncodingTransformer,\n TFType,\n} from '../models/mp-client-sdk';\nimport type { MapLike } from './app-types';\nimport { flatten, unflatten } from 'flat';\nimport { EventBus } from './event-bus';\nimport { Dimensions, ScaledSize } from 'react-native';\nimport { URL } from 'react-native-url-polyfill';\nimport AsyncStorage from '@react-native-async-storage/async-storage';\nimport { ulid } from 'ulid';\n\n/** Maximum payload size in bytes (250KB) to prevent DoS attacks */\nconst MAX_PAYLOAD_SIZE_BYTES = 250 * 1024;\n\nexport class Utils {\n static triggerEvent(eventName: string, payload: any): void {\n EventBus.triggerEvent(eventName, payload);\n }\n\n static calculateMsp(dim: ScaledSize, limit: number): boolean {\n return dim.scale * dim.width >= limit || dim.scale * dim.height >= limit;\n }\n\n static _makeUniqueStringArray(input: string[]): string[] {\n return [...new Set(input)];\n }\n\n static parseQueryParamsToObject(url?: string): Record<string, any> {\n const op: Record<string, any> = {};\n try {\n if (url && url?.trim().length > 0) {\n const urlObject = new URL(url);\n urlObject.searchParams.forEach((value, name) => {\n op[name] = value;\n });\n }\n } catch (err) {\n // TODO: Report error\n Logger.logError('Unable to parse query params', err);\n }\n return op;\n }\n\n static isTablet(): boolean {\n const dim = Dimensions.get('screen');\n return (\n (dim.scale < 2 && this.calculateMsp(dim, 1000)) ||\n (dim.scale >= 2 && this.calculateMsp(dim, 1900))\n );\n }\n\n static sleep(delay = 1000): Promise<void> {\n return new Promise((resolve: (val?: any) => void) => {\n setTimeout(() => {\n return resolve();\n }, delay);\n });\n }\n\n /**\n * deviceTypesMappings = {'1':'Desktop Web','2':'Mobile Web','3':'Tablet','4':'Other'};\n * @param deviceType\n */\n static dtToNum(deviceType: string): number {\n switch (deviceType) {\n case 'desktop':\n return 1;\n case 'mobile':\n return 2;\n case 'tablet':\n return 3;\n default:\n return 4;\n }\n }\n\n /**\n * static browserToOsMappings = {'101': 'ios','102': 'android', '7': 'Other'};\n * @param browser\n */\n static bwToNum(browser: string): number {\n switch (browser) {\n case 'ios':\n return 101;\n case 'android':\n return 102;\n default:\n return 7;\n }\n }\n\n static langToNum(language: string): number {\n if (language === 'en') {\n return 1;\n } else if (language === 'es') {\n return 2;\n } else {\n return 3;\n }\n }\n\n static mergeMaps<T>(\n input: MapLike<T>,\n ...toMerge: Array<MapLike<T>>\n ): MapLike<T> {\n if (!input) {\n input = {} as MapLike<T>;\n }\n for (const mapObject of toMerge) {\n if (mapObject) {\n Object.keys(mapObject).forEach((key: string) => {\n input[key] = mapObject[key];\n });\n }\n }\n return input;\n }\n\n static applyTransformationResourceParam(\n paramValue: string,\n tf: TFType | undefined\n ): any {\n if (!tf || tf.length === 0) {\n return paramValue;\n }\n\n if (typeof paramValue === 'undefined') {\n return paramValue;\n }\n\n // transformers here are expected to be ordered when we get it from the server after build\n for (let tfItem of tf) {\n if (tfItem.nm === 'enc') {\n // only url encode is implemented now\n tfItem = tfItem as SdkParamEncodingTransformer;\n if (tfItem.eTyp === 'URL_ENC') {\n paramValue = encodeURIComponent(paramValue);\n } else if (tfItem.eTyp === 'BASE64') {\n paramValue = this.toBase64(paramValue);\n }\n }\n }\n\n return paramValue;\n }\n\n /**\n * Verifies if the given 'toTest' string exists in any of the input array of strings.\n * By default, this method does a case sensitive match unless specified by the ignoreCase param.\n * @param toTest\n * @param inputs\n * @param ignoreCase - pass a value of 'true' to perform case-insensitive matching.\n * @param fullMatch\n */\n static isMatch(\n toTest: string,\n inputs: string[],\n ignoreCase: boolean,\n fullMatch: boolean\n ): boolean {\n if (!toTest) {\n return false;\n }\n let isMatched = false;\n for (let i = 0; i < inputs.length; i += 1) {\n const _val = inputs[i];\n if (_val) {\n if (this.convertToRegex(_val, ignoreCase, fullMatch).test(toTest)) {\n isMatched = true;\n break;\n }\n }\n }\n return isMatched;\n }\n\n static regExpEscape(input: string): string {\n return input.replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&');\n }\n\n static convertToRegex(\n input: string,\n ignoreCase: boolean,\n fullMatch: boolean\n ): RegExp {\n if (fullMatch) {\n return new RegExp(\n '^' + input.split(/\\*+/).map(this.regExpEscape).join('.*') + '$',\n ignoreCase ? 'i' : ''\n );\n } else {\n return new RegExp(\n input.split(/\\*+/).map(this.regExpEscape).join('.*'),\n ignoreCase ? 'i' : ''\n );\n }\n }\n\n static safeExecute(fn: (payload: any) => any, payload: any): any {\n try {\n return fn(payload);\n } catch (err) {\n Logger.logError('Error executing function: ', err);\n }\n }\n\n /**\n * Encode string to Base64 - React Native compatible\n * Works with both ASCII and UTF-8 strings\n * @param str String to encode\n * @returns Base64 encoded string\n */\n static toBase64(str: string): string {\n try {\n // Handle UTF-8 strings properly using encodeURIComponent + unescape trick\n // This works in all JavaScript engines including React Native's Hermes/JSC\n return btoa(unescape(encodeURIComponent(str)));\n } catch (err) {\n Logger.logError('Error encoding to Base64:', err);\n return str; // Return original value if encoding fails\n }\n }\n\n /**\n * Encode an object payload to Base64 string\n * @param payload Object to encode\n * @returns Base64 encoded string, or empty string on error\n */\n static encodeToBase64(payload: Record<string, any>): string {\n try {\n const jsonStr = JSON.stringify(payload);\n return this.toBase64(jsonStr);\n } catch (err) {\n Logger.logError('Error encoding payload to Base64:', err);\n return '';\n }\n }\n\n /**\n * Get the size of a payload in bytes\n * @param payload Object to measure\n * @returns Size in bytes\n */\n static getPayloadSizeBytes(payload: Record<string, any>): number {\n try {\n const jsonStr = JSON.stringify(payload);\n // Use TextEncoder for accurate byte count (handles UTF-8)\n return new TextEncoder().encode(jsonStr).length;\n } catch (err) {\n Logger.logError('Error calculating payload size:', err);\n return 0;\n }\n }\n\n /**\n * Check if payload exceeds the maximum allowed size (250KB)\n * @param payload Object to check\n * @returns True if payload is oversized\n */\n static isPayloadOversized(payload: Record<string, any>): boolean {\n return this.getPayloadSizeBytes(payload) > MAX_PAYLOAD_SIZE_BYTES;\n }\n\n static getUniqueID(): string {\n return ulid();\n }\n\n /**\n * Make HTTP GET request - React Native implementation\n * @param url URL to fetch\n * @returns Promise with response data\n */\n static async getHttp<T>(url: string): Promise<T> {\n try {\n const response = await fetch(url, {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json',\n },\n });\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n\n return await response.json();\n } catch (error) {\n Logger.logError('HTTP GET request failed:', error);\n throw error;\n }\n }\n\n /**\n * Get value from AsyncStorage (React Native equivalent of sessionStorage)\n * @param key Storage key\n * @param defaultValue Default value if key not found\n * @returns Promise with stored value or default\n */\n static async getValueFromAsyncStorage<T>(\n key: string,\n defaultValue: T\n ): Promise<T> {\n try {\n const value = await AsyncStorage.getItem(key);\n return value ? JSON.parse(value) : defaultValue;\n } catch (error) {\n Logger.logError('Error getting value from AsyncStorage:', error);\n return defaultValue;\n }\n }\n\n /**\n * Set value to AsyncStorage (React Native equivalent of sessionStorage)\n * @param key Storage key\n * @param value Value to store\n */\n static async setValueToAsyncStorage(key: string, value: any): Promise<void> {\n try {\n await AsyncStorage.setItem(key, JSON.stringify(value));\n } catch (error) {\n Logger.logError('Error setting value to AsyncStorage:', error);\n }\n }\n\n static getSimpleDebugId(prefix?: string): string {\n return `${prefix ?? ''}${this.randomNumber(100000000, 99999999999)}`;\n }\n\n static randomNumber(min: number, max: number): number {\n return Math.ceil(Math.random() * (max - min) + min);\n }\n\n static unFlattenResourceParams<T extends BaseResourceParamType>(\n input: T[]\n ): MapLike<T> {\n if (!input || input.length === 0) {\n return {};\n }\n\n const transformMap: MapLike<T> = {};\n const op: MapLike<T> = {};\n // convert input into a map for quick search O(1)\n for (const item of input) {\n if (item.pId) {\n if (!transformMap[item.pId]) {\n item.children = [];\n transformMap[item.id] = item;\n } else {\n transformMap[item.pId].children.push(item);\n }\n } else {\n item.children = [];\n transformMap[item.id] = item;\n }\n }\n\n // sort children according to child_order inside children if they have any children\n for (const item of Object.values(transformMap)) {\n if (item.children && item.children.length > 0) {\n item.children = item.children.sort(Constants.sortAscending);\n op[item.nm] = item;\n } else {\n op[item.nm] = item;\n }\n }\n\n return op;\n }\n\n static unFlattenObject(obj: any): Record<string, any> {\n if (!obj) {\n return {};\n }\n return unflatten(obj, { object: false, delimiter: '.' });\n }\n\n static flattenObject(obj: any): Record<string, any> {\n if (!obj) {\n return {};\n }\n return flatten(obj, { maxDepth: 5, safe: true });\n }\n}\n"],"mappings":"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","ignoreList":[]}
|