@adtrackify/at-service-common 3.18.19 → 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/services/currency-exchange-rate-lookup-service.d.ts +1 -2
- package/dist/cjs/services/currency-exchange-rate-lookup-service.js +0 -28
- package/dist/cjs/services/currency-exchange-rate-lookup-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/cjs/services/index.d.ts +0 -1
- package/dist/cjs/services/index.js +0 -1
- package/dist/cjs/services/index.js.map +1 -1
- package/dist/esm/services/currency-exchange-rate-lookup-service.d.ts +1 -2
- package/dist/esm/services/currency-exchange-rate-lookup-service.js +0 -28
- package/dist/esm/services/currency-exchange-rate-lookup-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/dist/esm/services/index.d.ts +0 -1
- package/dist/esm/services/index.js +0 -1
- package/dist/esm/services/index.js.map +1 -1
- package/package.json +2 -2
- package/dist/cjs/__tests__/services/cost/cost-calculator-service.spec.d.ts +0 -1
- package/dist/cjs/__tests__/services/cost/cost-calculator-service.spec.js +0 -3320
- package/dist/cjs/__tests__/services/cost/cost-calculator-service.spec.js.map +0 -1
- package/dist/cjs/__tests__/services/cost/cost-currency-service.spec.d.ts +0 -1
- package/dist/cjs/__tests__/services/cost/cost-currency-service.spec.js +0 -115
- package/dist/cjs/__tests__/services/cost/cost-currency-service.spec.js.map +0 -1
- package/dist/cjs/__tests__/services/cost/cost-filter-service.spec.d.ts +0 -1
- package/dist/cjs/__tests__/services/cost/cost-filter-service.spec.js +0 -469
- package/dist/cjs/__tests__/services/cost/cost-filter-service.spec.js.map +0 -1
- package/dist/cjs/__tests__/services/currency-exchange-rate-lookup-service.spec.d.ts +0 -1
- package/dist/cjs/__tests__/services/currency-exchange-rate-lookup-service.spec.js +0 -35
- package/dist/cjs/__tests__/services/currency-exchange-rate-lookup-service.spec.js.map +0 -1
- package/dist/cjs/services/cost/cost-calculation-types.d.ts +0 -69
- package/dist/cjs/services/cost/cost-calculation-types.js +0 -20
- package/dist/cjs/services/cost/cost-calculation-types.js.map +0 -1
- package/dist/cjs/services/cost/cost-calculator-service.d.ts +0 -24
- package/dist/cjs/services/cost/cost-calculator-service.js +0 -457
- package/dist/cjs/services/cost/cost-calculator-service.js.map +0 -1
- package/dist/cjs/services/cost/cost-currency-service.d.ts +0 -6
- package/dist/cjs/services/cost/cost-currency-service.js +0 -88
- package/dist/cjs/services/cost/cost-currency-service.js.map +0 -1
- package/dist/cjs/services/cost/cost-filter-service.d.ts +0 -10
- package/dist/cjs/services/cost/cost-filter-service.js +0 -122
- package/dist/cjs/services/cost/cost-filter-service.js.map +0 -1
- package/dist/cjs/services/cost/index.d.ts +0 -4
- package/dist/cjs/services/cost/index.js +0 -21
- package/dist/cjs/services/cost/index.js.map +0 -1
- package/dist/esm/__tests__/services/cost/cost-calculator-service.spec.d.ts +0 -1
- package/dist/esm/__tests__/services/cost/cost-calculator-service.spec.js +0 -3318
- package/dist/esm/__tests__/services/cost/cost-calculator-service.spec.js.map +0 -1
- package/dist/esm/__tests__/services/cost/cost-currency-service.spec.d.ts +0 -1
- package/dist/esm/__tests__/services/cost/cost-currency-service.spec.js +0 -113
- package/dist/esm/__tests__/services/cost/cost-currency-service.spec.js.map +0 -1
- package/dist/esm/__tests__/services/cost/cost-filter-service.spec.d.ts +0 -1
- package/dist/esm/__tests__/services/cost/cost-filter-service.spec.js +0 -467
- package/dist/esm/__tests__/services/cost/cost-filter-service.spec.js.map +0 -1
- package/dist/esm/__tests__/services/currency-exchange-rate-lookup-service.spec.d.ts +0 -1
- package/dist/esm/__tests__/services/currency-exchange-rate-lookup-service.spec.js +0 -33
- package/dist/esm/__tests__/services/currency-exchange-rate-lookup-service.spec.js.map +0 -1
- package/dist/esm/services/cost/cost-calculation-types.d.ts +0 -69
- package/dist/esm/services/cost/cost-calculation-types.js +0 -16
- package/dist/esm/services/cost/cost-calculation-types.js.map +0 -1
- package/dist/esm/services/cost/cost-calculator-service.d.ts +0 -24
- package/dist/esm/services/cost/cost-calculator-service.js +0 -451
- package/dist/esm/services/cost/cost-calculator-service.js.map +0 -1
- package/dist/esm/services/cost/cost-currency-service.d.ts +0 -6
- package/dist/esm/services/cost/cost-currency-service.js +0 -85
- package/dist/esm/services/cost/cost-currency-service.js.map +0 -1
- package/dist/esm/services/cost/cost-filter-service.d.ts +0 -10
- package/dist/esm/services/cost/cost-filter-service.js +0 -119
- package/dist/esm/services/cost/cost-filter-service.js.map +0 -1
- package/dist/esm/services/cost/index.d.ts +0 -4
- package/dist/esm/services/cost/index.js +0 -5
- package/dist/esm/services/cost/index.js.map +0 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { CurrencyExchangeRateRecord
|
|
1
|
+
import { CurrencyExchangeRateRecord } from './db/currency-exchange-rates-db-service';
|
|
2
2
|
export declare class CurrencyExchangeRateLookupService {
|
|
3
3
|
private TABLE_NAME;
|
|
4
4
|
private TABLE_KEY;
|
|
@@ -8,5 +8,4 @@ export declare class CurrencyExchangeRateLookupService {
|
|
|
8
8
|
private exchangeRateApiClient;
|
|
9
9
|
constructor(tableName: string, tableKey: string, exchangeRateApiKey: string, ttlInDays?: number);
|
|
10
10
|
lookupCurrencyExchangeRate: (currency: string) => Promise<CurrencyExchangeRateRecord | null>;
|
|
11
|
-
batchLookupCurrencyExchangeRatesMap: (currencies: string[], batchSize?: number) => Promise<Record<string, CurrencyRates>>;
|
|
12
11
|
}
|
|
@@ -62,34 +62,6 @@ class CurrencyExchangeRateLookupService {
|
|
|
62
62
|
return null;
|
|
63
63
|
}
|
|
64
64
|
};
|
|
65
|
-
batchLookupCurrencyExchangeRatesMap = async (currencies, batchSize = 5) => {
|
|
66
|
-
const ratesMap = {};
|
|
67
|
-
if (!currencies.length)
|
|
68
|
-
return ratesMap;
|
|
69
|
-
try {
|
|
70
|
-
const errors = [];
|
|
71
|
-
for (let i = 0; i < currencies.length; i += batchSize) {
|
|
72
|
-
const chunk = currencies.slice(i, i + batchSize);
|
|
73
|
-
const results = await Promise.allSettled(chunk.map(async (currency) => ({ currency, record: await this.lookupCurrencyExchangeRate(currency) })));
|
|
74
|
-
for (const result of results) {
|
|
75
|
-
if (result.status === 'fulfilled' && result.value.record?.rates) {
|
|
76
|
-
ratesMap[result.value.currency.toUpperCase()] = result.value.record.rates;
|
|
77
|
-
}
|
|
78
|
-
else if (result.status === 'rejected') {
|
|
79
|
-
errors.push(result.reason);
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
if (errors.length > 0) {
|
|
84
|
-
helpers_1.Logger.error('Failed to resolve some currency exchange rates', { error: errors[0], keyCount: currencies.length });
|
|
85
|
-
}
|
|
86
|
-
return ratesMap;
|
|
87
|
-
}
|
|
88
|
-
catch (error) {
|
|
89
|
-
helpers_1.Logger.error('Failed to resolve currency exchange rates map', { error, keyCount: currencies.length });
|
|
90
|
-
return ratesMap;
|
|
91
|
-
}
|
|
92
|
-
};
|
|
93
65
|
}
|
|
94
66
|
exports.CurrencyExchangeRateLookupService = CurrencyExchangeRateLookupService;
|
|
95
67
|
//# sourceMappingURL=currency-exchange-rate-lookup-service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"currency-exchange-rate-lookup-service.js","sourceRoot":"","sources":["../../../src/services/currency-exchange-rate-lookup-service.ts"],"names":[],"mappings":";;;AAAA,iCAAiC;AACjC,wCAAoC;AACpC,
|
|
1
|
+
{"version":3,"file":"currency-exchange-rate-lookup-service.js","sourceRoot":"","sources":["../../../src/services/currency-exchange-rate-lookup-service.ts"],"names":[],"mappings":"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"}
|
|
@@ -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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uEAAqD;AACrD,6DAA2C;AAC3C,6DAA2C;AAC3C,6EAA2D;AAC3D,0DAAwC;AACxC,uDAAqC;AACrC,uCAAqB;AACrB,4CAA0B;AAC1B,0CAAwB;AACxB,2CAAyB
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uEAAqD;AACrD,6DAA2C;AAC3C,6DAA2C;AAC3C,6EAA2D;AAC3D,0DAAwC;AACxC,uDAAqC;AACrC,uCAAqB;AACrB,4CAA0B;AAC1B,0CAAwB;AACxB,2CAAyB"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { CurrencyExchangeRateRecord
|
|
1
|
+
import { CurrencyExchangeRateRecord } from './db/currency-exchange-rates-db-service';
|
|
2
2
|
export declare class CurrencyExchangeRateLookupService {
|
|
3
3
|
private TABLE_NAME;
|
|
4
4
|
private TABLE_KEY;
|
|
@@ -8,5 +8,4 @@ export declare class CurrencyExchangeRateLookupService {
|
|
|
8
8
|
private exchangeRateApiClient;
|
|
9
9
|
constructor(tableName: string, tableKey: string, exchangeRateApiKey: string, ttlInDays?: number);
|
|
10
10
|
lookupCurrencyExchangeRate: (currency: string) => Promise<CurrencyExchangeRateRecord | null>;
|
|
11
|
-
batchLookupCurrencyExchangeRatesMap: (currencies: string[], batchSize?: number) => Promise<Record<string, CurrencyRates>>;
|
|
12
11
|
}
|
|
@@ -59,33 +59,5 @@ export class CurrencyExchangeRateLookupService {
|
|
|
59
59
|
return null;
|
|
60
60
|
}
|
|
61
61
|
};
|
|
62
|
-
batchLookupCurrencyExchangeRatesMap = async (currencies, batchSize = 5) => {
|
|
63
|
-
const ratesMap = {};
|
|
64
|
-
if (!currencies.length)
|
|
65
|
-
return ratesMap;
|
|
66
|
-
try {
|
|
67
|
-
const errors = [];
|
|
68
|
-
for (let i = 0; i < currencies.length; i += batchSize) {
|
|
69
|
-
const chunk = currencies.slice(i, i + batchSize);
|
|
70
|
-
const results = await Promise.allSettled(chunk.map(async (currency) => ({ currency, record: await this.lookupCurrencyExchangeRate(currency) })));
|
|
71
|
-
for (const result of results) {
|
|
72
|
-
if (result.status === 'fulfilled' && result.value.record?.rates) {
|
|
73
|
-
ratesMap[result.value.currency.toUpperCase()] = result.value.record.rates;
|
|
74
|
-
}
|
|
75
|
-
else if (result.status === 'rejected') {
|
|
76
|
-
errors.push(result.reason);
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
if (errors.length > 0) {
|
|
81
|
-
Logger.error('Failed to resolve some currency exchange rates', { error: errors[0], keyCount: currencies.length });
|
|
82
|
-
}
|
|
83
|
-
return ratesMap;
|
|
84
|
-
}
|
|
85
|
-
catch (error) {
|
|
86
|
-
Logger.error('Failed to resolve currency exchange rates map', { error, keyCount: currencies.length });
|
|
87
|
-
return ratesMap;
|
|
88
|
-
}
|
|
89
|
-
};
|
|
90
62
|
}
|
|
91
63
|
//# sourceMappingURL=currency-exchange-rate-lookup-service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"currency-exchange-rate-lookup-service.js","sourceRoot":"","sources":["../../../src/services/currency-exchange-rate-lookup-service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjC,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AACpC,OAAO,
|
|
1
|
+
{"version":3,"file":"currency-exchange-rate-lookup-service.js","sourceRoot":"","sources":["../../../src/services/currency-exchange-rate-lookup-service.ts"],"names":[],"mappings":"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"}
|
|
@@ -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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/index.ts"],"names":[],"mappings":"AAAA,cAAc,sCAAsC,CAAC;AACrD,cAAc,4BAA4B,CAAC;AAC3C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,4CAA4C,CAAC;AAC3D,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,MAAM,CAAC;AACrB,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/index.ts"],"names":[],"mappings":"AAAA,cAAc,sCAAsC,CAAC;AACrD,cAAc,4BAA4B,CAAC;AAC3C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,4CAA4C,CAAC;AAC3D,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,MAAM,CAAC;AACrB,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@adtrackify/at-service-common",
|
|
3
|
-
"version": "3.
|
|
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",
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|