@adtrackify/at-service-common 3.2.34 → 3.3.2
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/internal-api/identity-client.d.ts +12 -5
- package/dist/cjs/clients/internal-api/identity-client.js +31 -25
- package/dist/cjs/clients/internal-api/identity-client.js.map +1 -1
- package/dist/cjs/clients/third-party/emailable-client.d.ts +2 -25
- package/dist/cjs/clients/third-party/emailable-client.js +10 -1
- package/dist/cjs/clients/third-party/emailable-client.js.map +1 -1
- package/dist/cjs/helpers/identity-cache-helper.js +7 -0
- package/dist/cjs/helpers/identity-cache-helper.js.map +1 -1
- package/dist/cjs/libs/index.d.ts +1 -0
- package/dist/cjs/libs/index.js +1 -0
- package/dist/cjs/libs/index.js.map +1 -1
- package/dist/cjs/libs/strings.d.ts +3 -0
- package/dist/cjs/libs/strings.js +38 -0
- package/dist/cjs/libs/strings.js.map +1 -0
- package/dist/esm/clients/internal-api/identity-client.d.ts +12 -5
- package/dist/esm/clients/internal-api/identity-client.js +31 -25
- package/dist/esm/clients/internal-api/identity-client.js.map +1 -1
- package/dist/esm/clients/third-party/emailable-client.d.ts +2 -25
- package/dist/esm/clients/third-party/emailable-client.js +10 -1
- package/dist/esm/clients/third-party/emailable-client.js.map +1 -1
- package/dist/esm/helpers/identity-cache-helper.js +8 -1
- package/dist/esm/helpers/identity-cache-helper.js.map +1 -1
- package/dist/esm/libs/index.d.ts +1 -0
- package/dist/esm/libs/index.js +1 -0
- package/dist/esm/libs/index.js.map +1 -1
- package/dist/esm/libs/strings.d.ts +3 -0
- package/dist/esm/libs/strings.js +32 -0
- package/dist/esm/libs/strings.js.map +1 -0
- package/package.json +4 -4
|
@@ -11,15 +11,22 @@ export interface MergeIdentityResponse {
|
|
|
11
11
|
isIdentityMerged: boolean;
|
|
12
12
|
identity?: EventIdentity;
|
|
13
13
|
}
|
|
14
|
+
export interface IdentityLookupByEmailResponse {
|
|
15
|
+
identities: EventIdentity[];
|
|
16
|
+
}
|
|
14
17
|
export declare class IdentityClient {
|
|
15
|
-
|
|
16
|
-
|
|
18
|
+
BASE_API_URL: string;
|
|
19
|
+
SERVICE_API_ROOT_URL: string;
|
|
20
|
+
IDENTITY_API_KEY?: string;
|
|
17
21
|
client: GenericHttpClient;
|
|
18
22
|
constructor(baseApiUrl: string, identityApiKey?: string);
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
23
|
+
getHeaders: () => {
|
|
24
|
+
'x-api-key': string;
|
|
25
|
+
} | {
|
|
26
|
+
'x-api-key'?: undefined;
|
|
27
|
+
};
|
|
22
28
|
getIdentity: (pixelId: string, eventContext: EventContext | undefined) => Promise<any>;
|
|
23
29
|
identityAddPurchasedTraits: (pixelId: string, identityId: string, purchasedContactId: string, traits: PurchasedTraits, mergeToIdentityTraitsEnabled: boolean) => Promise<AddPurchasedTraitsResponse | null>;
|
|
24
30
|
mergeIdentity: (pixelId: string, primaryIdentityId: string, secondaryIdentityId: string) => Promise<MergeIdentityResponse | null>;
|
|
31
|
+
getIdentitiesByEmail: (email: string, pixelId?: string) => Promise<IdentityLookupByEmailResponse | null>;
|
|
25
32
|
}
|
|
@@ -4,41 +4,33 @@ exports.IdentityClient = void 0;
|
|
|
4
4
|
const libs_1 = require("../../libs");
|
|
5
5
|
const generic_1 = require("../generic");
|
|
6
6
|
const helpers_1 = require("../../helpers");
|
|
7
|
+
const client = (0, generic_1.axiosHttpService)({
|
|
8
|
+
headers: {
|
|
9
|
+
'Content-Type': 'application/json',
|
|
10
|
+
},
|
|
11
|
+
});
|
|
7
12
|
class IdentityClient {
|
|
8
13
|
BASE_API_URL;
|
|
14
|
+
SERVICE_API_ROOT_URL;
|
|
9
15
|
IDENTITY_API_KEY;
|
|
10
16
|
client;
|
|
11
17
|
constructor(baseApiUrl, identityApiKey) {
|
|
12
18
|
this.BASE_API_URL = baseApiUrl;
|
|
13
19
|
this.IDENTITY_API_KEY = identityApiKey;
|
|
14
|
-
this.
|
|
20
|
+
this.SERVICE_API_ROOT_URL = `${this.BASE_API_URL}/identities`;
|
|
21
|
+
this.client = client;
|
|
15
22
|
}
|
|
16
|
-
|
|
17
|
-
const IDENTITY_SERVICE_URL = `${this.BASE_API_URL}/identities`;
|
|
18
|
-
const params = {
|
|
19
|
-
baseURL: IDENTITY_SERVICE_URL,
|
|
20
|
-
};
|
|
23
|
+
getHeaders = () => {
|
|
21
24
|
if (this.IDENTITY_API_KEY) {
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
'x-api-key': this.IDENTITY_API_KEY,
|
|
25
|
-
},
|
|
25
|
+
return {
|
|
26
|
+
'x-api-key': this.IDENTITY_API_KEY,
|
|
26
27
|
};
|
|
27
28
|
}
|
|
28
|
-
return
|
|
29
|
-
};
|
|
30
|
-
_getClient = () => {
|
|
31
|
-
this.client = this.client ?? (0, generic_1.axiosHttpService)(this.getConfig());
|
|
32
|
-
return this.client;
|
|
33
|
-
};
|
|
34
|
-
_getIdentity = async (postBody) => {
|
|
35
|
-
const client = this._getClient();
|
|
36
|
-
const response = await client.post('/', postBody);
|
|
37
|
-
return response;
|
|
29
|
+
return {};
|
|
38
30
|
};
|
|
39
31
|
getIdentity = async (pixelId, eventContext) => {
|
|
40
32
|
try {
|
|
41
|
-
const identityResponse = await this.
|
|
33
|
+
const identityResponse = await this.client.post(`${this.SERVICE_API_ROOT_URL}`, { pixelId, context: eventContext || {} }, { headers: this.getHeaders() });
|
|
42
34
|
if (identityResponse.status != libs_1.HttpStatusCodes.OK) {
|
|
43
35
|
const msg = 'HTTP Status Code Failed while retrieving identity data';
|
|
44
36
|
helpers_1.Logger.error(msg, { identityResponse });
|
|
@@ -56,8 +48,7 @@ class IdentityClient {
|
|
|
56
48
|
};
|
|
57
49
|
identityAddPurchasedTraits = async (pixelId, identityId, purchasedContactId, traits, mergeToIdentityTraitsEnabled) => {
|
|
58
50
|
try {
|
|
59
|
-
const
|
|
60
|
-
const response = await client.post('/purchased-traits', { pixelId, identityId, purchasedContactId, traits, mergeToIdentityTraitsEnabled });
|
|
51
|
+
const response = await this.client.post(`${this.SERVICE_API_ROOT_URL}/purchased-traits`, { pixelId, identityId, purchasedContactId, traits, mergeToIdentityTraitsEnabled }, { headers: this.getHeaders() });
|
|
61
52
|
if (response.status === libs_1.HttpStatusCodes.OK) {
|
|
62
53
|
return response.data;
|
|
63
54
|
}
|
|
@@ -73,8 +64,7 @@ class IdentityClient {
|
|
|
73
64
|
};
|
|
74
65
|
mergeIdentity = async (pixelId, primaryIdentityId, secondaryIdentityId) => {
|
|
75
66
|
try {
|
|
76
|
-
const
|
|
77
|
-
const response = await client.post('/merge-identity', { pixelId, primaryIdentityId, secondaryIdentityId });
|
|
67
|
+
const response = await this.client.post(`${this.SERVICE_API_ROOT_URL}/merge-identity`, { pixelId, primaryIdentityId, secondaryIdentityId }, { headers: this.getHeaders() });
|
|
78
68
|
if (response.status === libs_1.HttpStatusCodes.OK) {
|
|
79
69
|
return response.data;
|
|
80
70
|
}
|
|
@@ -88,6 +78,22 @@ class IdentityClient {
|
|
|
88
78
|
return null;
|
|
89
79
|
}
|
|
90
80
|
};
|
|
81
|
+
getIdentitiesByEmail = async (email, pixelId) => {
|
|
82
|
+
try {
|
|
83
|
+
const response = await this.client.get(`${this.SERVICE_API_ROOT_URL}/identities-by-email`, { params: { pixelId, email }, headers: this.getHeaders() });
|
|
84
|
+
if (response.status === libs_1.HttpStatusCodes.OK) {
|
|
85
|
+
return response.data;
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
helpers_1.Logger.error('HTTP status code failed while looking up identity by email', { response, pixelId, email });
|
|
89
|
+
return null;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
catch (error) {
|
|
93
|
+
helpers_1.Logger.error('Error while looking up identity by email', { error, email });
|
|
94
|
+
return null;
|
|
95
|
+
}
|
|
96
|
+
};
|
|
91
97
|
}
|
|
92
98
|
exports.IdentityClient = IdentityClient;
|
|
93
99
|
//# sourceMappingURL=identity-client.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"identity-client.js","sourceRoot":"","sources":["../../../../src/clients/internal-api/identity-client.ts"],"names":[],"mappings":";;;AACA,qCAA6C;AAC7C,wCAAiE;AACjE,2CAAuC;
|
|
1
|
+
{"version":3,"file":"identity-client.js","sourceRoot":"","sources":["../../../../src/clients/internal-api/identity-client.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,30 +1,7 @@
|
|
|
1
|
-
import { EMAIL_STATUS } from '@adtrackify/at-tracking-event-types';
|
|
2
1
|
import { ApiResponse } from '../../types/api-response';
|
|
3
|
-
|
|
4
|
-
accept_all: boolean;
|
|
5
|
-
did_you_mean: string | null;
|
|
6
|
-
disposable: boolean;
|
|
7
|
-
domain: string;
|
|
8
|
-
duration: number;
|
|
9
|
-
email: string;
|
|
10
|
-
first_name: string | null;
|
|
11
|
-
free: boolean;
|
|
12
|
-
full_name: string | null;
|
|
13
|
-
gender: string | null;
|
|
14
|
-
last_name: string | null;
|
|
15
|
-
mailbox_full: boolean;
|
|
16
|
-
mx_record: string;
|
|
17
|
-
no_reply: boolean;
|
|
18
|
-
reason: string;
|
|
19
|
-
role: boolean;
|
|
20
|
-
score: number;
|
|
21
|
-
smtp_provider: string;
|
|
22
|
-
state: EMAIL_STATUS;
|
|
23
|
-
tag: string | null;
|
|
24
|
-
user: string;
|
|
25
|
-
}
|
|
2
|
+
import { EmailableVerifyEmailResponse } from '@adtrackify/at-tracking-event-types';
|
|
26
3
|
export declare class EmailableClient {
|
|
27
4
|
private EMAILABLE_API_KEY;
|
|
28
5
|
constructor(emailableApiKey: string);
|
|
29
|
-
verifyEmail: (email: string) => Promise<ApiResponse<EmailableVerifyEmailResponse>>;
|
|
6
|
+
verifyEmail: (email: string, retries?: number, maxRetries?: number, retryDelay?: number) => Promise<ApiResponse<EmailableVerifyEmailResponse>>;
|
|
30
7
|
}
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.EmailableClient = void 0;
|
|
4
4
|
const generic_1 = require("../generic");
|
|
5
|
+
const helpers_1 = require("../../helpers");
|
|
5
6
|
const EMAILABLE_API_URL = 'https://api.emailable.com/v1';
|
|
6
7
|
const client = (0, generic_1.axiosHttpService)({
|
|
7
8
|
baseURL: EMAILABLE_API_URL
|
|
@@ -11,8 +12,16 @@ class EmailableClient {
|
|
|
11
12
|
constructor(emailableApiKey) {
|
|
12
13
|
this.EMAILABLE_API_KEY = emailableApiKey;
|
|
13
14
|
}
|
|
14
|
-
verifyEmail = async (email) => {
|
|
15
|
+
verifyEmail = async (email, retries = 0, maxRetries = 3, retryDelay = 2000) => {
|
|
15
16
|
const response = await client.get('/verify', { params: { api_key: this.EMAILABLE_API_KEY, email } });
|
|
17
|
+
if (response.status === 249 || response.status >= 400) {
|
|
18
|
+
helpers_1.Logger.error('Failed to verify email', { response, email, retries, maxRetries, retryDelay });
|
|
19
|
+
if (retries < maxRetries) {
|
|
20
|
+
await new Promise(resolve => setTimeout(resolve, retryDelay));
|
|
21
|
+
helpers_1.Logger.info('Retrying to verify email', { email, retries, maxRetries, retryDelay });
|
|
22
|
+
return await this.verifyEmail(email, retries + 1, maxRetries, retryDelay);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
16
25
|
return response;
|
|
17
26
|
};
|
|
18
27
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"emailable-client.js","sourceRoot":"","sources":["../../../../src/clients/third-party/emailable-client.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"emailable-client.js","sourceRoot":"","sources":["../../../../src/clients/third-party/emailable-client.ts"],"names":[],"mappings":";;;AAAA,wCAA8C;AAG9C,2CAAuC;AAEvC,MAAM,iBAAiB,GAAG,8BAA8B,CAAC;AACzD,MAAM,MAAM,GAAG,IAAA,0BAAgB,EAAC;IAC9B,OAAO,EAAE,iBAAiB;CAC3B,CAAC,CAAC;AAEH,MAAa,eAAe;IAClB,iBAAiB,CAAS;IAElC,YAAY,eAAuB;QACjC,IAAI,CAAC,iBAAiB,GAAG,eAAe,CAAC;IAC3C,CAAC;IAEM,WAAW,GAAG,KAAK,EAAE,KAAa,EAAE,OAAO,GAAG,CAAC,EAAE,UAAU,GAAG,CAAC,EAAE,UAAU,GAAG,IAAI,EAAsD,EAAE;QAC/I,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,iBAAiB,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;QACrG,IAAI,QAAQ,CAAC,MAAM,KAAK,GAAG,IAAI,QAAQ,CAAC,MAAM,IAAI,GAAG,EAAE;YACrD,gBAAM,CAAC,KAAK,CAAC,wBAAwB,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,CAAC,CAAC;YAC7F,IAAI,OAAO,GAAG,UAAU,EAAE;gBACxB,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC;gBAC9D,gBAAM,CAAC,IAAI,CAAC,0BAA0B,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,CAAC,CAAC;gBACpF,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,OAAO,GAAG,CAAC,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;aAC3E;SACF;QACD,OAAO,QAAqD,CAAC;IAC/D,CAAC,CAAA;CACF;AAnBD,0CAmBC"}
|
|
@@ -21,6 +21,7 @@ const isIdentityCacheStale = (identityCache, incomingIdentity) => {
|
|
|
21
21
|
isClickInfosStale: false,
|
|
22
22
|
isIpAddressStale: false,
|
|
23
23
|
isUserAgentStale: false,
|
|
24
|
+
isThirdPartyContactIdsStale: false,
|
|
24
25
|
isCacheStale: false
|
|
25
26
|
};
|
|
26
27
|
const isNewUserIds = (0, at_shared_utils_1.hasNewTrait)(cachedTraits?.userIds ?? [], incomingTraits?.userIds ?? []);
|
|
@@ -87,6 +88,12 @@ const isIdentityCacheStale = (identityCache, incomingIdentity) => {
|
|
|
87
88
|
identityCacheStaleTracker.isUserAgentStale = true;
|
|
88
89
|
identityCacheStaleTracker.isCacheStale = true;
|
|
89
90
|
}
|
|
91
|
+
const isNewThirdPartyContactIds = (0, at_shared_utils_1.hasNewThirdPartyContact)(cachedTraits?.thirdPartyContacts ?? [], incomingTraits?.thirdPartyContacts ?? []);
|
|
92
|
+
if (isNewThirdPartyContactIds) {
|
|
93
|
+
logging_helper_1.Logger.debug('identity cache miss - thirdPartyContactIds changed', { cachedTraits, incomingTraits });
|
|
94
|
+
identityCacheStaleTracker.isThirdPartyContactIdsStale = true;
|
|
95
|
+
identityCacheStaleTracker.isCacheStale = true;
|
|
96
|
+
}
|
|
90
97
|
if (identityCacheStaleTracker.isCacheStale) {
|
|
91
98
|
logging_helper_1.Logger.debug('identity cache miss - cache stale', { identityCacheStaleTracker });
|
|
92
99
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"identity-cache-helper.js","sourceRoot":"","sources":["../../../src/helpers/identity-cache-helper.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"identity-cache-helper.js","sourceRoot":"","sources":["../../../src/helpers/identity-cache-helper.ts"],"names":[],"mappings":"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"}
|
package/dist/cjs/libs/index.d.ts
CHANGED
package/dist/cjs/libs/index.js
CHANGED
|
@@ -27,4 +27,5 @@ __exportStar(require("./csv.js"), exports);
|
|
|
27
27
|
__exportStar(require("./traits.js"), exports);
|
|
28
28
|
__exportStar(require("./currency.js"), exports);
|
|
29
29
|
__exportStar(require("./numbers.js"), exports);
|
|
30
|
+
__exportStar(require("./strings.js"), exports);
|
|
30
31
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/libs/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+DAA6C;AAC7C,8CAA4B;AAC5B,6CAA2B;AAC3B,kDAAgC;AAChC,yDAAuC;AACvC,2CAAyB;AACzB,6DAA2C;AAC3C,uDAAqC;AACrC,mDAAiC;AACjC,2CAAyB;AACzB,8CAA4B;AAC5B,gDAA8B;AAC9B,+CAA6B"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/libs/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+DAA6C;AAC7C,8CAA4B;AAC5B,6CAA2B;AAC3B,kDAAgC;AAChC,yDAAuC;AACvC,2CAAyB;AACzB,6DAA2C;AAC3C,uDAAqC;AACrC,mDAAiC;AACjC,2CAAyB;AACzB,8CAA4B;AAC5B,gDAA8B;AAC9B,+CAA6B;AAC7B,+CAA6B"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.containsUpperCase = exports.capitalizeFirstLetter = exports.capitalizeEachWord = void 0;
|
|
4
|
+
const helpers_1 = require("../helpers");
|
|
5
|
+
const capitalizeEachWord = (value) => {
|
|
6
|
+
try {
|
|
7
|
+
return value
|
|
8
|
+
.split(' ')
|
|
9
|
+
.map(word => word.charAt(0).toUpperCase() + word.slice(1).toLowerCase())
|
|
10
|
+
.join(' ');
|
|
11
|
+
}
|
|
12
|
+
catch (error) {
|
|
13
|
+
helpers_1.Logger.error('error capitalizing each word', { error, value });
|
|
14
|
+
return value;
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
exports.capitalizeEachWord = capitalizeEachWord;
|
|
18
|
+
const capitalizeFirstLetter = (value) => {
|
|
19
|
+
try {
|
|
20
|
+
return value.charAt(0).toUpperCase() + value.slice(1);
|
|
21
|
+
}
|
|
22
|
+
catch (error) {
|
|
23
|
+
helpers_1.Logger.error('error capitalizing first letter', { error, value });
|
|
24
|
+
return value;
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
exports.capitalizeFirstLetter = capitalizeFirstLetter;
|
|
28
|
+
const containsUpperCase = (input) => {
|
|
29
|
+
try {
|
|
30
|
+
return /[A-Z]/.test(input);
|
|
31
|
+
}
|
|
32
|
+
catch (error) {
|
|
33
|
+
helpers_1.Logger.error('error checking if string contains upper case', { error, input });
|
|
34
|
+
return false;
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
exports.containsUpperCase = containsUpperCase;
|
|
38
|
+
//# sourceMappingURL=strings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"strings.js","sourceRoot":"","sources":["../../../src/libs/strings.ts"],"names":[],"mappings":";;;AAAA,wCAAoC;AAE7B,MAAM,kBAAkB,GAAG,CAAC,KAAa,EAAE,EAAE;IAClD,IAAI;QACF,OAAO,KAAK;aACT,KAAK,CAAC,GAAG,CAAC;aACV,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;aACvE,IAAI,CAAC,GAAG,CAAC,CAAC;KACd;IAAC,OAAO,KAAK,EAAE;QACd,gBAAM,CAAC,KAAK,CAAC,8BAA8B,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QAC/D,OAAO,KAAK,CAAC;KACd;AACH,CAAC,CAAC;AAVW,QAAA,kBAAkB,sBAU7B;AAEK,MAAM,qBAAqB,GAAG,CAAC,KAAa,EAAE,EAAE;IACrD,IAAI;QACF,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KACvD;IAAC,OAAO,KAAK,EAAE;QACd,gBAAM,CAAC,KAAK,CAAC,iCAAiC,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QAClE,OAAO,KAAK,CAAC;KACd;AACH,CAAC,CAAC;AAPW,QAAA,qBAAqB,yBAOhC;AAEK,MAAM,iBAAiB,GAAG,CAAC,KAAa,EAAW,EAAE;IAC1D,IAAI;QACF,OAAO,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;KAC5B;IAAC,OAAO,KAAK,EAAE;QACd,gBAAM,CAAC,KAAK,CAAC,8CAA8C,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QAC/E,OAAO,KAAK,CAAC;KACd;AACH,CAAC,CAAC;AAPW,QAAA,iBAAiB,qBAO5B"}
|
|
@@ -11,15 +11,22 @@ export interface MergeIdentityResponse {
|
|
|
11
11
|
isIdentityMerged: boolean;
|
|
12
12
|
identity?: EventIdentity;
|
|
13
13
|
}
|
|
14
|
+
export interface IdentityLookupByEmailResponse {
|
|
15
|
+
identities: EventIdentity[];
|
|
16
|
+
}
|
|
14
17
|
export declare class IdentityClient {
|
|
15
|
-
|
|
16
|
-
|
|
18
|
+
BASE_API_URL: string;
|
|
19
|
+
SERVICE_API_ROOT_URL: string;
|
|
20
|
+
IDENTITY_API_KEY?: string;
|
|
17
21
|
client: GenericHttpClient;
|
|
18
22
|
constructor(baseApiUrl: string, identityApiKey?: string);
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
23
|
+
getHeaders: () => {
|
|
24
|
+
'x-api-key': string;
|
|
25
|
+
} | {
|
|
26
|
+
'x-api-key'?: undefined;
|
|
27
|
+
};
|
|
22
28
|
getIdentity: (pixelId: string, eventContext: EventContext | undefined) => Promise<any>;
|
|
23
29
|
identityAddPurchasedTraits: (pixelId: string, identityId: string, purchasedContactId: string, traits: PurchasedTraits, mergeToIdentityTraitsEnabled: boolean) => Promise<AddPurchasedTraitsResponse | null>;
|
|
24
30
|
mergeIdentity: (pixelId: string, primaryIdentityId: string, secondaryIdentityId: string) => Promise<MergeIdentityResponse | null>;
|
|
31
|
+
getIdentitiesByEmail: (email: string, pixelId?: string) => Promise<IdentityLookupByEmailResponse | null>;
|
|
25
32
|
}
|
|
@@ -1,41 +1,33 @@
|
|
|
1
1
|
import { HttpStatusCodes } from '../../libs';
|
|
2
2
|
import { axiosHttpService } from '../generic';
|
|
3
3
|
import { Logger } from '../../helpers';
|
|
4
|
+
const client = axiosHttpService({
|
|
5
|
+
headers: {
|
|
6
|
+
'Content-Type': 'application/json',
|
|
7
|
+
},
|
|
8
|
+
});
|
|
4
9
|
export class IdentityClient {
|
|
5
10
|
BASE_API_URL;
|
|
11
|
+
SERVICE_API_ROOT_URL;
|
|
6
12
|
IDENTITY_API_KEY;
|
|
7
13
|
client;
|
|
8
14
|
constructor(baseApiUrl, identityApiKey) {
|
|
9
15
|
this.BASE_API_URL = baseApiUrl;
|
|
10
16
|
this.IDENTITY_API_KEY = identityApiKey;
|
|
11
|
-
this.
|
|
17
|
+
this.SERVICE_API_ROOT_URL = `${this.BASE_API_URL}/identities`;
|
|
18
|
+
this.client = client;
|
|
12
19
|
}
|
|
13
|
-
|
|
14
|
-
const IDENTITY_SERVICE_URL = `${this.BASE_API_URL}/identities`;
|
|
15
|
-
const params = {
|
|
16
|
-
baseURL: IDENTITY_SERVICE_URL,
|
|
17
|
-
};
|
|
20
|
+
getHeaders = () => {
|
|
18
21
|
if (this.IDENTITY_API_KEY) {
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
'x-api-key': this.IDENTITY_API_KEY,
|
|
22
|
-
},
|
|
22
|
+
return {
|
|
23
|
+
'x-api-key': this.IDENTITY_API_KEY,
|
|
23
24
|
};
|
|
24
25
|
}
|
|
25
|
-
return
|
|
26
|
-
};
|
|
27
|
-
_getClient = () => {
|
|
28
|
-
this.client = this.client ?? axiosHttpService(this.getConfig());
|
|
29
|
-
return this.client;
|
|
30
|
-
};
|
|
31
|
-
_getIdentity = async (postBody) => {
|
|
32
|
-
const client = this._getClient();
|
|
33
|
-
const response = await client.post('/', postBody);
|
|
34
|
-
return response;
|
|
26
|
+
return {};
|
|
35
27
|
};
|
|
36
28
|
getIdentity = async (pixelId, eventContext) => {
|
|
37
29
|
try {
|
|
38
|
-
const identityResponse = await this.
|
|
30
|
+
const identityResponse = await this.client.post(`${this.SERVICE_API_ROOT_URL}`, { pixelId, context: eventContext || {} }, { headers: this.getHeaders() });
|
|
39
31
|
if (identityResponse.status != HttpStatusCodes.OK) {
|
|
40
32
|
const msg = 'HTTP Status Code Failed while retrieving identity data';
|
|
41
33
|
Logger.error(msg, { identityResponse });
|
|
@@ -53,8 +45,7 @@ export class IdentityClient {
|
|
|
53
45
|
};
|
|
54
46
|
identityAddPurchasedTraits = async (pixelId, identityId, purchasedContactId, traits, mergeToIdentityTraitsEnabled) => {
|
|
55
47
|
try {
|
|
56
|
-
const
|
|
57
|
-
const response = await client.post('/purchased-traits', { pixelId, identityId, purchasedContactId, traits, mergeToIdentityTraitsEnabled });
|
|
48
|
+
const response = await this.client.post(`${this.SERVICE_API_ROOT_URL}/purchased-traits`, { pixelId, identityId, purchasedContactId, traits, mergeToIdentityTraitsEnabled }, { headers: this.getHeaders() });
|
|
58
49
|
if (response.status === HttpStatusCodes.OK) {
|
|
59
50
|
return response.data;
|
|
60
51
|
}
|
|
@@ -70,8 +61,7 @@ export class IdentityClient {
|
|
|
70
61
|
};
|
|
71
62
|
mergeIdentity = async (pixelId, primaryIdentityId, secondaryIdentityId) => {
|
|
72
63
|
try {
|
|
73
|
-
const
|
|
74
|
-
const response = await client.post('/merge-identity', { pixelId, primaryIdentityId, secondaryIdentityId });
|
|
64
|
+
const response = await this.client.post(`${this.SERVICE_API_ROOT_URL}/merge-identity`, { pixelId, primaryIdentityId, secondaryIdentityId }, { headers: this.getHeaders() });
|
|
75
65
|
if (response.status === HttpStatusCodes.OK) {
|
|
76
66
|
return response.data;
|
|
77
67
|
}
|
|
@@ -85,5 +75,21 @@ export class IdentityClient {
|
|
|
85
75
|
return null;
|
|
86
76
|
}
|
|
87
77
|
};
|
|
78
|
+
getIdentitiesByEmail = async (email, pixelId) => {
|
|
79
|
+
try {
|
|
80
|
+
const response = await this.client.get(`${this.SERVICE_API_ROOT_URL}/identities-by-email`, { params: { pixelId, email }, headers: this.getHeaders() });
|
|
81
|
+
if (response.status === HttpStatusCodes.OK) {
|
|
82
|
+
return response.data;
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
Logger.error('HTTP status code failed while looking up identity by email', { response, pixelId, email });
|
|
86
|
+
return null;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
catch (error) {
|
|
90
|
+
Logger.error('Error while looking up identity by email', { error, email });
|
|
91
|
+
return null;
|
|
92
|
+
}
|
|
93
|
+
};
|
|
88
94
|
}
|
|
89
95
|
//# sourceMappingURL=identity-client.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"identity-client.js","sourceRoot":"","sources":["../../../../src/clients/internal-api/identity-client.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAC7C,OAAO,EAAqB,gBAAgB,EAAE,MAAM,YAAY,CAAC;AACjE,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"identity-client.js","sourceRoot":"","sources":["../../../../src/clients/internal-api/identity-client.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,30 +1,7 @@
|
|
|
1
|
-
import { EMAIL_STATUS } from '@adtrackify/at-tracking-event-types';
|
|
2
1
|
import { ApiResponse } from '../../types/api-response';
|
|
3
|
-
|
|
4
|
-
accept_all: boolean;
|
|
5
|
-
did_you_mean: string | null;
|
|
6
|
-
disposable: boolean;
|
|
7
|
-
domain: string;
|
|
8
|
-
duration: number;
|
|
9
|
-
email: string;
|
|
10
|
-
first_name: string | null;
|
|
11
|
-
free: boolean;
|
|
12
|
-
full_name: string | null;
|
|
13
|
-
gender: string | null;
|
|
14
|
-
last_name: string | null;
|
|
15
|
-
mailbox_full: boolean;
|
|
16
|
-
mx_record: string;
|
|
17
|
-
no_reply: boolean;
|
|
18
|
-
reason: string;
|
|
19
|
-
role: boolean;
|
|
20
|
-
score: number;
|
|
21
|
-
smtp_provider: string;
|
|
22
|
-
state: EMAIL_STATUS;
|
|
23
|
-
tag: string | null;
|
|
24
|
-
user: string;
|
|
25
|
-
}
|
|
2
|
+
import { EmailableVerifyEmailResponse } from '@adtrackify/at-tracking-event-types';
|
|
26
3
|
export declare class EmailableClient {
|
|
27
4
|
private EMAILABLE_API_KEY;
|
|
28
5
|
constructor(emailableApiKey: string);
|
|
29
|
-
verifyEmail: (email: string) => Promise<ApiResponse<EmailableVerifyEmailResponse>>;
|
|
6
|
+
verifyEmail: (email: string, retries?: number, maxRetries?: number, retryDelay?: number) => Promise<ApiResponse<EmailableVerifyEmailResponse>>;
|
|
30
7
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { axiosHttpService } from '../generic';
|
|
2
|
+
import { Logger } from '../../helpers';
|
|
2
3
|
const EMAILABLE_API_URL = 'https://api.emailable.com/v1';
|
|
3
4
|
const client = axiosHttpService({
|
|
4
5
|
baseURL: EMAILABLE_API_URL
|
|
@@ -8,8 +9,16 @@ export class EmailableClient {
|
|
|
8
9
|
constructor(emailableApiKey) {
|
|
9
10
|
this.EMAILABLE_API_KEY = emailableApiKey;
|
|
10
11
|
}
|
|
11
|
-
verifyEmail = async (email) => {
|
|
12
|
+
verifyEmail = async (email, retries = 0, maxRetries = 3, retryDelay = 2000) => {
|
|
12
13
|
const response = await client.get('/verify', { params: { api_key: this.EMAILABLE_API_KEY, email } });
|
|
14
|
+
if (response.status === 249 || response.status >= 400) {
|
|
15
|
+
Logger.error('Failed to verify email', { response, email, retries, maxRetries, retryDelay });
|
|
16
|
+
if (retries < maxRetries) {
|
|
17
|
+
await new Promise(resolve => setTimeout(resolve, retryDelay));
|
|
18
|
+
Logger.info('Retrying to verify email', { email, retries, maxRetries, retryDelay });
|
|
19
|
+
return await this.verifyEmail(email, retries + 1, maxRetries, retryDelay);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
13
22
|
return response;
|
|
14
23
|
};
|
|
15
24
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"emailable-client.js","sourceRoot":"","sources":["../../../../src/clients/third-party/emailable-client.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"emailable-client.js","sourceRoot":"","sources":["../../../../src/clients/third-party/emailable-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAG9C,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,MAAM,iBAAiB,GAAG,8BAA8B,CAAC;AACzD,MAAM,MAAM,GAAG,gBAAgB,CAAC;IAC9B,OAAO,EAAE,iBAAiB;CAC3B,CAAC,CAAC;AAEH,MAAM,OAAO,eAAe;IAClB,iBAAiB,CAAS;IAElC,YAAY,eAAuB;QACjC,IAAI,CAAC,iBAAiB,GAAG,eAAe,CAAC;IAC3C,CAAC;IAEM,WAAW,GAAG,KAAK,EAAE,KAAa,EAAE,OAAO,GAAG,CAAC,EAAE,UAAU,GAAG,CAAC,EAAE,UAAU,GAAG,IAAI,EAAsD,EAAE;QAC/I,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,iBAAiB,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;QACrG,IAAI,QAAQ,CAAC,MAAM,KAAK,GAAG,IAAI,QAAQ,CAAC,MAAM,IAAI,GAAG,EAAE;YACrD,MAAM,CAAC,KAAK,CAAC,wBAAwB,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,CAAC,CAAC;YAC7F,IAAI,OAAO,GAAG,UAAU,EAAE;gBACxB,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC;gBAC9D,MAAM,CAAC,IAAI,CAAC,0BAA0B,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,CAAC,CAAC;gBACpF,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,OAAO,GAAG,CAAC,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;aAC3E;SACF;QACD,OAAO,QAAqD,CAAC;IAC/D,CAAC,CAAA;CACF"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { hasNewTrait, hasNewAddress, removeEmptyFields } from '@adtrackify/at-shared-utils';
|
|
1
|
+
import { hasNewTrait, hasNewAddress, removeEmptyFields, hasNewThirdPartyContact } from '@adtrackify/at-shared-utils';
|
|
2
2
|
import { Logger } from './logging-helper';
|
|
3
3
|
export const isIdentityCacheStale = (identityCache, incomingIdentity) => {
|
|
4
4
|
try {
|
|
@@ -18,6 +18,7 @@ export const isIdentityCacheStale = (identityCache, incomingIdentity) => {
|
|
|
18
18
|
isClickInfosStale: false,
|
|
19
19
|
isIpAddressStale: false,
|
|
20
20
|
isUserAgentStale: false,
|
|
21
|
+
isThirdPartyContactIdsStale: false,
|
|
21
22
|
isCacheStale: false
|
|
22
23
|
};
|
|
23
24
|
const isNewUserIds = hasNewTrait(cachedTraits?.userIds ?? [], incomingTraits?.userIds ?? []);
|
|
@@ -84,6 +85,12 @@ export const isIdentityCacheStale = (identityCache, incomingIdentity) => {
|
|
|
84
85
|
identityCacheStaleTracker.isUserAgentStale = true;
|
|
85
86
|
identityCacheStaleTracker.isCacheStale = true;
|
|
86
87
|
}
|
|
88
|
+
const isNewThirdPartyContactIds = hasNewThirdPartyContact(cachedTraits?.thirdPartyContacts ?? [], incomingTraits?.thirdPartyContacts ?? []);
|
|
89
|
+
if (isNewThirdPartyContactIds) {
|
|
90
|
+
Logger.debug('identity cache miss - thirdPartyContactIds changed', { cachedTraits, incomingTraits });
|
|
91
|
+
identityCacheStaleTracker.isThirdPartyContactIdsStale = true;
|
|
92
|
+
identityCacheStaleTracker.isCacheStale = true;
|
|
93
|
+
}
|
|
87
94
|
if (identityCacheStaleTracker.isCacheStale) {
|
|
88
95
|
Logger.debug('identity cache miss - cache stale', { identityCacheStaleTracker });
|
|
89
96
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"identity-cache-helper.js","sourceRoot":"","sources":["../../../src/helpers/identity-cache-helper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;
|
|
1
|
+
{"version":3,"file":"identity-cache-helper.js","sourceRoot":"","sources":["../../../src/helpers/identity-cache-helper.ts"],"names":[],"mappings":"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"}
|
package/dist/esm/libs/index.d.ts
CHANGED
package/dist/esm/libs/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/libs/index.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC;AAC7C,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,iBAAiB,CAAC;AAChC,cAAc,wBAAwB,CAAC;AACvC,cAAc,UAAU,CAAC;AACzB,cAAc,4BAA4B,CAAC;AAC3C,cAAc,sBAAsB,CAAC;AACrC,cAAc,kBAAkB,CAAC;AACjC,cAAc,UAAU,CAAC;AACzB,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,cAAc,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/libs/index.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC;AAC7C,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,iBAAiB,CAAC;AAChC,cAAc,wBAAwB,CAAC;AACvC,cAAc,UAAU,CAAC;AACzB,cAAc,4BAA4B,CAAC;AAC3C,cAAc,sBAAsB,CAAC;AACrC,cAAc,kBAAkB,CAAC;AACjC,cAAc,UAAU,CAAC;AACzB,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Logger } from '../helpers';
|
|
2
|
+
export const capitalizeEachWord = (value) => {
|
|
3
|
+
try {
|
|
4
|
+
return value
|
|
5
|
+
.split(' ')
|
|
6
|
+
.map(word => word.charAt(0).toUpperCase() + word.slice(1).toLowerCase())
|
|
7
|
+
.join(' ');
|
|
8
|
+
}
|
|
9
|
+
catch (error) {
|
|
10
|
+
Logger.error('error capitalizing each word', { error, value });
|
|
11
|
+
return value;
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
export const capitalizeFirstLetter = (value) => {
|
|
15
|
+
try {
|
|
16
|
+
return value.charAt(0).toUpperCase() + value.slice(1);
|
|
17
|
+
}
|
|
18
|
+
catch (error) {
|
|
19
|
+
Logger.error('error capitalizing first letter', { error, value });
|
|
20
|
+
return value;
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
export const containsUpperCase = (input) => {
|
|
24
|
+
try {
|
|
25
|
+
return /[A-Z]/.test(input);
|
|
26
|
+
}
|
|
27
|
+
catch (error) {
|
|
28
|
+
Logger.error('error checking if string contains upper case', { error, input });
|
|
29
|
+
return false;
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
//# sourceMappingURL=strings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"strings.js","sourceRoot":"","sources":["../../../src/libs/strings.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAEpC,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,KAAa,EAAE,EAAE;IAClD,IAAI;QACF,OAAO,KAAK;aACT,KAAK,CAAC,GAAG,CAAC;aACV,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;aACvE,IAAI,CAAC,GAAG,CAAC,CAAC;KACd;IAAC,OAAO,KAAK,EAAE;QACd,MAAM,CAAC,KAAK,CAAC,8BAA8B,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QAC/D,OAAO,KAAK,CAAC;KACd;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,KAAa,EAAE,EAAE;IACrD,IAAI;QACF,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KACvD;IAAC,OAAO,KAAK,EAAE;QACd,MAAM,CAAC,KAAK,CAAC,iCAAiC,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QAClE,OAAO,KAAK,CAAC;KACd;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,KAAa,EAAW,EAAE;IAC1D,IAAI;QACF,OAAO,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;KAC5B;IAAC,OAAO,KAAK,EAAE;QACd,MAAM,CAAC,KAAK,CAAC,8CAA8C,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QAC/E,OAAO,KAAK,CAAC;KACd;AACH,CAAC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@adtrackify/at-service-common",
|
|
3
|
-
"version": "3.2
|
|
3
|
+
"version": "3.3.2",
|
|
4
4
|
"description": "",
|
|
5
5
|
"files": [
|
|
6
6
|
"dist/*"
|
|
@@ -36,7 +36,7 @@
|
|
|
36
36
|
"shopify:graphql:codegen": "graphql-codegen"
|
|
37
37
|
},
|
|
38
38
|
"dependencies": {
|
|
39
|
-
"@adtrackify/at-shared-utils": "^3.1.
|
|
39
|
+
"@adtrackify/at-shared-utils": "^3.1.4",
|
|
40
40
|
"@aws-sdk/util-utf8": "^3.374.0",
|
|
41
41
|
"@shopify/admin-api-client": "^1.0.4",
|
|
42
42
|
"@shopify/shopify-api": "^11.6.1",
|
|
@@ -61,7 +61,7 @@
|
|
|
61
61
|
"uuid": "^9.0.0"
|
|
62
62
|
},
|
|
63
63
|
"devDependencies": {
|
|
64
|
-
"@adtrackify/at-tracking-event-types": "^3.3.
|
|
64
|
+
"@adtrackify/at-tracking-event-types": "^3.3.12",
|
|
65
65
|
"@aws-sdk/client-cognito-identity-provider": "^3.345.0",
|
|
66
66
|
"@aws-sdk/client-dynamodb": "^3.345.0",
|
|
67
67
|
"@aws-sdk/client-eventbridge": "^3.345.0",
|
|
@@ -126,4 +126,4 @@
|
|
|
126
126
|
"author": "",
|
|
127
127
|
"license": "ISC",
|
|
128
128
|
"homepage": "https://bitbucket.org/eacap/at-service-common#readme"
|
|
129
|
-
}
|
|
129
|
+
}
|