@stigg/node-server-sdk 4.11.0 → 4.12.0

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.
Files changed (84) hide show
  1. package/dist/api/entitlements/entitlementsApi.d.ts +1 -2
  2. package/dist/api/entitlements/entitlementsApi.js +1 -6
  3. package/dist/clientInitialization.js +8 -7
  4. package/dist/configuration.d.ts +2 -21
  5. package/dist/configuration.js +1 -1
  6. package/dist/models.d.ts +4 -14
  7. package/dist/models.js +1 -1
  8. package/dist/services/ApiCacheMapper.d.ts +15 -0
  9. package/dist/services/ApiCacheMapper.js +96 -0
  10. package/dist/services/LegacyEventPayloadMapper.d.ts +1 -1
  11. package/dist/services/LegacyEventPayloadMapper.js +1 -3
  12. package/dist/services/cache/CacheMapper.d.ts +16 -0
  13. package/dist/services/cache/CacheMapper.js +3 -0
  14. package/dist/services/cache/RedisSingleExecutionService/RedisSingleExecution.d.ts +3 -3
  15. package/dist/services/cache/RedisSingleExecutionService/RedisSingleExecution.js +4 -3
  16. package/dist/services/cache/accessDeniedReasonMapper.d.ts +3 -0
  17. package/dist/services/cache/accessDeniedReasonMapper.js +16 -0
  18. package/dist/{utils → services/cache}/cacheKeysHelpers.d.ts +3 -2
  19. package/dist/services/cache/cacheKeysHelpers.js +55 -0
  20. package/dist/services/cache/cacheService.d.ts +10 -25
  21. package/dist/services/cache/entities/cachedEntitlement.d.ts +5 -2
  22. package/dist/services/cache/entities/cachedEntitlement.js +32 -7
  23. package/dist/services/cache/entities/calculatedEntitlement.d.ts +16 -15
  24. package/dist/services/cache/entities/entitlementsMap.d.ts +15 -4
  25. package/dist/services/cache/entities/entitlementsMap.js +34 -24
  26. package/dist/services/cache/entities/index.d.ts +1 -1
  27. package/dist/services/cache/entities/index.js +2 -3
  28. package/dist/services/cache/entities/usageData.d.ts +8 -4
  29. package/dist/services/cache/entities/usageData.js +7 -1
  30. package/dist/services/cache/extractWithDependencies.d.ts +12 -0
  31. package/dist/services/cache/extractWithDependencies.js +37 -0
  32. package/dist/services/cache/freshness/EntitlementsFreshener.d.ts +11 -0
  33. package/dist/services/cache/freshness/EntitlementsFreshener.js +27 -0
  34. package/dist/services/cache/freshness/transformers/CreditAccessPropagator.d.ts +15 -0
  35. package/dist/services/cache/freshness/transformers/CreditAccessPropagator.js +67 -0
  36. package/dist/services/cache/freshness/transformers/UsagePeriodReset.d.ts +11 -0
  37. package/dist/services/cache/freshness/transformers/UsagePeriodReset.js +45 -0
  38. package/dist/services/cache/inMemoryCacheService.d.ts +18 -13
  39. package/dist/services/cache/inMemoryCacheService.js +41 -57
  40. package/dist/services/cache/index.d.ts +13 -0
  41. package/dist/services/cache/index.js +38 -0
  42. package/dist/services/cache/redis/distributedLocks.d.ts +4 -3
  43. package/dist/services/cache/redis/distributedLocks.js +5 -4
  44. package/dist/services/cache/redisCacheService.constants.d.ts +1 -1
  45. package/dist/services/cache/redisCacheService.constants.js +3 -3
  46. package/dist/services/cache/redisCacheService.d.ts +43 -17
  47. package/dist/services/cache/redisCacheService.js +233 -169
  48. package/dist/services/cache/types/cacheInstrumentation.d.ts +37 -0
  49. package/dist/services/cache/types/cacheInstrumentation.js +3 -0
  50. package/dist/services/cache/types/cacheResponse.d.ts +26 -0
  51. package/dist/services/cache/types/cacheResponse.js +19 -0
  52. package/dist/services/cache/types/cacheServiceParams.d.ts +20 -0
  53. package/dist/services/cache/types/cacheServiceParams.js +3 -0
  54. package/dist/services/cache/types/entitlementFeature.d.ts +19 -0
  55. package/dist/services/cache/types/entitlementFeature.js +3 -0
  56. package/dist/services/cache/types/entitlementsMapTransformer.d.ts +4 -0
  57. package/dist/services/cache/types/entitlementsMapTransformer.js +3 -0
  58. package/dist/services/cache/types/logger.d.ts +6 -0
  59. package/dist/services/cache/types/logger.js +3 -0
  60. package/dist/services/cache/types/redisConfiguration.d.ts +39 -0
  61. package/dist/services/cache/types/redisConfiguration.js +14 -0
  62. package/dist/services/entitlementDecisionService.d.ts +1 -1
  63. package/dist/services/entitlementDecisionService.js +5 -5
  64. package/dist/services/entitlementsService.d.ts +21 -19
  65. package/dist/services/entitlementsService.js +57 -91
  66. package/dist/services/entitlementsService.utils.d.ts +0 -26
  67. package/dist/services/entitlementsService.utils.js +1 -17
  68. package/dist/services/eventEmitter.d.ts +1 -1
  69. package/dist/services/eventEmitterCacheInstrumentation.d.ts +9 -0
  70. package/dist/services/eventEmitterCacheInstrumentation.js +19 -0
  71. package/dist/services/inMemoryEntitlementsService.d.ts +5 -6
  72. package/dist/services/inMemoryEntitlementsService.js +36 -53
  73. package/dist/services/redisEntitlementsService.d.ts +5 -4
  74. package/dist/services/redisEntitlementsService.js +2 -2
  75. package/dist/types.d.ts +1 -0
  76. package/dist/utils/ModelMapper.d.ts +1 -1
  77. package/dist/{services/cache → utils}/calculateUsagePeriod.js +1 -1
  78. package/package.json +18 -1
  79. package/dist/services/cacheInstrumentation.d.ts +0 -18
  80. package/dist/services/cacheInstrumentation.js +0 -19
  81. package/dist/utils/CacheMapper.d.ts +0 -13
  82. package/dist/utils/CacheMapper.js +0 -95
  83. package/dist/utils/cacheKeysHelpers.js +0 -42
  84. /package/dist/{services/cache → utils}/calculateUsagePeriod.d.ts +0 -0
