@adtrackify/at-service-common 3.4.13 → 3.5.1
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/dist/cjs/services/db/identity-cache-db-service.d.ts +6 -3
- package/dist/cjs/services/db/identity-cache-db-service.js +117 -108
- package/dist/cjs/services/db/identity-cache-db-service.js.map +1 -1
- package/dist/esm/services/db/identity-cache-db-service.d.ts +6 -3
- package/dist/esm/services/db/identity-cache-db-service.js +117 -108
- package/dist/esm/services/db/identity-cache-db-service.js.map +1 -1
- package/package.json +1 -1
|
@@ -13,12 +13,15 @@ export declare class IdentityCacheDbService {
|
|
|
13
13
|
private lambdaInvokeClient;
|
|
14
14
|
constructor(cacheLambdaFunctionArn: string, identifyPrivateLambdaArn: string);
|
|
15
15
|
getIdentityWithCaching: (pixelId: string, incomingIdentity?: EventIdentity) => Promise<EventIdentity | undefined>;
|
|
16
|
-
|
|
17
|
-
|
|
16
|
+
identifyPrivateLambda(pixelId: string, incomingIdentity: EventIdentity): Promise<{
|
|
17
|
+
resolvedIdentity?: EventIdentity;
|
|
18
|
+
}>;
|
|
18
19
|
getIdentityFromCache(pixelId: string, incomingIdentity: EventIdentity): Promise<{
|
|
19
20
|
resolvedIdentity: EventIdentity | undefined;
|
|
20
|
-
|
|
21
|
+
isCacheStale: boolean;
|
|
21
22
|
}>;
|
|
22
23
|
deleteIdentityCache(pixelId: string, incomingIdentity: EventIdentity, resolvedIdentity: EventIdentity): Promise<void>;
|
|
23
24
|
private deleteIdentityCacheRedis;
|
|
25
|
+
private getIdentityCache;
|
|
26
|
+
updateIdentityCacheRedis: (pixelId: string, request: EventIdentity, response: EventIdentity) => Promise<import("../../clients").CacheRequestCommandResponse[] | undefined>;
|
|
24
27
|
}
|
|
@@ -25,23 +25,22 @@ class IdentityCacheDbService {
|
|
|
25
25
|
helpers_1.Logger.error('getIdentityWithCaching -No pixelId or incomingIdentity', { pixelId, incomingIdentity });
|
|
26
26
|
return undefined;
|
|
27
27
|
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
}
|
|
28
|
+
const cacheResponse = await this.getIdentityFromCache(pixelId, incomingIdentity);
|
|
29
|
+
let resolvedIdentity = cacheResponse?.resolvedIdentity;
|
|
30
|
+
const isCacheStale = cacheResponse?.isCacheStale;
|
|
31
|
+
if (resolvedIdentity && !isCacheStale) {
|
|
32
|
+
helpers_1.Logger.debug('identity cache hit', { incomingIdentity });
|
|
33
|
+
return resolvedIdentity;
|
|
34
|
+
}
|
|
35
|
+
helpers_1.Logger.debug('identity cache stale - fetching from identity service', { incomingIdentity });
|
|
36
|
+
const response = await this.identifyPrivateLambda(pixelId, incomingIdentity);
|
|
37
|
+
if (response?.resolvedIdentity) {
|
|
38
|
+
resolvedIdentity = response.resolvedIdentity;
|
|
40
39
|
}
|
|
41
40
|
else {
|
|
42
|
-
helpers_1.Logger.
|
|
41
|
+
helpers_1.Logger.error('Failed to getIdentity from identifyPrivateLambda', { response, pixelId, incomingIdentity, identifyPrivateLambdaArn: this.identifyPrivateLambdaArn });
|
|
43
42
|
}
|
|
44
|
-
if (
|
|
43
|
+
if (isCacheStale && resolvedIdentity) {
|
|
45
44
|
await this.updateIdentityCacheRedis(pixelId, incomingIdentity, resolvedIdentity);
|
|
46
45
|
}
|
|
47
46
|
if (!resolvedIdentity) {
|
|
@@ -54,109 +53,55 @@ class IdentityCacheDbService {
|
|
|
54
53
|
return undefined;
|
|
55
54
|
}
|
|
56
55
|
};
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
response,
|
|
64
|
-
updatedAt: (0, libs_1.getCurrentTimestamp)(),
|
|
65
|
-
};
|
|
66
|
-
const setCacheCommands = [];
|
|
67
|
-
const cacheKey = `identId_${pixelId}_${response.identityId}`;
|
|
68
|
-
setCacheCommands.push({
|
|
69
|
-
cacheKey,
|
|
70
|
-
commandType: 'set',
|
|
71
|
-
data: JSON.stringify(identityCache),
|
|
72
|
-
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
73
|
-
});
|
|
74
|
-
if (request?.identityId) {
|
|
75
|
-
const cacheKey = `identId_${pixelId}_${request.identityId}`;
|
|
76
|
-
setCacheCommands.push({
|
|
77
|
-
cacheKey,
|
|
78
|
-
commandType: 'set',
|
|
79
|
-
data: JSON.stringify(identityCache),
|
|
80
|
-
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
if (response?.traits?.emails && response?.traits?.emails?.length > 0) {
|
|
84
|
-
for (let i = 0; i < response.traits.emails.length; i++) {
|
|
85
|
-
const cacheKey = `identEmail_${pixelId}_${response.traits.emails[i]}`;
|
|
86
|
-
setCacheCommands.push({
|
|
87
|
-
cacheKey,
|
|
88
|
-
commandType: 'set',
|
|
89
|
-
data: JSON.stringify(identityCache),
|
|
90
|
-
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
if (response?.traits?.userIds && response?.traits?.userIds?.length > 0) {
|
|
95
|
-
for (let i = 0; i < response.traits.userIds.length; i++) {
|
|
96
|
-
const cacheKey = `identUserId_${pixelId}_${response.traits.userIds[i]}`;
|
|
97
|
-
setCacheCommands.push({
|
|
98
|
-
cacheKey,
|
|
99
|
-
commandType: 'set',
|
|
100
|
-
data: JSON.stringify(identityCache),
|
|
101
|
-
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
102
|
-
});
|
|
56
|
+
async identifyPrivateLambda(pixelId, incomingIdentity) {
|
|
57
|
+
try {
|
|
58
|
+
const response = await this.lambdaInvokeClient.invokeFunction(this.identifyPrivateLambdaArn, { pixelId, context: { identity: incomingIdentity } });
|
|
59
|
+
if (response?.statusCode === 200 && response?.body) {
|
|
60
|
+
const identifyResponse = JSON.parse(response.body);
|
|
61
|
+
return identifyResponse?.identity;
|
|
103
62
|
}
|
|
63
|
+
return { resolvedIdentity: undefined };
|
|
104
64
|
}
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
helpers_1.Logger.debug('updated identity cache', { res, duration: end - start });
|
|
109
|
-
return res;
|
|
110
|
-
};
|
|
111
|
-
getIdentityCache = async (cacheKey) => {
|
|
112
|
-
const start = performance.now();
|
|
113
|
-
const cacheResponse = await this.cacheLambdaClient.invokeGet(cacheKey);
|
|
114
|
-
const end = performance.now();
|
|
115
|
-
helpers_1.Logger.debug('getIdentityCache', { cacheKey, cacheResponse, duration: end - start });
|
|
116
|
-
if (cacheResponse && cacheResponse.responseData) {
|
|
117
|
-
return cacheResponse.responseData;
|
|
65
|
+
catch (err) {
|
|
66
|
+
helpers_1.Logger.error('Error while identifying private lambda', { err });
|
|
67
|
+
return { resolvedIdentity: undefined };
|
|
118
68
|
}
|
|
119
|
-
|
|
120
|
-
};
|
|
69
|
+
}
|
|
121
70
|
async getIdentityFromCache(pixelId, incomingIdentity) {
|
|
122
71
|
try {
|
|
123
|
-
if (!pixelId || !incomingIdentity) {
|
|
124
|
-
return { resolvedIdentity: undefined,
|
|
72
|
+
if (!pixelId || !incomingIdentity || !incomingIdentity?.identityId) {
|
|
73
|
+
return { resolvedIdentity: undefined, isCacheStale: true };
|
|
74
|
+
}
|
|
75
|
+
let isCacheStale = true;
|
|
76
|
+
const cacheKey = `identId_${pixelId}_${incomingIdentity.identityId}`;
|
|
77
|
+
helpers_1.Logger.debug(' try lookup with identityId', { cacheKey });
|
|
78
|
+
const cachedIdentity = await this.getIdentityCache(cacheKey);
|
|
79
|
+
if (!cachedIdentity) {
|
|
80
|
+
return { resolvedIdentity: undefined, isCacheStale: true };
|
|
81
|
+
}
|
|
82
|
+
helpers_1.Logger.debug(' found cached identity', { cacheKey, cachedIdentity });
|
|
83
|
+
const resolvedIdentity = cachedIdentity.response;
|
|
84
|
+
const identityStaleCacheTracker = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
|
|
85
|
+
const isDeepEqual = (0, fast_deep_equal_1.default)(cachedIdentity.response, incomingIdentity);
|
|
86
|
+
isCacheStale = identityStaleCacheTracker.isCacheStale;
|
|
87
|
+
if (isDeepEqual) {
|
|
88
|
+
helpers_1.Logger.warn('identity cache is deep equal', { pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker, isCacheStale });
|
|
89
|
+
isCacheStale = false;
|
|
125
90
|
}
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
helpers_1.Logger.
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
const isDeepEqual = (0, fast_deep_equal_1.default)(cachedIdentity.response, incomingIdentity);
|
|
137
|
-
if (isDeepEqual) {
|
|
138
|
-
helpers_1.Logger.warn('identity cache is deep equal', { pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker });
|
|
139
|
-
}
|
|
140
|
-
else {
|
|
141
|
-
helpers_1.Logger.warn('identity cache is not deep equal', { pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker });
|
|
142
|
-
updateCache = true;
|
|
143
|
-
}
|
|
144
|
-
const isCacheStale = identityStaleCacheTracker.isCacheStale;
|
|
145
|
-
if (isCacheStale) {
|
|
146
|
-
helpers_1.Logger.warn('identity cache stale', { isCacheStale, isDeepEqual, pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker });
|
|
147
|
-
updateCache = true;
|
|
148
|
-
}
|
|
149
|
-
else {
|
|
150
|
-
helpers_1.Logger.warn('identity cache not stale', { isCacheStale, isDeepEqual, pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker });
|
|
151
|
-
updateCache = false;
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
return { resolvedIdentity, updateCache };
|
|
91
|
+
else {
|
|
92
|
+
helpers_1.Logger.debug('identity cache is not deep equal', { pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker, isCacheStale });
|
|
93
|
+
}
|
|
94
|
+
if (isCacheStale) {
|
|
95
|
+
helpers_1.Logger.warn('identity cache stale', { isCacheStale, isDeepEqual, pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker });
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
helpers_1.Logger.warn('identity cache not stale', { isCacheStale, isDeepEqual, pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker });
|
|
99
|
+
}
|
|
100
|
+
return { resolvedIdentity, isCacheStale };
|
|
156
101
|
}
|
|
157
102
|
catch (err) {
|
|
158
103
|
helpers_1.Logger.error('Error while getting identity from cache', { err });
|
|
159
|
-
return { resolvedIdentity: undefined,
|
|
104
|
+
return { resolvedIdentity: undefined, isCacheStale: true };
|
|
160
105
|
}
|
|
161
106
|
}
|
|
162
107
|
async deleteIdentityCache(pixelId, incomingIdentity, resolvedIdentity) {
|
|
@@ -216,6 +161,70 @@ class IdentityCacheDbService {
|
|
|
216
161
|
helpers_1.Logger.error('Error while deleting identity cache', { err });
|
|
217
162
|
}
|
|
218
163
|
}
|
|
164
|
+
getIdentityCache = async (cacheKey) => {
|
|
165
|
+
const start = performance.now();
|
|
166
|
+
const cacheResponse = await this.cacheLambdaClient.invokeGet(cacheKey);
|
|
167
|
+
const end = performance.now();
|
|
168
|
+
helpers_1.Logger.debug('getIdentityCache', { cacheKey, cacheResponse, duration: end - start });
|
|
169
|
+
if (cacheResponse && cacheResponse.responseData) {
|
|
170
|
+
return cacheResponse.responseData;
|
|
171
|
+
}
|
|
172
|
+
return undefined;
|
|
173
|
+
};
|
|
174
|
+
updateIdentityCacheRedis = async (pixelId, request, response) => {
|
|
175
|
+
if (!response || !response.identityId || !pixelId) {
|
|
176
|
+
return;
|
|
177
|
+
}
|
|
178
|
+
const identityCache = {
|
|
179
|
+
identityId: response.identityId,
|
|
180
|
+
response,
|
|
181
|
+
updatedAt: (0, libs_1.getCurrentTimestamp)(),
|
|
182
|
+
};
|
|
183
|
+
const setCacheCommands = [];
|
|
184
|
+
const cacheKey = `identId_${pixelId}_${response.identityId}`;
|
|
185
|
+
setCacheCommands.push({
|
|
186
|
+
cacheKey,
|
|
187
|
+
commandType: 'set',
|
|
188
|
+
data: JSON.stringify(identityCache),
|
|
189
|
+
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
190
|
+
});
|
|
191
|
+
if (request?.identityId) {
|
|
192
|
+
const cacheKey = `identId_${pixelId}_${request.identityId}`;
|
|
193
|
+
setCacheCommands.push({
|
|
194
|
+
cacheKey,
|
|
195
|
+
commandType: 'set',
|
|
196
|
+
data: JSON.stringify(identityCache),
|
|
197
|
+
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
198
|
+
});
|
|
199
|
+
}
|
|
200
|
+
if (response?.traits?.emails && response?.traits?.emails?.length > 0) {
|
|
201
|
+
for (let i = 0; i < response.traits.emails.length; i++) {
|
|
202
|
+
const cacheKey = `identEmail_${pixelId}_${response.traits.emails[i]}`;
|
|
203
|
+
setCacheCommands.push({
|
|
204
|
+
cacheKey,
|
|
205
|
+
commandType: 'set',
|
|
206
|
+
data: JSON.stringify(identityCache),
|
|
207
|
+
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
if (response?.traits?.userIds && response?.traits?.userIds?.length > 0) {
|
|
212
|
+
for (let i = 0; i < response.traits.userIds.length; i++) {
|
|
213
|
+
const cacheKey = `identUserId_${pixelId}_${response.traits.userIds[i]}`;
|
|
214
|
+
setCacheCommands.push({
|
|
215
|
+
cacheKey,
|
|
216
|
+
commandType: 'set',
|
|
217
|
+
data: JSON.stringify(identityCache),
|
|
218
|
+
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
219
|
+
});
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
const start = performance.now();
|
|
223
|
+
const res = await this.cacheLambdaClient.batchInvoke(setCacheCommands);
|
|
224
|
+
const end = performance.now();
|
|
225
|
+
helpers_1.Logger.debug('updated identity cache', { res, duration: end - start });
|
|
226
|
+
return res;
|
|
227
|
+
};
|
|
219
228
|
}
|
|
220
229
|
exports.IdentityCacheDbService = IdentityCacheDbService;
|
|
221
230
|
//# sourceMappingURL=identity-cache-db-service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"identity-cache-db-service.js","sourceRoot":"","sources":["../../../../src/services/db/identity-cache-db-service.ts"],"names":[],"mappings":";;;;;;AACA,2CAA2F;AAC3F,qCAAiD;AACjD,2CAAuC;AAEvC,+EAA2E;AAC3E,sEAA4C;AAW5C,MAAM,6BAA6B,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;AAE5D,MAAa,sBAAsB;IACzB,iBAAiB,CAAoB;IACrC,wBAAwB,CAAS;IACjC,kBAAkB,CAAqB;IAE/C,YAAY,sBAA8B,EAAE,wBAAgC;QAC1E,IAAI,CAAC,iBAAiB,GAAG,IAAI,2BAAiB,CAAC,sBAAsB,CAAC,CAAC;QACvE,IAAI,CAAC,wBAAwB,GAAG,wBAAwB,CAAC;QACzD,IAAI,CAAC,kBAAkB,GAAG,IAAI,4BAAkB,EAAE,CAAC;IACrD,CAAC;IAEM,sBAAsB,GAAG,KAAK,EAAE,OAAe,EAAE,mBAAkC,EAAE,EAAE,EAAE;QAC9F,IAAI;YACF,IAAI,CAAC,OAAO,IAAI,CAAC,gBAAgB,EAAE;gBACjC,gBAAM,CAAC,KAAK,CAAC,wDAAwD,EAAE,EAAE,OAAO,EAAE,gBAAgB,EAAE,CAAC,CAAC;gBACtG,OAAO,SAAS,CAAC;aAClB;YACD,
|
|
1
|
+
{"version":3,"file":"identity-cache-db-service.js","sourceRoot":"","sources":["../../../../src/services/db/identity-cache-db-service.ts"],"names":[],"mappings":"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"}
|
|
@@ -13,12 +13,15 @@ export declare class IdentityCacheDbService {
|
|
|
13
13
|
private lambdaInvokeClient;
|
|
14
14
|
constructor(cacheLambdaFunctionArn: string, identifyPrivateLambdaArn: string);
|
|
15
15
|
getIdentityWithCaching: (pixelId: string, incomingIdentity?: EventIdentity) => Promise<EventIdentity | undefined>;
|
|
16
|
-
|
|
17
|
-
|
|
16
|
+
identifyPrivateLambda(pixelId: string, incomingIdentity: EventIdentity): Promise<{
|
|
17
|
+
resolvedIdentity?: EventIdentity;
|
|
18
|
+
}>;
|
|
18
19
|
getIdentityFromCache(pixelId: string, incomingIdentity: EventIdentity): Promise<{
|
|
19
20
|
resolvedIdentity: EventIdentity | undefined;
|
|
20
|
-
|
|
21
|
+
isCacheStale: boolean;
|
|
21
22
|
}>;
|
|
22
23
|
deleteIdentityCache(pixelId: string, incomingIdentity: EventIdentity, resolvedIdentity: EventIdentity): Promise<void>;
|
|
23
24
|
private deleteIdentityCacheRedis;
|
|
25
|
+
private getIdentityCache;
|
|
26
|
+
updateIdentityCacheRedis: (pixelId: string, request: EventIdentity, response: EventIdentity) => Promise<import("../../clients").CacheRequestCommandResponse[] | undefined>;
|
|
24
27
|
}
|
|
@@ -19,23 +19,22 @@ export class IdentityCacheDbService {
|
|
|
19
19
|
Logger.error('getIdentityWithCaching -No pixelId or incomingIdentity', { pixelId, incomingIdentity });
|
|
20
20
|
return undefined;
|
|
21
21
|
}
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
}
|
|
22
|
+
const cacheResponse = await this.getIdentityFromCache(pixelId, incomingIdentity);
|
|
23
|
+
let resolvedIdentity = cacheResponse?.resolvedIdentity;
|
|
24
|
+
const isCacheStale = cacheResponse?.isCacheStale;
|
|
25
|
+
if (resolvedIdentity && !isCacheStale) {
|
|
26
|
+
Logger.debug('identity cache hit', { incomingIdentity });
|
|
27
|
+
return resolvedIdentity;
|
|
28
|
+
}
|
|
29
|
+
Logger.debug('identity cache stale - fetching from identity service', { incomingIdentity });
|
|
30
|
+
const response = await this.identifyPrivateLambda(pixelId, incomingIdentity);
|
|
31
|
+
if (response?.resolvedIdentity) {
|
|
32
|
+
resolvedIdentity = response.resolvedIdentity;
|
|
34
33
|
}
|
|
35
34
|
else {
|
|
36
|
-
Logger.
|
|
35
|
+
Logger.error('Failed to getIdentity from identifyPrivateLambda', { response, pixelId, incomingIdentity, identifyPrivateLambdaArn: this.identifyPrivateLambdaArn });
|
|
37
36
|
}
|
|
38
|
-
if (
|
|
37
|
+
if (isCacheStale && resolvedIdentity) {
|
|
39
38
|
await this.updateIdentityCacheRedis(pixelId, incomingIdentity, resolvedIdentity);
|
|
40
39
|
}
|
|
41
40
|
if (!resolvedIdentity) {
|
|
@@ -48,109 +47,55 @@ export class IdentityCacheDbService {
|
|
|
48
47
|
return undefined;
|
|
49
48
|
}
|
|
50
49
|
};
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
response,
|
|
58
|
-
updatedAt: getCurrentTimestamp(),
|
|
59
|
-
};
|
|
60
|
-
const setCacheCommands = [];
|
|
61
|
-
const cacheKey = `identId_${pixelId}_${response.identityId}`;
|
|
62
|
-
setCacheCommands.push({
|
|
63
|
-
cacheKey,
|
|
64
|
-
commandType: 'set',
|
|
65
|
-
data: JSON.stringify(identityCache),
|
|
66
|
-
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
67
|
-
});
|
|
68
|
-
if (request?.identityId) {
|
|
69
|
-
const cacheKey = `identId_${pixelId}_${request.identityId}`;
|
|
70
|
-
setCacheCommands.push({
|
|
71
|
-
cacheKey,
|
|
72
|
-
commandType: 'set',
|
|
73
|
-
data: JSON.stringify(identityCache),
|
|
74
|
-
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
if (response?.traits?.emails && response?.traits?.emails?.length > 0) {
|
|
78
|
-
for (let i = 0; i < response.traits.emails.length; i++) {
|
|
79
|
-
const cacheKey = `identEmail_${pixelId}_${response.traits.emails[i]}`;
|
|
80
|
-
setCacheCommands.push({
|
|
81
|
-
cacheKey,
|
|
82
|
-
commandType: 'set',
|
|
83
|
-
data: JSON.stringify(identityCache),
|
|
84
|
-
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
if (response?.traits?.userIds && response?.traits?.userIds?.length > 0) {
|
|
89
|
-
for (let i = 0; i < response.traits.userIds.length; i++) {
|
|
90
|
-
const cacheKey = `identUserId_${pixelId}_${response.traits.userIds[i]}`;
|
|
91
|
-
setCacheCommands.push({
|
|
92
|
-
cacheKey,
|
|
93
|
-
commandType: 'set',
|
|
94
|
-
data: JSON.stringify(identityCache),
|
|
95
|
-
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
96
|
-
});
|
|
50
|
+
async identifyPrivateLambda(pixelId, incomingIdentity) {
|
|
51
|
+
try {
|
|
52
|
+
const response = await this.lambdaInvokeClient.invokeFunction(this.identifyPrivateLambdaArn, { pixelId, context: { identity: incomingIdentity } });
|
|
53
|
+
if (response?.statusCode === 200 && response?.body) {
|
|
54
|
+
const identifyResponse = JSON.parse(response.body);
|
|
55
|
+
return identifyResponse?.identity;
|
|
97
56
|
}
|
|
57
|
+
return { resolvedIdentity: undefined };
|
|
98
58
|
}
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
Logger.debug('updated identity cache', { res, duration: end - start });
|
|
103
|
-
return res;
|
|
104
|
-
};
|
|
105
|
-
getIdentityCache = async (cacheKey) => {
|
|
106
|
-
const start = performance.now();
|
|
107
|
-
const cacheResponse = await this.cacheLambdaClient.invokeGet(cacheKey);
|
|
108
|
-
const end = performance.now();
|
|
109
|
-
Logger.debug('getIdentityCache', { cacheKey, cacheResponse, duration: end - start });
|
|
110
|
-
if (cacheResponse && cacheResponse.responseData) {
|
|
111
|
-
return cacheResponse.responseData;
|
|
59
|
+
catch (err) {
|
|
60
|
+
Logger.error('Error while identifying private lambda', { err });
|
|
61
|
+
return { resolvedIdentity: undefined };
|
|
112
62
|
}
|
|
113
|
-
|
|
114
|
-
};
|
|
63
|
+
}
|
|
115
64
|
async getIdentityFromCache(pixelId, incomingIdentity) {
|
|
116
65
|
try {
|
|
117
|
-
if (!pixelId || !incomingIdentity) {
|
|
118
|
-
return { resolvedIdentity: undefined,
|
|
66
|
+
if (!pixelId || !incomingIdentity || !incomingIdentity?.identityId) {
|
|
67
|
+
return { resolvedIdentity: undefined, isCacheStale: true };
|
|
68
|
+
}
|
|
69
|
+
let isCacheStale = true;
|
|
70
|
+
const cacheKey = `identId_${pixelId}_${incomingIdentity.identityId}`;
|
|
71
|
+
Logger.debug(' try lookup with identityId', { cacheKey });
|
|
72
|
+
const cachedIdentity = await this.getIdentityCache(cacheKey);
|
|
73
|
+
if (!cachedIdentity) {
|
|
74
|
+
return { resolvedIdentity: undefined, isCacheStale: true };
|
|
75
|
+
}
|
|
76
|
+
Logger.debug(' found cached identity', { cacheKey, cachedIdentity });
|
|
77
|
+
const resolvedIdentity = cachedIdentity.response;
|
|
78
|
+
const identityStaleCacheTracker = isIdentityCacheStale(cachedIdentity, incomingIdentity);
|
|
79
|
+
const isDeepEqual = fastDeepEqual(cachedIdentity.response, incomingIdentity);
|
|
80
|
+
isCacheStale = identityStaleCacheTracker.isCacheStale;
|
|
81
|
+
if (isDeepEqual) {
|
|
82
|
+
Logger.warn('identity cache is deep equal', { pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker, isCacheStale });
|
|
83
|
+
isCacheStale = false;
|
|
119
84
|
}
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
Logger.
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
const isDeepEqual = fastDeepEqual(cachedIdentity.response, incomingIdentity);
|
|
131
|
-
if (isDeepEqual) {
|
|
132
|
-
Logger.warn('identity cache is deep equal', { pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker });
|
|
133
|
-
}
|
|
134
|
-
else {
|
|
135
|
-
Logger.warn('identity cache is not deep equal', { pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker });
|
|
136
|
-
updateCache = true;
|
|
137
|
-
}
|
|
138
|
-
const isCacheStale = identityStaleCacheTracker.isCacheStale;
|
|
139
|
-
if (isCacheStale) {
|
|
140
|
-
Logger.warn('identity cache stale', { isCacheStale, isDeepEqual, pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker });
|
|
141
|
-
updateCache = true;
|
|
142
|
-
}
|
|
143
|
-
else {
|
|
144
|
-
Logger.warn('identity cache not stale', { isCacheStale, isDeepEqual, pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker });
|
|
145
|
-
updateCache = false;
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
return { resolvedIdentity, updateCache };
|
|
85
|
+
else {
|
|
86
|
+
Logger.debug('identity cache is not deep equal', { pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker, isCacheStale });
|
|
87
|
+
}
|
|
88
|
+
if (isCacheStale) {
|
|
89
|
+
Logger.warn('identity cache stale', { isCacheStale, isDeepEqual, pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker });
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
Logger.warn('identity cache not stale', { isCacheStale, isDeepEqual, pixelId, incomingIdentity, cacheKey, cachedIdentity, identityStaleCacheTracker });
|
|
93
|
+
}
|
|
94
|
+
return { resolvedIdentity, isCacheStale };
|
|
150
95
|
}
|
|
151
96
|
catch (err) {
|
|
152
97
|
Logger.error('Error while getting identity from cache', { err });
|
|
153
|
-
return { resolvedIdentity: undefined,
|
|
98
|
+
return { resolvedIdentity: undefined, isCacheStale: true };
|
|
154
99
|
}
|
|
155
100
|
}
|
|
156
101
|
async deleteIdentityCache(pixelId, incomingIdentity, resolvedIdentity) {
|
|
@@ -210,5 +155,69 @@ export class IdentityCacheDbService {
|
|
|
210
155
|
Logger.error('Error while deleting identity cache', { err });
|
|
211
156
|
}
|
|
212
157
|
}
|
|
158
|
+
getIdentityCache = async (cacheKey) => {
|
|
159
|
+
const start = performance.now();
|
|
160
|
+
const cacheResponse = await this.cacheLambdaClient.invokeGet(cacheKey);
|
|
161
|
+
const end = performance.now();
|
|
162
|
+
Logger.debug('getIdentityCache', { cacheKey, cacheResponse, duration: end - start });
|
|
163
|
+
if (cacheResponse && cacheResponse.responseData) {
|
|
164
|
+
return cacheResponse.responseData;
|
|
165
|
+
}
|
|
166
|
+
return undefined;
|
|
167
|
+
};
|
|
168
|
+
updateIdentityCacheRedis = async (pixelId, request, response) => {
|
|
169
|
+
if (!response || !response.identityId || !pixelId) {
|
|
170
|
+
return;
|
|
171
|
+
}
|
|
172
|
+
const identityCache = {
|
|
173
|
+
identityId: response.identityId,
|
|
174
|
+
response,
|
|
175
|
+
updatedAt: getCurrentTimestamp(),
|
|
176
|
+
};
|
|
177
|
+
const setCacheCommands = [];
|
|
178
|
+
const cacheKey = `identId_${pixelId}_${response.identityId}`;
|
|
179
|
+
setCacheCommands.push({
|
|
180
|
+
cacheKey,
|
|
181
|
+
commandType: 'set',
|
|
182
|
+
data: JSON.stringify(identityCache),
|
|
183
|
+
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
184
|
+
});
|
|
185
|
+
if (request?.identityId) {
|
|
186
|
+
const cacheKey = `identId_${pixelId}_${request.identityId}`;
|
|
187
|
+
setCacheCommands.push({
|
|
188
|
+
cacheKey,
|
|
189
|
+
commandType: 'set',
|
|
190
|
+
data: JSON.stringify(identityCache),
|
|
191
|
+
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
192
|
+
});
|
|
193
|
+
}
|
|
194
|
+
if (response?.traits?.emails && response?.traits?.emails?.length > 0) {
|
|
195
|
+
for (let i = 0; i < response.traits.emails.length; i++) {
|
|
196
|
+
const cacheKey = `identEmail_${pixelId}_${response.traits.emails[i]}`;
|
|
197
|
+
setCacheCommands.push({
|
|
198
|
+
cacheKey,
|
|
199
|
+
commandType: 'set',
|
|
200
|
+
data: JSON.stringify(identityCache),
|
|
201
|
+
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
if (response?.traits?.userIds && response?.traits?.userIds?.length > 0) {
|
|
206
|
+
for (let i = 0; i < response.traits.userIds.length; i++) {
|
|
207
|
+
const cacheKey = `identUserId_${pixelId}_${response.traits.userIds[i]}`;
|
|
208
|
+
setCacheCommands.push({
|
|
209
|
+
cacheKey,
|
|
210
|
+
commandType: 'set',
|
|
211
|
+
data: JSON.stringify(identityCache),
|
|
212
|
+
expires: IDENTITY_CACHE_TTL_IN_SECONDS,
|
|
213
|
+
});
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
const start = performance.now();
|
|
217
|
+
const res = await this.cacheLambdaClient.batchInvoke(setCacheCommands);
|
|
218
|
+
const end = performance.now();
|
|
219
|
+
Logger.debug('updated identity cache', { res, duration: end - start });
|
|
220
|
+
return res;
|
|
221
|
+
};
|
|
213
222
|
}
|
|
214
223
|
//# sourceMappingURL=identity-cache-db-service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"identity-cache-db-service.js","sourceRoot":"","sources":["../../../../src/services/db/identity-cache-db-service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAuB,kBAAkB,EAAE,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAC;AAC3E,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAW5C,MAAM,6BAA6B,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;AAE5D,MAAM,OAAO,sBAAsB;IACzB,iBAAiB,CAAoB;IACrC,wBAAwB,CAAS;IACjC,kBAAkB,CAAqB;IAE/C,YAAY,sBAA8B,EAAE,wBAAgC;QAC1E,IAAI,CAAC,iBAAiB,GAAG,IAAI,iBAAiB,CAAC,sBAAsB,CAAC,CAAC;QACvE,IAAI,CAAC,wBAAwB,GAAG,wBAAwB,CAAC;QACzD,IAAI,CAAC,kBAAkB,GAAG,IAAI,kBAAkB,EAAE,CAAC;IACrD,CAAC;IAEM,sBAAsB,GAAG,KAAK,EAAE,OAAe,EAAE,mBAAkC,EAAE,EAAE,EAAE;QAC9F,IAAI;YACF,IAAI,CAAC,OAAO,IAAI,CAAC,gBAAgB,EAAE;gBACjC,MAAM,CAAC,KAAK,CAAC,wDAAwD,EAAE,EAAE,OAAO,EAAE,gBAAgB,EAAE,CAAC,CAAC;gBACtG,OAAO,SAAS,CAAC;aAClB;YACD,
|
|
1
|
+
{"version":3,"file":"identity-cache-db-service.js","sourceRoot":"","sources":["../../../../src/services/db/identity-cache-db-service.ts"],"names":[],"mappings":"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"}
|