@adtrackify/at-service-common 3.0.79 → 3.0.80
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/clients/generic/lambda-invoke-client.d.ts +6 -1
- package/dist/cjs/clients/generic/lambda-invoke-client.js +10 -10
- package/dist/cjs/clients/generic/lambda-invoke-client.js.map +1 -1
- package/dist/cjs/clients/generic/redis-client.d.ts +4 -2
- package/dist/cjs/clients/generic/redis-client.js +16 -2
- package/dist/cjs/clients/generic/redis-client.js.map +1 -1
- package/dist/cjs/clients/internal-api/cache-lambda-client.d.ts +23 -0
- package/dist/cjs/clients/internal-api/cache-lambda-client.js +60 -0
- package/dist/cjs/clients/internal-api/cache-lambda-client.js.map +1 -0
- package/dist/cjs/clients/internal-api/index.d.ts +1 -0
- package/dist/cjs/clients/internal-api/index.js +1 -0
- package/dist/cjs/clients/internal-api/index.js.map +1 -1
- package/dist/cjs/services/db/identity-cache-db-service.d.ts +4 -5
- package/dist/cjs/services/db/identity-cache-db-service.js +94 -62
- package/dist/cjs/services/db/identity-cache-db-service.js.map +1 -1
- package/dist/cjs/services/ipdata-lookup-service.d.ts +9 -2
- package/dist/cjs/services/ipdata-lookup-service.js +56 -77
- package/dist/cjs/services/ipdata-lookup-service.js.map +1 -1
- package/dist/esm/clients/generic/lambda-invoke-client.d.ts +6 -1
- package/dist/esm/clients/generic/lambda-invoke-client.js +10 -10
- package/dist/esm/clients/generic/lambda-invoke-client.js.map +1 -1
- package/dist/esm/clients/generic/redis-client.d.ts +4 -2
- package/dist/esm/clients/generic/redis-client.js +16 -2
- package/dist/esm/clients/generic/redis-client.js.map +1 -1
- package/dist/esm/clients/internal-api/cache-lambda-client.d.ts +23 -0
- package/dist/esm/clients/internal-api/cache-lambda-client.js +56 -0
- package/dist/esm/clients/internal-api/cache-lambda-client.js.map +1 -0
- package/dist/esm/clients/internal-api/index.d.ts +1 -0
- package/dist/esm/clients/internal-api/index.js +1 -0
- package/dist/esm/clients/internal-api/index.js.map +1 -1
- package/dist/esm/services/db/identity-cache-db-service.d.ts +4 -5
- package/dist/esm/services/db/identity-cache-db-service.js +95 -63
- package/dist/esm/services/db/identity-cache-db-service.js.map +1 -1
- package/dist/esm/services/ipdata-lookup-service.d.ts +9 -2
- package/dist/esm/services/ipdata-lookup-service.js +55 -75
- package/dist/esm/services/ipdata-lookup-service.js.map +1 -1
- package/package.json +2 -1
|
@@ -1,93 +1,72 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.IpDataLookupService = void 0;
|
|
4
4
|
const luxon_1 = require("luxon");
|
|
5
5
|
const clients_1 = require("../clients");
|
|
6
6
|
const helpers_1 = require("../helpers");
|
|
7
7
|
const libs_1 = require("../libs");
|
|
8
8
|
const net_1 = require("net");
|
|
9
9
|
const API_KEY = 'aae45f1e1f97ecf79bdc2bef3e96ef71961c4cb977c3085429b421bc';
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
return res?.data;
|
|
10
|
+
class IpDataLookupService {
|
|
11
|
+
cacheLambdaFunctionArn;
|
|
12
|
+
cacheLambdaClient;
|
|
13
|
+
constructor(cacheLambdaFunctionArn) {
|
|
14
|
+
this.cacheLambdaFunctionArn = cacheLambdaFunctionArn;
|
|
15
|
+
this.cacheLambdaClient = new clients_1.CacheLambdaClient(cacheLambdaFunctionArn);
|
|
17
16
|
}
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
try {
|
|
25
|
-
if (!ipAddress || (0, net_1.isIP)(ipAddress) === 0) {
|
|
26
|
-
helpers_1.Logger.warn('Unable to lookup IP. Invalid Ip Address', { ipAddress });
|
|
27
|
-
return null;
|
|
17
|
+
getLookupApi = async (ipAddress) => {
|
|
18
|
+
try {
|
|
19
|
+
const client = (0, clients_1.axiosHttpService)();
|
|
20
|
+
const url = `https://api.ipdata.co/${ipAddress}?api-key=${API_KEY}`;
|
|
21
|
+
const res = await client.get(url);
|
|
22
|
+
return res?.data;
|
|
28
23
|
}
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
return cachedResult.lookupResponse;
|
|
24
|
+
catch (error) {
|
|
25
|
+
helpers_1.Logger.error('IPData Lookup API Failed', { error });
|
|
26
|
+
return null;
|
|
33
27
|
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
const expiresAt = luxon_1.DateTime.now().plus({ days: 15 }).toSeconds();
|
|
44
|
-
lookupTableRecord.expiresAt = expiresAt;
|
|
28
|
+
};
|
|
29
|
+
getIpCache = async (ipAddress) => {
|
|
30
|
+
return this.cacheLambdaClient.invokeGet(`ipdata-${ipAddress}`);
|
|
31
|
+
};
|
|
32
|
+
lookupIP = async (ipAddress) => {
|
|
33
|
+
try {
|
|
34
|
+
if (!ipAddress || (0, net_1.isIP)(ipAddress) === 0) {
|
|
35
|
+
helpers_1.Logger.warn('Unable to lookup IP. Invalid Ip Address', { ipAddress });
|
|
36
|
+
return null;
|
|
45
37
|
}
|
|
38
|
+
const cacheResponse = await this.getIpCache(ipAddress);
|
|
39
|
+
const cachedResult = cacheResponse?.responseData;
|
|
40
|
+
const cacheExpirationDate = luxon_1.DateTime.utc().minus({ days: 6 }).toJSDate().toISOString();
|
|
41
|
+
if (cachedResult && cachedResult?.updatedAt > cacheExpirationDate) {
|
|
42
|
+
return cachedResult.lookupResponse;
|
|
43
|
+
}
|
|
44
|
+
const lookupResponse = await this.getLookupApi(ipAddress);
|
|
45
|
+
const expires = 60 * 60 * 24 * 15;
|
|
46
|
+
let lookupTableRecord;
|
|
47
|
+
if (cachedResult) {
|
|
48
|
+
lookupTableRecord = {
|
|
49
|
+
...cachedResult,
|
|
50
|
+
lookupResponse,
|
|
51
|
+
updatedAt: (0, libs_1.getCurrentTimestamp)(),
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
lookupTableRecord = {
|
|
56
|
+
ipAddress,
|
|
57
|
+
lookupResponse,
|
|
58
|
+
createdAt: (0, libs_1.getCurrentTimestamp)(),
|
|
59
|
+
updatedAt: (0, libs_1.getCurrentTimestamp)()
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
await this.cacheLambdaClient.invokeSet(`ipdata-${ipAddress}`, JSON.stringify(lookupTableRecord), expires);
|
|
63
|
+
return lookupResponse;
|
|
46
64
|
}
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
lookupTableRecord = {
|
|
50
|
-
ipAddress,
|
|
51
|
-
lookupResponse,
|
|
52
|
-
createdAt: (0, libs_1.getCurrentTimestamp)(),
|
|
53
|
-
updatedAt: (0, libs_1.getCurrentTimestamp)(),
|
|
54
|
-
expiresAt
|
|
55
|
-
};
|
|
56
|
-
}
|
|
57
|
-
await clients_1.DynamoDbClient.safePut(IP_LOOKUP_TABLE_NAME, lookupTableRecord);
|
|
58
|
-
return lookupResponse;
|
|
59
|
-
}
|
|
60
|
-
catch (e) {
|
|
61
|
-
helpers_1.Logger.error('Failed to lookup IP', { error: e });
|
|
62
|
-
return null;
|
|
63
|
-
}
|
|
64
|
-
};
|
|
65
|
-
exports.lookupIP = lookupIP;
|
|
66
|
-
const updateIPCache = async (ipAddress, data) => {
|
|
67
|
-
try {
|
|
68
|
-
if (!ipAddress || (0, net_1.isIP)(ipAddress) === 0) {
|
|
69
|
-
helpers_1.Logger.warn('Unable to update IP cache. Invalid Ip Address', { ipAddress, data });
|
|
65
|
+
catch (e) {
|
|
66
|
+
helpers_1.Logger.error('Failed to lookup IP', { error: e });
|
|
70
67
|
return null;
|
|
71
68
|
}
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
const updatedLookupResponse = cachedResult?.lookupResponse ?? { asn: {} };
|
|
76
|
-
Object.assign(updatedLookupResponse, data);
|
|
77
|
-
const updatedLookupTableRecord = {
|
|
78
|
-
...cachedResult,
|
|
79
|
-
lookupResponse,
|
|
80
|
-
updatedAt: (0, libs_1.getCurrentTimestamp)()
|
|
81
|
-
};
|
|
82
|
-
lookupResponse = updatedLookupResponse;
|
|
83
|
-
await clients_1.DynamoDbClient.safePut(IP_LOOKUP_TABLE_NAME, updatedLookupTableRecord);
|
|
84
|
-
}
|
|
85
|
-
return lookupResponse;
|
|
86
|
-
}
|
|
87
|
-
catch (error) {
|
|
88
|
-
helpers_1.Logger.error('Failed to update IP cache', { error });
|
|
89
|
-
return null;
|
|
90
|
-
}
|
|
91
|
-
};
|
|
92
|
-
exports.updateIPCache = updateIPCache;
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
exports.IpDataLookupService = IpDataLookupService;
|
|
93
72
|
//# sourceMappingURL=ipdata-lookup-service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ipdata-lookup-service.js","sourceRoot":"","sources":["../../../src/services/ipdata-lookup-service.ts"],"names":[],"mappings":";;;AACA,iCAAiC;AAEjC,
|
|
1
|
+
{"version":3,"file":"ipdata-lookup-service.js","sourceRoot":"","sources":["../../../src/services/ipdata-lookup-service.ts"],"names":[],"mappings":";;;AACA,iCAAiC;AAEjC,wCAAiE;AACjE,wCAAoC;AACpC,kCAA8C;AAC9C,6BAA2B;AAE3B,MAAM,OAAO,GAAG,0DAA0D,CAAC;AAU3E,MAAa,mBAAmB;IAEV;IADpB,iBAAiB,CAAoB;IACrC,YAAoB,sBAA8B;QAA9B,2BAAsB,GAAtB,sBAAsB,CAAQ;QAChD,IAAI,CAAC,iBAAiB,GAAG,IAAI,2BAAiB,CAAC,sBAAsB,CAAC,CAAC;IACzE,CAAC;IAED,YAAY,GAAG,KAAK,EAAE,SAAiB,EAAkC,EAAE;QACzE,IAAI;YACF,MAAM,MAAM,GAAG,IAAA,0BAAgB,GAAE,CAAC;YAClC,MAAM,GAAG,GAAG,yBAAyB,SAAS,YAAY,OAAO,EAAE,CAAC;YACpE,MAAM,GAAG,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAClC,OAAO,GAAG,EAAE,IAAsB,CAAC;SACpC;QAAC,OAAO,KAAK,EAAE;YACd,gBAAM,CAAC,KAAK,CAAC,0BAA0B,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;YACpD,OAAO,IAAI,CAAC;SACb;IACH,CAAC,CAAC;IACF,UAAU,GAAG,KAAK,EAAE,SAAiB,EAAE,EAAE;QACvC,OAAO,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,UAAU,SAAS,EAAE,CAAC,CAAC;IACjE,CAAC,CAAA;IACD,QAAQ,GAAG,KAAK,EAAE,SAAiB,EAAkC,EAAE;QACrE,IAAI;YACF,IAAI,CAAC,SAAS,IAAI,IAAA,UAAI,EAAC,SAAS,CAAC,KAAK,CAAC,EAAE;gBACvC,gBAAM,CAAC,IAAI,CAAC,0CAA0C,EAAE,EAAE,SAAS,EAAE,CAAC,CAAA;gBACtE,OAAO,IAAI,CAAC;aACb;YAED,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;YACvD,MAAM,YAAY,GAAG,aAAa,EAAE,YAAY,CAAC;YACjD,MAAM,mBAAmB,GAAG,gBAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC;YACvF,IAAI,YAAY,IAAI,YAAY,EAAE,SAAS,GAAG,mBAAmB,EAAE;gBACjE,OAAO,YAAY,CAAC,cAAc,CAAC;aACpC;YAED,MAAM,cAAc,GAA0B,MAAM,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;YAEjF,MAAM,OAAO,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YAClC,IAAI,iBAAsC,CAAC;YAC3C,IAAI,YAAY,EAAE;gBAChB,iBAAiB,GAAG;oBAClB,GAAG,YAAY;oBACf,cAAc;oBACd,SAAS,EAAE,IAAA,0BAAmB,GAAE;iBACjC,CAAC;aACH;iBAAM;gBACL,iBAAiB,GAAG;oBAClB,SAAS;oBACT,cAAc;oBACd,SAAS,EAAE,IAAA,0BAAmB,GAAE;oBAChC,SAAS,EAAE,IAAA,0BAAmB,GAAE;iBACjC,CAAC;aACH;YACD,MAAM,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,UAAU,SAAS,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAC,EAAE,OAAO,CAAC,CAAC;YAE1G,OAAO,cAAc,CAAC;SACvB;QAAC,OAAO,CAAC,EAAE;YACV,gBAAM,CAAC,KAAK,CAAC,qBAAqB,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;YAClD,OAAO,IAAI,CAAC;SACb;IACH,CAAC,CAAC;CACH;AA5DD,kDA4DC"}
|
|
@@ -1,5 +1,10 @@
|
|
|
1
|
+
export interface CacheLambdaInvokeResponse {
|
|
2
|
+
statusCode: number;
|
|
3
|
+
headers: any;
|
|
4
|
+
body: string;
|
|
5
|
+
}
|
|
1
6
|
export declare class LambdaInvokeClient {
|
|
2
7
|
private lambda;
|
|
3
8
|
constructor();
|
|
4
|
-
invokeFunction(functionName: string, payload:
|
|
9
|
+
invokeFunction(functionName: string, payload: any): Promise<CacheLambdaInvokeResponse | null>;
|
|
5
10
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { Logger } from '../../helpers';
|
|
2
1
|
import { LambdaClient, InvokeCommand } from '@aws-sdk/client-lambda';
|
|
2
|
+
import { toUint8Array } from '@aws-sdk/util-utf8';
|
|
3
|
+
import { Logger } from '../../helpers';
|
|
3
4
|
export class LambdaInvokeClient {
|
|
4
5
|
lambda;
|
|
5
6
|
constructor() {
|
|
@@ -9,22 +10,21 @@ export class LambdaInvokeClient {
|
|
|
9
10
|
const params = {
|
|
10
11
|
FunctionName: functionName,
|
|
11
12
|
InvocationType: 'RequestResponse',
|
|
12
|
-
Payload: JSON.stringify(payload),
|
|
13
|
+
Payload: toUint8Array(JSON.stringify(payload)),
|
|
13
14
|
};
|
|
14
15
|
try {
|
|
15
16
|
const response = await this.lambda.send(new InvokeCommand(params));
|
|
16
|
-
|
|
17
|
-
Logger.error('Error invoking lambda function:', { response });
|
|
18
|
-
return null;
|
|
19
|
-
}
|
|
17
|
+
Logger.debug('Lambda response:', { response });
|
|
20
18
|
if (response?.Payload) {
|
|
21
|
-
|
|
22
|
-
|
|
19
|
+
const parsedPayload = response?.Payload.transformToString();
|
|
20
|
+
const jsonPayload = JSON.parse(parsedPayload);
|
|
21
|
+
Logger.debug('parsed payload', { parsedPayload });
|
|
22
|
+
return jsonPayload;
|
|
23
23
|
}
|
|
24
|
-
return
|
|
24
|
+
return null;
|
|
25
25
|
}
|
|
26
26
|
catch (error) {
|
|
27
|
-
Logger.error('Error invoking lambda function:', { error });
|
|
27
|
+
Logger.error('Error invoking lambda function:', { err: error, params });
|
|
28
28
|
return null;
|
|
29
29
|
}
|
|
30
30
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lambda-invoke-client.js","sourceRoot":"","sources":["../../../../src/clients/generic/lambda-invoke-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"lambda-invoke-client.js","sourceRoot":"","sources":["../../../../src/clients/generic/lambda-invoke-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAsB,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACzF,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAQvC,MAAM,OAAO,kBAAkB;IACrB,MAAM,CAAe;IAE7B;QACE,IAAI,CAAC,MAAM,GAAG,IAAI,YAAY,EAAE,CAAC;IACnC,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,YAAoB,EAAE,OAAY;QACrD,MAAM,MAAM,GAAuB;YACjC,YAAY,EAAE,YAAY;YAC1B,cAAc,EAAE,iBAAiB;YACjC,OAAO,EAAE,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;SAC/C,CAAC;QAEF,IAAI;YACF,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC;YACnE,MAAM,CAAC,KAAK,CAAC,kBAAkB,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC;YAK/C,IAAI,QAAQ,EAAE,OAAO,EAAE;gBACrB,MAAM,aAAa,GAAG,QAAQ,EAAE,OAAO,CAAC,iBAAiB,EAAE,CAAC;gBAC5D,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;gBAC9C,MAAM,CAAC,KAAK,CAAC,gBAAgB,EAAE,EAAE,aAAa,EAAE,CAAC,CAAC;gBAClD,OAAO,WAAW,CAAC;aACpB;YACD,OAAO,IAAI,CAAC;SACb;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,CAAC,KAAK,CAAC,iCAAiC,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;YACxE,OAAO,IAAI,CAAC;SACb;IACH,CAAC;CACF"}
|
|
@@ -8,8 +8,10 @@ export declare class RedisClient {
|
|
|
8
8
|
private createClient;
|
|
9
9
|
private getClient;
|
|
10
10
|
connect(client: Redis): Promise<void>;
|
|
11
|
-
|
|
12
|
-
|
|
11
|
+
safeSet(key: string, value: string, ttlInSeconds?: number): Promise<void>;
|
|
12
|
+
unsafeSet(key: string, value: string, ttlInSeconds?: number): Promise<void>;
|
|
13
|
+
unsafeGet(key: string): Promise<string | null>;
|
|
14
|
+
safeGet(key: string): Promise<string | null>;
|
|
13
15
|
del(key: string): Promise<number>;
|
|
14
16
|
disconnect(): Promise<void>;
|
|
15
17
|
}
|
|
@@ -46,7 +46,7 @@ export class RedisClient {
|
|
|
46
46
|
return;
|
|
47
47
|
}
|
|
48
48
|
}
|
|
49
|
-
async
|
|
49
|
+
async safeSet(key, value, ttlInSeconds) {
|
|
50
50
|
try {
|
|
51
51
|
const client = this.getClient();
|
|
52
52
|
if (ttlInSeconds) {
|
|
@@ -61,7 +61,21 @@ export class RedisClient {
|
|
|
61
61
|
return;
|
|
62
62
|
}
|
|
63
63
|
}
|
|
64
|
-
async
|
|
64
|
+
async unsafeSet(key, value, ttlInSeconds) {
|
|
65
|
+
const client = this.getClient();
|
|
66
|
+
if (ttlInSeconds) {
|
|
67
|
+
await client.set(key, value, 'EX', ttlInSeconds);
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
await client.set(key, value);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
async unsafeGet(key) {
|
|
74
|
+
const client = this.getClient();
|
|
75
|
+
Logger.debug('get', { key, client });
|
|
76
|
+
return await client.get(key);
|
|
77
|
+
}
|
|
78
|
+
async safeGet(key) {
|
|
65
79
|
try {
|
|
66
80
|
const client = this.getClient();
|
|
67
81
|
Logger.debug('get', { key, client });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"redis-client.js","sourceRoot":"","sources":["../../../../src/clients/generic/redis-client.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,SAAS,CAAC;AAC5B,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,MAAM,OAAO,WAAW;IAKyB;IAJvC,IAAI,CAAmB;IAC/B,IAAI,CAAS;IACb,IAAI,CAAS;IAEb,YAAY,IAAY,EAAE,IAAI,GAAG,IAAI,EAAU,WAAmB,CAAC;QAApB,aAAQ,GAAR,QAAQ,CAAY;QACjE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;IACpF,CAAC;IACO,YAAY,CAAC,IAAY,EAAE,IAAY;QAC7C,IAAI;YACF,MAAM,MAAM,GAAG,IAAI,KAAK,CAAC;gBACvB,IAAI,EAAE,IAAI;gBACV,IAAI,EAAE,IAAI;gBACV,oBAAoB,EAAE,CAAC;gBACvB,cAAc,EAAE,IAAI;gBACpB,WAAW,EAAE,IAAI;gBACjB,SAAS,EAAE,IAAI;aAEhB,CAAC,CAAC;YAEH,OAAO,MAAM,CAAC;SACf;QAAC,OAAO,GAAG,EAAE;YACZ,MAAM,CAAC,KAAK,CAAC,8BAA8B,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;YACtD,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IACO,SAAS;QACf,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC9D,IAAI,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACpC,IAAI,CAAC,MAAM,EAAE;YACX,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;SAClD;QACD,OAAO,MAAe,CAAC;IACzB,CAAC;IAEM,KAAK,CAAC,OAAO,CAAC,MAAa;QAChC,IAAI;YACF,MAAM,MAAM,CAAC,OAAO,EAAE,CAAC;YACvB,MAAM,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC;SACpC;QAAC,OAAO,GAAG,EAAE;YACZ,MAAM,CAAC,KAAK,CAAC,4BAA4B,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;YACpD,OAAO;SACR;IACH,CAAC;IAEM,KAAK,CAAC,
|
|
1
|
+
{"version":3,"file":"redis-client.js","sourceRoot":"","sources":["../../../../src/clients/generic/redis-client.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { LambdaInvokeClient } from '../generic/lambda-invoke-client';
|
|
2
|
+
export interface CacheRequestCommand {
|
|
3
|
+
cacheKey: string;
|
|
4
|
+
commandType: string;
|
|
5
|
+
expires?: number;
|
|
6
|
+
data?: string;
|
|
7
|
+
}
|
|
8
|
+
export interface CacheRequestCommandResponse {
|
|
9
|
+
cacheKey: string;
|
|
10
|
+
commandType: string;
|
|
11
|
+
expires?: number;
|
|
12
|
+
status?: number;
|
|
13
|
+
responseData?: any;
|
|
14
|
+
}
|
|
15
|
+
export declare class CacheLambdaClient {
|
|
16
|
+
FUNCTION_NAME: string;
|
|
17
|
+
lambdaInvokeClient: LambdaInvokeClient;
|
|
18
|
+
constructor(functionName: string);
|
|
19
|
+
batchInvoke(commands: CacheRequestCommand[]): Promise<CacheRequestCommandResponse[]>;
|
|
20
|
+
invokeDelete(cacheKey: string): Promise<CacheRequestCommandResponse | undefined>;
|
|
21
|
+
invokeGet(cacheKey: string): Promise<CacheRequestCommandResponse | undefined>;
|
|
22
|
+
invokeSet(cacheKey: string, data: string, expires?: number): Promise<CacheRequestCommandResponse | undefined>;
|
|
23
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { LambdaInvokeClient } from '../generic/lambda-invoke-client';
|
|
2
|
+
export class CacheLambdaClient {
|
|
3
|
+
FUNCTION_NAME;
|
|
4
|
+
lambdaInvokeClient;
|
|
5
|
+
constructor(functionName) {
|
|
6
|
+
this.FUNCTION_NAME = functionName;
|
|
7
|
+
this.lambdaInvokeClient = new LambdaInvokeClient();
|
|
8
|
+
}
|
|
9
|
+
async batchInvoke(commands) {
|
|
10
|
+
const response = await this.lambdaInvokeClient.invokeFunction(this.FUNCTION_NAME, commands);
|
|
11
|
+
if (response && response.body) {
|
|
12
|
+
const responseBody = JSON.parse(response.body);
|
|
13
|
+
return responseBody;
|
|
14
|
+
}
|
|
15
|
+
return [];
|
|
16
|
+
}
|
|
17
|
+
async invokeDelete(cacheKey) {
|
|
18
|
+
const payload = [{
|
|
19
|
+
cacheKey,
|
|
20
|
+
commandType: 'delete',
|
|
21
|
+
}];
|
|
22
|
+
const response = await this.lambdaInvokeClient.invokeFunction(this.FUNCTION_NAME, payload);
|
|
23
|
+
if (response && response?.body) {
|
|
24
|
+
const responseBody = JSON.parse(response.body);
|
|
25
|
+
return responseBody?.[0];
|
|
26
|
+
}
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
async invokeGet(cacheKey) {
|
|
30
|
+
const payload = [{
|
|
31
|
+
cacheKey,
|
|
32
|
+
commandType: 'get',
|
|
33
|
+
}];
|
|
34
|
+
const response = await this.lambdaInvokeClient.invokeFunction(this.FUNCTION_NAME, payload);
|
|
35
|
+
if (response && response?.body) {
|
|
36
|
+
const responseBody = JSON.parse(response.body);
|
|
37
|
+
return responseBody?.[0];
|
|
38
|
+
}
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
async invokeSet(cacheKey, data, expires) {
|
|
42
|
+
const payload = [{
|
|
43
|
+
cacheKey,
|
|
44
|
+
commandType: 'set',
|
|
45
|
+
expires,
|
|
46
|
+
data
|
|
47
|
+
}];
|
|
48
|
+
const response = await this.lambdaInvokeClient.invokeFunction(this.FUNCTION_NAME, payload);
|
|
49
|
+
if (response && response?.body) {
|
|
50
|
+
const responseBody = JSON.parse(response.body);
|
|
51
|
+
return responseBody?.[0];
|
|
52
|
+
}
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=cache-lambda-client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache-lambda-client.js","sourceRoot":"","sources":["../../../../src/clients/internal-api/cache-lambda-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,iCAAiC,CAAC;AAgBrE,MAAM,OAAO,iBAAiB;IACrB,aAAa,CAAS;IAC7B,kBAAkB,CAAqB;IAEvC,YAAY,YAAoB;QAC9B,IAAI,CAAC,aAAa,GAAG,YAAY,CAAC;QAClC,IAAI,CAAC,kBAAkB,GAAG,IAAI,kBAAkB,EAAE,CAAC;IACrD,CAAC;IAEM,KAAK,CAAC,WAAW,CAAC,QAA+B;QACtD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;QAC5F,IAAI,QAAQ,IAAI,QAAQ,CAAC,IAAI,EAAE;YAC7B,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAkC,CAAC;YAChF,OAAO,YAAY,CAAC;SACrB;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAEM,KAAK,CAAC,YAAY,CAAC,QAAgB;QACxC,MAAM,OAAO,GAA0B,CAAC;gBACtC,QAAQ;gBACR,WAAW,EAAE,QAAQ;aACtB,CAAC,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QAC3F,IAAI,QAAQ,IAAI,QAAQ,EAAE,IAAI,EAAE;YAC9B,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAkC,CAAC;YAChF,OAAO,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;SAC1B;QACD,OAAO;IACT,CAAC;IACM,KAAK,CAAC,SAAS,CAAC,QAAgB;QACrC,MAAM,OAAO,GAA0B,CAAC;gBACtC,QAAQ;gBACR,WAAW,EAAE,KAAK;aACnB,CAAC,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QAC3F,IAAI,QAAQ,IAAI,QAAQ,EAAE,IAAI,EAAE;YAC9B,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAkC,CAAC;YAChF,OAAO,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;SAC1B;QACD,OAAO;IACT,CAAC;IACM,KAAK,CAAC,SAAS,CAAC,QAAgB,EAAE,IAAY,EAAE,OAAgB;QACrE,MAAM,OAAO,GAA0B,CAAC;gBACtC,QAAQ;gBACR,WAAW,EAAE,KAAK;gBAClB,OAAO;gBACP,IAAI;aACL,CAAC,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QAC3F,IAAI,QAAQ,IAAI,QAAQ,EAAE,IAAI,EAAE;YAC9B,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAkC,CAAC;YAChF,OAAO,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;SAC1B;QACD,OAAO;IACT,CAAC;CAEF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/clients/internal-api/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,wBAAwB,CAAC;AACvC,cAAc,iCAAiC,CAAC;AAChD,cAAc,sBAAsB,CAAC;AACrC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,6BAA6B,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/clients/internal-api/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,wBAAwB,CAAC;AACvC,cAAc,iCAAiC,CAAC;AAChD,cAAc,sBAAsB,CAAC;AACrC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,0BAA0B,CAAC"}
|
|
@@ -11,13 +11,12 @@ export declare class IdentityCacheDbService {
|
|
|
11
11
|
TABLE_NAME: string;
|
|
12
12
|
TABLE_KEY: string;
|
|
13
13
|
TTL_IN_MONTHS: number;
|
|
14
|
-
private
|
|
14
|
+
private cacheLambdaClient;
|
|
15
15
|
private lambdaInvokeClient;
|
|
16
|
-
constructor(
|
|
16
|
+
constructor(cacheLambdaFunctionArn: string, tableName: string, tableKey: string, cacheTtlInMonths?: number);
|
|
17
17
|
getIdentityWithCaching: (pixelId: string, incomingIdentity: EventIdentity | undefined, identifyPrivateLambdaArn: string) => Promise<EventIdentity | undefined>;
|
|
18
|
-
updateIdentityCacheRedis: (pixelId: string, request: EventIdentity, response: EventIdentity) => Promise<
|
|
19
|
-
|
|
20
|
-
deleteIdentityCacheDynamoDb: (incomingIdentity: EventIdentity, resolvedIdentity: EventIdentity) => Promise<void>;
|
|
18
|
+
updateIdentityCacheRedis: (pixelId: string, request: EventIdentity, response: EventIdentity) => Promise<import("../../clients").CacheRequestCommandResponse[] | undefined>;
|
|
19
|
+
private getIdentityCache;
|
|
21
20
|
getIdentityFromCache(pixelId: string, incomingIdentity: EventIdentity): Promise<{
|
|
22
21
|
resolvedIdentity: EventIdentity | undefined;
|
|
23
22
|
updateCache: boolean;
|