@adtrackify/at-service-common 3.19.25 → 4.0.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 (761) hide show
  1. package/dist/cjs/__tests__/clients/acuity-client.spec.d.ts +1 -1
  2. package/dist/cjs/__tests__/clients/acuity-client.spec.js +43 -43
  3. package/dist/cjs/__tests__/clients/cross-platform-compression.spec.d.ts +1 -1
  4. package/dist/cjs/__tests__/clients/cross-platform-compression.spec.js +354 -354
  5. package/dist/cjs/__tests__/clients/dynamodb-client.spec.d.ts +1 -1
  6. package/dist/cjs/__tests__/clients/dynamodb-client.spec.js +194 -194
  7. package/dist/cjs/__tests__/clients/sqs-bundled-client.spec.d.ts +1 -1
  8. package/dist/cjs/__tests__/clients/sqs-bundled-client.spec.js +931 -931
  9. package/dist/cjs/__tests__/clients/sqs-bundling-contracts.spec.d.ts +1 -1
  10. package/dist/cjs/__tests__/clients/sqs-bundling-contracts.spec.js +563 -563
  11. package/dist/cjs/__tests__/clients/sqs-client.spec.d.ts +1 -1
  12. package/dist/cjs/__tests__/clients/sqs-client.spec.js +191 -191
  13. package/dist/cjs/__tests__/clients/sqs-unbundle.spec.d.ts +1 -1
  14. package/dist/cjs/__tests__/clients/sqs-unbundle.spec.js +1357 -1357
  15. package/dist/cjs/__tests__/db/contact-enrichments-db-service.spec.d.ts +1 -1
  16. package/dist/cjs/__tests__/db/contact-enrichments-db-service.spec.js +68 -68
  17. package/dist/cjs/__tests__/db/destinations-db-service.spec.d.ts +1 -1
  18. package/dist/cjs/__tests__/db/destinations-db-service.spec.js +125 -125
  19. package/dist/cjs/__tests__/db/shared-read-db-services.spec.d.ts +1 -1
  20. package/dist/cjs/__tests__/db/shared-read-db-services.spec.js +89 -89
  21. package/dist/cjs/__tests__/db/shopify-app-installs-db-service.spec.d.ts +1 -1
  22. package/dist/cjs/__tests__/db/shopify-app-installs-db-service.spec.js +104 -104
  23. package/dist/cjs/__tests__/db/subscriptions-db-service.spec.d.ts +1 -1
  24. package/dist/cjs/__tests__/db/subscriptions-db-service.spec.js +95 -95
  25. package/dist/cjs/__tests__/db/user-accounts-db-service.spec.d.ts +1 -1
  26. package/dist/cjs/__tests__/db/user-accounts-db-service.spec.js +76 -76
  27. package/dist/cjs/__tests__/helpers/account-users-helper.spec.d.ts +1 -1
  28. package/dist/cjs/__tests__/helpers/account-users-helper.spec.js +220 -220
  29. package/dist/cjs/__tests__/helpers/acuity-helper.spec.d.ts +1 -1
  30. package/dist/cjs/__tests__/helpers/acuity-helper.spec.js +69 -69
  31. package/dist/cjs/__tests__/helpers/api-key-auth-helper.spec.d.ts +1 -1
  32. package/dist/cjs/__tests__/helpers/api-key-auth-helper.spec.js +82 -82
  33. package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.d.ts +1 -1
  34. package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.js +676 -674
  35. package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.js.map +1 -1
  36. package/dist/cjs/__tests__/identity-cache/identity-cache-dynamodb-service.spec.d.ts +1 -1
  37. package/dist/cjs/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js +1140 -1140
  38. package/dist/cjs/__tests__/{db/products-db-service.spec.d.ts → identity-cache/identity-cache-tier-routing.spec.d.ts} +1 -1
  39. package/dist/cjs/__tests__/identity-cache/identity-cache-tier-routing.spec.js +852 -0
  40. package/dist/cjs/__tests__/identity-cache/identity-cache-tier-routing.spec.js.map +1 -0
  41. package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.d.ts +1 -1
  42. package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.js +1060 -588
  43. package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.js.map +1 -1
  44. package/dist/cjs/__tests__/{services/cost/cost-calculator-service.spec.d.ts → identity-cache/volatile-traits-optimization.spec.d.ts} +1 -1
  45. package/dist/cjs/__tests__/identity-cache/volatile-traits-optimization.spec.js +819 -0
  46. package/dist/cjs/__tests__/identity-cache/volatile-traits-optimization.spec.js.map +1 -0
  47. package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.d.ts +1 -1
  48. package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.js +584 -584
  49. package/dist/cjs/__tests__/libs/compress-decompress.spec.d.ts +1 -1
  50. package/dist/cjs/__tests__/libs/compress-decompress.spec.js +16 -16
  51. package/dist/cjs/__tests__/libs/contacts.spec.d.ts +1 -1
  52. package/dist/cjs/__tests__/libs/contacts.spec.js +294 -294
  53. package/dist/cjs/__tests__/libs/currency.spec.d.ts +1 -1
  54. package/dist/cjs/__tests__/libs/currency.spec.js +220 -220
  55. package/dist/cjs/__tests__/libs/dates.spec.d.ts +1 -1
  56. package/dist/cjs/__tests__/libs/dates.spec.js +130 -130
  57. package/dist/cjs/__tests__/libs/domain.spec.d.ts +1 -1
  58. package/dist/cjs/__tests__/libs/domain.spec.js +107 -107
  59. package/dist/cjs/__tests__/libs/numbers.spec.d.ts +1 -1
  60. package/dist/cjs/__tests__/libs/numbers.spec.js +261 -261
  61. package/dist/cjs/__tests__/s3-client/s3-client.spec.d.ts +1 -1
  62. package/dist/cjs/__tests__/s3-client/s3-client.spec.js +33 -33
  63. package/dist/cjs/__tests__/services/acuity-api-service.spec.d.ts +1 -1
  64. package/dist/cjs/__tests__/services/acuity-api-service.spec.js +71 -71
  65. package/dist/cjs/__tests__/services/email-verification/contact-email-verification-service.spec.d.ts +1 -1
  66. package/dist/cjs/__tests__/services/email-verification/contact-email-verification-service.spec.js +93 -93
  67. package/dist/cjs/__tests__/services/email-verification/email-verification-service.spec.d.ts +1 -1
  68. package/dist/cjs/__tests__/services/email-verification/email-verification-service.spec.js +57 -57
  69. package/dist/cjs/__tests__/shopify/shopify-graphql-transformer.spec.d.ts +1 -1
  70. package/dist/cjs/__tests__/shopify/shopify-graphql-transformer.spec.js +35 -35
  71. package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.d.ts +1 -1
  72. package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.js +181 -181
  73. package/dist/cjs/__tests__/unit/libs/api-router/route-matcher.spec.d.ts +1 -1
  74. package/dist/cjs/__tests__/unit/libs/api-router/route-matcher.spec.js +69 -69
  75. package/dist/cjs/__tests__/utils/custom-measure-formula-utils.spec.d.ts +1 -1
  76. package/dist/cjs/__tests__/utils/custom-measure-formula-utils.spec.js +139 -139
  77. package/dist/cjs/clients/generic/cognito-client.d.ts +23 -23
  78. package/dist/cjs/clients/generic/cognito-client.js +209 -209
  79. package/dist/cjs/clients/generic/dynamodb-client.d.ts +20 -20
  80. package/dist/cjs/clients/generic/dynamodb-client.js +235 -235
  81. package/dist/cjs/clients/generic/eventbridge-client.d.ts +14 -14
  82. package/dist/cjs/clients/generic/eventbridge-client.js +51 -51
  83. package/dist/cjs/clients/generic/http-client.d.ts +14 -14
  84. package/dist/cjs/clients/generic/http-client.js +61 -61
  85. package/dist/cjs/clients/generic/index.d.ts +13 -13
  86. package/dist/cjs/clients/generic/index.js +29 -29
  87. package/dist/cjs/clients/generic/lambda-invoke-client.d.ts +10 -10
  88. package/dist/cjs/clients/generic/lambda-invoke-client.js +39 -39
  89. package/dist/cjs/clients/generic/location-client.d.ts +8 -8
  90. package/dist/cjs/clients/generic/location-client.js +31 -31
  91. package/dist/cjs/clients/generic/redis-client.d.ts +33 -33
  92. package/dist/cjs/clients/generic/redis-client.js +191 -191
  93. package/dist/cjs/clients/generic/s3-client.d.ts +23 -23
  94. package/dist/cjs/clients/generic/s3-client.js +216 -216
  95. package/dist/cjs/clients/generic/singlestore-db-client.d.ts +14 -14
  96. package/dist/cjs/clients/generic/singlestore-db-client.js +67 -67
  97. package/dist/cjs/clients/generic/sqs-bundled-client.d.ts +15 -15
  98. package/dist/cjs/clients/generic/sqs-bundled-client.js +311 -311
  99. package/dist/cjs/clients/generic/sqs-bundled-client.types.d.ts +53 -53
  100. package/dist/cjs/clients/generic/sqs-bundled-client.types.js +17 -17
  101. package/dist/cjs/clients/generic/sqs-client.d.ts +53 -53
  102. package/dist/cjs/clients/generic/sqs-client.js +285 -285
  103. package/dist/cjs/clients/generic/sqs-unbundle.d.ts +32 -32
  104. package/dist/cjs/clients/generic/sqs-unbundle.js +144 -144
  105. package/dist/cjs/clients/index.d.ts +3 -3
  106. package/dist/cjs/clients/index.js +19 -19
  107. package/dist/cjs/clients/internal-api/accounts-client.d.ts +91 -91
  108. package/dist/cjs/clients/internal-api/accounts-client.js +129 -129
  109. package/dist/cjs/clients/internal-api/cache-lambda-client.d.ts +26 -26
  110. package/dist/cjs/clients/internal-api/cache-lambda-client.js +89 -89
  111. package/dist/cjs/clients/internal-api/db-management-client.d.ts +18 -18
  112. package/dist/cjs/clients/internal-api/db-management-client.js +36 -36
  113. package/dist/cjs/clients/internal-api/destinations-client.d.ts +34 -34
  114. package/dist/cjs/clients/internal-api/destinations-client.js +79 -79
  115. package/dist/cjs/clients/internal-api/event-collector-client.d.ts +20 -20
  116. package/dist/cjs/clients/internal-api/event-collector-client.js +36 -36
  117. package/dist/cjs/clients/internal-api/identity-client.d.ts +31 -31
  118. package/dist/cjs/clients/internal-api/identity-client.js +91 -91
  119. package/dist/cjs/clients/internal-api/index.d.ts +9 -9
  120. package/dist/cjs/clients/internal-api/index.js +25 -25
  121. package/dist/cjs/clients/internal-api/shopify-app-install-client.d.ts +37 -37
  122. package/dist/cjs/clients/internal-api/shopify-app-install-client.js +81 -81
  123. package/dist/cjs/clients/internal-api/subscriptions-client.d.ts +26 -26
  124. package/dist/cjs/clients/internal-api/subscriptions-client.js +77 -77
  125. package/dist/cjs/clients/internal-api/users-auth-client.d.ts +35 -35
  126. package/dist/cjs/clients/internal-api/users-auth-client.js +110 -110
  127. package/dist/cjs/clients/third-party/acuity-client.d.ts +10 -10
  128. package/dist/cjs/clients/third-party/acuity-client.js +40 -40
  129. package/dist/cjs/clients/third-party/emailable-client.d.ts +7 -7
  130. package/dist/cjs/clients/third-party/emailable-client.js +25 -25
  131. package/dist/cjs/clients/third-party/exchange-rate-api-client.d.ts +17 -17
  132. package/dist/cjs/clients/third-party/exchange-rate-api-client.js +19 -19
  133. package/dist/cjs/clients/third-party/index.d.ts +5 -5
  134. package/dist/cjs/clients/third-party/index.js +21 -21
  135. package/dist/cjs/clients/third-party/loops-client.d.ts +10 -10
  136. package/dist/cjs/clients/third-party/loops-client.js +30 -30
  137. package/dist/cjs/clients/third-party/shopify/graphql-order-queries.d.ts +25 -25
  138. package/dist/cjs/clients/third-party/shopify/graphql-order-queries.js +4 -4
  139. package/dist/cjs/clients/third-party/shopify/graphql-product-queries.d.ts +2 -2
  140. package/dist/cjs/clients/third-party/shopify/graphql-product-queries.js +5 -5
  141. package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.d.ts +10 -10
  142. package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.js +161 -161
  143. package/dist/cjs/clients/third-party/shopify-client.d.ts +29 -29
  144. package/dist/cjs/clients/third-party/shopify-client.js +146 -146
  145. package/dist/cjs/constants/index.d.ts +1 -1
  146. package/dist/cjs/constants/index.js +17 -17
  147. package/dist/cjs/constants/sqs.d.ts +20 -20
  148. package/dist/cjs/constants/sqs.js +26 -26
  149. package/dist/cjs/helpers/account-users-helper.d.ts +2 -2
  150. package/dist/cjs/helpers/account-users-helper.js +22 -22
  151. package/dist/cjs/helpers/acuity-helper.d.ts +4 -4
  152. package/dist/cjs/helpers/acuity-helper.js +56 -56
  153. package/dist/cjs/helpers/api-key-auth-helper.d.ts +9 -9
  154. package/dist/cjs/helpers/api-key-auth-helper.js +40 -40
  155. package/dist/cjs/helpers/api-key-authorizer-helper.d.ts +36 -36
  156. package/dist/cjs/helpers/api-key-authorizer-helper.js +87 -87
  157. package/dist/cjs/helpers/identity-cache-helper.d.ts +30 -21
  158. package/dist/cjs/helpers/identity-cache-helper.js +253 -157
  159. package/dist/cjs/helpers/identity-cache-helper.js.map +1 -1
  160. package/dist/cjs/helpers/index.d.ts +10 -10
  161. package/dist/cjs/helpers/index.js +26 -26
  162. package/dist/cjs/helpers/input-validation-helper.d.ts +3 -3
  163. package/dist/cjs/helpers/input-validation-helper.js +22 -22
  164. package/dist/cjs/helpers/logging-helper.d.ts +16 -16
  165. package/dist/cjs/helpers/logging-helper.js +84 -84
  166. package/dist/cjs/helpers/response-helper.d.ts +18 -18
  167. package/dist/cjs/helpers/response-helper.js +43 -43
  168. package/dist/cjs/helpers/shopify-helper.d.ts +9 -9
  169. package/dist/cjs/helpers/shopify-helper.js +26 -26
  170. package/dist/cjs/helpers/sqs-utils.d.ts +6 -6
  171. package/dist/cjs/helpers/sqs-utils.js +14 -14
  172. package/dist/cjs/index.d.ts +7 -7
  173. package/dist/cjs/index.js +23 -23
  174. package/dist/cjs/libs/api-router/index.d.ts +2 -2
  175. package/dist/cjs/libs/api-router/index.js +18 -18
  176. package/dist/cjs/libs/api-router/public-api-router.d.ts +3 -3
  177. package/dist/cjs/libs/api-router/public-api-router.js +36 -36
  178. package/dist/cjs/libs/api-router/route-matcher.d.ts +21 -21
  179. package/dist/cjs/libs/api-router/route-matcher.js +36 -36
  180. package/dist/cjs/libs/click-id-parser.d.ts +23 -23
  181. package/dist/cjs/libs/click-id-parser.js +49 -49
  182. package/dist/cjs/libs/compression.d.ts +2 -2
  183. package/dist/cjs/libs/compression.js +33 -33
  184. package/dist/cjs/libs/contacts.d.ts +7 -7
  185. package/dist/cjs/libs/contacts.js +152 -152
  186. package/dist/cjs/libs/cookie.d.ts +17 -17
  187. package/dist/cjs/libs/cookie.js +76 -76
  188. package/dist/cjs/libs/crypto.d.ts +4 -4
  189. package/dist/cjs/libs/crypto.js +25 -25
  190. package/dist/cjs/libs/csv.d.ts +2 -2
  191. package/dist/cjs/libs/csv.js +35 -35
  192. package/dist/cjs/libs/currency.d.ts +1 -1
  193. package/dist/cjs/libs/currency.js +29 -29
  194. package/dist/cjs/libs/dates.d.ts +12 -12
  195. package/dist/cjs/libs/dates.js +96 -96
  196. package/dist/cjs/libs/domain.d.ts +2 -2
  197. package/dist/cjs/libs/domain.js +38 -38
  198. package/dist/cjs/libs/emails.d.ts +8 -8
  199. package/dist/cjs/libs/emails.js +154 -154
  200. package/dist/cjs/libs/http-error.d.ts +21 -21
  201. package/dist/cjs/libs/http-error.js +63 -63
  202. package/dist/cjs/libs/http-status-codes.d.ts +58 -58
  203. package/dist/cjs/libs/http-status-codes.js +62 -62
  204. package/dist/cjs/libs/index.d.ts +19 -19
  205. package/dist/cjs/libs/index.js +35 -35
  206. package/dist/cjs/libs/numbers.d.ts +1 -1
  207. package/dist/cjs/libs/numbers.js +15 -15
  208. package/dist/cjs/libs/referrer-parser/index.d.ts +2 -2
  209. package/dist/cjs/libs/referrer-parser/index.js +18 -18
  210. package/dist/cjs/libs/referrer-parser/referrer-data.d.ts +9 -9
  211. package/dist/cjs/libs/referrer-parser/referrer-data.js +3307 -3307
  212. package/dist/cjs/libs/referrer-parser/referrer-parser-util.d.ts +20 -20
  213. package/dist/cjs/libs/referrer-parser/referrer-parser-util.js +131 -131
  214. package/dist/cjs/libs/strings.d.ts +3 -3
  215. package/dist/cjs/libs/strings.js +46 -46
  216. package/dist/cjs/libs/traits.d.ts +6 -6
  217. package/dist/cjs/libs/traits.js +65 -65
  218. package/dist/cjs/libs/url.d.ts +1 -1
  219. package/dist/cjs/libs/url.js +13 -13
  220. package/dist/cjs/services/acuity-api-service.d.ts +9 -9
  221. package/dist/cjs/services/acuity-api-service.js +73 -73
  222. package/dist/cjs/services/cache/generic-cached-object.d.ts +5 -5
  223. package/dist/cjs/services/cache/generic-cached-object.js +2 -2
  224. package/dist/cjs/services/cache/index.d.ts +1 -1
  225. package/dist/cjs/services/cache/index.js +17 -17
  226. package/dist/cjs/services/cache/product-cache-service.d.ts +21 -21
  227. package/dist/cjs/services/cache/product-cache-service.js +76 -76
  228. package/dist/cjs/services/currency-exchange-rate-lookup-service.d.ts +11 -12
  229. package/dist/cjs/services/currency-exchange-rate-lookup-service.js +66 -94
  230. package/dist/cjs/services/currency-exchange-rate-lookup-service.js.map +1 -1
  231. package/dist/cjs/services/db/accounts-db-service.d.ts +9 -9
  232. package/dist/cjs/services/db/accounts-db-service.js +33 -33
  233. package/dist/cjs/services/db/api-keys-db-service.d.ts +10 -10
  234. package/dist/cjs/services/db/api-keys-db-service.js +36 -36
  235. package/dist/cjs/services/db/contact-enrichments-db-service.d.ts +15 -15
  236. package/dist/cjs/services/db/contact-enrichments-db-service.js +94 -94
  237. package/dist/cjs/services/db/currency-exchange-rates-db-service.d.ts +21 -21
  238. package/dist/cjs/services/db/currency-exchange-rates-db-service.js +39 -39
  239. package/dist/cjs/services/db/custom-measures-db-service.d.ts +14 -14
  240. package/dist/cjs/services/db/custom-measures-db-service.js +48 -48
  241. package/dist/cjs/services/db/destinations-db-service.d.ts +13 -13
  242. package/dist/cjs/services/db/destinations-db-service.js +74 -74
  243. package/dist/cjs/services/db/identity-cache-db-service.d.ts +28 -28
  244. package/dist/cjs/services/db/identity-cache-db-service.js +320 -320
  245. package/dist/cjs/services/db/identity-cache-dynamodb-service.d.ts +44 -38
  246. package/dist/cjs/services/db/identity-cache-dynamodb-service.js +649 -439
  247. package/dist/cjs/services/db/identity-cache-dynamodb-service.js.map +1 -1
  248. package/dist/cjs/services/db/index.d.ts +17 -19
  249. package/dist/cjs/services/db/index.js +33 -35
  250. package/dist/cjs/services/db/index.js.map +1 -1
  251. package/dist/cjs/services/db/log-events-db-service.d.ts +11 -11
  252. package/dist/cjs/services/db/log-events-db-service.js +181 -181
  253. package/dist/cjs/services/db/pixels-db-service.d.ts +8 -8
  254. package/dist/cjs/services/db/pixels-db-service.js +35 -35
  255. package/dist/cjs/services/db/purchasable-contacts-db-service.d.ts +9 -9
  256. package/dist/cjs/services/db/purchasable-contacts-db-service.js +43 -43
  257. package/dist/cjs/services/db/purchased-contacts/index.d.ts +2 -2
  258. package/dist/cjs/services/db/purchased-contacts/index.js +18 -18
  259. package/dist/cjs/services/db/purchased-contacts/purchased-contacts-db-service.d.ts +18 -18
  260. package/dist/cjs/services/db/purchased-contacts/purchased-contacts-db-service.js +152 -152
  261. package/dist/cjs/services/db/purchased-contacts/types.d.ts +11 -11
  262. package/dist/cjs/services/db/purchased-contacts/types.js +2 -2
  263. package/dist/cjs/services/db/shopify-app-installs-db-service.d.ts +10 -10
  264. package/dist/cjs/services/db/shopify-app-installs-db-service.js +52 -52
  265. package/dist/cjs/services/db/shopify-products-cache-db-service.d.ts +16 -16
  266. package/dist/cjs/services/db/shopify-products-cache-db-service.js +73 -73
  267. package/dist/cjs/services/db/subscriptions-db-service.d.ts +11 -11
  268. package/dist/cjs/services/db/subscriptions-db-service.js +38 -38
  269. package/dist/cjs/services/db/tracking-events-db-service.d.ts +21 -21
  270. package/dist/cjs/services/db/tracking-events-db-service.js +188 -188
  271. package/dist/cjs/services/db/user-accounts-db-service.d.ts +7 -7
  272. package/dist/cjs/services/db/user-accounts-db-service.js +17 -17
  273. package/dist/cjs/services/email-verification/contact-email-verification-service.d.ts +7 -7
  274. package/dist/cjs/services/email-verification/contact-email-verification-service.js +101 -101
  275. package/dist/cjs/services/email-verification/email-verification-service.d.ts +19 -19
  276. package/dist/cjs/services/email-verification/email-verification-service.js +131 -131
  277. package/dist/cjs/services/email-verification/index.d.ts +2 -2
  278. package/dist/cjs/services/email-verification/index.js +18 -18
  279. package/dist/cjs/services/eventbridge-integration-service.d.ts +9 -9
  280. package/dist/cjs/services/eventbridge-integration-service.js +28 -28
  281. package/dist/cjs/services/events/index.d.ts +3 -3
  282. package/dist/cjs/services/events/index.js +19 -19
  283. package/dist/cjs/services/events/log-event-service.d.ts +19 -19
  284. package/dist/cjs/services/events/log-event-service.js +77 -77
  285. package/dist/cjs/services/events/metric-event-service.d.ts +9 -9
  286. package/dist/cjs/services/events/metric-event-service.js +49 -49
  287. package/dist/cjs/services/events/tracking-event-sqs-service.d.ts +8 -8
  288. package/dist/cjs/services/events/tracking-event-sqs-service.js +34 -34
  289. package/dist/cjs/services/generic-cache-service.d.ts +7 -7
  290. package/dist/cjs/services/generic-cache-service.js +33 -33
  291. package/dist/cjs/services/index.d.ts +10 -11
  292. package/dist/cjs/services/index.js +26 -27
  293. package/dist/cjs/services/index.js.map +1 -1
  294. package/dist/cjs/services/ipdata-lookup-service.d.ts +20 -20
  295. package/dist/cjs/services/ipdata-lookup-service.js +112 -112
  296. package/dist/cjs/services/shopify/index.d.ts +2 -2
  297. package/dist/cjs/services/shopify/index.js +18 -18
  298. package/dist/cjs/services/shopify/products/index.d.ts +1 -1
  299. package/dist/cjs/services/shopify/products/index.js +17 -17
  300. package/dist/cjs/services/shopify/products/shopify-products-serviceV2.d.ts +17 -17
  301. package/dist/cjs/services/shopify/products/shopify-products-serviceV2.js +112 -112
  302. package/dist/cjs/services/shopify/shopify-graphql-transformer.d.ts +8 -8
  303. package/dist/cjs/services/shopify/shopify-graphql-transformer.js +141 -141
  304. package/dist/cjs/types/acuity-types.d.ts +74 -74
  305. package/dist/cjs/types/acuity-types.js +2 -2
  306. package/dist/cjs/types/api-response.d.ts +6 -6
  307. package/dist/cjs/types/api-response.js +2 -2
  308. package/dist/cjs/types/index.d.ts +4 -4
  309. package/dist/cjs/types/index.js +33 -33
  310. package/dist/cjs/types/internal-events/event-detail-types.d.ts +20 -20
  311. package/dist/cjs/types/internal-events/event-detail-types.js +27 -27
  312. package/dist/cjs/types/internal-events/index.d.ts +1 -1
  313. package/dist/cjs/types/internal-events/index.js +17 -17
  314. package/dist/cjs/types/shopify-graphql-types/admin.generated.d.ts +123 -123
  315. package/dist/cjs/types/shopify-graphql-types/admin.generated.js +2 -2
  316. package/dist/cjs/types/shopify-graphql-types/admin.types.d.ts +26289 -26289
  317. package/dist/cjs/types/shopify-graphql-types/admin.types.js +5311 -5311
  318. package/dist/cjs/types/shopify-graphql-types/index.d.ts +2 -2
  319. package/dist/cjs/types/shopify-graphql-types/index.js +18 -18
  320. package/dist/cjs/types/shopify-rest-types.d.ts +767 -767
  321. package/dist/cjs/types/shopify-rest-types.js +2 -2
  322. package/dist/cjs/utils/compression.d.ts +36 -36
  323. package/dist/cjs/utils/compression.js +198 -198
  324. package/dist/cjs/utils/custom-measure-formula-utils.d.ts +6 -6
  325. package/dist/cjs/utils/custom-measure-formula-utils.js +209 -209
  326. package/dist/cjs/utils/index.d.ts +4 -4
  327. package/dist/cjs/utils/index.js +20 -20
  328. package/dist/cjs/utils/retry-envelope.d.ts +12 -12
  329. package/dist/cjs/utils/retry-envelope.js +28 -28
  330. package/dist/cjs/utils/size.d.ts +2 -2
  331. package/dist/cjs/utils/size.js +49 -49
  332. package/dist/esm/__tests__/clients/acuity-client.spec.d.ts +1 -1
  333. package/dist/esm/__tests__/clients/acuity-client.spec.js +41 -41
  334. package/dist/esm/__tests__/clients/cross-platform-compression.spec.d.ts +1 -1
  335. package/dist/esm/__tests__/clients/cross-platform-compression.spec.js +329 -329
  336. package/dist/esm/__tests__/clients/dynamodb-client.spec.d.ts +1 -1
  337. package/dist/esm/__tests__/clients/dynamodb-client.spec.js +192 -192
  338. package/dist/esm/__tests__/clients/sqs-bundled-client.spec.d.ts +1 -1
  339. package/dist/esm/__tests__/clients/sqs-bundled-client.spec.js +906 -906
  340. package/dist/esm/__tests__/clients/sqs-bundling-contracts.spec.d.ts +1 -1
  341. package/dist/esm/__tests__/clients/sqs-bundling-contracts.spec.js +538 -538
  342. package/dist/esm/__tests__/clients/sqs-client.spec.d.ts +1 -1
  343. package/dist/esm/__tests__/clients/sqs-client.spec.js +189 -189
  344. package/dist/esm/__tests__/clients/sqs-unbundle.spec.d.ts +1 -1
  345. package/dist/esm/__tests__/clients/sqs-unbundle.spec.js +1355 -1355
  346. package/dist/esm/__tests__/db/contact-enrichments-db-service.spec.d.ts +1 -1
  347. package/dist/esm/__tests__/db/contact-enrichments-db-service.spec.js +66 -66
  348. package/dist/esm/__tests__/db/destinations-db-service.spec.d.ts +1 -1
  349. package/dist/esm/__tests__/db/destinations-db-service.spec.js +123 -123
  350. package/dist/esm/__tests__/db/shared-read-db-services.spec.d.ts +1 -1
  351. package/dist/esm/__tests__/db/shared-read-db-services.spec.js +87 -87
  352. package/dist/esm/__tests__/db/shopify-app-installs-db-service.spec.d.ts +1 -1
  353. package/dist/esm/__tests__/db/shopify-app-installs-db-service.spec.js +102 -102
  354. package/dist/esm/__tests__/db/subscriptions-db-service.spec.d.ts +1 -1
  355. package/dist/esm/__tests__/db/subscriptions-db-service.spec.js +93 -93
  356. package/dist/esm/__tests__/db/user-accounts-db-service.spec.d.ts +1 -1
  357. package/dist/esm/__tests__/db/user-accounts-db-service.spec.js +74 -74
  358. package/dist/esm/__tests__/helpers/account-users-helper.spec.d.ts +1 -1
  359. package/dist/esm/__tests__/helpers/account-users-helper.spec.js +218 -218
  360. package/dist/esm/__tests__/helpers/acuity-helper.spec.d.ts +1 -1
  361. package/dist/esm/__tests__/helpers/acuity-helper.spec.js +67 -67
  362. package/dist/esm/__tests__/helpers/api-key-auth-helper.spec.d.ts +1 -1
  363. package/dist/esm/__tests__/helpers/api-key-auth-helper.spec.js +80 -80
  364. package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.d.ts +1 -1
  365. package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.js +674 -672
  366. package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.js.map +1 -1
  367. package/dist/esm/__tests__/identity-cache/identity-cache-dynamodb-service.spec.d.ts +1 -1
  368. package/dist/esm/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js +1138 -1138
  369. package/dist/{cjs/__tests__/services/cost/cost-currency-service.spec.d.ts → esm/__tests__/identity-cache/identity-cache-tier-routing.spec.d.ts} +1 -1
  370. package/dist/esm/__tests__/identity-cache/identity-cache-tier-routing.spec.js +850 -0
  371. package/dist/esm/__tests__/identity-cache/identity-cache-tier-routing.spec.js.map +1 -0
  372. package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.d.ts +1 -1
  373. package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.js +1058 -586
  374. package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.js.map +1 -1
  375. package/dist/{cjs/__tests__/services/cost/cost-calculation-types.spec.d.ts → esm/__tests__/identity-cache/volatile-traits-optimization.spec.d.ts} +1 -1
  376. package/dist/esm/__tests__/identity-cache/volatile-traits-optimization.spec.js +817 -0
  377. package/dist/esm/__tests__/identity-cache/volatile-traits-optimization.spec.js.map +1 -0
  378. package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.d.ts +1 -1
  379. package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.js +582 -582
  380. package/dist/esm/__tests__/libs/compress-decompress.spec.d.ts +1 -1
  381. package/dist/esm/__tests__/libs/compress-decompress.spec.js +14 -14
  382. package/dist/esm/__tests__/libs/contacts.spec.d.ts +1 -1
  383. package/dist/esm/__tests__/libs/contacts.spec.js +292 -292
  384. package/dist/esm/__tests__/libs/currency.spec.d.ts +1 -1
  385. package/dist/esm/__tests__/libs/currency.spec.js +218 -218
  386. package/dist/esm/__tests__/libs/dates.spec.d.ts +1 -1
  387. package/dist/esm/__tests__/libs/dates.spec.js +128 -128
  388. package/dist/esm/__tests__/libs/domain.spec.d.ts +1 -1
  389. package/dist/esm/__tests__/libs/domain.spec.js +105 -105
  390. package/dist/esm/__tests__/libs/numbers.spec.d.ts +1 -1
  391. package/dist/esm/__tests__/libs/numbers.spec.js +259 -259
  392. package/dist/esm/__tests__/s3-client/s3-client.spec.d.ts +1 -1
  393. package/dist/esm/__tests__/s3-client/s3-client.spec.js +31 -31
  394. package/dist/esm/__tests__/services/acuity-api-service.spec.d.ts +1 -1
  395. package/dist/esm/__tests__/services/acuity-api-service.spec.js +69 -69
  396. package/dist/esm/__tests__/services/email-verification/contact-email-verification-service.spec.d.ts +1 -1
  397. package/dist/esm/__tests__/services/email-verification/contact-email-verification-service.spec.js +91 -91
  398. package/dist/esm/__tests__/services/email-verification/email-verification-service.spec.d.ts +1 -1
  399. package/dist/esm/__tests__/services/email-verification/email-verification-service.spec.js +55 -55
  400. package/dist/esm/__tests__/shopify/shopify-graphql-transformer.spec.d.ts +1 -1
  401. package/dist/esm/__tests__/shopify/shopify-graphql-transformer.spec.js +33 -33
  402. package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.d.ts +1 -1
  403. package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.js +156 -156
  404. package/dist/esm/__tests__/unit/libs/api-router/route-matcher.spec.d.ts +1 -1
  405. package/dist/esm/__tests__/unit/libs/api-router/route-matcher.spec.js +67 -67
  406. package/dist/esm/__tests__/utils/custom-measure-formula-utils.spec.d.ts +1 -1
  407. package/dist/esm/__tests__/utils/custom-measure-formula-utils.spec.js +137 -137
  408. package/dist/esm/clients/generic/cognito-client.d.ts +23 -23
  409. package/dist/esm/clients/generic/cognito-client.js +204 -204
  410. package/dist/esm/clients/generic/dynamodb-client.d.ts +20 -20
  411. package/dist/esm/clients/generic/dynamodb-client.js +231 -231
  412. package/dist/esm/clients/generic/eventbridge-client.d.ts +14 -14
  413. package/dist/esm/clients/generic/eventbridge-client.js +47 -47
  414. package/dist/esm/clients/generic/http-client.d.ts +14 -14
  415. package/dist/esm/clients/generic/http-client.js +53 -53
  416. package/dist/esm/clients/generic/index.d.ts +13 -13
  417. package/dist/esm/clients/generic/index.js +13 -13
  418. package/dist/esm/clients/generic/lambda-invoke-client.d.ts +10 -10
  419. package/dist/esm/clients/generic/lambda-invoke-client.js +35 -35
  420. package/dist/esm/clients/generic/location-client.d.ts +8 -8
  421. package/dist/esm/clients/generic/location-client.js +27 -27
  422. package/dist/esm/clients/generic/redis-client.d.ts +33 -33
  423. package/dist/esm/clients/generic/redis-client.js +184 -184
  424. package/dist/esm/clients/generic/s3-client.d.ts +23 -23
  425. package/dist/esm/clients/generic/s3-client.js +209 -209
  426. package/dist/esm/clients/generic/singlestore-db-client.d.ts +14 -14
  427. package/dist/esm/clients/generic/singlestore-db-client.js +40 -40
  428. package/dist/esm/clients/generic/sqs-bundled-client.d.ts +15 -15
  429. package/dist/esm/clients/generic/sqs-bundled-client.js +307 -307
  430. package/dist/esm/clients/generic/sqs-bundled-client.types.d.ts +53 -53
  431. package/dist/esm/clients/generic/sqs-bundled-client.types.js +14 -14
  432. package/dist/esm/clients/generic/sqs-client.d.ts +53 -53
  433. package/dist/esm/clients/generic/sqs-client.js +281 -281
  434. package/dist/esm/clients/generic/sqs-unbundle.d.ts +32 -32
  435. package/dist/esm/clients/generic/sqs-unbundle.js +137 -137
  436. package/dist/esm/clients/index.d.ts +3 -3
  437. package/dist/esm/clients/index.js +3 -3
  438. package/dist/esm/clients/internal-api/accounts-client.d.ts +91 -91
  439. package/dist/esm/clients/internal-api/accounts-client.js +125 -125
  440. package/dist/esm/clients/internal-api/cache-lambda-client.d.ts +26 -26
  441. package/dist/esm/clients/internal-api/cache-lambda-client.js +85 -85
  442. package/dist/esm/clients/internal-api/db-management-client.d.ts +18 -18
  443. package/dist/esm/clients/internal-api/db-management-client.js +32 -32
  444. package/dist/esm/clients/internal-api/destinations-client.d.ts +34 -34
  445. package/dist/esm/clients/internal-api/destinations-client.js +75 -75
  446. package/dist/esm/clients/internal-api/event-collector-client.d.ts +20 -20
  447. package/dist/esm/clients/internal-api/event-collector-client.js +32 -32
  448. package/dist/esm/clients/internal-api/identity-client.d.ts +31 -31
  449. package/dist/esm/clients/internal-api/identity-client.js +87 -87
  450. package/dist/esm/clients/internal-api/index.d.ts +9 -9
  451. package/dist/esm/clients/internal-api/index.js +9 -9
  452. package/dist/esm/clients/internal-api/shopify-app-install-client.d.ts +37 -37
  453. package/dist/esm/clients/internal-api/shopify-app-install-client.js +77 -77
  454. package/dist/esm/clients/internal-api/subscriptions-client.d.ts +26 -26
  455. package/dist/esm/clients/internal-api/subscriptions-client.js +73 -73
  456. package/dist/esm/clients/internal-api/users-auth-client.d.ts +35 -35
  457. package/dist/esm/clients/internal-api/users-auth-client.js +106 -106
  458. package/dist/esm/clients/third-party/acuity-client.d.ts +10 -10
  459. package/dist/esm/clients/third-party/acuity-client.js +36 -36
  460. package/dist/esm/clients/third-party/emailable-client.d.ts +7 -7
  461. package/dist/esm/clients/third-party/emailable-client.js +21 -21
  462. package/dist/esm/clients/third-party/exchange-rate-api-client.d.ts +17 -17
  463. package/dist/esm/clients/third-party/exchange-rate-api-client.js +15 -15
  464. package/dist/esm/clients/third-party/index.d.ts +5 -5
  465. package/dist/esm/clients/third-party/index.js +5 -5
  466. package/dist/esm/clients/third-party/loops-client.d.ts +10 -10
  467. package/dist/esm/clients/third-party/loops-client.js +26 -26
  468. package/dist/esm/clients/third-party/shopify/graphql-order-queries.d.ts +25 -25
  469. package/dist/esm/clients/third-party/shopify/graphql-order-queries.js +1 -1
  470. package/dist/esm/clients/third-party/shopify/graphql-product-queries.d.ts +2 -2
  471. package/dist/esm/clients/third-party/shopify/graphql-product-queries.js +2 -2
  472. package/dist/esm/clients/third-party/shopify/shopify-graphql-client.d.ts +10 -10
  473. package/dist/esm/clients/third-party/shopify/shopify-graphql-client.js +157 -157
  474. package/dist/esm/clients/third-party/shopify-client.d.ts +29 -29
  475. package/dist/esm/clients/third-party/shopify-client.js +142 -142
  476. package/dist/esm/constants/index.d.ts +1 -1
  477. package/dist/esm/constants/index.js +1 -1
  478. package/dist/esm/constants/sqs.d.ts +20 -20
  479. package/dist/esm/constants/sqs.js +22 -22
  480. package/dist/esm/helpers/account-users-helper.d.ts +2 -2
  481. package/dist/esm/helpers/account-users-helper.js +18 -18
  482. package/dist/esm/helpers/acuity-helper.d.ts +4 -4
  483. package/dist/esm/helpers/acuity-helper.js +51 -51
  484. package/dist/esm/helpers/api-key-auth-helper.d.ts +9 -9
  485. package/dist/esm/helpers/api-key-auth-helper.js +35 -35
  486. package/dist/esm/helpers/api-key-authorizer-helper.d.ts +36 -36
  487. package/dist/esm/helpers/api-key-authorizer-helper.js +83 -83
  488. package/dist/esm/helpers/identity-cache-helper.d.ts +30 -21
  489. package/dist/esm/helpers/identity-cache-helper.js +248 -152
  490. package/dist/esm/helpers/identity-cache-helper.js.map +1 -1
  491. package/dist/esm/helpers/index.d.ts +10 -10
  492. package/dist/esm/helpers/index.js +10 -10
  493. package/dist/esm/helpers/input-validation-helper.d.ts +3 -3
  494. package/dist/esm/helpers/input-validation-helper.js +18 -18
  495. package/dist/esm/helpers/logging-helper.d.ts +16 -16
  496. package/dist/esm/helpers/logging-helper.js +56 -56
  497. package/dist/esm/helpers/response-helper.d.ts +18 -18
  498. package/dist/esm/helpers/response-helper.js +37 -37
  499. package/dist/esm/helpers/shopify-helper.d.ts +9 -9
  500. package/dist/esm/helpers/shopify-helper.js +21 -21
  501. package/dist/esm/helpers/sqs-utils.d.ts +6 -6
  502. package/dist/esm/helpers/sqs-utils.js +9 -9
  503. package/dist/esm/index.d.ts +7 -7
  504. package/dist/esm/index.js +7 -7
  505. package/dist/esm/libs/api-router/index.d.ts +2 -2
  506. package/dist/esm/libs/api-router/index.js +2 -2
  507. package/dist/esm/libs/api-router/public-api-router.d.ts +3 -3
  508. package/dist/esm/libs/api-router/public-api-router.js +32 -32
  509. package/dist/esm/libs/api-router/route-matcher.d.ts +21 -21
  510. package/dist/esm/libs/api-router/route-matcher.js +30 -30
  511. package/dist/esm/libs/click-id-parser.d.ts +23 -23
  512. package/dist/esm/libs/click-id-parser.js +45 -45
  513. package/dist/esm/libs/compression.d.ts +2 -2
  514. package/dist/esm/libs/compression.js +25 -25
  515. package/dist/esm/libs/contacts.d.ts +7 -7
  516. package/dist/esm/libs/contacts.js +143 -143
  517. package/dist/esm/libs/cookie.d.ts +17 -17
  518. package/dist/esm/libs/cookie.js +70 -70
  519. package/dist/esm/libs/crypto.d.ts +4 -4
  520. package/dist/esm/libs/crypto.js +15 -15
  521. package/dist/esm/libs/csv.d.ts +2 -2
  522. package/dist/esm/libs/csv.js +30 -30
  523. package/dist/esm/libs/currency.d.ts +1 -1
  524. package/dist/esm/libs/currency.js +22 -22
  525. package/dist/esm/libs/dates.d.ts +12 -12
  526. package/dist/esm/libs/dates.js +83 -83
  527. package/dist/esm/libs/domain.d.ts +2 -2
  528. package/dist/esm/libs/domain.js +33 -33
  529. package/dist/esm/libs/emails.d.ts +8 -8
  530. package/dist/esm/libs/emails.js +146 -146
  531. package/dist/esm/libs/http-error.d.ts +21 -21
  532. package/dist/esm/libs/http-error.js +59 -59
  533. package/dist/esm/libs/http-status-codes.d.ts +58 -58
  534. package/dist/esm/libs/http-status-codes.js +59 -59
  535. package/dist/esm/libs/index.d.ts +19 -19
  536. package/dist/esm/libs/index.js +19 -19
  537. package/dist/esm/libs/numbers.d.ts +1 -1
  538. package/dist/esm/libs/numbers.js +11 -11
  539. package/dist/esm/libs/referrer-parser/index.d.ts +2 -2
  540. package/dist/esm/libs/referrer-parser/index.js +2 -2
  541. package/dist/esm/libs/referrer-parser/referrer-data.d.ts +9 -9
  542. package/dist/esm/libs/referrer-parser/referrer-data.js +3304 -3304
  543. package/dist/esm/libs/referrer-parser/referrer-parser-util.d.ts +20 -20
  544. package/dist/esm/libs/referrer-parser/referrer-parser-util.js +124 -124
  545. package/dist/esm/libs/strings.d.ts +3 -3
  546. package/dist/esm/libs/strings.js +40 -40
  547. package/dist/esm/libs/traits.d.ts +6 -6
  548. package/dist/esm/libs/traits.js +54 -54
  549. package/dist/esm/libs/url.d.ts +1 -1
  550. package/dist/esm/libs/url.js +9 -9
  551. package/dist/esm/services/acuity-api-service.d.ts +9 -9
  552. package/dist/esm/services/acuity-api-service.js +69 -69
  553. package/dist/esm/services/cache/generic-cached-object.d.ts +5 -5
  554. package/dist/esm/services/cache/generic-cached-object.js +1 -1
  555. package/dist/esm/services/cache/index.d.ts +1 -1
  556. package/dist/esm/services/cache/index.js +1 -1
  557. package/dist/esm/services/cache/product-cache-service.d.ts +21 -21
  558. package/dist/esm/services/cache/product-cache-service.js +68 -68
  559. package/dist/esm/services/currency-exchange-rate-lookup-service.d.ts +11 -12
  560. package/dist/esm/services/currency-exchange-rate-lookup-service.js +62 -90
  561. package/dist/esm/services/currency-exchange-rate-lookup-service.js.map +1 -1
  562. package/dist/esm/services/db/accounts-db-service.d.ts +9 -9
  563. package/dist/esm/services/db/accounts-db-service.js +29 -29
  564. package/dist/esm/services/db/api-keys-db-service.d.ts +10 -10
  565. package/dist/esm/services/db/api-keys-db-service.js +32 -32
  566. package/dist/esm/services/db/contact-enrichments-db-service.d.ts +15 -15
  567. package/dist/esm/services/db/contact-enrichments-db-service.js +90 -90
  568. package/dist/esm/services/db/currency-exchange-rates-db-service.d.ts +21 -21
  569. package/dist/esm/services/db/currency-exchange-rates-db-service.js +35 -35
  570. package/dist/esm/services/db/custom-measures-db-service.d.ts +14 -14
  571. package/dist/esm/services/db/custom-measures-db-service.js +44 -44
  572. package/dist/esm/services/db/destinations-db-service.d.ts +13 -13
  573. package/dist/esm/services/db/destinations-db-service.js +70 -70
  574. package/dist/esm/services/db/identity-cache-db-service.d.ts +28 -28
  575. package/dist/esm/services/db/identity-cache-db-service.js +313 -313
  576. package/dist/esm/services/db/identity-cache-dynamodb-service.d.ts +44 -38
  577. package/dist/esm/services/db/identity-cache-dynamodb-service.js +642 -432
  578. package/dist/esm/services/db/identity-cache-dynamodb-service.js.map +1 -1
  579. package/dist/esm/services/db/index.d.ts +17 -19
  580. package/dist/esm/services/db/index.js +17 -19
  581. package/dist/esm/services/db/index.js.map +1 -1
  582. package/dist/esm/services/db/log-events-db-service.d.ts +11 -11
  583. package/dist/esm/services/db/log-events-db-service.js +177 -177
  584. package/dist/esm/services/db/pixels-db-service.d.ts +8 -8
  585. package/dist/esm/services/db/pixels-db-service.js +31 -31
  586. package/dist/esm/services/db/purchasable-contacts-db-service.d.ts +9 -9
  587. package/dist/esm/services/db/purchasable-contacts-db-service.js +39 -39
  588. package/dist/esm/services/db/purchased-contacts/index.d.ts +2 -2
  589. package/dist/esm/services/db/purchased-contacts/index.js +2 -2
  590. package/dist/esm/services/db/purchased-contacts/purchased-contacts-db-service.d.ts +18 -18
  591. package/dist/esm/services/db/purchased-contacts/purchased-contacts-db-service.js +148 -148
  592. package/dist/esm/services/db/purchased-contacts/types.d.ts +11 -11
  593. package/dist/esm/services/db/purchased-contacts/types.js +1 -1
  594. package/dist/esm/services/db/shopify-app-installs-db-service.d.ts +10 -10
  595. package/dist/esm/services/db/shopify-app-installs-db-service.js +48 -48
  596. package/dist/esm/services/db/shopify-products-cache-db-service.d.ts +16 -16
  597. package/dist/esm/services/db/shopify-products-cache-db-service.js +66 -66
  598. package/dist/esm/services/db/subscriptions-db-service.d.ts +11 -11
  599. package/dist/esm/services/db/subscriptions-db-service.js +34 -34
  600. package/dist/esm/services/db/tracking-events-db-service.d.ts +21 -21
  601. package/dist/esm/services/db/tracking-events-db-service.js +184 -184
  602. package/dist/esm/services/db/user-accounts-db-service.d.ts +7 -7
  603. package/dist/esm/services/db/user-accounts-db-service.js +13 -13
  604. package/dist/esm/services/email-verification/contact-email-verification-service.d.ts +7 -7
  605. package/dist/esm/services/email-verification/contact-email-verification-service.js +97 -97
  606. package/dist/esm/services/email-verification/email-verification-service.d.ts +19 -19
  607. package/dist/esm/services/email-verification/email-verification-service.js +127 -127
  608. package/dist/esm/services/email-verification/index.d.ts +2 -2
  609. package/dist/esm/services/email-verification/index.js +2 -2
  610. package/dist/esm/services/eventbridge-integration-service.d.ts +9 -9
  611. package/dist/esm/services/eventbridge-integration-service.js +24 -24
  612. package/dist/esm/services/events/index.d.ts +3 -3
  613. package/dist/esm/services/events/index.js +3 -3
  614. package/dist/esm/services/events/log-event-service.d.ts +19 -19
  615. package/dist/esm/services/events/log-event-service.js +73 -73
  616. package/dist/esm/services/events/metric-event-service.d.ts +9 -9
  617. package/dist/esm/services/events/metric-event-service.js +45 -45
  618. package/dist/esm/services/events/tracking-event-sqs-service.d.ts +8 -8
  619. package/dist/esm/services/events/tracking-event-sqs-service.js +30 -30
  620. package/dist/esm/services/generic-cache-service.d.ts +7 -7
  621. package/dist/esm/services/generic-cache-service.js +29 -29
  622. package/dist/esm/services/index.d.ts +10 -11
  623. package/dist/esm/services/index.js +10 -11
  624. package/dist/esm/services/index.js.map +1 -1
  625. package/dist/esm/services/ipdata-lookup-service.d.ts +20 -20
  626. package/dist/esm/services/ipdata-lookup-service.js +108 -108
  627. package/dist/esm/services/shopify/index.d.ts +2 -2
  628. package/dist/esm/services/shopify/index.js +2 -2
  629. package/dist/esm/services/shopify/products/index.d.ts +1 -1
  630. package/dist/esm/services/shopify/products/index.js +1 -1
  631. package/dist/esm/services/shopify/products/shopify-products-serviceV2.d.ts +17 -17
  632. package/dist/esm/services/shopify/products/shopify-products-serviceV2.js +108 -108
  633. package/dist/esm/services/shopify/shopify-graphql-transformer.d.ts +8 -8
  634. package/dist/esm/services/shopify/shopify-graphql-transformer.js +138 -138
  635. package/dist/esm/types/acuity-types.d.ts +74 -74
  636. package/dist/esm/types/acuity-types.js +1 -1
  637. package/dist/esm/types/api-response.d.ts +6 -6
  638. package/dist/esm/types/api-response.js +1 -1
  639. package/dist/esm/types/index.d.ts +4 -4
  640. package/dist/esm/types/index.js +4 -4
  641. package/dist/esm/types/internal-events/event-detail-types.d.ts +20 -20
  642. package/dist/esm/types/internal-events/event-detail-types.js +24 -24
  643. package/dist/esm/types/internal-events/index.d.ts +1 -1
  644. package/dist/esm/types/internal-events/index.js +1 -1
  645. package/dist/esm/types/shopify-graphql-types/admin.generated.d.ts +123 -123
  646. package/dist/esm/types/shopify-graphql-types/admin.generated.js +1 -1
  647. package/dist/esm/types/shopify-graphql-types/admin.types.d.ts +26289 -26289
  648. package/dist/esm/types/shopify-graphql-types/admin.types.js +5299 -5299
  649. package/dist/esm/types/shopify-graphql-types/index.d.ts +2 -2
  650. package/dist/esm/types/shopify-graphql-types/index.js +2 -2
  651. package/dist/esm/types/shopify-rest-types.d.ts +767 -767
  652. package/dist/esm/types/shopify-rest-types.js +1 -1
  653. package/dist/esm/utils/compression.d.ts +36 -36
  654. package/dist/esm/utils/compression.js +187 -187
  655. package/dist/esm/utils/custom-measure-formula-utils.d.ts +6 -6
  656. package/dist/esm/utils/custom-measure-formula-utils.js +201 -201
  657. package/dist/esm/utils/index.d.ts +4 -4
  658. package/dist/esm/utils/index.js +4 -4
  659. package/dist/esm/utils/retry-envelope.d.ts +12 -12
  660. package/dist/esm/utils/retry-envelope.js +22 -22
  661. package/dist/esm/utils/size.d.ts +2 -2
  662. package/dist/esm/utils/size.js +44 -44
  663. package/package.json +134 -134
  664. package/dist/cjs/__tests__/db/products-db-service.spec.js +0 -90
  665. package/dist/cjs/__tests__/db/products-db-service.spec.js.map +0 -1
  666. package/dist/cjs/__tests__/services/cost/cost-calculation-types.spec.js +0 -24
  667. package/dist/cjs/__tests__/services/cost/cost-calculation-types.spec.js.map +0 -1
  668. package/dist/cjs/__tests__/services/cost/cost-calculator-service.spec.js +0 -3320
  669. package/dist/cjs/__tests__/services/cost/cost-calculator-service.spec.js.map +0 -1
  670. package/dist/cjs/__tests__/services/cost/cost-currency-service.spec.js +0 -115
  671. package/dist/cjs/__tests__/services/cost/cost-currency-service.spec.js.map +0 -1
  672. package/dist/cjs/__tests__/services/cost/cost-filter-service.spec.d.ts +0 -1
  673. package/dist/cjs/__tests__/services/cost/cost-filter-service.spec.js +0 -469
  674. package/dist/cjs/__tests__/services/cost/cost-filter-service.spec.js.map +0 -1
  675. package/dist/cjs/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.d.ts +0 -1
  676. package/dist/cjs/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.js +0 -207
  677. package/dist/cjs/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.js.map +0 -1
  678. package/dist/cjs/__tests__/services/currency-exchange-rate-lookup-service.spec.d.ts +0 -1
  679. package/dist/cjs/__tests__/services/currency-exchange-rate-lookup-service.spec.js +0 -35
  680. package/dist/cjs/__tests__/services/currency-exchange-rate-lookup-service.spec.js.map +0 -1
  681. package/dist/cjs/services/cost/cost-calculation-types.d.ts +0 -69
  682. package/dist/cjs/services/cost/cost-calculation-types.js +0 -20
  683. package/dist/cjs/services/cost/cost-calculation-types.js.map +0 -1
  684. package/dist/cjs/services/cost/cost-calculator-service.d.ts +0 -24
  685. package/dist/cjs/services/cost/cost-calculator-service.js +0 -457
  686. package/dist/cjs/services/cost/cost-calculator-service.js.map +0 -1
  687. package/dist/cjs/services/cost/cost-currency-service.d.ts +0 -6
  688. package/dist/cjs/services/cost/cost-currency-service.js +0 -88
  689. package/dist/cjs/services/cost/cost-currency-service.js.map +0 -1
  690. package/dist/cjs/services/cost/cost-filter-service.d.ts +0 -10
  691. package/dist/cjs/services/cost/cost-filter-service.js +0 -122
  692. package/dist/cjs/services/cost/cost-filter-service.js.map +0 -1
  693. package/dist/cjs/services/cost/index.d.ts +0 -5
  694. package/dist/cjs/services/cost/index.js +0 -22
  695. package/dist/cjs/services/cost/index.js.map +0 -1
  696. package/dist/cjs/services/cost/order-cost/index.d.ts +0 -2
  697. package/dist/cjs/services/cost/order-cost/index.js +0 -19
  698. package/dist/cjs/services/cost/order-cost/index.js.map +0 -1
  699. package/dist/cjs/services/cost/order-cost/order-cost-resolution-service.d.ts +0 -23
  700. package/dist/cjs/services/cost/order-cost/order-cost-resolution-service.js +0 -362
  701. package/dist/cjs/services/cost/order-cost/order-cost-resolution-service.js.map +0 -1
  702. package/dist/cjs/services/cost/order-cost/order-cost-resolution-types.d.ts +0 -37
  703. package/dist/cjs/services/cost/order-cost/order-cost-resolution-types.js +0 -3
  704. package/dist/cjs/services/cost/order-cost/order-cost-resolution-types.js.map +0 -1
  705. package/dist/cjs/services/db/products-db-service-types.d.ts +0 -10
  706. package/dist/cjs/services/db/products-db-service-types.js +0 -3
  707. package/dist/cjs/services/db/products-db-service-types.js.map +0 -1
  708. package/dist/cjs/services/db/products-db-service.d.ts +0 -19
  709. package/dist/cjs/services/db/products-db-service.js +0 -282
  710. package/dist/cjs/services/db/products-db-service.js.map +0 -1
  711. package/dist/esm/__tests__/db/products-db-service.spec.d.ts +0 -1
  712. package/dist/esm/__tests__/db/products-db-service.spec.js +0 -88
  713. package/dist/esm/__tests__/db/products-db-service.spec.js.map +0 -1
  714. package/dist/esm/__tests__/services/cost/cost-calculation-types.spec.d.ts +0 -1
  715. package/dist/esm/__tests__/services/cost/cost-calculation-types.spec.js +0 -22
  716. package/dist/esm/__tests__/services/cost/cost-calculation-types.spec.js.map +0 -1
  717. package/dist/esm/__tests__/services/cost/cost-calculator-service.spec.d.ts +0 -1
  718. package/dist/esm/__tests__/services/cost/cost-calculator-service.spec.js +0 -3318
  719. package/dist/esm/__tests__/services/cost/cost-calculator-service.spec.js.map +0 -1
  720. package/dist/esm/__tests__/services/cost/cost-currency-service.spec.d.ts +0 -1
  721. package/dist/esm/__tests__/services/cost/cost-currency-service.spec.js +0 -113
  722. package/dist/esm/__tests__/services/cost/cost-currency-service.spec.js.map +0 -1
  723. package/dist/esm/__tests__/services/cost/cost-filter-service.spec.d.ts +0 -1
  724. package/dist/esm/__tests__/services/cost/cost-filter-service.spec.js +0 -467
  725. package/dist/esm/__tests__/services/cost/cost-filter-service.spec.js.map +0 -1
  726. package/dist/esm/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.d.ts +0 -1
  727. package/dist/esm/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.js +0 -205
  728. package/dist/esm/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.js.map +0 -1
  729. package/dist/esm/__tests__/services/currency-exchange-rate-lookup-service.spec.d.ts +0 -1
  730. package/dist/esm/__tests__/services/currency-exchange-rate-lookup-service.spec.js +0 -33
  731. package/dist/esm/__tests__/services/currency-exchange-rate-lookup-service.spec.js.map +0 -1
  732. package/dist/esm/services/cost/cost-calculation-types.d.ts +0 -69
  733. package/dist/esm/services/cost/cost-calculation-types.js +0 -16
  734. package/dist/esm/services/cost/cost-calculation-types.js.map +0 -1
  735. package/dist/esm/services/cost/cost-calculator-service.d.ts +0 -24
  736. package/dist/esm/services/cost/cost-calculator-service.js +0 -451
  737. package/dist/esm/services/cost/cost-calculator-service.js.map +0 -1
  738. package/dist/esm/services/cost/cost-currency-service.d.ts +0 -6
  739. package/dist/esm/services/cost/cost-currency-service.js +0 -85
  740. package/dist/esm/services/cost/cost-currency-service.js.map +0 -1
  741. package/dist/esm/services/cost/cost-filter-service.d.ts +0 -10
  742. package/dist/esm/services/cost/cost-filter-service.js +0 -119
  743. package/dist/esm/services/cost/cost-filter-service.js.map +0 -1
  744. package/dist/esm/services/cost/index.d.ts +0 -5
  745. package/dist/esm/services/cost/index.js +0 -6
  746. package/dist/esm/services/cost/index.js.map +0 -1
  747. package/dist/esm/services/cost/order-cost/index.d.ts +0 -2
  748. package/dist/esm/services/cost/order-cost/index.js +0 -3
  749. package/dist/esm/services/cost/order-cost/index.js.map +0 -1
  750. package/dist/esm/services/cost/order-cost/order-cost-resolution-service.d.ts +0 -23
  751. package/dist/esm/services/cost/order-cost/order-cost-resolution-service.js +0 -356
  752. package/dist/esm/services/cost/order-cost/order-cost-resolution-service.js.map +0 -1
  753. package/dist/esm/services/cost/order-cost/order-cost-resolution-types.d.ts +0 -37
  754. package/dist/esm/services/cost/order-cost/order-cost-resolution-types.js +0 -2
  755. package/dist/esm/services/cost/order-cost/order-cost-resolution-types.js.map +0 -1
  756. package/dist/esm/services/db/products-db-service-types.d.ts +0 -10
  757. package/dist/esm/services/db/products-db-service-types.js +0 -2
  758. package/dist/esm/services/db/products-db-service-types.js.map +0 -1
  759. package/dist/esm/services/db/products-db-service.d.ts +0 -19
  760. package/dist/esm/services/db/products-db-service.js +0 -278
  761. package/dist/esm/services/db/products-db-service.js.map +0 -1