@@ -14,23 +14,15 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
14
14
  return (mod && mod.__esModule) ? mod : { "default": mod };
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
- exports.EntitlementsService = exports.accessDeniedReasonMap = void 0;
17
+ exports.EntitlementsService = void 0;
18
18
  const entitlementsApi_1 = __importDefault(require("../api/entitlements/entitlementsApi"));
19
19
  const ModelMapper_1 = require("../utils/ModelMapper");
20
20
  const entitlementDecisionService_1 = require("./entitlementDecisionService");
21
+ const cache_1 = require("./cache");
21
22
  const lodash_1 = require("lodash");
22
23
  const dateUtils_1 = require("../utils/dateUtils");
23
- const sdk_1 = require("@stigg/api-client-js/src/generated/sdk");
24
- const CacheMapper_1 = __importDefault(require("../utils/CacheMapper"));
25
- const entitlementsService_utils_1 = require("./entitlementsService.utils");
24
+ const cache_2 = require("./cache");
26
25
  const featureTypes_1 = require("../utils/featureTypes");
27
- const entities_1 = require("./cache/entities");
28
- const calculateUsagePeriod_1 = require("./cache/calculateUsagePeriod");
29
- exports.accessDeniedReasonMap = {
30
- [sdk_1.EntitlementsStateAccessDeniedReason.CustomerNotFound]: sdk_1.AccessDeniedReason.CustomerNotFound,
31
- [sdk_1.EntitlementsStateAccessDeniedReason.NoActiveSubscription]: sdk_1.AccessDeniedReason.NoActiveSubscription,
32
- [sdk_1.EntitlementsStateAccessDeniedReason.CustomerIsArchived]: sdk_1.AccessDeniedReason.CustomerIsArchived,
33
- };
34
26
  class EntitlementsService {
35
27
  constructor(client, loggerService, edgeApiClient, cacheService, entitlementsTimeout) {
36
28
  this.loggerService = loggerService;
@@ -38,22 +30,21 @@ class EntitlementsService {
38
30
  this.entitlementsTimeout = entitlementsTimeout;
39
31
  this.isInitialized = false;
40
32
  this.modelMapper = new ModelMapper_1.ModelMapper();
41
- this.cacheMapper = new CacheMapper_1.default(loggerService);
42
33
  this.entitlementsApi = new entitlementsApi_1.default(client, edgeApiClient, loggerService);
43
34
  }
44
- async getBooleanEntitlement(customerRefId, featureRefId, fallbackEntitlement, resourceId, options) {
45
- const { entitlement, accessDeniedReason } = await this.getCustomerAndEntitlementFromCacheOrRefetch({ type: entities_1.EntitlementType.Feature, id: featureRefId }, customerRefId, resourceId, 'getBooleanEntitlement');
35
+ async getBooleanEntitlement(customerId, featureRefId, fallbackEntitlement, resourceId, options) {
36
+ const { entitlement, accessDeniedReason } = await this.getCustomerAndEntitlementFromCacheOrRefetch({ type: cache_1.EntitlementType.Feature, id: featureRefId }, customerId, resourceId, 'getBooleanEntitlement');
46
37
  const decision = entitlementDecisionService_1.EntitlementDecisionService.decideEntitlementPolicy({
47
- entitlementType: entities_1.EntitlementType.Feature,
38
+ entitlementType: cache_1.EntitlementType.Feature,
48
39
  accessDeniedReason,
49
40
  entitlement,
50
41
  });
51
42
  if (entitlement && !(0, featureTypes_1.isBoolean)(entitlement.calculatedEntitlement.feature)) {
52
- return Object.assign(Object.assign({}, fallbackEntitlement), { accessDeniedReason: sdk_1.AccessDeniedReason.FeatureTypeMismatch });
43
+ return Object.assign(Object.assign({}, fallbackEntitlement), { accessDeniedReason: cache_1.AccessDeniedReason.FeatureTypeMismatch });
53
44
  }
54
45
  if (!entitlement) {
55
46
  this.loggerService.log(`No entitlement for boolean feature found`, {
56
- customerRefId,
47
+ customerId,
57
48
  resourceId,
58
49
  featureRefId,
59
50
  accessDeniedReason: decision.accessDeniedReason,
@@ -62,19 +53,19 @@ class EntitlementsService {
62
53
  }
63
54
  return this.modelMapper.mapBooleanEntitlement(entitlement, decision);
64
55
  }
65
- async getNumericEntitlement(customerRefId, featureRefId, fallbackEntitlement, resourceId, options) {
66
- const { entitlement, accessDeniedReason } = await this.getCustomerAndEntitlementFromCacheOrRefetch({ type: entities_1.EntitlementType.Feature, id: featureRefId }, customerRefId, resourceId, 'getNumericEntitlement');
56
+ async getNumericEntitlement(customerId, featureRefId, fallbackEntitlement, resourceId, options) {
57
+ const { entitlement, accessDeniedReason } = await this.getCustomerAndEntitlementFromCacheOrRefetch({ type: cache_1.EntitlementType.Feature, id: featureRefId }, customerId, resourceId, 'getNumericEntitlement');
67
58
  const decision = entitlementDecisionService_1.EntitlementDecisionService.decideEntitlementPolicy({
68
- entitlementType: entities_1.EntitlementType.Feature,
59
+ entitlementType: cache_1.EntitlementType.Feature,
69
60
  accessDeniedReason,
70
61
  entitlement,
71
62
  });
72
63
  if (entitlement && !(0, featureTypes_1.isNumeric)(entitlement.calculatedEntitlement.feature)) {
73
- return Object.assign(Object.assign({}, fallbackEntitlement), { accessDeniedReason: sdk_1.AccessDeniedReason.FeatureTypeMismatch });
64
+ return Object.assign(Object.assign({}, fallbackEntitlement), { accessDeniedReason: cache_1.AccessDeniedReason.FeatureTypeMismatch });
74
65
  }
75
66
  if (!entitlement) {
76
67
  this.loggerService.log(`No entitlement for numeric feature found`, {
77
- customerRefId,
68
+ customerId,
78
69
  resourceId,
79
70
  featureRefId,
80
71
  accessDeniedReason: decision.accessDeniedReason,
@@ -83,22 +74,21 @@ class EntitlementsService {
83
74
  }
84
75
  return this.modelMapper.mapNumericEntitlement(entitlement, decision);
85
76
  }
86
- async getMeteredEntitlement(customerRefId, featureRefId, fallbackEntitlement, resourceId, options) {
77
+ async getMeteredEntitlement(customerId, featureRefId, fallbackEntitlement, resourceId, options) {
87
78
  const requestUsage = options === null || options === void 0 ? void 0 : options.requestedUsage;
88
- const { entitlement: originalEntitlement, accessDeniedReason } = await this.getCustomerAndEntitlementFromCacheOrRefetch({ type: entities_1.EntitlementType.Feature, id: featureRefId }, customerRefId, resourceId, 'getMeteredEntitlement');
89
- const entitlement = this.handleUsagePeriodOver(originalEntitlement);
79
+ const { entitlement, accessDeniedReason } = await this.getCustomerAndEntitlementFromCacheOrRefetch({ type: cache_1.EntitlementType.Feature, id: featureRefId }, customerId, resourceId, 'getMeteredEntitlement');
90
80
  const decision = entitlementDecisionService_1.EntitlementDecisionService.decideEntitlementPolicy({
91
- entitlementType: entities_1.EntitlementType.Feature,
81
+ entitlementType: cache_1.EntitlementType.Feature,
92
82
  accessDeniedReason,
93
83
  entitlement,
94
84
  requestedUsage: requestUsage,
95
85
  });
96
86
  if (entitlement && !(0, featureTypes_1.isMetered)(entitlement.calculatedEntitlement.feature)) {
97
- return Object.assign(Object.assign({}, fallbackEntitlement), { accessDeniedReason: sdk_1.AccessDeniedReason.FeatureTypeMismatch });
87
+ return Object.assign(Object.assign({}, fallbackEntitlement), { accessDeniedReason: cache_1.AccessDeniedReason.FeatureTypeMismatch });
98
88
  }
99
89
  if (!entitlement) {
100
90
  this.loggerService.log(`No entitlement for metered feature found`, {
101
- customerRefId,
91
+ customerId,
102
92
  resourceId,
103
93
  featureRefId,
104
94
  accessDeniedReason: decision.accessDeniedReason,
@@ -107,21 +97,21 @@ class EntitlementsService {
107
97
  }
108
98
  return this.modelMapper.mapMeteredEntitlement(entitlement, decision, requestUsage);
109
99
  }
110
- async getEnumEntitlement(customerRefId, featureRefId, fallbackEntitlement, resourceId, options) {
100
+ async getEnumEntitlement(customerId, featureRefId, fallbackEntitlement, resourceId, options) {
111
101
  const requestedValues = options === null || options === void 0 ? void 0 : options.requestedValues;
112
- const { entitlement, accessDeniedReason } = await this.getCustomerAndEntitlementFromCacheOrRefetch({ type: entities_1.EntitlementType.Feature, id: featureRefId }, customerRefId, resourceId, 'getEnumEntitlement');
102
+ const { entitlement, accessDeniedReason } = await this.getCustomerAndEntitlementFromCacheOrRefetch({ type: cache_1.EntitlementType.Feature, id: featureRefId }, customerId, resourceId, 'getEnumEntitlement');
113
103
  const decision = entitlementDecisionService_1.EntitlementDecisionService.decideEntitlementPolicy({
114
- entitlementType: entities_1.EntitlementType.Feature,
104
+ entitlementType: cache_1.EntitlementType.Feature,
115
105
  accessDeniedReason,
116
106
  entitlement,
117
107
  requestedValues,
118
108
  });
119
109
  if (entitlement && !(0, featureTypes_1.isEnum)(entitlement.calculatedEntitlement.feature)) {
120
- return Object.assign(Object.assign({}, fallbackEntitlement), { accessDeniedReason: sdk_1.AccessDeniedReason.FeatureTypeMismatch });
110
+ return Object.assign(Object.assign({}, fallbackEntitlement), { accessDeniedReason: cache_1.AccessDeniedReason.FeatureTypeMismatch });
121
111
  }
122
112
  if (!entitlement) {
123
113
  this.loggerService.log(`No entitlement for enum feature found`, {
124
- customerRefId,
114
+ customerId,
125
115
  resourceId,
126
116
  featureRefId,
127
117
  accessDeniedReason: decision.accessDeniedReason,
@@ -130,16 +120,16 @@ class EntitlementsService {
130
120
  }
131
121
  return this.modelMapper.mapEnumEntitlement(entitlement, decision, requestedValues);
132
122
  }
133
- async getCreditEntitlement(customerRefId, currencyId, resourceId) {
134
- const { entitlement, accessDeniedReason } = await this.getCustomerAndEntitlementFromCacheOrRefetch({ type: entities_1.EntitlementType.Credit, id: currencyId }, customerRefId, resourceId, 'getCreditEntitlement');
123
+ async getCreditEntitlement(customerId, currencyId, resourceId) {
124
+ const { entitlement, accessDeniedReason } = await this.getCustomerAndEntitlementFromCacheOrRefetch({ type: cache_1.EntitlementType.Credit, id: currencyId }, customerId, resourceId, 'getCreditEntitlement');
135
125
  const decision = entitlementDecisionService_1.EntitlementDecisionService.decideEntitlementPolicy({
136
- entitlementType: entities_1.EntitlementType.Credit,
126
+ entitlementType: cache_1.EntitlementType.Credit,
137
127
  accessDeniedReason,
138
128
  entitlement,
139
129
  });
140
130
  if (!entitlement) {
141
131
  this.loggerService.log(`No entitlement for credit currency found`, {
142
- customerRefId,
132
+ customerId,
143
133
  resourceId,
144
134
  currencyId,
145
135
  accessDeniedReason: decision.accessDeniedReason,
@@ -156,10 +146,10 @@ class EntitlementsService {
156
146
  }
157
147
  return this.modelMapper.mapCreditEntitlement(entitlement, decision);
158
148
  }
159
- async getEntitlement(customerRefId, featureRefId, fallbackEntitlement, resourceId, requestedUsage, requestedValues) {
160
- const { entitlement, accessDeniedReason } = await this.getCustomerAndEntitlementFromCacheOrRefetch({ type: entities_1.EntitlementType.Feature, id: featureRefId }, customerRefId, resourceId, 'getEntitlement');
149
+ async getEntitlement(customerId, featureRefId, fallbackEntitlement, resourceId, requestedUsage, requestedValues) {
150
+ const { entitlement, accessDeniedReason } = await this.getCustomerAndEntitlementFromCacheOrRefetch({ type: cache_1.EntitlementType.Feature, id: featureRefId }, customerId, resourceId, 'getEntitlement');
161
151
  const decision = entitlementDecisionService_1.EntitlementDecisionService.decideEntitlementPolicy({
162
- entitlementType: entities_1.EntitlementType.Feature,
152
+ entitlementType: cache_1.EntitlementType.Feature,
163
153
  accessDeniedReason,
164
154
  entitlement,
165
155
  requestedUsage,
@@ -167,7 +157,7 @@ class EntitlementsService {
167
157
  });
168
158
  if (!entitlement) {
169
159
  this.loggerService.log(`No entitlement for feature found`, {
170
- customerRefId,
160
+ customerId,
171
161
  resourceId,
172
162
  featureRefId,
173
163
  accessDeniedReason: decision.accessDeniedReason,
@@ -178,33 +168,14 @@ class EntitlementsService {
178
168
  }
179
169
  return this.modelMapper.mapEntitlement(entitlement, decision, requestedUsage, requestedValues);
180
170
  }
181
- handleUsagePeriodOver(entitlement) {
182
- if (!entitlement) {
183
- return entitlement;
184
- }
185
- const { calculatedEntitlement, usageData } = entitlement;
186
- const now = new Date();
187
- const wasPeriodOver = (0, featureTypes_1.isMetered)(calculatedEntitlement.feature) && usageData.usagePeriodEnd && usageData.usagePeriodEnd < now.getTime();
188
- if (!wasPeriodOver) {
189
- return entitlement;
190
- }
191
- const { resetPeriod, usagePeriodAnchor } = calculatedEntitlement;
192
- let usagePeriodStart;
193
- let usagePeriodEnd;
194
- // Calculate new usage period
195
- if (usagePeriodAnchor && resetPeriod) {
196
- ({ usagePeriodStart, usagePeriodEnd } = (0, calculateUsagePeriod_1.calculateUsagePeriod)(new Date(usagePeriodAnchor), now, resetPeriod));
197
- }
198
- return new entities_1.CachedEntitlement(calculatedEntitlement, Object.assign(Object.assign({}, usageData), { currentUsage: 0, usagePeriodStart: usagePeriodStart === null || usagePeriodStart === void 0 ? void 0 : usagePeriodStart.getTime(), usagePeriodEnd: usagePeriodEnd === null || usagePeriodEnd === void 0 ? void 0 : usagePeriodEnd.getTime() }));
199
- }
200
- async getCustomerAndEntitlementFromCacheOrRefetch(query, customerRefId, resourceId, triggeredBy) {
171
+ async getCustomerAndEntitlementFromCacheOrRefetch(query, customerId, resourceId, triggeredBy) {
201
172
  var _a, _b;
202
- const result = await this.cacheService.getCustomerEntitlement(query, customerRefId, resourceId);
173
+ const result = await this.cacheService.getCustomerEntitlement({ query, customerId, resourceId });
203
174
  let { entitlement, accessDeniedReason } = result;
204
175
  const shouldRefetch = result.cacheMiss || !this.isInitialized || this.isEntitlementExpired(entitlement);
205
176
  if (shouldRefetch) {
206
177
  const postMissResult = await this.refetchEntitlementsAfterCacheMiss({
207
- customerId: customerRefId,
178
+ customerId,
208
179
  resourceId,
209
180
  refetchGlobalCustomer: result.globalCustomerMissing,
210
181
  triggeredBy,
@@ -214,13 +185,13 @@ class EntitlementsService {
214
185
  }
215
186
  return { entitlement, accessDeniedReason };
216
187
  }
217
- async getCustomerEntitlements(customerRefId, resourceId) {
218
- const result = await this.cacheService.getCustomerEntitlements(customerRefId, resourceId);
188
+ async getCustomerEntitlements(customerId, resourceId) {
189
+ const result = await this.cacheService.getCustomerEntitlements({ customerId, resourceId });
219
190
  let { entitlements, accessDeniedReason } = result;
220
191
  const shouldRefetch = result.cacheMiss || !this.isInitialized || this.areEntitlementsExpired(entitlements);
221
192
  if (shouldRefetch) {
222
193
  ({ entitlements, accessDeniedReason } = await this.refetchEntitlementsAfterCacheMiss({
223
- customerId: customerRefId,
194
+ customerId,
224
195
  resourceId,
225
196
  refetchGlobalCustomer: result.globalCustomerMissing,
226
197
  triggeredBy: 'getCustomerEntitlements',
@@ -230,11 +201,11 @@ class EntitlementsService {
230
201
  return { entitlements: [], accessDeniedReason: accessDeniedReason !== null && accessDeniedReason !== void 0 ? accessDeniedReason : null };
231
202
  }
232
203
  // Filter to feature entitlements only - credit entitlement mapping is out of scope for now
233
- const featureEntitlements = entitlements.values().filter(entities_1.isFeatureEntitlement);
204
+ const featureEntitlements = entitlements.values().filter(cache_1.isFeatureEntitlement);
234
205
  return {
235
206
  entitlements: featureEntitlements.map((value) => {
236
207
  const decision = entitlementDecisionService_1.EntitlementDecisionService.decideEntitlementPolicy({
237
- entitlementType: entities_1.EntitlementType.Feature,
208
+ entitlementType: cache_1.EntitlementType.Feature,
238
209
  accessDeniedReason,
239
210
  entitlement: value,
240
211
  });
@@ -285,17 +256,14 @@ class EntitlementsService {
285
256
  });
286
257
  const entitlementsResult = await this.entitlementsApi.getEntitlementsState(customerId, resourceId, skipEdge, this.entitlementsTimeout);
287
258
  const { entitlementsV2: entitlements, accessDeniedReason } = entitlementsResult.data.entitlementsState;
288
- let localAccessDeniedReason = null;
289
- if (accessDeniedReason) {
290
- localAccessDeniedReason = exports.accessDeniedReasonMap[accessDeniedReason];
291
- }
259
+ const localAccessDeniedReason = (0, cache_1.mapAccessDeniedReason)(accessDeniedReason);
292
260
  const updatedEntitlements = await this.setEntitlements({
293
- entitlements: entitlements,
294
- accessDeniedReason: localAccessDeniedReason,
261
+ entitlements,
262
+ accessDeniedReason,
295
263
  customerId,
296
264
  resourceId,
297
265
  });
298
- return entitlementsService_utils_1.entitlementsResponseMapper.cacheHit(updatedEntitlements, localAccessDeniedReason);
266
+ return cache_2.entitlementsResponseMapper.cacheHit(updatedEntitlements, localAccessDeniedReason);
299
267
  }
300
268
  async setEntitlementsIfExists(options) {
301
269
  const { entitlements } = options, rest = __rest(options, ["entitlements"]);
@@ -311,20 +279,18 @@ class EntitlementsService {
311
279
  customerId,
312
280
  resourceId,
313
281
  });
314
- const cachedEntitlements = this.cacheMapper.mapCachedEntitlements(entitlements);
315
- // optimistically update the cache
316
- try {
317
- await this.cacheService.setCustomer(customerId, cachedEntitlements, accessDeniedReason, resourceId, entitlementsUpdatedAtTimestamp.getTime());
318
- }
319
- catch (err) {
320
- this.loggerService.error('Failed to set customer entitlements in cache (soft ignored)', err);
321
- }
322
- return cachedEntitlements;
282
+ return this.cacheService.setCustomer({
283
+ customerId,
284
+ resourceId,
285
+ entitlements,
286
+ accessDeniedReason,
287
+ entitlementsTimestamp: entitlementsUpdatedAtTimestamp.getTime(),
288
+ });
323
289
  }
324
290
  getEntitlementsUpdatedAtTimestamp({ entitlements, customerId, resourceId, }) {
325
291
  if ((0, lodash_1.isEmpty)(entitlements)) {
326
292
  // empty entitlements means we don't have a timestamp
327
- return entitlementsService_utils_1.DATE_IN_FAR_PAST;
293
+ return cache_2.DATE_IN_FAR_PAST;
328
294
  }
329
295
  const entitlementsUpdatedAt = entitlements
330
296
  .map(({ entitlementUpdatedAt }) => entitlementUpdatedAt)
@@ -339,7 +305,7 @@ class EntitlementsService {
339
305
  return new Date(entitlementsUpdatedAt);
340
306
  }
341
307
  async updateFeatureUsage({ featureId, customerId, resourceId, currentUsage, usagePeriodStart, usagePeriodEnd, timestamp, }) {
342
- var _a, _b, _c, _d;
308
+ var _a, _b, _c, _d, _e;
343
309
  if ((0, lodash_1.isNil)(currentUsage)) {
344
310
  return;
345
311
  }
@@ -347,14 +313,14 @@ class EntitlementsService {
347
313
  customerId,
348
314
  resourceId,
349
315
  entitlementReference: {
350
- type: entities_1.EntitlementType.Feature,
316
+ type: cache_1.EntitlementType.Feature,
351
317
  id: featureId,
352
318
  },
319
+ usageTimestamp: (_a = (0, dateUtils_1.mapDate)(timestamp)) !== null && _a !== void 0 ? _a : new Date(),
353
320
  usage: {
354
321
  currentUsage,
355
- usagePeriodStart: (_a = (0, dateUtils_1.mapDate)(usagePeriodStart)) === null || _a === void 0 ? void 0 : _a.getTime(),
356
- usagePeriodEnd: (_b = (0, dateUtils_1.mapDate)(usagePeriodEnd)) === null || _b === void 0 ? void 0 : _b.getTime(),
357
- updatedAt: (_d = (_c = (0, dateUtils_1.mapDate)(timestamp)) === null || _c === void 0 ? void 0 : _c.getTime()) !== null && _d !== void 0 ? _d : Date.now(),
322
+ usagePeriodStart: (_c = (_b = (0, dateUtils_1.mapDate)(usagePeriodStart)) === null || _b === void 0 ? void 0 : _b.getTime()) !== null && _c !== void 0 ? _c : null,
323
+ usagePeriodEnd: (_e = (_d = (0, dateUtils_1.mapDate)(usagePeriodEnd)) === null || _d === void 0 ? void 0 : _d.getTime()) !== null && _e !== void 0 ? _e : null,
358
324
  },
359
325
  });
360
326
  }
@@ -376,4 +342,4 @@ class EntitlementsService {
376
342
  }
377
343
  }
378
344
  exports.EntitlementsService = EntitlementsService;
379
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50aXRsZW1lbnRzU2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZXJ2aWNlcy9lbnRpdGxlbWVudHNTZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsMEZBQWtFO0FBaUJsRSxzREFBbUQ7QUFDbkQsNkVBQTBFO0FBRzFFLG1DQUF3QztBQUV4QyxrREFBMEQ7QUFDMUQsZ0VBU2dEO0FBQ2hELHVFQUErQztBQUMvQywyRUFTcUM7QUFDckMsd0RBQWdGO0FBQ2hGLCtDQUE2RztBQUM3Ryx1RUFBb0U7QUFFdkQsUUFBQSxxQkFBcUIsR0FBb0U7SUFDcEcsQ0FBQyx5Q0FBbUMsQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLHdCQUFrQixDQUFDLGdCQUFnQjtJQUMzRixDQUFDLHlDQUFtQyxDQUFDLG9CQUFvQixDQUFDLEVBQUUsd0JBQWtCLENBQUMsb0JBQW9CO0lBQ25HLENBQUMseUNBQW1DLENBQUMsa0JBQWtCLENBQUMsRUFBRSx3QkFBa0IsQ0FBQyxrQkFBa0I7Q0FDaEcsQ0FBQztBQU1GLE1BQXNCLG1CQUFtQjtJQU92QyxZQUNFLE1BQTJDLEVBQ3hCLGFBQTRCLEVBQy9DLGFBQW1DLEVBQ2hCLFlBQTBCLEVBQzVCLG1CQUEyQjtRQUh6QixrQkFBYSxHQUFiLGFBQWEsQ0FBZTtRQUU1QixpQkFBWSxHQUFaLFlBQVksQ0FBYztRQUM1Qix3QkFBbUIsR0FBbkIsbUJBQW1CLENBQVE7UUFQcEMsa0JBQWEsR0FBRyxLQUFLLENBQUM7UUFTOUIsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLHlCQUFXLEVBQUUsQ0FBQztRQUNyQyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUkscUJBQVcsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUNsRCxJQUFJLENBQUMsZUFBZSxHQUFHLElBQUkseUJBQWUsQ0FBQyxNQUFNLEVBQUUsYUFBYSxFQUFFLGFBQWEsQ0FBQyxDQUFDO0lBQ25GLENBQUM7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
345
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50aXRsZW1lbnRzU2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZXJ2aWNlcy9lbnRpdGxlbWVudHNTZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsMEZBQWtFO0FBaUJsRSxzREFBbUQ7QUFDbkQsNkVBQTBFO0FBQzFFLG1DQVNpQjtBQUNqQixtQ0FBd0M7QUFHeEMsa0RBQTBEO0FBUzFELG1DQUtpQjtBQU9qQix3REFBZ0Y7QUFPaEYsTUFBc0IsbUJBQW1CO0lBTXZDLFlBQ0UsTUFBMkMsRUFDeEIsYUFBNEIsRUFDL0MsYUFBbUMsRUFDaEIsWUFBZ0QsRUFDbEQsbUJBQTJCO1FBSHpCLGtCQUFhLEdBQWIsYUFBYSxDQUFlO1FBRTVCLGlCQUFZLEdBQVosWUFBWSxDQUFvQztRQUNsRCx3QkFBbUIsR0FBbkIsbUJBQW1CLENBQVE7UUFQcEMsa0JBQWEsR0FBRyxLQUFLLENBQUM7UUFTOUIsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLHlCQUFXLEVBQUUsQ0FBQztRQUNyQyxJQUFJLENBQUMsZUFBZSxHQUFHLElBQUkseUJBQWUsQ0FBQyxNQUFNLEVBQUUsYUFBYSxFQUFFLGFBQWEsQ0FBQyxDQUFDO0lBQ25GLENBQUM7SUFFRCxLQUFLLENBQUMscUJBQXFCLENBQ3pCLFVBQWtCLEVBQ2xCLFlBQW9CLEVBQ3BCLG1CQUF1QyxFQUN2QyxVQUFtQixFQUNuQixPQUFtQztRQUVuQyxNQUFNLEVBQUUsV0FBVyxFQUFFLGtCQUFrQixFQUFFLEdBQUcsTUFBTSxJQUFJLENBQUMsMkNBQTJDLENBQ2hHLEVBQUUsSUFBSSxFQUFFLHVCQUFlLENBQUMsT0FBTyxFQUFFLEVBQUUsRUFBRSxZQUFZLEVBQUUsRUFDbkQsVUFBVSxFQUNWLFVBQVUsRUFDVix1QkFBdUIsQ0FDeEIsQ0FBQztRQUVGLE1BQU0sUUFBUSxHQUFHLHVEQUEwQixDQUFDLHVCQUF1QixDQUFDO1lBQ2xFLGVB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
@@ -1,31 +1,5 @@
1
- import { CachedEntitlement, EntitlementType, EntitlementsMap } from './cache/entities';
2
- import { AccessDeniedReason } from '../models';
3
1
  export type GetEntitlementsOperations = 'getBooleanEntitlement' | 'getNumericEntitlement' | 'getMeteredEntitlement' | 'getEnumEntitlement' | 'getCreditEntitlement' | 'getEntitlement' | 'getCustomerEntitlements';
4
2
  export type RefetchEntitlementsTriggeredBy = GetEntitlementsOperations | 'updateSubscription' | 'cancelSubscription' | 'createSubscription' | 'reloadEntitlements';
5
- export declare const DATE_IN_FAR_PAST: Date;
6
- export type EntitlementsResponseCacheHit = {
7
- cacheMiss: false;
8
- entitlements: EntitlementsMap;
9
- accessDeniedReason: AccessDeniedReason | null;
10
- globalCustomerMissing: false;
11
- };
12
- export type EntitlementsResponseCacheMiss = {
13
- cacheMiss: true;
14
- entitlements: null;
15
- accessDeniedReason: undefined;
16
- globalCustomerMissing: boolean;
17
- };
18
- export type EntitlementsResponse = EntitlementsResponseCacheHit | EntitlementsResponseCacheMiss;
19
- export type EntitlementResponse<T extends EntitlementType = EntitlementType> = {
20
- cacheMiss: boolean;
21
- accessDeniedReason?: AccessDeniedReason | null;
22
- entitlement: CachedEntitlement<T> | null;
23
- globalCustomerMissing: boolean;
24
- };
25
- export declare const entitlementsResponseMapper: {
26
- cacheHit: (entitlements: EntitlementsMap, accessDeniedReason: AccessDeniedReason | null) => EntitlementsResponseCacheHit;
27
- cacheMiss: (globalCustomerMissing?: boolean) => EntitlementsResponseCacheMiss;
28
- };
29
3
  export type RefetchEntityEntitlementsAfterCacheMissParams = {
30
4
  customerId: string;
31
5
  resourceId: string | undefined;
@@ -1,19 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.entitlementsResponseMapper = exports.DATE_IN_FAR_PAST = void 0;
4
- exports.DATE_IN_FAR_PAST = new Date(0);
5
- exports.entitlementsResponseMapper = {
6
- cacheHit: (entitlements, accessDeniedReason) => ({
7
- cacheMiss: false,
8
- entitlements,
9
- accessDeniedReason,
10
- globalCustomerMissing: false,
11
- }),
12
- cacheMiss: (globalCustomerMissing = false) => ({
13
- cacheMiss: true,
14
- entitlements: null,
15
- accessDeniedReason: undefined,
16
- globalCustomerMissing,
17
- }),
18
- };
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50aXRsZW1lbnRzU2VydmljZS51dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZXJ2aWNlcy9lbnRpdGxlbWVudHNTZXJ2aWNlLnV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQW1CYSxRQUFBLGdCQUFnQixHQUFHLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBeUIvQixRQUFBLDBCQUEwQixHQUFHO0lBQ3hDLFFBQVEsRUFBRSxDQUNSLFlBQTZCLEVBQzdCLGtCQUE2QyxFQUNmLEVBQUUsQ0FBQyxDQUFDO1FBQ2xDLFNBQVMsRUFBRSxLQUFLO1FBQ2hCLFlBQVk7UUFDWixrQkFBa0I7UUFDbEIscUJBQXFCLEVBQUUsS0FBSztLQUM3QixDQUFDO0lBQ0YsU0FBUyxFQUFFLENBQUMscUJBQXFCLEdBQUcsS0FBSyxFQUFpQyxFQUFFLENBQUMsQ0FBQztRQUM1RSxTQUFTLEVBQUUsSUFBSTtRQUNmLFlBQVksRUFBRSxJQUFJO1FBQ2xCLGtCQUFrQixFQUFFLFNBQVM7UUFDN0IscUJBQXFCO0tBQ3RCLENBQUM7Q0FDSCxDQUFDIn0=
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50aXRsZW1lbnRzU2VydmljZS51dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZXJ2aWNlcy9lbnRpdGxlbWVudHNTZXJ2aWNlLnV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIifQ==
@@ -1,6 +1,6 @@
1
1
  import { TypedEmitter } from 'tiny-typed-emitter';
2
2
  import { CreditBalanceUpdatedPayloadFragment, EntitlementsUpdatedPayloadFragment, EntitlementUsageUpdatedFragment, PackagePublishedPayloadFragment } from '@stigg/api-client-js/src/generated/sdk';
3
- import { CacheHit, CacheMiss } from './cacheInstrumentation';
3
+ import { CacheHit, CacheMiss } from './cache';
4
4
  import { AxiosRequestConfig, AxiosResponse } from 'axios';
5
5
  export type NetworkRequestFailed = {
6
6
  errorMessage: string;
@@ -0,0 +1,9 @@
1
+ import { TypedEventEmitter } from './eventEmitter';
2
+ import { CacheInstrumentation, CacheHit, CacheMiss, RedisClientErrorData } from './cache';
3
+ export declare class EventEmitterCacheInstrumentation implements CacheInstrumentation {
4
+ private readonly eventEmitter;
5
+ constructor(eventEmitter: TypedEventEmitter);
6
+ trackHit(data: CacheHit): void;
7
+ trackMiss(data: CacheMiss): void;
8
+ trackRedisClientError(data: RedisClientErrorData): void;
9
+ }
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EventEmitterCacheInstrumentation = void 0;
4
+ class EventEmitterCacheInstrumentation {
5
+ constructor(eventEmitter) {
6
+ this.eventEmitter = eventEmitter;
7
+ }
8
+ trackHit(data) {
9
+ this.eventEmitter.emit('cacheHit', data);
10
+ }
11
+ trackMiss(data) {
12
+ this.eventEmitter.emit('cacheMiss', data);
13
+ }
14
+ trackRedisClientError(data) {
15
+ this.eventEmitter.emit('redisClientError', data);
16
+ }
17
+ }
18
+ exports.EventEmitterCacheInstrumentation = EventEmitterCacheInstrumentation;
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnRFbWl0dGVyQ2FjaGVJbnN0cnVtZW50YXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2VydmljZXMvZXZlbnRFbWl0dGVyQ2FjaGVJbnN0cnVtZW50YXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBR0EsTUFBYSxnQ0FBZ0M7SUFDM0MsWUFBNkIsWUFBK0I7UUFBL0IsaUJBQVksR0FBWixZQUFZLENBQW1CO0lBQUcsQ0FBQztJQUVoRSxRQUFRLENBQUMsSUFBYztRQUNyQixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUVELFNBQVMsQ0FBQyxJQUFlO1FBQ3ZCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUM1QyxDQUFDO0lBRUQscUJBQXFCLENBQUMsSUFBMEI7UUFDOUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsa0JBQWtCLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDbkQsQ0FBQztDQUNGO0FBZEQsNEVBY0MifQ==
@@ -2,25 +2,24 @@ import { ApolloClient, NormalizedCacheObject } from '@apollo/client/core';
2
2
  import { LoggerService } from './loggerService';
3
3
  import { TypedEventEmitter } from './eventEmitter';
4
4
  import { EntitlementsService } from './entitlementsService';
5
- import { InMemoryCacheService } from './cache/inMemoryCacheService';
5
+ import { InMemoryCacheService } from './cache';
6
6
  import { EdgeApiClient } from './EdgeApiClient';
7
7
  import { RefetchEntityEntitlementsAfterCacheMissParams } from './entitlementsService.utils';
8
+ import { CacheableEntitlement } from './ApiCacheMapper';
8
9
  export declare class InMemoryEntitlementsService extends EntitlementsService {
9
- protected readonly cacheService: InMemoryCacheService;
10
+ protected readonly cacheService: InMemoryCacheService<CacheableEntitlement>;
10
11
  private readonly eventEmitter;
11
12
  private entitlementsSubscription;
12
13
  private usageSubscription;
13
14
  private packagePublished;
14
- private creditBalance;
15
- constructor(cacheService: InMemoryCacheService, client: ApolloClient<NormalizedCacheObject>, eventEmitter: TypedEventEmitter, loggerService: LoggerService, edgeApiClient: EdgeApiClient | null, entitlementsTimeout: number);
15
+ constructor(cacheService: InMemoryCacheService<CacheableEntitlement>, client: ApolloClient<NormalizedCacheObject>, eventEmitter: TypedEventEmitter, loggerService: LoggerService, edgeApiClient: EdgeApiClient | null, entitlementsTimeout: number);
16
16
  init(): void;
17
17
  private websocketErrorHandling;
18
18
  cleanup(): void;
19
19
  private onEntitlementsUpdated;
20
20
  private onUsageUpdated;
21
- private onCreditBalanceUpdated;
22
21
  private isErrorRecoverable;
23
22
  clearCache(): void;
24
23
  private onPackagePublished;
25
- protected refetchEntityEntitlementsAfterCacheMiss(params: RefetchEntityEntitlementsAfterCacheMissParams): Promise<import("./entitlementsService.utils").EntitlementsResponseCacheHit>;
24
+ protected refetchEntityEntitlementsAfterCacheMiss(params: RefetchEntityEntitlementsAfterCacheMissParams): Promise<import("./cache").EntitlementsResponseCacheHit>;
26
25
  }