@adtrackify/at-service-common 4.0.0 → 4.0.2

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