@adtrackify/at-service-common 3.19.0 → 3.19.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/__tests__/clients/acuity-client.spec.js +0 -10
- package/dist/cjs/__tests__/clients/acuity-client.spec.js.map +1 -1
- package/dist/cjs/__tests__/services/acuity-api-service.spec.js +0 -20
- package/dist/cjs/__tests__/services/acuity-api-service.spec.js.map +1 -1
- package/dist/cjs/clients/third-party/acuity-client.d.ts +0 -1
- package/dist/cjs/clients/third-party/acuity-client.js +0 -6
- package/dist/cjs/clients/third-party/acuity-client.js.map +1 -1
- package/dist/cjs/services/acuity-api-service.d.ts +0 -1
- package/dist/cjs/services/acuity-api-service.js +0 -19
- package/dist/cjs/services/acuity-api-service.js.map +1 -1
- package/dist/cjs/services/db/custom-measures-db-service.d.ts +10 -0
- package/dist/cjs/services/db/custom-measures-db-service.js +35 -0
- package/dist/cjs/services/db/custom-measures-db-service.js.map +1 -0
- package/dist/cjs/services/db/index.d.ts +1 -0
- package/dist/cjs/services/db/index.js +1 -0
- package/dist/cjs/services/db/index.js.map +1 -1
- package/dist/esm/__tests__/clients/acuity-client.spec.js +0 -10
- package/dist/esm/__tests__/clients/acuity-client.spec.js.map +1 -1
- package/dist/esm/__tests__/services/acuity-api-service.spec.js +0 -20
- package/dist/esm/__tests__/services/acuity-api-service.spec.js.map +1 -1
- package/dist/esm/clients/third-party/acuity-client.d.ts +0 -1
- package/dist/esm/clients/third-party/acuity-client.js +0 -6
- package/dist/esm/clients/third-party/acuity-client.js.map +1 -1
- package/dist/esm/services/acuity-api-service.d.ts +0 -1
- package/dist/esm/services/acuity-api-service.js +0 -19
- package/dist/esm/services/acuity-api-service.js.map +1 -1
- package/dist/esm/services/db/custom-measures-db-service.d.ts +10 -0
- package/dist/esm/services/db/custom-measures-db-service.js +31 -0
- package/dist/esm/services/db/custom-measures-db-service.js.map +1 -0
- package/dist/esm/services/db/index.d.ts +1 -0
- package/dist/esm/services/db/index.js +1 -0
- package/dist/esm/services/db/index.js.map +1 -1
- package/package.json +2 -2
|
@@ -24,16 +24,6 @@ describe('AcuityClient', () => {
|
|
|
24
24
|
expect(config.headers.Authorization).toContain('MD5HASH');
|
|
25
25
|
expect(response).toEqual({ status: 200, data: { identities: [{ id: 1 }] } });
|
|
26
26
|
});
|
|
27
|
-
it('requests byEmail with the template id, a url-encoded email, and a bearer auth header', async () => {
|
|
28
|
-
mockGet.mockResolvedValue({ status: 200, data: { identities: [{ id: 1 }] } });
|
|
29
|
-
const client = new acuity_client_1.AcuityClient('KEY_ID', 'SECRET');
|
|
30
|
-
const response = await client.getContactsByEmail('a+b@x.com');
|
|
31
|
-
expect(mockGet).toHaveBeenCalledTimes(1);
|
|
32
|
-
const [url, config] = mockGet.mock.calls[0];
|
|
33
|
-
expect(url).toBe('/v2/identities/byEmail?email=a%2Bb%40x.com&template=1701523581');
|
|
34
|
-
expect(config.headers.Authorization).toMatch(/^Bearer KEY_ID/);
|
|
35
|
-
expect(response).toEqual({ status: 200, data: { identities: [{ id: 1 }] } });
|
|
36
|
-
});
|
|
37
27
|
it('passes a non-200 response through without throwing', async () => {
|
|
38
28
|
mockGet.mockResolvedValue({ status: 500, data: undefined });
|
|
39
29
|
const client = new acuity_client_1.AcuityClient('KEY_ID', 'SECRET');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"acuity-client.spec.js","sourceRoot":"","sources":["../../../../src/__tests__/clients/acuity-client.spec.ts"],"names":[],"mappings":";;AAGA,mDAAyD;AAEzD,IAAI,CAAC,IAAI,CAAC,uBAAuB,EAAE,GAAG,EAAE,CAAC,CAAC;IACxC,gBAAgB,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;CACtD,CAAC,CAAC,CAAC;AAEJ,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,GAAG,EAAE,CAAC,CAAC;IACpC,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC;CAC1C,CAAC,CAAC,CAAC;AAEJ,2EAAuE;AAGvE,MAAM,OAAO,GAAI,0BAA8B,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAgB,CAAC;AAEvF,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,UAAU,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;QAC5E,OAAO,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;QAC9E,MAAM,MAAM,GAAG,IAAI,4BAAY,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAEpD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAEzD,MAAM,CAAC,OAAO,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC5C,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,qDAAqD,CAAC,CAAC;QACxE,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;QAC/D,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAC1D,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IAC/E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"acuity-client.spec.js","sourceRoot":"","sources":["../../../../src/__tests__/clients/acuity-client.spec.ts"],"names":[],"mappings":";;AAGA,mDAAyD;AAEzD,IAAI,CAAC,IAAI,CAAC,uBAAuB,EAAE,GAAG,EAAE,CAAC,CAAC;IACxC,gBAAgB,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;CACtD,CAAC,CAAC,CAAC;AAEJ,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,GAAG,EAAE,CAAC,CAAC;IACpC,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC;CAC1C,CAAC,CAAC,CAAC;AAEJ,2EAAuE;AAGvE,MAAM,OAAO,GAAI,0BAA8B,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAgB,CAAC;AAEvF,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,UAAU,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;QAC5E,OAAO,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;QAC9E,MAAM,MAAM,GAAG,IAAI,4BAAY,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAEpD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAEzD,MAAM,CAAC,OAAO,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC5C,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,qDAAqD,CAAC,CAAC;QACxE,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;QAC/D,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAC1D,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IAC/E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE,KAAK,IAAI,EAAE;QAClE,OAAO,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;QAC5D,MAAM,MAAM,GAAG,IAAI,4BAAY,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAEpD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAEzD,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const mockGetContactsByMd5 = jest.fn();
|
|
4
|
-
const mockGetContactsByEmail = jest.fn();
|
|
5
4
|
jest.mock('../../clients/third-party/acuity-client', () => ({
|
|
6
5
|
AcuityClient: jest.fn().mockImplementation(() => ({
|
|
7
6
|
getContactsByMd5: mockGetContactsByMd5,
|
|
8
|
-
getContactsByEmail: mockGetContactsByEmail,
|
|
9
7
|
})),
|
|
10
8
|
}));
|
|
11
9
|
jest.mock('../../helpers/logging-helper', () => ({
|
|
@@ -36,24 +34,6 @@ describe('AcuityApiService', () => {
|
|
|
36
34
|
expect(result).toBeNull();
|
|
37
35
|
});
|
|
38
36
|
});
|
|
39
|
-
describe('getAcuityContactsByEmail', () => {
|
|
40
|
-
it('returns the response data on a 200', async () => {
|
|
41
|
-
mockGetContactsByEmail.mockResolvedValue({ status: 200, data: { identities: [{ id: 1 }] } });
|
|
42
|
-
const result = await service.getAcuityContactsByEmail('pixel', 'identity', 'a@x.com', DESTINATION);
|
|
43
|
-
expect(mockGetContactsByEmail).toHaveBeenCalledWith('a@x.com');
|
|
44
|
-
expect(result).toEqual({ identities: [{ id: 1 }] });
|
|
45
|
-
});
|
|
46
|
-
it('returns null on a non-200 response', async () => {
|
|
47
|
-
mockGetContactsByEmail.mockResolvedValue({ status: 404, data: undefined });
|
|
48
|
-
const result = await service.getAcuityContactsByEmail('pixel', 'identity', 'a@x.com', DESTINATION);
|
|
49
|
-
expect(result).toBeNull();
|
|
50
|
-
});
|
|
51
|
-
it('returns null when the client throws', async () => {
|
|
52
|
-
mockGetContactsByEmail.mockRejectedValue(new Error('network'));
|
|
53
|
-
const result = await service.getAcuityContactsByEmail('pixel', 'identity', 'a@x.com', DESTINATION);
|
|
54
|
-
expect(result).toBeNull();
|
|
55
|
-
});
|
|
56
|
-
});
|
|
57
37
|
describe('getAcuityContactsByMd5Batch', () => {
|
|
58
38
|
it('aggregates 200 identities keyed by md5 and skips non-200 hashes', async () => {
|
|
59
39
|
mockGetContactsByMd5
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"acuity-api-service.spec.js","sourceRoot":"","sources":["../../../../src/__tests__/services/acuity-api-service.spec.ts"],"names":[],"mappings":";;AAKA,MAAM,oBAAoB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"acuity-api-service.spec.js","sourceRoot":"","sources":["../../../../src/__tests__/services/acuity-api-service.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,6 +5,5 @@ export declare class AcuityClient {
|
|
|
5
5
|
private AA_SECRET;
|
|
6
6
|
constructor(acuityKeyId: string, acuitySecret: string);
|
|
7
7
|
getContactsByMd5: (md5Hash: string) => Promise<ApiResponse<AcuityContactResponse>>;
|
|
8
|
-
getContactsByEmail: (email: string) => Promise<ApiResponse<AcuityContactResponse>>;
|
|
9
8
|
private generateAuthorization;
|
|
10
9
|
}
|
|
@@ -25,12 +25,6 @@ class AcuityClient {
|
|
|
25
25
|
});
|
|
26
26
|
return response;
|
|
27
27
|
};
|
|
28
|
-
getContactsByEmail = async (email) => {
|
|
29
|
-
const response = await client.get(`/v2/identities/byEmail?email=${encodeURIComponent(email)}&template=${AA_TEMPLATE_ID}`, {
|
|
30
|
-
headers: { Authorization: this.generateAuthorization() },
|
|
31
|
-
});
|
|
32
|
-
return response;
|
|
33
|
-
};
|
|
34
28
|
generateAuthorization = () => {
|
|
35
29
|
const now = Date.now().toString(36);
|
|
36
30
|
const hash = (0, crypto_1.generateMd5Hash)(`${now}${this.AA_SECRET}`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"acuity-client.js","sourceRoot":"","sources":["../../../../src/clients/third-party/acuity-client.ts"],"names":[],"mappings":";;;AAAA,wCAA8C;AAE9C,8CAAoD;AAGpD,MAAM,UAAU,GAAG,gCAAgC,CAAC;AACpD,MAAM,cAAc,GAAG,YAAY,CAAC;AAEpC,MAAM,MAAM,GAAG,IAAA,0BAAgB,EAAC;IAC9B,OAAO,EAAE,UAAU;IACnB,OAAO,EAAE;QACP,MAAM,EAAE,kBAAkB;QAC1B,cAAc,EAAE,kBAAkB;KACnC;CACF,CAAC,CAAC;AAEH,MAAa,YAAY;IACf,SAAS,CAAS;IAClB,SAAS,CAAS;IAE1B,YAAY,WAAmB,EAAE,YAAoB;QACnD,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC;QAC7B,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC;IAChC,CAAC;IAEM,gBAAgB,GAAG,KAAK,EAAE,OAAe,EAA+C,EAAE;QAC/F,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,4BAA4B,OAAO,aAAa,cAAc,EAAE,EAAE;YAClG,OAAO,EAAE,EAAE,aAAa,EAAE,IAAI,CAAC,qBAAqB,EAAE,EAAE;SACzD,CAAC,CAAC;QACH,OAAO,QAA8C,CAAC;IACxD,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"acuity-client.js","sourceRoot":"","sources":["../../../../src/clients/third-party/acuity-client.ts"],"names":[],"mappings":";;;AAAA,wCAA8C;AAE9C,8CAAoD;AAGpD,MAAM,UAAU,GAAG,gCAAgC,CAAC;AACpD,MAAM,cAAc,GAAG,YAAY,CAAC;AAEpC,MAAM,MAAM,GAAG,IAAA,0BAAgB,EAAC;IAC9B,OAAO,EAAE,UAAU;IACnB,OAAO,EAAE;QACP,MAAM,EAAE,kBAAkB;QAC1B,cAAc,EAAE,kBAAkB;KACnC;CACF,CAAC,CAAC;AAEH,MAAa,YAAY;IACf,SAAS,CAAS;IAClB,SAAS,CAAS;IAE1B,YAAY,WAAmB,EAAE,YAAoB;QACnD,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC;QAC7B,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC;IAChC,CAAC;IAEM,gBAAgB,GAAG,KAAK,EAAE,OAAe,EAA+C,EAAE;QAC/F,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,4BAA4B,OAAO,aAAa,cAAc,EAAE,EAAE;YAClG,OAAO,EAAE,EAAE,aAAa,EAAE,IAAI,CAAC,qBAAqB,EAAE,EAAE;SACzD,CAAC,CAAC;QACH,OAAO,QAA8C,CAAC;IACxD,CAAC,CAAC;IAEM,qBAAqB,GAAG,GAAW,EAAE;QAC3C,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QACpC,MAAM,IAAI,GAAG,IAAA,wBAAe,EAAC,GAAG,GAAG,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QACxD,OAAO,UAAU,IAAI,CAAC,SAAS,GAAG,GAAG,GAAG,IAAI,EAAE,CAAC;IACjD,CAAC,CAAC;CACH;AArBD,oCAqBC"}
|
|
@@ -4,6 +4,5 @@ export declare class AcuityApiService {
|
|
|
4
4
|
private acuityClient;
|
|
5
5
|
constructor(acuityKeyId: string, acuitySecret: string);
|
|
6
6
|
getAcuityContactsByMd5: (pixelId: string, identityId: string, md5Hash: string, contactAcquisitionIntegration: Destination) => Promise<AcuityContactResponse | null>;
|
|
7
|
-
getAcuityContactsByEmail: (pixelId: string, identityId: string, email: string, contactAcquisitionIntegration: Destination) => Promise<AcuityContactResponse | null>;
|
|
8
7
|
getAcuityContactsByMd5Batch: (pixelId: string, identityId: string, md5Hashes: string[], contactAcquisitionIntegration: Destination) => Promise<AcuityBatchContactResponse | null>;
|
|
9
8
|
}
|
|
@@ -28,25 +28,6 @@ class AcuityApiService {
|
|
|
28
28
|
return null;
|
|
29
29
|
}
|
|
30
30
|
};
|
|
31
|
-
getAcuityContactsByEmail = async (pixelId, identityId, email, contactAcquisitionIntegration) => {
|
|
32
|
-
try {
|
|
33
|
-
const emailContactsResponse = await this.acuityClient.getContactsByEmail(email);
|
|
34
|
-
if (emailContactsResponse.status !== 200) {
|
|
35
|
-
helpers_1.Logger.error('Failed to get acuity contacts by email', {
|
|
36
|
-
pixelId,
|
|
37
|
-
identityId,
|
|
38
|
-
contactAcquisitionIntegration,
|
|
39
|
-
emailContactsResponse,
|
|
40
|
-
});
|
|
41
|
-
return null;
|
|
42
|
-
}
|
|
43
|
-
return emailContactsResponse.data;
|
|
44
|
-
}
|
|
45
|
-
catch (error) {
|
|
46
|
-
helpers_1.Logger.error('Failed to get acuity contacts by email', { error, pixelId, identityId });
|
|
47
|
-
return null;
|
|
48
|
-
}
|
|
49
|
-
};
|
|
50
31
|
getAcuityContactsByMd5Batch = async (pixelId, identityId, md5Hashes, contactAcquisitionIntegration) => {
|
|
51
32
|
try {
|
|
52
33
|
const result = {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"acuity-api-service.js","sourceRoot":"","sources":["../../../src/services/acuity-api-service.ts"],"names":[],"mappings":";;;AAEA,wEAAoE;AACpE,wCAAoC;AAGpC,MAAa,gBAAgB;IACnB,YAAY,CAAe;IAEnC,YAAY,WAAmB,EAAE,YAAoB;QACnD,IAAI,CAAC,YAAY,GAAG,IAAI,4BAAY,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;IAClE,CAAC;IAEM,sBAAsB,GAAG,KAAK,EACnC,OAAe,EACf,UAAkB,EAClB,OAAe,EACf,6BAA0C,EACH,EAAE;QACzC,IAAI;YACF,MAAM,mBAAmB,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;YAC9E,IAAI,mBAAmB,CAAC,MAAM,KAAK,GAAG,EAAE;gBACtC,gBAAM,CAAC,KAAK,CAAC,sCAAsC,EAAE;oBACnD,OAAO;oBACP,UAAU;oBACV,OAAO;oBACP,6BAA6B;oBAC7B,mBAAmB;iBACpB,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC;aACb;YACD,OAAO,mBAAmB,CAAC,IAAI,CAAC;SACjC;QAAC,OAAO,KAAK,EAAE;YACd,gBAAM,CAAC,KAAK,CAAC,sCAAsC,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;YAChE,OAAO,IAAI,CAAC;SACb;IACH,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"acuity-api-service.js","sourceRoot":"","sources":["../../../src/services/acuity-api-service.ts"],"names":[],"mappings":";;;AAEA,wEAAoE;AACpE,wCAAoC;AAGpC,MAAa,gBAAgB;IACnB,YAAY,CAAe;IAEnC,YAAY,WAAmB,EAAE,YAAoB;QACnD,IAAI,CAAC,YAAY,GAAG,IAAI,4BAAY,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;IAClE,CAAC;IAEM,sBAAsB,GAAG,KAAK,EACnC,OAAe,EACf,UAAkB,EAClB,OAAe,EACf,6BAA0C,EACH,EAAE;QACzC,IAAI;YACF,MAAM,mBAAmB,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;YAC9E,IAAI,mBAAmB,CAAC,MAAM,KAAK,GAAG,EAAE;gBACtC,gBAAM,CAAC,KAAK,CAAC,sCAAsC,EAAE;oBACnD,OAAO;oBACP,UAAU;oBACV,OAAO;oBACP,6BAA6B;oBAC7B,mBAAmB;iBACpB,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC;aACb;YACD,OAAO,mBAAmB,CAAC,IAAI,CAAC;SACjC;QAAC,OAAO,KAAK,EAAE;YACd,gBAAM,CAAC,KAAK,CAAC,sCAAsC,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;YAChE,OAAO,IAAI,CAAC;SACb;IACH,CAAC,CAAC;IAEK,2BAA2B,GAAG,KAAK,EACxC,OAAe,EACf,UAAkB,EAClB,SAAmB,EACnB,6BAA0C,EACE,EAAE;QAC9C,IAAI;YACF,MAAM,MAAM,GAA+B,EAAE,CAAC;YAC9C,KAAK,MAAM,OAAO,IAAI,SAAS,EAAE;gBAC/B,MAAM,mBAAmB,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;gBAC9E,IAAI,mBAAmB,CAAC,MAAM,KAAK,GAAG,IAAI,mBAAmB,CAAC,IAAI,EAAE,UAAU,EAAE;oBAC9E,MAAM,CAAC,OAAO,CAAC,GAAG,mBAAmB,CAAC,IAAI,CAAC,UAAU,CAAC;iBACvD;aACF;YACD,OAAO,MAAM,CAAC;SACf;QAAC,OAAO,KAAK,EAAE;YACd,gBAAM,CAAC,KAAK,CAAC,4CAA4C,EAAE;gBACzD,KAAK;gBACL,OAAO;gBACP,UAAU;gBACV,cAAc,EAAE,SAAS,CAAC,MAAM;gBAChC,6BAA6B;aAC9B,CAAC,CAAC;YACH,OAAO,IAAI,CAAC;SACb;IACH,CAAC,CAAC;CACH;AA1DD,4CA0DC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { type CustomMeasureRecord } from '@adtrackify/at-tracking-event-types';
|
|
2
|
+
export declare class CustomMeasuresDbService {
|
|
3
|
+
TABLE_NAME: string;
|
|
4
|
+
TABLE_KEY: string;
|
|
5
|
+
constructor(tableName: string, tableKey?: string);
|
|
6
|
+
listByPixelId: (gsiName: string, pixelId: string) => Promise<CustomMeasureRecord[]>;
|
|
7
|
+
getById: (id: string) => Promise<CustomMeasureRecord | null>;
|
|
8
|
+
putMeasure: (record: CustomMeasureRecord) => Promise<CustomMeasureRecord>;
|
|
9
|
+
deleteMeasure: (id: string) => Promise<void>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CustomMeasuresDbService = void 0;
|
|
4
|
+
const dynamodb_client_js_1 = require("../../clients/generic/dynamodb-client.js");
|
|
5
|
+
const http_error_js_1 = require("../../libs/http-error.js");
|
|
6
|
+
const logging_helper_js_1 = require("../../helpers/logging-helper.js");
|
|
7
|
+
class CustomMeasuresDbService {
|
|
8
|
+
TABLE_NAME;
|
|
9
|
+
TABLE_KEY;
|
|
10
|
+
constructor(tableName, tableKey = 'id') {
|
|
11
|
+
this.TABLE_NAME = tableName;
|
|
12
|
+
this.TABLE_KEY = tableKey;
|
|
13
|
+
}
|
|
14
|
+
listByPixelId = async (gsiName, pixelId) => {
|
|
15
|
+
const records = await dynamodb_client_js_1.DynamoDbClient.safeQueryByGSI(this.TABLE_NAME, gsiName, 'pixelId', pixelId);
|
|
16
|
+
return records || [];
|
|
17
|
+
};
|
|
18
|
+
getById = async (id) => {
|
|
19
|
+
const result = await dynamodb_client_js_1.DynamoDbClient.safeGet(this.TABLE_NAME, this.TABLE_KEY, id);
|
|
20
|
+
return result ?? null;
|
|
21
|
+
};
|
|
22
|
+
putMeasure = async (record) => {
|
|
23
|
+
const res = await dynamodb_client_js_1.DynamoDbClient.safePut(this.TABLE_NAME, record);
|
|
24
|
+
if (!res) {
|
|
25
|
+
logging_helper_js_1.Logger.error('CustomMeasuresDbService: putMeasure failed', { record });
|
|
26
|
+
throw http_error_js_1.HttpError.internal();
|
|
27
|
+
}
|
|
28
|
+
return record;
|
|
29
|
+
};
|
|
30
|
+
deleteMeasure = async (id) => {
|
|
31
|
+
await dynamodb_client_js_1.DynamoDbClient.safeDelete(this.TABLE_NAME, this.TABLE_KEY, id);
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
exports.CustomMeasuresDbService = CustomMeasuresDbService;
|
|
35
|
+
//# sourceMappingURL=custom-measures-db-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"custom-measures-db-service.js","sourceRoot":"","sources":["../../../../src/services/db/custom-measures-db-service.ts"],"names":[],"mappings":";;;AACA,iFAA0E;AAC1E,4DAAqD;AACrD,uEAAyD;AAQzD,MAAa,uBAAuB;IAC3B,UAAU,CAAS;IACnB,SAAS,CAAS;IAEzB,YAAY,SAAiB,EAAE,QAAQ,GAAG,IAAI;QAC5C,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;IAC5B,CAAC;IAEM,aAAa,GAAG,KAAK,EAAE,OAAe,EAAE,OAAe,EAAkC,EAAE;QAChG,MAAM,OAAO,GAAG,MAAM,mCAAc,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAClG,OAAQ,OAAiC,IAAI,EAAE,CAAC;IAClD,CAAC,CAAC;IAEK,OAAO,GAAG,KAAK,EAAE,EAAU,EAAuC,EAAE;QACzE,MAAM,MAAM,GAAG,MAAM,mCAAc,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;QACjF,OAAQ,MAA8B,IAAI,IAAI,CAAC;IACjD,CAAC,CAAC;IAEK,UAAU,GAAG,KAAK,EAAE,MAA2B,EAAgC,EAAE;QACtF,MAAM,GAAG,GAAG,MAAM,mCAAc,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;QAClE,IAAI,CAAC,GAAG,EAAE;YACR,0BAAM,CAAC,KAAK,CAAC,4CAA4C,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;YACvE,MAAM,yBAAS,CAAC,QAAQ,EAAE,CAAC;SAC5B;QACD,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC;IAEK,aAAa,GAAG,KAAK,EAAE,EAAU,EAAiB,EAAE;QACzD,MAAM,mCAAc,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;IACvE,CAAC,CAAC;CACH;AA/BD,0DA+BC"}
|
|
@@ -27,4 +27,5 @@ __exportStar(require("./currency-exchange-rates-db-service.js"), exports);
|
|
|
27
27
|
__exportStar(require("./accounts-db-service.js"), exports);
|
|
28
28
|
__exportStar(require("./subscriptions-db-service.js"), exports);
|
|
29
29
|
__exportStar(require("./api-keys-db-service.js"), exports);
|
|
30
|
+
__exportStar(require("./custom-measures-db-service.js"), exports);
|
|
30
31
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/services/db/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+DAA6C;AAC7C,6DAA2C;AAC3C,yDAAuC;AACvC,uEAAqD;AACrD,qEAAmD;AACnD,kEAAgD;AAChD,yEAAuD;AACvD,uEAAqD;AACrD,iEAA+C;AAC/C,0EAAwD;AACxD,2DAAyC;AACzC,gEAA8C;AAC9C,2DAAyC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/services/db/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+DAA6C;AAC7C,6DAA2C;AAC3C,yDAAuC;AACvC,uEAAqD;AACrD,qEAAmD;AACnD,kEAAgD;AAChD,yEAAuD;AACvD,uEAAqD;AACrD,iEAA+C;AAC/C,0EAAwD;AACxD,2DAAyC;AACzC,gEAA8C;AAC9C,2DAAyC;AACzC,kEAAgD"}
|
|
@@ -22,16 +22,6 @@ describe('AcuityClient', () => {
|
|
|
22
22
|
expect(config.headers.Authorization).toContain('MD5HASH');
|
|
23
23
|
expect(response).toEqual({ status: 200, data: { identities: [{ id: 1 }] } });
|
|
24
24
|
});
|
|
25
|
-
it('requests byEmail with the template id, a url-encoded email, and a bearer auth header', async () => {
|
|
26
|
-
mockGet.mockResolvedValue({ status: 200, data: { identities: [{ id: 1 }] } });
|
|
27
|
-
const client = new AcuityClient('KEY_ID', 'SECRET');
|
|
28
|
-
const response = await client.getContactsByEmail('a+b@x.com');
|
|
29
|
-
expect(mockGet).toHaveBeenCalledTimes(1);
|
|
30
|
-
const [url, config] = mockGet.mock.calls[0];
|
|
31
|
-
expect(url).toBe('/v2/identities/byEmail?email=a%2Bb%40x.com&template=1701523581');
|
|
32
|
-
expect(config.headers.Authorization).toMatch(/^Bearer KEY_ID/);
|
|
33
|
-
expect(response).toEqual({ status: 200, data: { identities: [{ id: 1 }] } });
|
|
34
|
-
});
|
|
35
25
|
it('passes a non-200 response through without throwing', async () => {
|
|
36
26
|
mockGet.mockResolvedValue({ status: 500, data: undefined });
|
|
37
27
|
const client = new AcuityClient('KEY_ID', 'SECRET');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"acuity-client.spec.js","sourceRoot":"","sources":["../../../../src/__tests__/clients/acuity-client.spec.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAEzD,IAAI,CAAC,IAAI,CAAC,uBAAuB,EAAE,GAAG,EAAE,CAAC,CAAC;IACxC,gBAAgB,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;CACtD,CAAC,CAAC,CAAC;AAEJ,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,GAAG,EAAE,CAAC,CAAC;IACpC,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC;CAC1C,CAAC,CAAC,CAAC;AAEJ,OAAO,EAAE,YAAY,EAAE,MAAM,yCAAyC,CAAC;AAGvE,MAAM,OAAO,GAAI,gBAA8B,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAgB,CAAC;AAEvF,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,UAAU,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;QAC5E,OAAO,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;QAC9E,MAAM,MAAM,GAAG,IAAI,YAAY,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAEpD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAEzD,MAAM,CAAC,OAAO,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC5C,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,qDAAqD,CAAC,CAAC;QACxE,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;QAC/D,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAC1D,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IAC/E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"acuity-client.spec.js","sourceRoot":"","sources":["../../../../src/__tests__/clients/acuity-client.spec.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAEzD,IAAI,CAAC,IAAI,CAAC,uBAAuB,EAAE,GAAG,EAAE,CAAC,CAAC;IACxC,gBAAgB,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;CACtD,CAAC,CAAC,CAAC;AAEJ,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,GAAG,EAAE,CAAC,CAAC;IACpC,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC;CAC1C,CAAC,CAAC,CAAC;AAEJ,OAAO,EAAE,YAAY,EAAE,MAAM,yCAAyC,CAAC;AAGvE,MAAM,OAAO,GAAI,gBAA8B,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAgB,CAAC;AAEvF,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,UAAU,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;QAC5E,OAAO,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;QAC9E,MAAM,MAAM,GAAG,IAAI,YAAY,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAEpD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAEzD,MAAM,CAAC,OAAO,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC5C,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,qDAAqD,CAAC,CAAC;QACxE,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;QAC/D,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAC1D,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IAC/E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE,KAAK,IAAI,EAAE;QAClE,OAAO,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;QAC5D,MAAM,MAAM,GAAG,IAAI,YAAY,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAEpD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAEzD,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,9 +1,7 @@
|
|
|
1
1
|
const mockGetContactsByMd5 = jest.fn();
|
|
2
|
-
const mockGetContactsByEmail = jest.fn();
|
|
3
2
|
jest.mock('../../clients/third-party/acuity-client', () => ({
|
|
4
3
|
AcuityClient: jest.fn().mockImplementation(() => ({
|
|
5
4
|
getContactsByMd5: mockGetContactsByMd5,
|
|
6
|
-
getContactsByEmail: mockGetContactsByEmail,
|
|
7
5
|
})),
|
|
8
6
|
}));
|
|
9
7
|
jest.mock('../../helpers/logging-helper', () => ({
|
|
@@ -34,24 +32,6 @@ describe('AcuityApiService', () => {
|
|
|
34
32
|
expect(result).toBeNull();
|
|
35
33
|
});
|
|
36
34
|
});
|
|
37
|
-
describe('getAcuityContactsByEmail', () => {
|
|
38
|
-
it('returns the response data on a 200', async () => {
|
|
39
|
-
mockGetContactsByEmail.mockResolvedValue({ status: 200, data: { identities: [{ id: 1 }] } });
|
|
40
|
-
const result = await service.getAcuityContactsByEmail('pixel', 'identity', 'a@x.com', DESTINATION);
|
|
41
|
-
expect(mockGetContactsByEmail).toHaveBeenCalledWith('a@x.com');
|
|
42
|
-
expect(result).toEqual({ identities: [{ id: 1 }] });
|
|
43
|
-
});
|
|
44
|
-
it('returns null on a non-200 response', async () => {
|
|
45
|
-
mockGetContactsByEmail.mockResolvedValue({ status: 404, data: undefined });
|
|
46
|
-
const result = await service.getAcuityContactsByEmail('pixel', 'identity', 'a@x.com', DESTINATION);
|
|
47
|
-
expect(result).toBeNull();
|
|
48
|
-
});
|
|
49
|
-
it('returns null when the client throws', async () => {
|
|
50
|
-
mockGetContactsByEmail.mockRejectedValue(new Error('network'));
|
|
51
|
-
const result = await service.getAcuityContactsByEmail('pixel', 'identity', 'a@x.com', DESTINATION);
|
|
52
|
-
expect(result).toBeNull();
|
|
53
|
-
});
|
|
54
|
-
});
|
|
55
35
|
describe('getAcuityContactsByMd5Batch', () => {
|
|
56
36
|
it('aggregates 200 identities keyed by md5 and skips non-200 hashes', async () => {
|
|
57
37
|
mockGetContactsByMd5
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"acuity-api-service.spec.js","sourceRoot":"","sources":["../../../../src/__tests__/services/acuity-api-service.spec.ts"],"names":[],"mappings":"AAKA,MAAM,oBAAoB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"acuity-api-service.spec.js","sourceRoot":"","sources":["../../../../src/__tests__/services/acuity-api-service.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,6 +5,5 @@ export declare class AcuityClient {
|
|
|
5
5
|
private AA_SECRET;
|
|
6
6
|
constructor(acuityKeyId: string, acuitySecret: string);
|
|
7
7
|
getContactsByMd5: (md5Hash: string) => Promise<ApiResponse<AcuityContactResponse>>;
|
|
8
|
-
getContactsByEmail: (email: string) => Promise<ApiResponse<AcuityContactResponse>>;
|
|
9
8
|
private generateAuthorization;
|
|
10
9
|
}
|
|
@@ -22,12 +22,6 @@ export class AcuityClient {
|
|
|
22
22
|
});
|
|
23
23
|
return response;
|
|
24
24
|
};
|
|
25
|
-
getContactsByEmail = async (email) => {
|
|
26
|
-
const response = await client.get(`/v2/identities/byEmail?email=${encodeURIComponent(email)}&template=${AA_TEMPLATE_ID}`, {
|
|
27
|
-
headers: { Authorization: this.generateAuthorization() },
|
|
28
|
-
});
|
|
29
|
-
return response;
|
|
30
|
-
};
|
|
31
25
|
generateAuthorization = () => {
|
|
32
26
|
const now = Date.now().toString(36);
|
|
33
27
|
const hash = generateMd5Hash(`${now}${this.AA_SECRET}`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"acuity-client.js","sourceRoot":"","sources":["../../../../src/clients/third-party/acuity-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAE9C,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAGpD,MAAM,UAAU,GAAG,gCAAgC,CAAC;AACpD,MAAM,cAAc,GAAG,YAAY,CAAC;AAEpC,MAAM,MAAM,GAAG,gBAAgB,CAAC;IAC9B,OAAO,EAAE,UAAU;IACnB,OAAO,EAAE;QACP,MAAM,EAAE,kBAAkB;QAC1B,cAAc,EAAE,kBAAkB;KACnC;CACF,CAAC,CAAC;AAEH,MAAM,OAAO,YAAY;IACf,SAAS,CAAS;IAClB,SAAS,CAAS;IAE1B,YAAY,WAAmB,EAAE,YAAoB;QACnD,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC;QAC7B,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC;IAChC,CAAC;IAEM,gBAAgB,GAAG,KAAK,EAAE,OAAe,EAA+C,EAAE;QAC/F,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,4BAA4B,OAAO,aAAa,cAAc,EAAE,EAAE;YAClG,OAAO,EAAE,EAAE,aAAa,EAAE,IAAI,CAAC,qBAAqB,EAAE,EAAE;SACzD,CAAC,CAAC;QACH,OAAO,QAA8C,CAAC;IACxD,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"acuity-client.js","sourceRoot":"","sources":["../../../../src/clients/third-party/acuity-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAE9C,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAGpD,MAAM,UAAU,GAAG,gCAAgC,CAAC;AACpD,MAAM,cAAc,GAAG,YAAY,CAAC;AAEpC,MAAM,MAAM,GAAG,gBAAgB,CAAC;IAC9B,OAAO,EAAE,UAAU;IACnB,OAAO,EAAE;QACP,MAAM,EAAE,kBAAkB;QAC1B,cAAc,EAAE,kBAAkB;KACnC;CACF,CAAC,CAAC;AAEH,MAAM,OAAO,YAAY;IACf,SAAS,CAAS;IAClB,SAAS,CAAS;IAE1B,YAAY,WAAmB,EAAE,YAAoB;QACnD,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC;QAC7B,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC;IAChC,CAAC;IAEM,gBAAgB,GAAG,KAAK,EAAE,OAAe,EAA+C,EAAE;QAC/F,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,4BAA4B,OAAO,aAAa,cAAc,EAAE,EAAE;YAClG,OAAO,EAAE,EAAE,aAAa,EAAE,IAAI,CAAC,qBAAqB,EAAE,EAAE;SACzD,CAAC,CAAC;QACH,OAAO,QAA8C,CAAC;IACxD,CAAC,CAAC;IAEM,qBAAqB,GAAG,GAAW,EAAE;QAC3C,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QACpC,MAAM,IAAI,GAAG,eAAe,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QACxD,OAAO,UAAU,IAAI,CAAC,SAAS,GAAG,GAAG,GAAG,IAAI,EAAE,CAAC;IACjD,CAAC,CAAC;CACH"}
|
|
@@ -4,6 +4,5 @@ export declare class AcuityApiService {
|
|
|
4
4
|
private acuityClient;
|
|
5
5
|
constructor(acuityKeyId: string, acuitySecret: string);
|
|
6
6
|
getAcuityContactsByMd5: (pixelId: string, identityId: string, md5Hash: string, contactAcquisitionIntegration: Destination) => Promise<AcuityContactResponse | null>;
|
|
7
|
-
getAcuityContactsByEmail: (pixelId: string, identityId: string, email: string, contactAcquisitionIntegration: Destination) => Promise<AcuityContactResponse | null>;
|
|
8
7
|
getAcuityContactsByMd5Batch: (pixelId: string, identityId: string, md5Hashes: string[], contactAcquisitionIntegration: Destination) => Promise<AcuityBatchContactResponse | null>;
|
|
9
8
|
}
|
|
@@ -25,25 +25,6 @@ export class AcuityApiService {
|
|
|
25
25
|
return null;
|
|
26
26
|
}
|
|
27
27
|
};
|
|
28
|
-
getAcuityContactsByEmail = async (pixelId, identityId, email, contactAcquisitionIntegration) => {
|
|
29
|
-
try {
|
|
30
|
-
const emailContactsResponse = await this.acuityClient.getContactsByEmail(email);
|
|
31
|
-
if (emailContactsResponse.status !== 200) {
|
|
32
|
-
Logger.error('Failed to get acuity contacts by email', {
|
|
33
|
-
pixelId,
|
|
34
|
-
identityId,
|
|
35
|
-
contactAcquisitionIntegration,
|
|
36
|
-
emailContactsResponse,
|
|
37
|
-
});
|
|
38
|
-
return null;
|
|
39
|
-
}
|
|
40
|
-
return emailContactsResponse.data;
|
|
41
|
-
}
|
|
42
|
-
catch (error) {
|
|
43
|
-
Logger.error('Failed to get acuity contacts by email', { error, pixelId, identityId });
|
|
44
|
-
return null;
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
28
|
getAcuityContactsByMd5Batch = async (pixelId, identityId, md5Hashes, contactAcquisitionIntegration) => {
|
|
48
29
|
try {
|
|
49
30
|
const result = {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"acuity-api-service.js","sourceRoot":"","sources":["../../../src/services/acuity-api-service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AACpE,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAGpC,MAAM,OAAO,gBAAgB;IACnB,YAAY,CAAe;IAEnC,YAAY,WAAmB,EAAE,YAAoB;QACnD,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;IAClE,CAAC;IAEM,sBAAsB,GAAG,KAAK,EACnC,OAAe,EACf,UAAkB,EAClB,OAAe,EACf,6BAA0C,EACH,EAAE;QACzC,IAAI;YACF,MAAM,mBAAmB,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;YAC9E,IAAI,mBAAmB,CAAC,MAAM,KAAK,GAAG,EAAE;gBACtC,MAAM,CAAC,KAAK,CAAC,sCAAsC,EAAE;oBACnD,OAAO;oBACP,UAAU;oBACV,OAAO;oBACP,6BAA6B;oBAC7B,mBAAmB;iBACpB,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC;aACb;YACD,OAAO,mBAAmB,CAAC,IAAI,CAAC;SACjC;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,CAAC,KAAK,CAAC,sCAAsC,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;YAChE,OAAO,IAAI,CAAC;SACb;IACH,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"acuity-api-service.js","sourceRoot":"","sources":["../../../src/services/acuity-api-service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AACpE,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAGpC,MAAM,OAAO,gBAAgB;IACnB,YAAY,CAAe;IAEnC,YAAY,WAAmB,EAAE,YAAoB;QACnD,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;IAClE,CAAC;IAEM,sBAAsB,GAAG,KAAK,EACnC,OAAe,EACf,UAAkB,EAClB,OAAe,EACf,6BAA0C,EACH,EAAE;QACzC,IAAI;YACF,MAAM,mBAAmB,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;YAC9E,IAAI,mBAAmB,CAAC,MAAM,KAAK,GAAG,EAAE;gBACtC,MAAM,CAAC,KAAK,CAAC,sCAAsC,EAAE;oBACnD,OAAO;oBACP,UAAU;oBACV,OAAO;oBACP,6BAA6B;oBAC7B,mBAAmB;iBACpB,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC;aACb;YACD,OAAO,mBAAmB,CAAC,IAAI,CAAC;SACjC;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,CAAC,KAAK,CAAC,sCAAsC,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;YAChE,OAAO,IAAI,CAAC;SACb;IACH,CAAC,CAAC;IAEK,2BAA2B,GAAG,KAAK,EACxC,OAAe,EACf,UAAkB,EAClB,SAAmB,EACnB,6BAA0C,EACE,EAAE;QAC9C,IAAI;YACF,MAAM,MAAM,GAA+B,EAAE,CAAC;YAC9C,KAAK,MAAM,OAAO,IAAI,SAAS,EAAE;gBAC/B,MAAM,mBAAmB,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;gBAC9E,IAAI,mBAAmB,CAAC,MAAM,KAAK,GAAG,IAAI,mBAAmB,CAAC,IAAI,EAAE,UAAU,EAAE;oBAC9E,MAAM,CAAC,OAAO,CAAC,GAAG,mBAAmB,CAAC,IAAI,CAAC,UAAU,CAAC;iBACvD;aACF;YACD,OAAO,MAAM,CAAC;SACf;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,CAAC,KAAK,CAAC,4CAA4C,EAAE;gBACzD,KAAK;gBACL,OAAO;gBACP,UAAU;gBACV,cAAc,EAAE,SAAS,CAAC,MAAM;gBAChC,6BAA6B;aAC9B,CAAC,CAAC;YACH,OAAO,IAAI,CAAC;SACb;IACH,CAAC,CAAC;CACH"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { type CustomMeasureRecord } from '@adtrackify/at-tracking-event-types';
|
|
2
|
+
export declare class CustomMeasuresDbService {
|
|
3
|
+
TABLE_NAME: string;
|
|
4
|
+
TABLE_KEY: string;
|
|
5
|
+
constructor(tableName: string, tableKey?: string);
|
|
6
|
+
listByPixelId: (gsiName: string, pixelId: string) => Promise<CustomMeasureRecord[]>;
|
|
7
|
+
getById: (id: string) => Promise<CustomMeasureRecord | null>;
|
|
8
|
+
putMeasure: (record: CustomMeasureRecord) => Promise<CustomMeasureRecord>;
|
|
9
|
+
deleteMeasure: (id: string) => Promise<void>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { DynamoDbClient } from '../../clients/generic/dynamodb-client.js';
|
|
2
|
+
import { HttpError } from '../../libs/http-error.js';
|
|
3
|
+
import { Logger } from '../../helpers/logging-helper.js';
|
|
4
|
+
export class CustomMeasuresDbService {
|
|
5
|
+
TABLE_NAME;
|
|
6
|
+
TABLE_KEY;
|
|
7
|
+
constructor(tableName, tableKey = 'id') {
|
|
8
|
+
this.TABLE_NAME = tableName;
|
|
9
|
+
this.TABLE_KEY = tableKey;
|
|
10
|
+
}
|
|
11
|
+
listByPixelId = async (gsiName, pixelId) => {
|
|
12
|
+
const records = await DynamoDbClient.safeQueryByGSI(this.TABLE_NAME, gsiName, 'pixelId', pixelId);
|
|
13
|
+
return records || [];
|
|
14
|
+
};
|
|
15
|
+
getById = async (id) => {
|
|
16
|
+
const result = await DynamoDbClient.safeGet(this.TABLE_NAME, this.TABLE_KEY, id);
|
|
17
|
+
return result ?? null;
|
|
18
|
+
};
|
|
19
|
+
putMeasure = async (record) => {
|
|
20
|
+
const res = await DynamoDbClient.safePut(this.TABLE_NAME, record);
|
|
21
|
+
if (!res) {
|
|
22
|
+
Logger.error('CustomMeasuresDbService: putMeasure failed', { record });
|
|
23
|
+
throw HttpError.internal();
|
|
24
|
+
}
|
|
25
|
+
return record;
|
|
26
|
+
};
|
|
27
|
+
deleteMeasure = async (id) => {
|
|
28
|
+
await DynamoDbClient.safeDelete(this.TABLE_NAME, this.TABLE_KEY, id);
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=custom-measures-db-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"custom-measures-db-service.js","sourceRoot":"","sources":["../../../../src/services/db/custom-measures-db-service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,0CAA0C,CAAC;AAC1E,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,iCAAiC,CAAC;AAQzD,MAAM,OAAO,uBAAuB;IAC3B,UAAU,CAAS;IACnB,SAAS,CAAS;IAEzB,YAAY,SAAiB,EAAE,QAAQ,GAAG,IAAI;QAC5C,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;IAC5B,CAAC;IAEM,aAAa,GAAG,KAAK,EAAE,OAAe,EAAE,OAAe,EAAkC,EAAE;QAChG,MAAM,OAAO,GAAG,MAAM,cAAc,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAClG,OAAQ,OAAiC,IAAI,EAAE,CAAC;IAClD,CAAC,CAAC;IAEK,OAAO,GAAG,KAAK,EAAE,EAAU,EAAuC,EAAE;QACzE,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;QACjF,OAAQ,MAA8B,IAAI,IAAI,CAAC;IACjD,CAAC,CAAC;IAEK,UAAU,GAAG,KAAK,EAAE,MAA2B,EAAgC,EAAE;QACtF,MAAM,GAAG,GAAG,MAAM,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;QAClE,IAAI,CAAC,GAAG,EAAE;YACR,MAAM,CAAC,KAAK,CAAC,4CAA4C,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;YACvE,MAAM,SAAS,CAAC,QAAQ,EAAE,CAAC;SAC5B;QACD,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC;IAEK,aAAa,GAAG,KAAK,EAAE,EAAU,EAAiB,EAAE;QACzD,MAAM,cAAc,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;IACvE,CAAC,CAAC;CACH"}
|
|
@@ -11,4 +11,5 @@ export * from './currency-exchange-rates-db-service.js';
|
|
|
11
11
|
export * from './accounts-db-service.js';
|
|
12
12
|
export * from './subscriptions-db-service.js';
|
|
13
13
|
export * from './api-keys-db-service.js';
|
|
14
|
+
export * from './custom-measures-db-service.js';
|
|
14
15
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/services/db/index.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC;AAC7C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,wBAAwB,CAAC;AACvC,cAAc,sCAAsC,CAAC;AACrD,cAAc,oCAAoC,CAAC;AACnD,cAAc,iCAAiC,CAAC;AAChD,cAAc,wCAAwC,CAAC;AACvD,cAAc,sCAAsC,CAAC;AACrD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,yCAAyC,CAAC;AACxD,cAAc,0BAA0B,CAAC;AACzC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,0BAA0B,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/services/db/index.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC;AAC7C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,wBAAwB,CAAC;AACvC,cAAc,sCAAsC,CAAC;AACrD,cAAc,oCAAoC,CAAC;AACnD,cAAc,iCAAiC,CAAC;AAChD,cAAc,wCAAwC,CAAC;AACvD,cAAc,sCAAsC,CAAC;AACrD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,yCAAyC,CAAC;AACxD,cAAc,0BAA0B,CAAC;AACzC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,0BAA0B,CAAC;AACzC,cAAc,iCAAiC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@adtrackify/at-service-common",
|
|
3
|
-
"version": "3.19.
|
|
3
|
+
"version": "3.19.1",
|
|
4
4
|
"description": "",
|
|
5
5
|
"files": [
|
|
6
6
|
"dist/*"
|
|
@@ -37,7 +37,7 @@
|
|
|
37
37
|
},
|
|
38
38
|
"dependencies": {
|
|
39
39
|
"@adtrackify/at-shared-utils": "^3.2.23",
|
|
40
|
-
"@adtrackify/at-tracking-event-types": "^4.
|
|
40
|
+
"@adtrackify/at-tracking-event-types": "^4.71.4",
|
|
41
41
|
"@aws-sdk/util-utf8": "^3.374.0",
|
|
42
42
|
"@shopify/admin-api-client": "^1.0.4",
|
|
43
43
|
"@shopify/shopify-api": "^11.6.1",
|