@@ -1,440 +1,650 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.IdentityCacheDynamoDbService = void 0;
7
- const at_tracking_event_types_1 = require("@adtrackify/at-tracking-event-types");
8
- const at_shared_utils_1 = require("@adtrackify/at-shared-utils");
9
- const fast_deep_equal_1 = __importDefault(require("fast-deep-equal"));
10
- const luxon_1 = require("luxon");
11
- const index_js_1 = require("../../clients/index.js");
12
- const index_js_2 = require("../../helpers/index.js");
13
- const identity_cache_helper_js_1 = require("../../helpers/identity-cache-helper.js");
14
- const TABLE_NAME = process.env.IDENTITY_CACHE_TABLE_V2 ?? '';
15
- const GSI1_NAME = process.env.IDENTITY_CACHE_GSI1 ?? 'gsi1pk-index';
16
- const FORCE_PURGE_TTL_SECONDS = 60 * 60 * 24 * 30;
17
- var CACHE_WRITE_REASON;
18
- (function (CACHE_WRITE_REASON) {
19
- CACHE_WRITE_REASON["CACHE_MISS"] = "cache_miss";
20
- CACHE_WRITE_REASON["STALE_TRAITS"] = "stale_traits";
21
- CACHE_WRITE_REASON["EMAIL_POINTER_DISCOVERY"] = "email_pointer_discovery";
22
- })(CACHE_WRITE_REASON || (CACHE_WRITE_REASON = {}));
23
- class IdentityCacheDynamoDbService {
24
- static lambdaInvokeClient;
25
- static getLambdaInvokeClient() {
26
- if (!this.lambdaInvokeClient) {
27
- this.lambdaInvokeClient = new index_js_1.LambdaInvokeClient();
28
- }
29
- return this.lambdaInvokeClient;
30
- }
31
- static getIdentityWithCaching = async (pixelId, incomingIdentity, identifyPrivateLambdaArn) => {
32
- try {
33
- if (!pixelId || !incomingIdentity) {
34
- index_js_2.Logger.error('getIdentityWithCaching - No pixelId or incomingIdentity', { pixelId, incomingIdentity });
35
- return undefined;
36
- }
37
- const cacheResponse = await this.readFromCache(pixelId, incomingIdentity);
38
- let resolvedIdentity = cacheResponse.resolvedIdentity;
39
- const isCacheStale = cacheResponse.isCacheStale;
40
- const cachedIdentity = cacheResponse.cachedIdentity;
41
- const staleTracker = cacheResponse.staleTracker;
42
- const writeReason = cacheResponse.writeReason;
43
- if (resolvedIdentity && !isCacheStale) {
44
- index_js_2.Logger.debug('identity cache hit', { incomingIdentity });
45
- return resolvedIdentity;
46
- }
47
- const identityForNeptune = resolvedIdentity ?? incomingIdentity;
48
- index_js_2.Logger.debug('identity cache stale - fetching from identity service', {
49
- incomingIdentity,
50
- identityForNeptune,
51
- hasDiscoveredIdentityId: !!resolvedIdentity?.identityId,
52
- });
53
- const neptuneIdentity = await this.resolveFromNeptune(pixelId, identityForNeptune, identifyPrivateLambdaArn);
54
- if (neptuneIdentity) {
55
- resolvedIdentity = neptuneIdentity;
56
- const shouldWrite = !cachedIdentity || !(0, fast_deep_equal_1.default)(cachedIdentity, neptuneIdentity);
57
- if (shouldWrite) {
58
- const staleTraits = staleTracker ? this.extractStaleTraitNames(staleTracker) : [];
59
- index_js_2.Logger.info('identity cache write', {
60
- pixelId,
61
- identityId: neptuneIdentity.identityId,
62
- writeReason,
63
- staleTraits,
64
- emailCount: neptuneIdentity.traits?.emails?.length ?? 0,
65
- });
66
- await this.writeBackToCache(pixelId, resolvedIdentity);
67
- }
68
- else {
69
- index_js_2.Logger.debug('skipping write-back - Neptune result matches cached data', {
70
- pixelId,
71
- identityId: neptuneIdentity.identityId,
72
- });
73
- }
74
- }
75
- else {
76
- index_js_2.Logger.error('Failed to getIdentity from Neptune', {
77
- pixelId,
78
- incomingIdentity,
79
- identifyPrivateLambdaArn,
80
- });
81
- }
82
- if (!resolvedIdentity) {
83
- index_js_2.Logger.error('No identity found', { pixelId, incomingIdentity });
84
- resolvedIdentity = incomingIdentity;
85
- }
86
- return resolvedIdentity;
87
- }
88
- catch (error) {
89
- index_js_2.Logger.error('Error while getting identity with caching', { error });
90
- return undefined;
91
- }
92
- };
93
- static getIdentityFromCache = async (pixelId, incomingIdentity) => {
94
- try {
95
- if (!pixelId || !incomingIdentity) {
96
- return { resolvedIdentity: undefined, isCacheStale: true, writeReason: CACHE_WRITE_REASON.CACHE_MISS };
97
- }
98
- if (incomingIdentity.identityId) {
99
- const pk = (0, at_tracking_event_types_1.buildIdentityPk)(pixelId, incomingIdentity.identityId);
100
- index_js_2.Logger.debug('try lookup with identityId', { pk });
101
- const cachedIdentityResponse = await this.getItemByPk(pk);
102
- if (!cachedIdentityResponse) {
103
- return { resolvedIdentity: undefined, isCacheStale: true, writeReason: CACHE_WRITE_REASON.CACHE_MISS };
104
- }
105
- index_js_2.Logger.debug('found cached identity', { cachedIdentityResponse });
106
- const mergedTraits = (0, at_shared_utils_1.mergeIdentityTraits)(incomingIdentity.traits, cachedIdentityResponse.response.traits);
107
- const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
108
- const identityStaleCacheTracker = (0, identity_cache_helper_js_1.isIdentityCacheStale)(cachedIdentityResponse.response, mergedIdentity);
109
- const isDeepEqual = (0, fast_deep_equal_1.default)(cachedIdentityResponse.response, mergedIdentity);
110
- let isCacheStale = identityStaleCacheTracker.isCacheStale;
111
- if (isDeepEqual) {
112
- index_js_2.Logger.debug('identity cache is deep equal', { pixelId, isCacheStale });
113
- isCacheStale = false;
114
- }
115
- else {
116
- index_js_2.Logger.debug('identity cache is not deep equal', { pixelId, identityStaleCacheTracker, isCacheStale });
117
- }
118
- if (isCacheStale) {
119
- index_js_2.Logger.debug('identity cache stale', { isCacheStale, isDeepEqual, pixelId });
120
- }
121
- return {
122
- resolvedIdentity: mergedIdentity,
123
- isCacheStale,
124
- cachedIdentity: cachedIdentityResponse.response,
125
- staleTracker: isCacheStale ? identityStaleCacheTracker : undefined,
126
- writeReason: isCacheStale ? CACHE_WRITE_REASON.STALE_TRAITS : undefined,
127
- };
128
- }
129
- const discoveredIdentityId = await this.getIdentityIdFromEmailLookup(pixelId, incomingIdentity);
130
- if (discoveredIdentityId) {
131
- index_js_2.Logger.debug('discovered identityId from email pointer', { pixelId, discoveredIdentityId });
132
- const identityWithDiscoveredId = {
133
- ...incomingIdentity,
134
- identityId: discoveredIdentityId,
135
- };
136
- return { resolvedIdentity: identityWithDiscoveredId, isCacheStale: true, writeReason: CACHE_WRITE_REASON.EMAIL_POINTER_DISCOVERY };
137
- }
138
- return { resolvedIdentity: undefined, isCacheStale: true, writeReason: CACHE_WRITE_REASON.CACHE_MISS };
139
- }
140
- catch (error) {
141
- index_js_2.Logger.error('Error while getting identity from cache', { error });
142
- return { resolvedIdentity: undefined, isCacheStale: true, writeReason: CACHE_WRITE_REASON.CACHE_MISS };
143
- }
144
- };
145
- static getIdentityMap = async (pixelId, identityId) => {
146
- try {
147
- if (!pixelId || !identityId) {
148
- return undefined;
149
- }
150
- const pk = (0, at_tracking_event_types_1.buildIdentityMapPk)(pixelId, identityId);
151
- const result = (await index_js_1.DynamoDbClient.safeGet(TABLE_NAME, 'pk', pk));
152
- return result ?? undefined;
153
- }
154
- catch (error) {
155
- index_js_2.Logger.error('Error while getting identity map', { error, pixelId, identityId });
156
- return undefined;
157
- }
158
- };
159
- static getForcePurgeFlag = async (pixelId, identityId) => {
160
- try {
161
- if (!pixelId || !identityId) {
162
- return false;
163
- }
164
- const pk = (0, at_tracking_event_types_1.buildForcePurgePk)(pixelId, identityId);
165
- const result = await index_js_1.DynamoDbClient.safeGet(TABLE_NAME, 'pk', pk);
166
- return result !== null;
167
- }
168
- catch (error) {
169
- index_js_2.Logger.error('Error while getting force purge flag', { error, pixelId, identityId });
170
- return false;
171
- }
172
- };
173
- static updateIdentityCache = async (pixelId, response) => {
174
- try {
175
- if (!response?.identityId || !pixelId) {
176
- return;
177
- }
178
- const items = [];
179
- const now = new Date().toISOString();
180
- items.push({
181
- pk: (0, at_tracking_event_types_1.buildIdentityPk)(pixelId, response.identityId),
182
- response,
183
- updatedAt: now,
184
- pixelId,
185
- identityId: response.identityId,
186
- gsi1pk: response.identityId,
187
- });
188
- const emails = response.traits?.emails ?? [];
189
- for (const email of emails) {
190
- if (email) {
191
- const pointerRecord = {
192
- pk: (0, at_tracking_event_types_1.buildEmailPk)(pixelId, email),
193
- updatedAt: now,
194
- pixelId,
195
- identityId: response.identityId,
196
- gsi1pk: response.identityId,
197
- };
198
- items.push(pointerRecord);
199
- }
200
- }
201
- await index_js_1.DynamoDbClient.safeBatchWrite(TABLE_NAME, items);
202
- index_js_2.Logger.debug('updated identity cache', { pixelId, identityId: response.identityId, itemCount: items.length });
203
- }
204
- catch (error) {
205
- index_js_2.Logger.error('Error while updating identity cache', { error, pixelId });
206
- }
207
- };
208
- static putIdentityMap = async (pixelId, identityId, linkedIdentities) => {
209
- try {
210
- if (!pixelId || !identityId) {
211
- return;
212
- }
213
- const item = {
214
- pk: (0, at_tracking_event_types_1.buildIdentityMapPk)(pixelId, identityId),
215
- pixelId,
216
- identityId,
217
- linkedIdentities,
218
- updatedAt: new Date().toISOString(),
219
- };
220
- await index_js_1.DynamoDbClient.safePut(TABLE_NAME, item);
221
- index_js_2.Logger.debug('put identity map', { pixelId, identityId, linkedIdentities });
222
- }
223
- catch (error) {
224
- index_js_2.Logger.error('Error while putting identity map', { error, pixelId, identityId });
225
- }
226
- };
227
- static setForcePurgeFlag = async (pixelId, identityId, ttlSeconds = FORCE_PURGE_TTL_SECONDS) => {
228
- try {
229
- if (!pixelId || !identityId) {
230
- return;
231
- }
232
- const now = new Date().toISOString();
233
- const ttl = luxon_1.DateTime.utc().plus({ seconds: ttlSeconds }).toSeconds();
234
- const item = {
235
- pk: (0, at_tracking_event_types_1.buildForcePurgePk)(pixelId, identityId),
236
- pixelId,
237
- identityId,
238
- createdAt: now,
239
- ttl: Math.floor(ttl),
240
- };
241
- await index_js_1.DynamoDbClient.safePut(TABLE_NAME, item);
242
- index_js_2.Logger.debug('set force purge flag', { pixelId, identityId, ttlSeconds });
243
- }
244
- catch (error) {
245
- index_js_2.Logger.error('Error while setting force purge flag', { error, pixelId, identityId });
246
- }
247
- };
248
- static deleteIdentityCache = async (pixelId, incomingIdentity, resolvedIdentity) => {
249
- try {
250
- if (!pixelId) {
251
- return;
252
- }
253
- const deleteKeys = [];
254
- const identityIdsToDelete = new Set();
255
- if (incomingIdentity?.identityId) {
256
- identityIdsToDelete.add(incomingIdentity.identityId);
257
- }
258
- if (resolvedIdentity?.identityId) {
259
- identityIdsToDelete.add(resolvedIdentity.identityId);
260
- }
261
- for (const identityId of identityIdsToDelete) {
262
- const relatedItems = await this.queryByGsi1(identityId);
263
- for (const item of relatedItems) {
264
- if (item.pk && item.pixelId === pixelId) {
265
- deleteKeys.push({ pk: item.pk });
266
- }
267
- }
268
- }
269
- if (incomingIdentity?.traits?.emails) {
270
- for (const email of incomingIdentity.traits.emails) {
271
- deleteKeys.push({ pk: (0, at_tracking_event_types_1.buildEmailPk)(pixelId, email) });
272
- }
273
- }
274
- if (resolvedIdentity?.traits?.emails) {
275
- for (const email of resolvedIdentity.traits.emails) {
276
- deleteKeys.push({ pk: (0, at_tracking_event_types_1.buildEmailPk)(pixelId, email) });
277
- }
278
- }
279
- const uniqueKeys = Array.from(new Set(deleteKeys.map((k) => k.pk))).map((pk) => ({ pk }));
280
- if (uniqueKeys.length > 0) {
281
- await this.safeBatchDelete(uniqueKeys);
282
- index_js_2.Logger.debug('deleted identity cache items', { pixelId, deletedCount: uniqueKeys.length });
283
- }
284
- }
285
- catch (error) {
286
- index_js_2.Logger.error('Error while deleting identity cache', { error, pixelId });
287
- }
288
- };
289
- static deleteIdentityMap = async (pixelId, identityId) => {
290
- try {
291
- if (!pixelId || !identityId) {
292
- return;
293
- }
294
- const pk = (0, at_tracking_event_types_1.buildIdentityMapPk)(pixelId, identityId);
295
- await index_js_1.DynamoDbClient.safeDelete(TABLE_NAME, 'pk', pk);
296
- index_js_2.Logger.debug('deleted identity map', { pixelId, identityId });
297
- }
298
- catch (error) {
299
- index_js_2.Logger.error('Error while deleting identity map', { error, pixelId, identityId });
300
- }
301
- };
302
- static deleteForcePurgeFlag = async (pixelId, identityId) => {
303
- try {
304
- if (!pixelId || !identityId) {
305
- return;
306
- }
307
- const pk = (0, at_tracking_event_types_1.buildForcePurgePk)(pixelId, identityId);
308
- await index_js_1.DynamoDbClient.safeDelete(TABLE_NAME, 'pk', pk);
309
- index_js_2.Logger.debug('deleted force purge flag', { pixelId, identityId });
310
- }
311
- catch (error) {
312
- index_js_2.Logger.error('Error while deleting force purge flag', { error, pixelId, identityId });
313
- }
314
- };
315
- static readFromCache = async (pixelId, incomingIdentity) => {
316
- return await this.getIdentityFromCache(pixelId, incomingIdentity);
317
- };
318
- static resolveFromNeptune = async (pixelId, incomingIdentity, identifyPrivateLambdaArn) => {
319
- try {
320
- const client = this.getLambdaInvokeClient();
321
- const response = await client.invokeFunction(identifyPrivateLambdaArn, {
322
- pixelId,
323
- context: { identity: incomingIdentity },
324
- });
325
- if (response?.statusCode === 200 && response?.body) {
326
- const identifyResponse = JSON.parse(response.body);
327
- return identifyResponse?.identity;
328
- }
329
- return incomingIdentity;
330
- }
331
- catch (error) {
332
- index_js_2.Logger.error('Error while resolving identity from Neptune', { error });
333
- return undefined;
334
- }
335
- };
336
- static writeBackToCache = async (pixelId, resolvedIdentity) => {
337
- await this.updateIdentityCache(pixelId, resolvedIdentity);
338
- };
339
- static getIdentityIdFromEmailLookup = async (pixelId, incomingIdentity) => {
340
- try {
341
- if (!pixelId || !incomingIdentity) {
342
- return undefined;
343
- }
344
- const firstEmail = incomingIdentity.traits?.emails?.[0];
345
- if (!firstEmail) {
346
- return undefined;
347
- }
348
- const pk = (0, at_tracking_event_types_1.buildEmailPk)(pixelId, firstEmail);
349
- index_js_2.Logger.debug('email secondary lookup', { pk });
350
- const result = (await index_js_1.DynamoDbClient.safeGet(TABLE_NAME, 'pk', pk));
351
- if (!result) {
352
- return undefined;
353
- }
354
- index_js_2.Logger.debug('found identityId from email lookup', { pixelId, identityId: result.identityId });
355
- return result.identityId;
356
- }
357
- catch (error) {
358
- index_js_2.Logger.error('Error while getting identity from email lookup', { error, pixelId });
359
- return undefined;
360
- }
361
- };
362
- static getItemByPk = async (pk) => {
363
- try {
364
- const result = (await index_js_1.DynamoDbClient.safeGet(TABLE_NAME, 'pk', pk));
365
- return result ?? undefined;
366
- }
367
- catch (error) {
368
- index_js_2.Logger.error('Error while getting item by pk', { error, pk });
369
- return undefined;
370
- }
371
- };
372
- static queryByGsi1 = async (identityId) => {
373
- try {
374
- const results = await index_js_1.DynamoDbClient.safeQueryByGSI(TABLE_NAME, GSI1_NAME, 'gsi1pk', identityId);
375
- return (results ?? []);
376
- }
377
- catch (error) {
378
- index_js_2.Logger.error('Error while querying by GSI1', { error, identityId });
379
- return [];
380
- }
381
- };
382
- static safeBatchDelete = async (keys) => {
383
- if (keys.length === 0) {
384
- return;
385
- }
386
- const chunks = this.chunkArray(keys, 25);
387
- for (const chunk of chunks) {
388
- try {
389
- const deleteRequests = chunk.map((key) => ({
390
- DeleteRequest: { Key: { pk: key.pk } },
391
- }));
392
- await index_js_1.DynamoDbClient.batchWrite({
393
- RequestItems: { [TABLE_NAME]: deleteRequests },
394
- });
395
- }
396
- catch (error) {
397
- index_js_2.Logger.error('Batch delete failed', { error, chunkSize: chunk.length });
398
- }
399
- }
400
- };
401
- static chunkArray(items, size) {
402
- const chunks = [];
403
- for (let i = 0; i < items.length; i += size) {
404
- chunks.push(items.slice(i, i + size));
405
- }
406
- return chunks;
407
- }
408
- static extractStaleTraitNames(tracker) {
409
- const staleTraits = [];
410
- if (tracker.isIdentityIdStale)
411
- staleTraits.push('identityId');
412
- if (tracker.isUserIdsStale)
413
- staleTraits.push('userIds');
414
- if (tracker.isIdsStale)
415
- staleTraits.push('ids');
416
- if (tracker.isEmailsStale)
417
- staleTraits.push('emails');
418
- if (tracker.isPhonesStale)
419
- staleTraits.push('phones');
420
- if (tracker.isShopifyYIdsStale)
421
- staleTraits.push('shopifyYIds');
422
- if (tracker.isGendersStale)
423
- staleTraits.push('genders');
424
- if (tracker.isDobsStale)
425
- staleTraits.push('dobs');
426
- if (tracker.isAddressesStale)
427
- staleTraits.push('addresses');
428
- if (tracker.isClickInfosStale)
429
- staleTraits.push('clickInfos');
430
- if (tracker.isIpAddressStale)
431
- staleTraits.push('ipAddress');
432
- if (tracker.isUserAgentStale)
433
- staleTraits.push('userAgent');
434
- if (tracker.isThirdPartyContactsStale)
435
- staleTraits.push('thirdPartyContacts');
436
- return staleTraits;
437
- }
438
- }
439
- exports.IdentityCacheDynamoDbService = IdentityCacheDynamoDbService;
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.IdentityCacheDynamoDbService = exports.CACHE_WRITE_REASON = void 0;
7
+ const at_tracking_event_types_1 = require("@adtrackify/at-tracking-event-types");
8
+ const at_shared_utils_1 = require("@adtrackify/at-shared-utils");
9
+ const fast_deep_equal_1 = __importDefault(require("fast-deep-equal"));
10
+ const luxon_1 = require("luxon");
11
+ const index_js_1 = require("../../clients/index.js");
12
+ const index_js_2 = require("../../helpers/index.js");
13
+ const identity_cache_helper_js_1 = require("../../helpers/identity-cache-helper.js");
14
+ const TABLE_NAME = process.env.IDENTITY_CACHE_TABLE_V2 ?? '';
15
+ const GSI1_NAME = process.env.IDENTITY_CACHE_GSI1 ?? 'gsi1pk-index';
16
+ const FORCE_PURGE_TTL_SECONDS = 60 * 60 * 24 * 30;
17
+ var CACHE_WRITE_REASON;
18
+ (function (CACHE_WRITE_REASON) {
19
+ CACHE_WRITE_REASON["CACHE_MISS"] = "cache_miss";
20
+ CACHE_WRITE_REASON["STALE_TRAITS"] = "stale_traits";
21
+ CACHE_WRITE_REASON["EMAIL_POINTER_DISCOVERY"] = "email_pointer_discovery";
22
+ CACHE_WRITE_REASON["ADDRESS_UPDATE"] = "address_update";
23
+ })(CACHE_WRITE_REASON = exports.CACHE_WRITE_REASON || (exports.CACHE_WRITE_REASON = {}));
24
+ class IdentityCacheDynamoDbService {
25
+ static lambdaInvokeClient;
26
+ static getLambdaInvokeClient() {
27
+ if (!this.lambdaInvokeClient) {
28
+ this.lambdaInvokeClient = new index_js_1.LambdaInvokeClient();
29
+ }
30
+ return this.lambdaInvokeClient;
31
+ }
32
+ static getIdentityWithCaching = async (pixelId, incomingIdentity, identifyPrivateLambdaArn) => {
33
+ try {
34
+ if (!pixelId || !incomingIdentity) {
35
+ index_js_2.Logger.error('getIdentityWithCaching - No pixelId or incomingIdentity', { pixelId, incomingIdentity });
36
+ return undefined;
37
+ }
38
+ const cacheResponse = await this.readFromCache(pixelId, incomingIdentity);
39
+ let resolvedIdentity = cacheResponse.resolvedIdentity;
40
+ const isCacheStale = cacheResponse.isCacheStale;
41
+ const cachedIdentity = cacheResponse.cachedIdentity;
42
+ const staleTracker = cacheResponse.staleTracker;
43
+ const writeReason = cacheResponse.writeReason;
44
+ const staleTier = cacheResponse.staleTier;
45
+ const skipNeptune = cacheResponse.skipNeptune;
46
+ if (resolvedIdentity && !isCacheStale) {
47
+ const tierLabel = staleTier === identity_cache_helper_js_1.IDENTITY_CACHE_STALENESS_TIER.VOLATILE_ONLY ? 'volatile_traits_only' : 'fresh';
48
+ index_js_2.Logger.debug(`identity cache hit - ${tierLabel}`, { pixelId, staleTier, incomingIdentity });
49
+ return resolvedIdentity;
50
+ }
51
+ if (resolvedIdentity && skipNeptune && writeReason === CACHE_WRITE_REASON.ADDRESS_UPDATE) {
52
+ const staleTraits = staleTracker ? this.extractStaleTraitNames(staleTracker) : [];
53
+ index_js_2.Logger.info('identity cache write: address update only (skipping Neptune)', {
54
+ pixelId,
55
+ identityId: resolvedIdentity.identityId,
56
+ writeReason,
57
+ staleTier,
58
+ staleTraits,
59
+ cachedIdentity: cachedIdentity ?? null,
60
+ resolvedIdentity,
61
+ traitChanges: cachedIdentity ? this.computeTraitChanges(cachedIdentity, resolvedIdentity) : { reason: 'no cached identity' },
62
+ });
63
+ await this.safeWriteBackToCache(pixelId, resolvedIdentity, 'address update');
64
+ return resolvedIdentity;
65
+ }
66
+ const identityForNeptune = resolvedIdentity ?? incomingIdentity;
67
+ index_js_2.Logger.debug('identity cache stale - fetching from identity service', {
68
+ pixelId,
69
+ staleTier,
70
+ writeReason,
71
+ incomingIdentity,
72
+ identityForNeptune,
73
+ hasDiscoveredIdentityId: !!resolvedIdentity?.identityId,
74
+ });
75
+ const neptuneIdentity = await this.resolveFromNeptune(pixelId, identityForNeptune, identifyPrivateLambdaArn);
76
+ if (neptuneIdentity) {
77
+ resolvedIdentity = neptuneIdentity;
78
+ const cachedForComparison = cachedIdentity ? this.stripAddressTimestamps(cachedIdentity) : undefined;
79
+ const neptuneForComparison = this.stripAddressTimestamps(neptuneIdentity);
80
+ const shouldWrite = !cachedForComparison || !(0, fast_deep_equal_1.default)(cachedForComparison, neptuneForComparison);
81
+ if (shouldWrite) {
82
+ const staleTraits = staleTracker ? this.extractStaleTraitNames(staleTracker) : [];
83
+ const isNewIdentity = writeReason === CACHE_WRITE_REASON.CACHE_MISS || writeReason === CACHE_WRITE_REASON.EMAIL_POINTER_DISCOVERY;
84
+ const logMessage = isNewIdentity
85
+ ? 'identity cache write: new identity'
86
+ : 'identity cache write: stale identity traits update';
87
+ index_js_2.Logger.info(logMessage, {
88
+ pixelId,
89
+ identityId: neptuneIdentity.identityId,
90
+ writeReason,
91
+ staleTier,
92
+ staleTraits,
93
+ cachedIdentity: cachedIdentity ?? null,
94
+ resolvedIdentity: neptuneIdentity,
95
+ traitChanges: cachedIdentity
96
+ ? this.computeTraitChanges(cachedIdentity, neptuneIdentity)
97
+ : { reason: 'no cached identity' },
98
+ });
99
+ await this.safeWriteBackToCache(pixelId, resolvedIdentity, 'neptune write-back');
100
+ }
101
+ else {
102
+ index_js_2.Logger.debug('skipping write-back - Neptune result matches cached data', {
103
+ pixelId,
104
+ identityId: neptuneIdentity.identityId,
105
+ staleTier,
106
+ });
107
+ }
108
+ }
109
+ else {
110
+ index_js_2.Logger.error('Failed to getIdentity from Neptune', {
111
+ pixelId,
112
+ staleTier,
113
+ incomingIdentity,
114
+ identifyPrivateLambdaArn,
115
+ });
116
+ }
117
+ if (!resolvedIdentity) {
118
+ index_js_2.Logger.error('No identity found', { pixelId, incomingIdentity });
119
+ resolvedIdentity = incomingIdentity;
120
+ }
121
+ return resolvedIdentity;
122
+ }
123
+ catch (error) {
124
+ index_js_2.Logger.error('Error while getting identity with caching', {
125
+ error,
126
+ errorMessage: error instanceof Error ? error.message : String(error),
127
+ pixelId,
128
+ });
129
+ return undefined;
130
+ }
131
+ };
132
+ static getIdentityFromCache = async (pixelId, incomingIdentity) => {
133
+ try {
134
+ if (!pixelId || !incomingIdentity) {
135
+ return { resolvedIdentity: undefined, isCacheStale: true, writeReason: CACHE_WRITE_REASON.CACHE_MISS };
136
+ }
137
+ if (incomingIdentity.identityId) {
138
+ const pk = (0, at_tracking_event_types_1.buildIdentityPk)(pixelId, incomingIdentity.identityId);
139
+ index_js_2.Logger.debug('try lookup with identityId', { pk });
140
+ const cachedIdentityResponse = await this.getItemByPk(pk);
141
+ if (!cachedIdentityResponse) {
142
+ return { resolvedIdentity: undefined, isCacheStale: true, writeReason: CACHE_WRITE_REASON.CACHE_MISS };
143
+ }
144
+ index_js_2.Logger.debug('found cached identity', { cachedIdentityResponse });
145
+ const mergedTraits = (0, at_shared_utils_1.mergeIdentityTraits)(incomingIdentity.traits, cachedIdentityResponse.response.traits);
146
+ const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
147
+ const identityStaleCacheTracker = (0, identity_cache_helper_js_1.isIdentityCacheStale)(cachedIdentityResponse.response, mergedIdentity);
148
+ const cachedForComparison = this.stripAddressTimestamps(cachedIdentityResponse.response);
149
+ const mergedForComparison = this.stripAddressTimestamps(mergedIdentity);
150
+ const isDeepEqual = (0, fast_deep_equal_1.default)(cachedForComparison, mergedForComparison);
151
+ const staleTier = identityStaleCacheTracker.staleTier;
152
+ let isCacheStale = identityStaleCacheTracker.isCacheStale;
153
+ if (isDeepEqual) {
154
+ index_js_2.Logger.debug('identity cache is deep equal (after stripping timestamps)', { pixelId, staleTier });
155
+ isCacheStale = false;
156
+ }
157
+ else {
158
+ index_js_2.Logger.debug('identity cache is not deep equal', { pixelId, staleTier, identityStaleCacheTracker });
159
+ }
160
+ const isVolatileOnly = staleTier === identity_cache_helper_js_1.IDENTITY_CACHE_STALENESS_TIER.VOLATILE_ONLY;
161
+ const isAddressUpdateOnly = staleTier === identity_cache_helper_js_1.IDENTITY_CACHE_STALENESS_TIER.ADDRESS_UPDATE;
162
+ const skipNeptune = isVolatileOnly || isAddressUpdateOnly;
163
+ if (isVolatileOnly && !isDeepEqual) {
164
+ index_js_2.Logger.debug('volatile traits only stale - treating as cache hit', { pixelId, staleTier });
165
+ isCacheStale = false;
166
+ }
167
+ let writeReason;
168
+ if (isCacheStale) {
169
+ if (isAddressUpdateOnly) {
170
+ writeReason = CACHE_WRITE_REASON.ADDRESS_UPDATE;
171
+ }
172
+ else {
173
+ writeReason = CACHE_WRITE_REASON.STALE_TRAITS;
174
+ }
175
+ }
176
+ if (isCacheStale) {
177
+ index_js_2.Logger.debug('identity cache stale', { isCacheStale, isDeepEqual, staleTier, skipNeptune, pixelId });
178
+ }
179
+ return {
180
+ resolvedIdentity: mergedIdentity,
181
+ isCacheStale,
182
+ cachedIdentity: cachedIdentityResponse.response,
183
+ staleTracker: isCacheStale ? identityStaleCacheTracker : undefined,
184
+ writeReason,
185
+ staleTier,
186
+ skipNeptune: isCacheStale ? skipNeptune : undefined,
187
+ };
188
+ }
189
+ const discoveredIdentityId = await this.getIdentityIdFromEmailLookup(pixelId, incomingIdentity);
190
+ if (discoveredIdentityId) {
191
+ index_js_2.Logger.debug('discovered identityId from email pointer', { pixelId, discoveredIdentityId });
192
+ const identityWithDiscoveredId = {
193
+ ...incomingIdentity,
194
+ identityId: discoveredIdentityId,
195
+ };
196
+ return { resolvedIdentity: identityWithDiscoveredId, isCacheStale: true, writeReason: CACHE_WRITE_REASON.EMAIL_POINTER_DISCOVERY };
197
+ }
198
+ return { resolvedIdentity: undefined, isCacheStale: true, writeReason: CACHE_WRITE_REASON.CACHE_MISS };
199
+ }
200
+ catch (error) {
201
+ index_js_2.Logger.error('Error while getting identity from cache', {
202
+ error,
203
+ errorMessage: error instanceof Error ? error.message : String(error),
204
+ pixelId,
205
+ });
206
+ return { resolvedIdentity: undefined, isCacheStale: true, writeReason: CACHE_WRITE_REASON.CACHE_MISS };
207
+ }
208
+ };
209
+ static getIdentityMap = async (pixelId, identityId) => {
210
+ try {
211
+ if (!pixelId || !identityId) {
212
+ return undefined;
213
+ }
214
+ const pk = (0, at_tracking_event_types_1.buildIdentityMapPk)(pixelId, identityId);
215
+ const result = (await index_js_1.DynamoDbClient.safeGet(TABLE_NAME, 'pk', pk));
216
+ return result ?? undefined;
217
+ }
218
+ catch (error) {
219
+ index_js_2.Logger.error('Error while getting identity map', {
220
+ error,
221
+ errorMessage: error instanceof Error ? error.message : String(error),
222
+ pixelId,
223
+ identityId,
224
+ });
225
+ return undefined;
226
+ }
227
+ };
228
+ static getForcePurgeFlag = async (pixelId, identityId) => {
229
+ try {
230
+ if (!pixelId || !identityId) {
231
+ return false;
232
+ }
233
+ const pk = (0, at_tracking_event_types_1.buildForcePurgePk)(pixelId, identityId);
234
+ const result = await index_js_1.DynamoDbClient.safeGet(TABLE_NAME, 'pk', pk);
235
+ return result !== null;
236
+ }
237
+ catch (error) {
238
+ index_js_2.Logger.error('Error while getting force purge flag', {
239
+ error,
240
+ errorMessage: error instanceof Error ? error.message : String(error),
241
+ pixelId,
242
+ identityId,
243
+ });
244
+ return false;
245
+ }
246
+ };
247
+ static updateIdentityCache = async (pixelId, response) => {
248
+ try {
249
+ if (!response?.identityId || !pixelId) {
250
+ return;
251
+ }
252
+ const items = [];
253
+ const now = new Date().toISOString();
254
+ items.push({
255
+ pk: (0, at_tracking_event_types_1.buildIdentityPk)(pixelId, response.identityId),
256
+ response,
257
+ updatedAt: now,
258
+ pixelId,
259
+ identityId: response.identityId,
260
+ gsi1pk: response.identityId,
261
+ });
262
+ const emails = response.traits?.emails ?? [];
263
+ for (const email of emails) {
264
+ if (email) {
265
+ const pointerRecord = {
266
+ pk: (0, at_tracking_event_types_1.buildEmailPk)(pixelId, email),
267
+ updatedAt: now,
268
+ pixelId,
269
+ identityId: response.identityId,
270
+ gsi1pk: response.identityId,
271
+ };
272
+ items.push(pointerRecord);
273
+ }
274
+ }
275
+ await index_js_1.DynamoDbClient.safeBatchWrite(TABLE_NAME, items);
276
+ index_js_2.Logger.debug('updated identity cache', { pixelId, identityId: response.identityId, itemCount: items.length });
277
+ }
278
+ catch (error) {
279
+ index_js_2.Logger.error('Error while updating identity cache', {
280
+ error,
281
+ errorMessage: error instanceof Error ? error.message : String(error),
282
+ pixelId,
283
+ });
284
+ }
285
+ };
286
+ static putIdentityMap = async (pixelId, identityId, linkedIdentities) => {
287
+ try {
288
+ if (!pixelId || !identityId) {
289
+ return;
290
+ }
291
+ const item = {
292
+ pk: (0, at_tracking_event_types_1.buildIdentityMapPk)(pixelId, identityId),
293
+ pixelId,
294
+ identityId,
295
+ linkedIdentities,
296
+ updatedAt: new Date().toISOString(),
297
+ };
298
+ await index_js_1.DynamoDbClient.safePut(TABLE_NAME, item);
299
+ index_js_2.Logger.debug('put identity map', { pixelId, identityId, linkedIdentities });
300
+ }
301
+ catch (error) {
302
+ index_js_2.Logger.error('Error while putting identity map', {
303
+ error,
304
+ errorMessage: error instanceof Error ? error.message : String(error),
305
+ pixelId,
306
+ identityId,
307
+ });
308
+ }
309
+ };
310
+ static setForcePurgeFlag = async (pixelId, identityId, ttlSeconds = FORCE_PURGE_TTL_SECONDS) => {
311
+ try {
312
+ if (!pixelId || !identityId) {
313
+ return;
314
+ }
315
+ const now = new Date().toISOString();
316
+ const ttl = luxon_1.DateTime.utc().plus({ seconds: ttlSeconds }).toSeconds();
317
+ const item = {
318
+ pk: (0, at_tracking_event_types_1.buildForcePurgePk)(pixelId, identityId),
319
+ pixelId,
320
+ identityId,
321
+ createdAt: now,
322
+ ttl: Math.floor(ttl),
323
+ };
324
+ await index_js_1.DynamoDbClient.safePut(TABLE_NAME, item);
325
+ index_js_2.Logger.debug('set force purge flag', { pixelId, identityId, ttlSeconds });
326
+ }
327
+ catch (error) {
328
+ index_js_2.Logger.error('Error while setting force purge flag', {
329
+ error,
330
+ errorMessage: error instanceof Error ? error.message : String(error),
331
+ pixelId,
332
+ identityId,
333
+ });
334
+ }
335
+ };
336
+ static deleteIdentityCache = async (pixelId, incomingIdentity, resolvedIdentity) => {
337
+ try {
338
+ if (!pixelId) {
339
+ return;
340
+ }
341
+ const deleteKeys = [];
342
+ const identityIdsToDelete = new Set();
343
+ if (incomingIdentity?.identityId) {
344
+ identityIdsToDelete.add(incomingIdentity.identityId);
345
+ }
346
+ if (resolvedIdentity?.identityId) {
347
+ identityIdsToDelete.add(resolvedIdentity.identityId);
348
+ }
349
+ for (const identityId of identityIdsToDelete) {
350
+ const relatedItems = await this.queryByGsi1(identityId);
351
+ for (const item of relatedItems) {
352
+ if (item.pk && item.pixelId === pixelId) {
353
+ deleteKeys.push({ pk: item.pk });
354
+ }
355
+ }
356
+ }
357
+ if (incomingIdentity?.traits?.emails) {
358
+ for (const email of incomingIdentity.traits.emails) {
359
+ deleteKeys.push({ pk: (0, at_tracking_event_types_1.buildEmailPk)(pixelId, email) });
360
+ }
361
+ }
362
+ if (resolvedIdentity?.traits?.emails) {
363
+ for (const email of resolvedIdentity.traits.emails) {
364
+ deleteKeys.push({ pk: (0, at_tracking_event_types_1.buildEmailPk)(pixelId, email) });
365
+ }
366
+ }
367
+ const uniqueKeys = Array.from(new Set(deleteKeys.map((k) => k.pk))).map((pk) => ({ pk }));
368
+ if (uniqueKeys.length > 0) {
369
+ await this.safeBatchDelete(uniqueKeys);
370
+ index_js_2.Logger.debug('deleted identity cache items', { pixelId, deletedCount: uniqueKeys.length });
371
+ }
372
+ }
373
+ catch (error) {
374
+ index_js_2.Logger.error('Error while deleting identity cache', {
375
+ error,
376
+ errorMessage: error instanceof Error ? error.message : String(error),
377
+ pixelId,
378
+ });
379
+ }
380
+ };
381
+ static deleteIdentityMap = async (pixelId, identityId) => {
382
+ try {
383
+ if (!pixelId || !identityId) {
384
+ return;
385
+ }
386
+ const pk = (0, at_tracking_event_types_1.buildIdentityMapPk)(pixelId, identityId);
387
+ await index_js_1.DynamoDbClient.safeDelete(TABLE_NAME, 'pk', pk);
388
+ index_js_2.Logger.debug('deleted identity map', { pixelId, identityId });
389
+ }
390
+ catch (error) {
391
+ index_js_2.Logger.error('Error while deleting identity map', {
392
+ error,
393
+ errorMessage: error instanceof Error ? error.message : String(error),
394
+ pixelId,
395
+ identityId,
396
+ });
397
+ }
398
+ };
399
+ static deleteForcePurgeFlag = async (pixelId, identityId) => {
400
+ try {
401
+ if (!pixelId || !identityId) {
402
+ return;
403
+ }
404
+ const pk = (0, at_tracking_event_types_1.buildForcePurgePk)(pixelId, identityId);
405
+ await index_js_1.DynamoDbClient.safeDelete(TABLE_NAME, 'pk', pk);
406
+ index_js_2.Logger.debug('deleted force purge flag', { pixelId, identityId });
407
+ }
408
+ catch (error) {
409
+ index_js_2.Logger.error('Error while deleting force purge flag', {
410
+ error,
411
+ errorMessage: error instanceof Error ? error.message : String(error),
412
+ pixelId,
413
+ identityId,
414
+ });
415
+ }
416
+ };
417
+ static readFromCache = async (pixelId, incomingIdentity) => {
418
+ return await this.getIdentityFromCache(pixelId, incomingIdentity);
419
+ };
420
+ static resolveFromNeptune = async (pixelId, incomingIdentity, identifyPrivateLambdaArn) => {
421
+ try {
422
+ const client = this.getLambdaInvokeClient();
423
+ const response = await client.invokeFunction(identifyPrivateLambdaArn, {
424
+ pixelId,
425
+ context: { identity: incomingIdentity },
426
+ });
427
+ if (response?.statusCode === 200 && response?.body) {
428
+ const identifyResponse = JSON.parse(response.body);
429
+ return identifyResponse?.identity;
430
+ }
431
+ return incomingIdentity;
432
+ }
433
+ catch (error) {
434
+ index_js_2.Logger.error('Error while resolving identity from Neptune', {
435
+ error,
436
+ errorMessage: error instanceof Error ? error.message : String(error),
437
+ pixelId,
438
+ });
439
+ return undefined;
440
+ }
441
+ };
442
+ static writeBackToCache = async (pixelId, resolvedIdentity) => {
443
+ await this.updateIdentityCache(pixelId, resolvedIdentity);
444
+ };
445
+ static safeWriteBackToCache = async (pixelId, resolvedIdentity, context) => {
446
+ try {
447
+ await this.writeBackToCache(pixelId, resolvedIdentity);
448
+ }
449
+ catch (writeError) {
450
+ index_js_2.Logger.error(`identity cache write failed (${context}) - continuing with resolved identity`, {
451
+ error: writeError,
452
+ errorMessage: writeError instanceof Error ? writeError.message : String(writeError),
453
+ pixelId,
454
+ identityId: resolvedIdentity?.identityId,
455
+ });
456
+ }
457
+ };
458
+ static getIdentityIdFromEmailLookup = async (pixelId, incomingIdentity) => {
459
+ try {
460
+ if (!pixelId || !incomingIdentity) {
461
+ return undefined;
462
+ }
463
+ const firstEmail = incomingIdentity.traits?.emails?.[0];
464
+ if (!firstEmail) {
465
+ return undefined;
466
+ }
467
+ const pk = (0, at_tracking_event_types_1.buildEmailPk)(pixelId, firstEmail);
468
+ index_js_2.Logger.debug('email secondary lookup', { pk });
469
+ const result = (await index_js_1.DynamoDbClient.safeGet(TABLE_NAME, 'pk', pk));
470
+ if (!result) {
471
+ return undefined;
472
+ }
473
+ index_js_2.Logger.debug('found identityId from email lookup', { pixelId, identityId: result.identityId });
474
+ return result.identityId;
475
+ }
476
+ catch (error) {
477
+ index_js_2.Logger.error('Error while getting identity from email lookup', {
478
+ error,
479
+ errorMessage: error instanceof Error ? error.message : String(error),
480
+ pixelId,
481
+ });
482
+ return undefined;
483
+ }
484
+ };
485
+ static getItemByPk = async (pk) => {
486
+ try {
487
+ const result = (await index_js_1.DynamoDbClient.safeGet(TABLE_NAME, 'pk', pk));
488
+ return result ?? undefined;
489
+ }
490
+ catch (error) {
491
+ index_js_2.Logger.error('Error while getting item by pk', {
492
+ error,
493
+ errorMessage: error instanceof Error ? error.message : String(error),
494
+ pk,
495
+ });
496
+ return undefined;
497
+ }
498
+ };
499
+ static queryByGsi1 = async (identityId) => {
500
+ try {
501
+ const results = await index_js_1.DynamoDbClient.safeQueryByGSI(TABLE_NAME, GSI1_NAME, 'gsi1pk', identityId);
502
+ return (results ?? []);
503
+ }
504
+ catch (error) {
505
+ index_js_2.Logger.error('Error while querying by GSI1', {
506
+ error,
507
+ errorMessage: error instanceof Error ? error.message : String(error),
508
+ identityId,
509
+ });
510
+ return [];
511
+ }
512
+ };
513
+ static safeBatchDelete = async (keys) => {
514
+ if (keys.length === 0) {
515
+ return;
516
+ }
517
+ const chunks = this.chunkArray(keys, 25);
518
+ for (const chunk of chunks) {
519
+ try {
520
+ const deleteRequests = chunk.map((key) => ({
521
+ DeleteRequest: { Key: { pk: key.pk } },
522
+ }));
523
+ await index_js_1.DynamoDbClient.batchWrite({
524
+ RequestItems: { [TABLE_NAME]: deleteRequests },
525
+ });
526
+ }
527
+ catch (error) {
528
+ index_js_2.Logger.error('Batch delete failed', {
529
+ error,
530
+ errorMessage: error instanceof Error ? error.message : String(error),
531
+ chunkSize: chunk.length,
532
+ });
533
+ }
534
+ }
535
+ };
536
+ static chunkArray(items, size) {
537
+ const chunks = [];
538
+ for (let i = 0; i < items.length; i += size) {
539
+ chunks.push(items.slice(i, i + size));
540
+ }
541
+ return chunks;
542
+ }
543
+ static stripAddressTimestamps(identity) {
544
+ if (!identity?.traits?.addresses?.length) {
545
+ return identity;
546
+ }
547
+ const strippedAddresses = identity.traits.addresses.map((addr) => {
548
+ if (!addr)
549
+ return addr;
550
+ const { cra, upa, ...rest } = addr;
551
+ return rest;
552
+ });
553
+ return {
554
+ ...identity,
555
+ traits: {
556
+ ...identity.traits,
557
+ addresses: strippedAddresses,
558
+ },
559
+ };
560
+ }
561
+ static extractStaleTraitNames(tracker) {
562
+ const staleTraits = [];
563
+ if (tracker.isIdentityIdStale)
564
+ staleTraits.push('identityId');
565
+ if (tracker.isUserIdsStale)
566
+ staleTraits.push('userIds');
567
+ if (tracker.isIdsStale)
568
+ staleTraits.push('ids');
569
+ if (tracker.isEmailsStale)
570
+ staleTraits.push('emails');
571
+ if (tracker.isPhonesStale)
572
+ staleTraits.push('phones');
573
+ if (tracker.isShopifyYIdsStale)
574
+ staleTraits.push('shopifyYIds');
575
+ if (tracker.isGendersStale)
576
+ staleTraits.push('genders');
577
+ if (tracker.isDobsStale)
578
+ staleTraits.push('dobs');
579
+ if (tracker.isAddressesStale)
580
+ staleTraits.push('addresses');
581
+ if (tracker.isClickInfosStale)
582
+ staleTraits.push('clickInfos');
583
+ if (tracker.isIpAddressStale)
584
+ staleTraits.push('ipAddress');
585
+ if (tracker.isUserAgentStale)
586
+ staleTraits.push('userAgent');
587
+ if (tracker.isThirdPartyContactsStale)
588
+ staleTraits.push('thirdPartyContacts');
589
+ return staleTraits;
590
+ }
591
+ static computeTraitChanges(cachedIdentity, resolvedIdentity) {
592
+ const changes = {};
593
+ const cachedTraits = cachedIdentity.traits ?? {};
594
+ const resolvedTraits = resolvedIdentity.traits ?? {};
595
+ const arrayTraits = [
596
+ 'emails',
597
+ 'phones',
598
+ 'userIds',
599
+ 'shopifyYIds',
600
+ 'shopifyCustomerIds',
601
+ 'klaviyoIds',
602
+ 'genders',
603
+ 'dobs',
604
+ 'ids',
605
+ ];
606
+ for (const trait of arrayTraits) {
607
+ const cachedValue = cachedTraits[trait];
608
+ const resolvedValue = resolvedTraits[trait];
609
+ if (!(0, fast_deep_equal_1.default)(cachedValue, resolvedValue)) {
610
+ changes[trait] = {
611
+ cached: cachedValue ?? [],
612
+ resolved: resolvedValue ?? [],
613
+ };
614
+ }
615
+ }
616
+ if (!(0, fast_deep_equal_1.default)(cachedTraits.addresses, resolvedTraits.addresses)) {
617
+ changes.addresses = {
618
+ cached: cachedTraits.addresses ?? [],
619
+ resolved: resolvedTraits.addresses ?? [],
620
+ };
621
+ }
622
+ if (!(0, fast_deep_equal_1.default)(cachedTraits.click, resolvedTraits.click)) {
623
+ changes.click = {
624
+ cached: cachedTraits.click ?? {},
625
+ resolved: resolvedTraits.click ?? {},
626
+ };
627
+ }
628
+ if (cachedTraits.ipAddress !== resolvedTraits.ipAddress) {
629
+ changes.ipAddress = {
630
+ cached: cachedTraits.ipAddress,
631
+ resolved: resolvedTraits.ipAddress,
632
+ };
633
+ }
634
+ if (cachedTraits.userAgent !== resolvedTraits.userAgent) {
635
+ changes.userAgent = {
636
+ cached: cachedTraits.userAgent,
637
+ resolved: resolvedTraits.userAgent,
638
+ };
639
+ }
640
+ if (cachedIdentity.identityId !== resolvedIdentity.identityId) {
641
+ changes.identityId = {
642
+ cached: cachedIdentity.identityId,
643
+ resolved: resolvedIdentity.identityId,
644
+ };
645
+ }
646
+ return changes;
647
+ }
648
+ }
649
+ exports.IdentityCacheDynamoDbService = IdentityCacheDynamoDbService;
440
650
  //# sourceMappingURL=identity-cache-dynamodb-service.js.map