@adtrackify/at-service-common 4.0.4 → 4.0.5

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 (715) 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 -1
  20. package/dist/cjs/__tests__/db/products-db-service.spec.js +89 -89
  21. package/dist/cjs/__tests__/db/shared-read-db-services.spec.d.ts +1 -1
  22. package/dist/cjs/__tests__/db/shared-read-db-services.spec.js +89 -89
  23. package/dist/cjs/__tests__/db/shopify-app-installs-db-service.spec.d.ts +1 -1
  24. package/dist/cjs/__tests__/db/shopify-app-installs-db-service.spec.js +104 -104
  25. package/dist/cjs/__tests__/db/subscriptions-db-service.spec.d.ts +1 -1
  26. package/dist/cjs/__tests__/db/subscriptions-db-service.spec.js +95 -95
  27. package/dist/cjs/__tests__/db/user-accounts-db-service.spec.d.ts +1 -1
  28. package/dist/cjs/__tests__/db/user-accounts-db-service.spec.js +76 -76
  29. package/dist/cjs/__tests__/helpers/account-users-helper.spec.d.ts +1 -1
  30. package/dist/cjs/__tests__/helpers/account-users-helper.spec.js +220 -220
  31. package/dist/cjs/__tests__/helpers/acuity-helper.spec.d.ts +1 -1
  32. package/dist/cjs/__tests__/helpers/acuity-helper.spec.js +69 -69
  33. package/dist/cjs/__tests__/helpers/api-key-auth-helper.spec.d.ts +1 -1
  34. package/dist/cjs/__tests__/helpers/api-key-auth-helper.spec.js +82 -82
  35. package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.d.ts +1 -1
  36. package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.js +676 -676
  37. package/dist/cjs/__tests__/identity-cache/identity-cache-dynamodb-service.spec.d.ts +1 -1
  38. package/dist/cjs/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js +1140 -1140
  39. package/dist/cjs/__tests__/identity-cache/identity-cache-tier-routing.spec.d.ts +1 -1
  40. package/dist/cjs/__tests__/identity-cache/identity-cache-tier-routing.spec.js +851 -851
  41. package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.d.ts +1 -1
  42. package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.js +1060 -1060
  43. package/dist/cjs/__tests__/identity-cache/volatile-traits-optimization.spec.d.ts +1 -1
  44. package/dist/cjs/__tests__/identity-cache/volatile-traits-optimization.spec.js +818 -818
  45. package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.d.ts +1 -1
  46. package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.js +584 -584
  47. package/dist/cjs/__tests__/libs/compress-decompress.spec.d.ts +1 -1
  48. package/dist/cjs/__tests__/libs/compress-decompress.spec.js +16 -16
  49. package/dist/cjs/__tests__/libs/contacts.spec.d.ts +1 -1
  50. package/dist/cjs/__tests__/libs/contacts.spec.js +294 -294
  51. package/dist/cjs/__tests__/libs/currency.spec.d.ts +1 -1
  52. package/dist/cjs/__tests__/libs/currency.spec.js +220 -220
  53. package/dist/cjs/__tests__/libs/dates.spec.d.ts +1 -1
  54. package/dist/cjs/__tests__/libs/dates.spec.js +130 -130
  55. package/dist/cjs/__tests__/libs/domain.spec.d.ts +1 -1
  56. package/dist/cjs/__tests__/libs/domain.spec.js +107 -107
  57. package/dist/cjs/__tests__/libs/numbers.spec.d.ts +1 -1
  58. package/dist/cjs/__tests__/libs/numbers.spec.js +261 -261
  59. package/dist/cjs/__tests__/s3-client/s3-client.spec.d.ts +1 -1
  60. package/dist/cjs/__tests__/s3-client/s3-client.spec.js +33 -33
  61. package/dist/cjs/__tests__/services/acuity-api-service.spec.d.ts +1 -1
  62. package/dist/cjs/__tests__/services/acuity-api-service.spec.js +71 -71
  63. package/dist/cjs/__tests__/services/cost/cost-calculation-types.spec.d.ts +1 -1
  64. package/dist/cjs/__tests__/services/cost/cost-calculation-types.spec.js +23 -23
  65. package/dist/cjs/__tests__/services/cost/cost-calculator-service.spec.d.ts +1 -1
  66. package/dist/cjs/__tests__/services/cost/cost-calculator-service.spec.js +3319 -3319
  67. package/dist/cjs/__tests__/services/cost/cost-currency-service.spec.d.ts +1 -1
  68. package/dist/cjs/__tests__/services/cost/cost-currency-service.spec.js +114 -114
  69. package/dist/cjs/__tests__/services/cost/cost-filter-service.spec.d.ts +1 -1
  70. package/dist/cjs/__tests__/services/cost/cost-filter-service.spec.js +468 -468
  71. package/dist/cjs/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.d.ts +1 -1
  72. package/dist/cjs/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.js +206 -206
  73. package/dist/cjs/__tests__/services/currency-exchange-rate-lookup-service.spec.d.ts +1 -1
  74. package/dist/cjs/__tests__/services/currency-exchange-rate-lookup-service.spec.js +34 -34
  75. package/dist/cjs/__tests__/services/email-verification/contact-email-verification-service.spec.d.ts +1 -1
  76. package/dist/cjs/__tests__/services/email-verification/contact-email-verification-service.spec.js +93 -93
  77. package/dist/cjs/__tests__/services/email-verification/email-verification-service.spec.d.ts +1 -1
  78. package/dist/cjs/__tests__/services/email-verification/email-verification-service.spec.js +57 -57
  79. package/dist/cjs/__tests__/shopify/shopify-graphql-transformer.spec.d.ts +1 -1
  80. package/dist/cjs/__tests__/shopify/shopify-graphql-transformer.spec.js +35 -35
  81. package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.d.ts +1 -1
  82. package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.js +181 -181
  83. package/dist/cjs/__tests__/unit/libs/api-router/route-matcher.spec.d.ts +1 -1
  84. package/dist/cjs/__tests__/unit/libs/api-router/route-matcher.spec.js +69 -69
  85. package/dist/cjs/__tests__/utils/custom-measure-formula-utils.spec.d.ts +1 -1
  86. package/dist/cjs/__tests__/utils/custom-measure-formula-utils.spec.js +139 -139
  87. package/dist/cjs/clients/generic/cognito-client.d.ts +23 -23
  88. package/dist/cjs/clients/generic/cognito-client.js +209 -209
  89. package/dist/cjs/clients/generic/dynamodb-client.d.ts +20 -20
  90. package/dist/cjs/clients/generic/dynamodb-client.js +235 -235
  91. package/dist/cjs/clients/generic/eventbridge-client.d.ts +14 -14
  92. package/dist/cjs/clients/generic/eventbridge-client.js +51 -51
  93. package/dist/cjs/clients/generic/http-client.d.ts +14 -14
  94. package/dist/cjs/clients/generic/http-client.js +61 -61
  95. package/dist/cjs/clients/generic/index.d.ts +13 -13
  96. package/dist/cjs/clients/generic/index.js +29 -29
  97. package/dist/cjs/clients/generic/lambda-invoke-client.d.ts +10 -10
  98. package/dist/cjs/clients/generic/lambda-invoke-client.js +39 -39
  99. package/dist/cjs/clients/generic/location-client.d.ts +8 -8
  100. package/dist/cjs/clients/generic/location-client.js +31 -31
  101. package/dist/cjs/clients/generic/redis-client.d.ts +33 -33
  102. package/dist/cjs/clients/generic/redis-client.js +191 -191
  103. package/dist/cjs/clients/generic/s3-client.d.ts +23 -23
  104. package/dist/cjs/clients/generic/s3-client.js +216 -216
  105. package/dist/cjs/clients/generic/singlestore-db-client.d.ts +14 -14
  106. package/dist/cjs/clients/generic/singlestore-db-client.js +67 -67
  107. package/dist/cjs/clients/generic/sqs-bundled-client.d.ts +15 -15
  108. package/dist/cjs/clients/generic/sqs-bundled-client.js +311 -311
  109. package/dist/cjs/clients/generic/sqs-bundled-client.types.d.ts +53 -53
  110. package/dist/cjs/clients/generic/sqs-bundled-client.types.js +17 -17
  111. package/dist/cjs/clients/generic/sqs-client.d.ts +53 -53
  112. package/dist/cjs/clients/generic/sqs-client.js +285 -285
  113. package/dist/cjs/clients/generic/sqs-unbundle.d.ts +32 -32
  114. package/dist/cjs/clients/generic/sqs-unbundle.js +144 -144
  115. package/dist/cjs/clients/index.d.ts +3 -3
  116. package/dist/cjs/clients/index.js +19 -19
  117. package/dist/cjs/clients/internal-api/accounts-client.d.ts +91 -91
  118. package/dist/cjs/clients/internal-api/accounts-client.js +129 -129
  119. package/dist/cjs/clients/internal-api/cache-lambda-client.d.ts +26 -26
  120. package/dist/cjs/clients/internal-api/cache-lambda-client.js +89 -89
  121. package/dist/cjs/clients/internal-api/db-management-client.d.ts +18 -18
  122. package/dist/cjs/clients/internal-api/db-management-client.js +36 -36
  123. package/dist/cjs/clients/internal-api/destinations-client.d.ts +34 -34
  124. package/dist/cjs/clients/internal-api/destinations-client.js +79 -79
  125. package/dist/cjs/clients/internal-api/event-collector-client.d.ts +20 -20
  126. package/dist/cjs/clients/internal-api/event-collector-client.js +36 -36
  127. package/dist/cjs/clients/internal-api/identity-client.d.ts +31 -31
  128. package/dist/cjs/clients/internal-api/identity-client.js +91 -91
  129. package/dist/cjs/clients/internal-api/index.d.ts +9 -9
  130. package/dist/cjs/clients/internal-api/index.js +25 -25
  131. package/dist/cjs/clients/internal-api/shopify-app-install-client.d.ts +37 -37
  132. package/dist/cjs/clients/internal-api/shopify-app-install-client.js +81 -81
  133. package/dist/cjs/clients/internal-api/subscriptions-client.d.ts +26 -26
  134. package/dist/cjs/clients/internal-api/subscriptions-client.js +77 -77
  135. package/dist/cjs/clients/internal-api/users-auth-client.d.ts +35 -35
  136. package/dist/cjs/clients/internal-api/users-auth-client.js +110 -110
  137. package/dist/cjs/clients/third-party/acuity-client.d.ts +10 -10
  138. package/dist/cjs/clients/third-party/acuity-client.js +40 -40
  139. package/dist/cjs/clients/third-party/emailable-client.d.ts +7 -7
  140. package/dist/cjs/clients/third-party/emailable-client.js +25 -25
  141. package/dist/cjs/clients/third-party/exchange-rate-api-client.d.ts +17 -17
  142. package/dist/cjs/clients/third-party/exchange-rate-api-client.js +19 -19
  143. package/dist/cjs/clients/third-party/index.d.ts +5 -5
  144. package/dist/cjs/clients/third-party/index.js +21 -21
  145. package/dist/cjs/clients/third-party/loops-client.d.ts +10 -10
  146. package/dist/cjs/clients/third-party/loops-client.js +30 -30
  147. package/dist/cjs/clients/third-party/shopify/graphql-order-queries.d.ts +25 -25
  148. package/dist/cjs/clients/third-party/shopify/graphql-order-queries.js +4 -4
  149. package/dist/cjs/clients/third-party/shopify/graphql-product-queries.d.ts +2 -2
  150. package/dist/cjs/clients/third-party/shopify/graphql-product-queries.js +5 -5
  151. package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.d.ts +10 -10
  152. package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.js +161 -161
  153. package/dist/cjs/clients/third-party/shopify-client.d.ts +29 -29
  154. package/dist/cjs/clients/third-party/shopify-client.js +146 -146
  155. package/dist/cjs/constants/index.d.ts +1 -1
  156. package/dist/cjs/constants/index.js +17 -17
  157. package/dist/cjs/constants/sqs.d.ts +20 -20
  158. package/dist/cjs/constants/sqs.js +26 -26
  159. package/dist/cjs/helpers/account-users-helper.d.ts +2 -2
  160. package/dist/cjs/helpers/account-users-helper.js +22 -22
  161. package/dist/cjs/helpers/acuity-helper.d.ts +4 -4
  162. package/dist/cjs/helpers/acuity-helper.js +56 -56
  163. package/dist/cjs/helpers/api-key-auth-helper.d.ts +9 -9
  164. package/dist/cjs/helpers/api-key-auth-helper.js +40 -40
  165. package/dist/cjs/helpers/api-key-authorizer-helper.d.ts +36 -36
  166. package/dist/cjs/helpers/api-key-authorizer-helper.js +87 -87
  167. package/dist/cjs/helpers/identity-cache-helper.d.ts +30 -30
  168. package/dist/cjs/helpers/identity-cache-helper.js +253 -253
  169. package/dist/cjs/helpers/index.d.ts +10 -10
  170. package/dist/cjs/helpers/index.js +26 -26
  171. package/dist/cjs/helpers/input-validation-helper.d.ts +3 -3
  172. package/dist/cjs/helpers/input-validation-helper.js +22 -22
  173. package/dist/cjs/helpers/logging-helper.d.ts +16 -16
  174. package/dist/cjs/helpers/logging-helper.js +84 -84
  175. package/dist/cjs/helpers/response-helper.d.ts +18 -18
  176. package/dist/cjs/helpers/response-helper.js +43 -43
  177. package/dist/cjs/helpers/shopify-helper.d.ts +9 -9
  178. package/dist/cjs/helpers/shopify-helper.js +26 -26
  179. package/dist/cjs/helpers/sqs-utils.d.ts +6 -6
  180. package/dist/cjs/helpers/sqs-utils.js +14 -14
  181. package/dist/cjs/index.d.ts +7 -7
  182. package/dist/cjs/index.js +23 -23
  183. package/dist/cjs/libs/api-router/index.d.ts +2 -2
  184. package/dist/cjs/libs/api-router/index.js +18 -18
  185. package/dist/cjs/libs/api-router/public-api-router.d.ts +3 -3
  186. package/dist/cjs/libs/api-router/public-api-router.js +36 -36
  187. package/dist/cjs/libs/api-router/route-matcher.d.ts +21 -21
  188. package/dist/cjs/libs/api-router/route-matcher.js +36 -36
  189. package/dist/cjs/libs/click-id-parser.d.ts +23 -23
  190. package/dist/cjs/libs/click-id-parser.js +49 -49
  191. package/dist/cjs/libs/compression.d.ts +2 -2
  192. package/dist/cjs/libs/compression.js +33 -33
  193. package/dist/cjs/libs/contacts.d.ts +7 -7
  194. package/dist/cjs/libs/contacts.js +152 -152
  195. package/dist/cjs/libs/cookie.d.ts +17 -17
  196. package/dist/cjs/libs/cookie.js +76 -76
  197. package/dist/cjs/libs/crypto.d.ts +4 -4
  198. package/dist/cjs/libs/crypto.js +25 -25
  199. package/dist/cjs/libs/csv.d.ts +2 -2
  200. package/dist/cjs/libs/csv.js +35 -35
  201. package/dist/cjs/libs/currency.d.ts +1 -1
  202. package/dist/cjs/libs/currency.js +29 -29
  203. package/dist/cjs/libs/dates.d.ts +12 -12
  204. package/dist/cjs/libs/dates.js +96 -96
  205. package/dist/cjs/libs/domain.d.ts +2 -2
  206. package/dist/cjs/libs/domain.js +38 -38
  207. package/dist/cjs/libs/emails.d.ts +8 -8
  208. package/dist/cjs/libs/emails.js +154 -154
  209. package/dist/cjs/libs/http-error.d.ts +21 -21
  210. package/dist/cjs/libs/http-error.js +63 -63
  211. package/dist/cjs/libs/http-status-codes.d.ts +58 -58
  212. package/dist/cjs/libs/http-status-codes.js +62 -62
  213. package/dist/cjs/libs/index.d.ts +19 -19
  214. package/dist/cjs/libs/index.js +35 -35
  215. package/dist/cjs/libs/numbers.d.ts +1 -1
  216. package/dist/cjs/libs/numbers.js +15 -15
  217. package/dist/cjs/libs/referrer-parser/index.d.ts +2 -2
  218. package/dist/cjs/libs/referrer-parser/index.js +18 -18
  219. package/dist/cjs/libs/referrer-parser/referrer-data.d.ts +9 -9
  220. package/dist/cjs/libs/referrer-parser/referrer-data.js +3307 -3307
  221. package/dist/cjs/libs/referrer-parser/referrer-parser-util.d.ts +20 -20
  222. package/dist/cjs/libs/referrer-parser/referrer-parser-util.js +131 -131
  223. package/dist/cjs/libs/strings.d.ts +3 -3
  224. package/dist/cjs/libs/strings.js +46 -46
  225. package/dist/cjs/libs/traits.d.ts +6 -6
  226. package/dist/cjs/libs/traits.js +65 -65
  227. package/dist/cjs/libs/url.d.ts +1 -1
  228. package/dist/cjs/libs/url.js +13 -13
  229. package/dist/cjs/services/acuity-api-service.d.ts +9 -9
  230. package/dist/cjs/services/acuity-api-service.js +73 -73
  231. package/dist/cjs/services/cache/generic-cached-object.d.ts +5 -5
  232. package/dist/cjs/services/cache/generic-cached-object.js +2 -2
  233. package/dist/cjs/services/cache/index.d.ts +1 -1
  234. package/dist/cjs/services/cache/index.js +17 -17
  235. package/dist/cjs/services/cache/product-cache-service.d.ts +21 -21
  236. package/dist/cjs/services/cache/product-cache-service.js +76 -76
  237. package/dist/cjs/services/cost/cost-calculation-types.d.ts +69 -69
  238. package/dist/cjs/services/cost/cost-calculation-types.js +19 -19
  239. package/dist/cjs/services/cost/cost-calculator-service.d.ts +24 -24
  240. package/dist/cjs/services/cost/cost-calculator-service.js +456 -456
  241. package/dist/cjs/services/cost/cost-currency-service.d.ts +6 -6
  242. package/dist/cjs/services/cost/cost-currency-service.js +87 -87
  243. package/dist/cjs/services/cost/cost-filter-service.d.ts +10 -10
  244. package/dist/cjs/services/cost/cost-filter-service.js +121 -121
  245. package/dist/cjs/services/cost/index.d.ts +5 -5
  246. package/dist/cjs/services/cost/index.js +21 -21
  247. package/dist/cjs/services/cost/order-cost/index.d.ts +2 -2
  248. package/dist/cjs/services/cost/order-cost/index.js +18 -18
  249. package/dist/cjs/services/cost/order-cost/order-cost-resolution-service.d.ts +23 -23
  250. package/dist/cjs/services/cost/order-cost/order-cost-resolution-service.js +361 -361
  251. package/dist/cjs/services/cost/order-cost/order-cost-resolution-types.d.ts +37 -37
  252. package/dist/cjs/services/cost/order-cost/order-cost-resolution-types.js +2 -2
  253. package/dist/cjs/services/currency-exchange-rate-lookup-service.d.ts +12 -12
  254. package/dist/cjs/services/currency-exchange-rate-lookup-service.js +94 -94
  255. package/dist/cjs/services/db/accounts-db-service.d.ts +9 -9
  256. package/dist/cjs/services/db/accounts-db-service.js +33 -33
  257. package/dist/cjs/services/db/api-keys-db-service.d.ts +10 -10
  258. package/dist/cjs/services/db/api-keys-db-service.js +36 -36
  259. package/dist/cjs/services/db/contact-enrichments-db-service.d.ts +15 -15
  260. package/dist/cjs/services/db/contact-enrichments-db-service.js +94 -94
  261. package/dist/cjs/services/db/currency-exchange-rates-db-service.d.ts +21 -21
  262. package/dist/cjs/services/db/currency-exchange-rates-db-service.js +39 -39
  263. package/dist/cjs/services/db/custom-measures-db-service.d.ts +14 -14
  264. package/dist/cjs/services/db/custom-measures-db-service.js +48 -48
  265. package/dist/cjs/services/db/destinations-db-service.d.ts +13 -13
  266. package/dist/cjs/services/db/destinations-db-service.js +74 -74
  267. package/dist/cjs/services/db/identity-cache-db-service.d.ts +28 -28
  268. package/dist/cjs/services/db/identity-cache-db-service.js +320 -320
  269. package/dist/cjs/services/db/identity-cache-dynamodb-service.d.ts +44 -44
  270. package/dist/cjs/services/db/identity-cache-dynamodb-service.js +734 -734
  271. package/dist/cjs/services/db/identity-cache-dynamodb-service.js.map +1 -1
  272. package/dist/cjs/services/db/index.d.ts +19 -19
  273. package/dist/cjs/services/db/index.js +35 -35
  274. package/dist/cjs/services/db/log-events-db-service.d.ts +11 -11
  275. package/dist/cjs/services/db/log-events-db-service.js +181 -181
  276. package/dist/cjs/services/db/pixels-db-service.d.ts +8 -8
  277. package/dist/cjs/services/db/pixels-db-service.js +35 -35
  278. package/dist/cjs/services/db/products-db-service-types.d.ts +10 -10
  279. package/dist/cjs/services/db/products-db-service-types.js +2 -2
  280. package/dist/cjs/services/db/products-db-service.d.ts +19 -19
  281. package/dist/cjs/services/db/products-db-service.js +281 -281
  282. package/dist/cjs/services/db/purchasable-contacts-db-service.d.ts +9 -9
  283. package/dist/cjs/services/db/purchasable-contacts-db-service.js +43 -43
  284. package/dist/cjs/services/db/purchased-contacts/index.d.ts +2 -2
  285. package/dist/cjs/services/db/purchased-contacts/index.js +18 -18
  286. package/dist/cjs/services/db/purchased-contacts/purchased-contacts-db-service.d.ts +18 -18
  287. package/dist/cjs/services/db/purchased-contacts/purchased-contacts-db-service.js +152 -152
  288. package/dist/cjs/services/db/purchased-contacts/types.d.ts +11 -11
  289. package/dist/cjs/services/db/purchased-contacts/types.js +2 -2
  290. package/dist/cjs/services/db/shopify-app-installs-db-service.d.ts +10 -10
  291. package/dist/cjs/services/db/shopify-app-installs-db-service.js +52 -52
  292. package/dist/cjs/services/db/shopify-products-cache-db-service.d.ts +16 -16
  293. package/dist/cjs/services/db/shopify-products-cache-db-service.js +73 -73
  294. package/dist/cjs/services/db/subscriptions-db-service.d.ts +11 -11
  295. package/dist/cjs/services/db/subscriptions-db-service.js +38 -38
  296. package/dist/cjs/services/db/tracking-events-db-service.d.ts +21 -21
  297. package/dist/cjs/services/db/tracking-events-db-service.js +188 -188
  298. package/dist/cjs/services/db/user-accounts-db-service.d.ts +7 -7
  299. package/dist/cjs/services/db/user-accounts-db-service.js +17 -17
  300. package/dist/cjs/services/email-verification/contact-email-verification-service.d.ts +7 -7
  301. package/dist/cjs/services/email-verification/contact-email-verification-service.js +101 -101
  302. package/dist/cjs/services/email-verification/email-verification-service.d.ts +19 -19
  303. package/dist/cjs/services/email-verification/email-verification-service.js +131 -131
  304. package/dist/cjs/services/email-verification/index.d.ts +2 -2
  305. package/dist/cjs/services/email-verification/index.js +18 -18
  306. package/dist/cjs/services/eventbridge-integration-service.d.ts +9 -9
  307. package/dist/cjs/services/eventbridge-integration-service.js +28 -28
  308. package/dist/cjs/services/events/index.d.ts +3 -3
  309. package/dist/cjs/services/events/index.js +19 -19
  310. package/dist/cjs/services/events/log-event-service.d.ts +19 -19
  311. package/dist/cjs/services/events/log-event-service.js +77 -77
  312. package/dist/cjs/services/events/metric-event-service.d.ts +9 -9
  313. package/dist/cjs/services/events/metric-event-service.js +49 -49
  314. package/dist/cjs/services/events/tracking-event-sqs-service.d.ts +8 -8
  315. package/dist/cjs/services/events/tracking-event-sqs-service.js +34 -34
  316. package/dist/cjs/services/generic-cache-service.d.ts +7 -7
  317. package/dist/cjs/services/generic-cache-service.js +33 -33
  318. package/dist/cjs/services/index.d.ts +11 -11
  319. package/dist/cjs/services/index.js +27 -27
  320. package/dist/cjs/services/ipdata-lookup-service.d.ts +20 -20
  321. package/dist/cjs/services/ipdata-lookup-service.js +112 -112
  322. package/dist/cjs/services/shopify/index.d.ts +2 -2
  323. package/dist/cjs/services/shopify/index.js +18 -18
  324. package/dist/cjs/services/shopify/products/index.d.ts +1 -1
  325. package/dist/cjs/services/shopify/products/index.js +17 -17
  326. package/dist/cjs/services/shopify/products/shopify-products-serviceV2.d.ts +17 -17
  327. package/dist/cjs/services/shopify/products/shopify-products-serviceV2.js +112 -112
  328. package/dist/cjs/services/shopify/shopify-graphql-transformer.d.ts +8 -8
  329. package/dist/cjs/services/shopify/shopify-graphql-transformer.js +141 -141
  330. package/dist/cjs/types/acuity-types.d.ts +74 -74
  331. package/dist/cjs/types/acuity-types.js +2 -2
  332. package/dist/cjs/types/api-response.d.ts +6 -6
  333. package/dist/cjs/types/api-response.js +2 -2
  334. package/dist/cjs/types/index.d.ts +4 -4
  335. package/dist/cjs/types/index.js +33 -33
  336. package/dist/cjs/types/internal-events/event-detail-types.d.ts +20 -20
  337. package/dist/cjs/types/internal-events/event-detail-types.js +27 -27
  338. package/dist/cjs/types/internal-events/index.d.ts +1 -1
  339. package/dist/cjs/types/internal-events/index.js +17 -17
  340. package/dist/cjs/types/shopify-graphql-types/admin.generated.d.ts +123 -123
  341. package/dist/cjs/types/shopify-graphql-types/admin.generated.js +2 -2
  342. package/dist/cjs/types/shopify-graphql-types/admin.types.d.ts +26289 -26289
  343. package/dist/cjs/types/shopify-graphql-types/admin.types.js +5311 -5311
  344. package/dist/cjs/types/shopify-graphql-types/index.d.ts +2 -2
  345. package/dist/cjs/types/shopify-graphql-types/index.js +18 -18
  346. package/dist/cjs/types/shopify-rest-types.d.ts +767 -767
  347. package/dist/cjs/types/shopify-rest-types.js +2 -2
  348. package/dist/cjs/utils/compression.d.ts +36 -36
  349. package/dist/cjs/utils/compression.js +198 -198
  350. package/dist/cjs/utils/custom-measure-formula-utils.d.ts +6 -6
  351. package/dist/cjs/utils/custom-measure-formula-utils.js +209 -209
  352. package/dist/cjs/utils/index.d.ts +4 -4
  353. package/dist/cjs/utils/index.js +20 -20
  354. package/dist/cjs/utils/retry-envelope.d.ts +12 -12
  355. package/dist/cjs/utils/retry-envelope.js +28 -28
  356. package/dist/cjs/utils/size.d.ts +2 -2
  357. package/dist/cjs/utils/size.js +49 -49
  358. package/dist/esm/__tests__/clients/acuity-client.spec.d.ts +1 -1
  359. package/dist/esm/__tests__/clients/acuity-client.spec.js +41 -41
  360. package/dist/esm/__tests__/clients/cross-platform-compression.spec.d.ts +1 -1
  361. package/dist/esm/__tests__/clients/cross-platform-compression.spec.js +329 -329
  362. package/dist/esm/__tests__/clients/dynamodb-client.spec.d.ts +1 -1
  363. package/dist/esm/__tests__/clients/dynamodb-client.spec.js +192 -192
  364. package/dist/esm/__tests__/clients/sqs-bundled-client.spec.d.ts +1 -1
  365. package/dist/esm/__tests__/clients/sqs-bundled-client.spec.js +906 -906
  366. package/dist/esm/__tests__/clients/sqs-bundling-contracts.spec.d.ts +1 -1
  367. package/dist/esm/__tests__/clients/sqs-bundling-contracts.spec.js +538 -538
  368. package/dist/esm/__tests__/clients/sqs-client.spec.d.ts +1 -1
  369. package/dist/esm/__tests__/clients/sqs-client.spec.js +189 -189
  370. package/dist/esm/__tests__/clients/sqs-unbundle.spec.d.ts +1 -1
  371. package/dist/esm/__tests__/clients/sqs-unbundle.spec.js +1355 -1355
  372. package/dist/esm/__tests__/db/contact-enrichments-db-service.spec.d.ts +1 -1
  373. package/dist/esm/__tests__/db/contact-enrichments-db-service.spec.js +66 -66
  374. package/dist/esm/__tests__/db/destinations-db-service.spec.d.ts +1 -1
  375. package/dist/esm/__tests__/db/destinations-db-service.spec.js +123 -123
  376. package/dist/esm/__tests__/db/products-db-service.spec.d.ts +1 -1
  377. package/dist/esm/__tests__/db/products-db-service.spec.js +87 -87
  378. package/dist/esm/__tests__/db/shared-read-db-services.spec.d.ts +1 -1
  379. package/dist/esm/__tests__/db/shared-read-db-services.spec.js +87 -87
  380. package/dist/esm/__tests__/db/shopify-app-installs-db-service.spec.d.ts +1 -1
  381. package/dist/esm/__tests__/db/shopify-app-installs-db-service.spec.js +102 -102
  382. package/dist/esm/__tests__/db/subscriptions-db-service.spec.d.ts +1 -1
  383. package/dist/esm/__tests__/db/subscriptions-db-service.spec.js +93 -93
  384. package/dist/esm/__tests__/db/user-accounts-db-service.spec.d.ts +1 -1
  385. package/dist/esm/__tests__/db/user-accounts-db-service.spec.js +74 -74
  386. package/dist/esm/__tests__/helpers/account-users-helper.spec.d.ts +1 -1
  387. package/dist/esm/__tests__/helpers/account-users-helper.spec.js +218 -218
  388. package/dist/esm/__tests__/helpers/acuity-helper.spec.d.ts +1 -1
  389. package/dist/esm/__tests__/helpers/acuity-helper.spec.js +67 -67
  390. package/dist/esm/__tests__/helpers/api-key-auth-helper.spec.d.ts +1 -1
  391. package/dist/esm/__tests__/helpers/api-key-auth-helper.spec.js +80 -80
  392. package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.d.ts +1 -1
  393. package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.js +674 -674
  394. package/dist/esm/__tests__/identity-cache/identity-cache-dynamodb-service.spec.d.ts +1 -1
  395. package/dist/esm/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js +1138 -1138
  396. package/dist/esm/__tests__/identity-cache/identity-cache-tier-routing.spec.d.ts +1 -1
  397. package/dist/esm/__tests__/identity-cache/identity-cache-tier-routing.spec.js +849 -849
  398. package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.d.ts +1 -1
  399. package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.js +1058 -1058
  400. package/dist/esm/__tests__/identity-cache/volatile-traits-optimization.spec.d.ts +1 -1
  401. package/dist/esm/__tests__/identity-cache/volatile-traits-optimization.spec.js +816 -816
  402. package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.d.ts +1 -1
  403. package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.js +582 -582
  404. package/dist/esm/__tests__/libs/compress-decompress.spec.d.ts +1 -1
  405. package/dist/esm/__tests__/libs/compress-decompress.spec.js +14 -14
  406. package/dist/esm/__tests__/libs/contacts.spec.d.ts +1 -1
  407. package/dist/esm/__tests__/libs/contacts.spec.js +292 -292
  408. package/dist/esm/__tests__/libs/currency.spec.d.ts +1 -1
  409. package/dist/esm/__tests__/libs/currency.spec.js +218 -218
  410. package/dist/esm/__tests__/libs/dates.spec.d.ts +1 -1
  411. package/dist/esm/__tests__/libs/dates.spec.js +128 -128
  412. package/dist/esm/__tests__/libs/domain.spec.d.ts +1 -1
  413. package/dist/esm/__tests__/libs/domain.spec.js +105 -105
  414. package/dist/esm/__tests__/libs/numbers.spec.d.ts +1 -1
  415. package/dist/esm/__tests__/libs/numbers.spec.js +259 -259
  416. package/dist/esm/__tests__/s3-client/s3-client.spec.d.ts +1 -1
  417. package/dist/esm/__tests__/s3-client/s3-client.spec.js +31 -31
  418. package/dist/esm/__tests__/services/acuity-api-service.spec.d.ts +1 -1
  419. package/dist/esm/__tests__/services/acuity-api-service.spec.js +69 -69
  420. package/dist/esm/__tests__/services/cost/cost-calculation-types.spec.d.ts +1 -1
  421. package/dist/esm/__tests__/services/cost/cost-calculation-types.spec.js +21 -21
  422. package/dist/esm/__tests__/services/cost/cost-calculator-service.spec.d.ts +1 -1
  423. package/dist/esm/__tests__/services/cost/cost-calculator-service.spec.js +3317 -3317
  424. package/dist/esm/__tests__/services/cost/cost-currency-service.spec.d.ts +1 -1
  425. package/dist/esm/__tests__/services/cost/cost-currency-service.spec.js +112 -112
  426. package/dist/esm/__tests__/services/cost/cost-filter-service.spec.d.ts +1 -1
  427. package/dist/esm/__tests__/services/cost/cost-filter-service.spec.js +466 -466
  428. package/dist/esm/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.d.ts +1 -1
  429. package/dist/esm/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.js +204 -204
  430. package/dist/esm/__tests__/services/currency-exchange-rate-lookup-service.spec.d.ts +1 -1
  431. package/dist/esm/__tests__/services/currency-exchange-rate-lookup-service.spec.js +32 -32
  432. package/dist/esm/__tests__/services/email-verification/contact-email-verification-service.spec.d.ts +1 -1
  433. package/dist/esm/__tests__/services/email-verification/contact-email-verification-service.spec.js +91 -91
  434. package/dist/esm/__tests__/services/email-verification/email-verification-service.spec.d.ts +1 -1
  435. package/dist/esm/__tests__/services/email-verification/email-verification-service.spec.js +55 -55
  436. package/dist/esm/__tests__/shopify/shopify-graphql-transformer.spec.d.ts +1 -1
  437. package/dist/esm/__tests__/shopify/shopify-graphql-transformer.spec.js +33 -33
  438. package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.d.ts +1 -1
  439. package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.js +156 -156
  440. package/dist/esm/__tests__/unit/libs/api-router/route-matcher.spec.d.ts +1 -1
  441. package/dist/esm/__tests__/unit/libs/api-router/route-matcher.spec.js +67 -67
  442. package/dist/esm/__tests__/utils/custom-measure-formula-utils.spec.d.ts +1 -1
  443. package/dist/esm/__tests__/utils/custom-measure-formula-utils.spec.js +137 -137
  444. package/dist/esm/clients/generic/cognito-client.d.ts +23 -23
  445. package/dist/esm/clients/generic/cognito-client.js +204 -204
  446. package/dist/esm/clients/generic/dynamodb-client.d.ts +20 -20
  447. package/dist/esm/clients/generic/dynamodb-client.js +231 -231
  448. package/dist/esm/clients/generic/eventbridge-client.d.ts +14 -14
  449. package/dist/esm/clients/generic/eventbridge-client.js +47 -47
  450. package/dist/esm/clients/generic/http-client.d.ts +14 -14
  451. package/dist/esm/clients/generic/http-client.js +53 -53
  452. package/dist/esm/clients/generic/index.d.ts +13 -13
  453. package/dist/esm/clients/generic/index.js +13 -13
  454. package/dist/esm/clients/generic/lambda-invoke-client.d.ts +10 -10
  455. package/dist/esm/clients/generic/lambda-invoke-client.js +35 -35
  456. package/dist/esm/clients/generic/location-client.d.ts +8 -8
  457. package/dist/esm/clients/generic/location-client.js +27 -27
  458. package/dist/esm/clients/generic/redis-client.d.ts +33 -33
  459. package/dist/esm/clients/generic/redis-client.js +184 -184
  460. package/dist/esm/clients/generic/s3-client.d.ts +23 -23
  461. package/dist/esm/clients/generic/s3-client.js +209 -209
  462. package/dist/esm/clients/generic/singlestore-db-client.d.ts +14 -14
  463. package/dist/esm/clients/generic/singlestore-db-client.js +40 -40
  464. package/dist/esm/clients/generic/sqs-bundled-client.d.ts +15 -15
  465. package/dist/esm/clients/generic/sqs-bundled-client.js +307 -307
  466. package/dist/esm/clients/generic/sqs-bundled-client.types.d.ts +53 -53
  467. package/dist/esm/clients/generic/sqs-bundled-client.types.js +14 -14
  468. package/dist/esm/clients/generic/sqs-client.d.ts +53 -53
  469. package/dist/esm/clients/generic/sqs-client.js +281 -281
  470. package/dist/esm/clients/generic/sqs-unbundle.d.ts +32 -32
  471. package/dist/esm/clients/generic/sqs-unbundle.js +137 -137
  472. package/dist/esm/clients/index.d.ts +3 -3
  473. package/dist/esm/clients/index.js +3 -3
  474. package/dist/esm/clients/internal-api/accounts-client.d.ts +91 -91
  475. package/dist/esm/clients/internal-api/accounts-client.js +125 -125
  476. package/dist/esm/clients/internal-api/cache-lambda-client.d.ts +26 -26
  477. package/dist/esm/clients/internal-api/cache-lambda-client.js +85 -85
  478. package/dist/esm/clients/internal-api/db-management-client.d.ts +18 -18
  479. package/dist/esm/clients/internal-api/db-management-client.js +32 -32
  480. package/dist/esm/clients/internal-api/destinations-client.d.ts +34 -34
  481. package/dist/esm/clients/internal-api/destinations-client.js +75 -75
  482. package/dist/esm/clients/internal-api/event-collector-client.d.ts +20 -20
  483. package/dist/esm/clients/internal-api/event-collector-client.js +32 -32
  484. package/dist/esm/clients/internal-api/identity-client.d.ts +31 -31
  485. package/dist/esm/clients/internal-api/identity-client.js +87 -87
  486. package/dist/esm/clients/internal-api/index.d.ts +9 -9
  487. package/dist/esm/clients/internal-api/index.js +9 -9
  488. package/dist/esm/clients/internal-api/shopify-app-install-client.d.ts +37 -37
  489. package/dist/esm/clients/internal-api/shopify-app-install-client.js +77 -77
  490. package/dist/esm/clients/internal-api/subscriptions-client.d.ts +26 -26
  491. package/dist/esm/clients/internal-api/subscriptions-client.js +73 -73
  492. package/dist/esm/clients/internal-api/users-auth-client.d.ts +35 -35
  493. package/dist/esm/clients/internal-api/users-auth-client.js +106 -106
  494. package/dist/esm/clients/third-party/acuity-client.d.ts +10 -10
  495. package/dist/esm/clients/third-party/acuity-client.js +36 -36
  496. package/dist/esm/clients/third-party/emailable-client.d.ts +7 -7
  497. package/dist/esm/clients/third-party/emailable-client.js +21 -21
  498. package/dist/esm/clients/third-party/exchange-rate-api-client.d.ts +17 -17
  499. package/dist/esm/clients/third-party/exchange-rate-api-client.js +15 -15
  500. package/dist/esm/clients/third-party/index.d.ts +5 -5
  501. package/dist/esm/clients/third-party/index.js +5 -5
  502. package/dist/esm/clients/third-party/loops-client.d.ts +10 -10
  503. package/dist/esm/clients/third-party/loops-client.js +26 -26
  504. package/dist/esm/clients/third-party/shopify/graphql-order-queries.d.ts +25 -25
  505. package/dist/esm/clients/third-party/shopify/graphql-order-queries.js +1 -1
  506. package/dist/esm/clients/third-party/shopify/graphql-product-queries.d.ts +2 -2
  507. package/dist/esm/clients/third-party/shopify/graphql-product-queries.js +2 -2
  508. package/dist/esm/clients/third-party/shopify/shopify-graphql-client.d.ts +10 -10
  509. package/dist/esm/clients/third-party/shopify/shopify-graphql-client.js +157 -157
  510. package/dist/esm/clients/third-party/shopify-client.d.ts +29 -29
  511. package/dist/esm/clients/third-party/shopify-client.js +142 -142
  512. package/dist/esm/constants/index.d.ts +1 -1
  513. package/dist/esm/constants/index.js +1 -1
  514. package/dist/esm/constants/sqs.d.ts +20 -20
  515. package/dist/esm/constants/sqs.js +22 -22
  516. package/dist/esm/helpers/account-users-helper.d.ts +2 -2
  517. package/dist/esm/helpers/account-users-helper.js +18 -18
  518. package/dist/esm/helpers/acuity-helper.d.ts +4 -4
  519. package/dist/esm/helpers/acuity-helper.js +51 -51
  520. package/dist/esm/helpers/api-key-auth-helper.d.ts +9 -9
  521. package/dist/esm/helpers/api-key-auth-helper.js +35 -35
  522. package/dist/esm/helpers/api-key-authorizer-helper.d.ts +36 -36
  523. package/dist/esm/helpers/api-key-authorizer-helper.js +83 -83
  524. package/dist/esm/helpers/identity-cache-helper.d.ts +30 -30
  525. package/dist/esm/helpers/identity-cache-helper.js +248 -248
  526. package/dist/esm/helpers/index.d.ts +10 -10
  527. package/dist/esm/helpers/index.js +10 -10
  528. package/dist/esm/helpers/input-validation-helper.d.ts +3 -3
  529. package/dist/esm/helpers/input-validation-helper.js +18 -18
  530. package/dist/esm/helpers/logging-helper.d.ts +16 -16
  531. package/dist/esm/helpers/logging-helper.js +56 -56
  532. package/dist/esm/helpers/response-helper.d.ts +18 -18
  533. package/dist/esm/helpers/response-helper.js +37 -37
  534. package/dist/esm/helpers/shopify-helper.d.ts +9 -9
  535. package/dist/esm/helpers/shopify-helper.js +21 -21
  536. package/dist/esm/helpers/sqs-utils.d.ts +6 -6
  537. package/dist/esm/helpers/sqs-utils.js +9 -9
  538. package/dist/esm/index.d.ts +7 -7
  539. package/dist/esm/index.js +7 -7
  540. package/dist/esm/libs/api-router/index.d.ts +2 -2
  541. package/dist/esm/libs/api-router/index.js +2 -2
  542. package/dist/esm/libs/api-router/public-api-router.d.ts +3 -3
  543. package/dist/esm/libs/api-router/public-api-router.js +32 -32
  544. package/dist/esm/libs/api-router/route-matcher.d.ts +21 -21
  545. package/dist/esm/libs/api-router/route-matcher.js +30 -30
  546. package/dist/esm/libs/click-id-parser.d.ts +23 -23
  547. package/dist/esm/libs/click-id-parser.js +45 -45
  548. package/dist/esm/libs/compression.d.ts +2 -2
  549. package/dist/esm/libs/compression.js +25 -25
  550. package/dist/esm/libs/contacts.d.ts +7 -7
  551. package/dist/esm/libs/contacts.js +143 -143
  552. package/dist/esm/libs/cookie.d.ts +17 -17
  553. package/dist/esm/libs/cookie.js +70 -70
  554. package/dist/esm/libs/crypto.d.ts +4 -4
  555. package/dist/esm/libs/crypto.js +15 -15
  556. package/dist/esm/libs/csv.d.ts +2 -2
  557. package/dist/esm/libs/csv.js +30 -30
  558. package/dist/esm/libs/currency.d.ts +1 -1
  559. package/dist/esm/libs/currency.js +22 -22
  560. package/dist/esm/libs/dates.d.ts +12 -12
  561. package/dist/esm/libs/dates.js +83 -83
  562. package/dist/esm/libs/domain.d.ts +2 -2
  563. package/dist/esm/libs/domain.js +33 -33
  564. package/dist/esm/libs/emails.d.ts +8 -8
  565. package/dist/esm/libs/emails.js +146 -146
  566. package/dist/esm/libs/http-error.d.ts +21 -21
  567. package/dist/esm/libs/http-error.js +59 -59
  568. package/dist/esm/libs/http-status-codes.d.ts +58 -58
  569. package/dist/esm/libs/http-status-codes.js +59 -59
  570. package/dist/esm/libs/index.d.ts +19 -19
  571. package/dist/esm/libs/index.js +19 -19
  572. package/dist/esm/libs/numbers.d.ts +1 -1
  573. package/dist/esm/libs/numbers.js +11 -11
  574. package/dist/esm/libs/referrer-parser/index.d.ts +2 -2
  575. package/dist/esm/libs/referrer-parser/index.js +2 -2
  576. package/dist/esm/libs/referrer-parser/referrer-data.d.ts +9 -9
  577. package/dist/esm/libs/referrer-parser/referrer-data.js +3304 -3304
  578. package/dist/esm/libs/referrer-parser/referrer-parser-util.d.ts +20 -20
  579. package/dist/esm/libs/referrer-parser/referrer-parser-util.js +124 -124
  580. package/dist/esm/libs/strings.d.ts +3 -3
  581. package/dist/esm/libs/strings.js +40 -40
  582. package/dist/esm/libs/traits.d.ts +6 -6
  583. package/dist/esm/libs/traits.js +54 -54
  584. package/dist/esm/libs/url.d.ts +1 -1
  585. package/dist/esm/libs/url.js +9 -9
  586. package/dist/esm/services/acuity-api-service.d.ts +9 -9
  587. package/dist/esm/services/acuity-api-service.js +69 -69
  588. package/dist/esm/services/cache/generic-cached-object.d.ts +5 -5
  589. package/dist/esm/services/cache/generic-cached-object.js +1 -1
  590. package/dist/esm/services/cache/index.d.ts +1 -1
  591. package/dist/esm/services/cache/index.js +1 -1
  592. package/dist/esm/services/cache/product-cache-service.d.ts +21 -21
  593. package/dist/esm/services/cache/product-cache-service.js +68 -68
  594. package/dist/esm/services/cost/cost-calculation-types.d.ts +69 -69
  595. package/dist/esm/services/cost/cost-calculation-types.js +15 -15
  596. package/dist/esm/services/cost/cost-calculator-service.d.ts +24 -24
  597. package/dist/esm/services/cost/cost-calculator-service.js +450 -450
  598. package/dist/esm/services/cost/cost-currency-service.d.ts +6 -6
  599. package/dist/esm/services/cost/cost-currency-service.js +84 -84
  600. package/dist/esm/services/cost/cost-filter-service.d.ts +10 -10
  601. package/dist/esm/services/cost/cost-filter-service.js +118 -118
  602. package/dist/esm/services/cost/index.d.ts +5 -5
  603. package/dist/esm/services/cost/index.js +5 -5
  604. package/dist/esm/services/cost/order-cost/index.d.ts +2 -2
  605. package/dist/esm/services/cost/order-cost/index.js +2 -2
  606. package/dist/esm/services/cost/order-cost/order-cost-resolution-service.d.ts +23 -23
  607. package/dist/esm/services/cost/order-cost/order-cost-resolution-service.js +355 -355
  608. package/dist/esm/services/cost/order-cost/order-cost-resolution-types.d.ts +37 -37
  609. package/dist/esm/services/cost/order-cost/order-cost-resolution-types.js +1 -1
  610. package/dist/esm/services/currency-exchange-rate-lookup-service.d.ts +12 -12
  611. package/dist/esm/services/currency-exchange-rate-lookup-service.js +90 -90
  612. package/dist/esm/services/db/accounts-db-service.d.ts +9 -9
  613. package/dist/esm/services/db/accounts-db-service.js +29 -29
  614. package/dist/esm/services/db/api-keys-db-service.d.ts +10 -10
  615. package/dist/esm/services/db/api-keys-db-service.js +32 -32
  616. package/dist/esm/services/db/contact-enrichments-db-service.d.ts +15 -15
  617. package/dist/esm/services/db/contact-enrichments-db-service.js +90 -90
  618. package/dist/esm/services/db/currency-exchange-rates-db-service.d.ts +21 -21
  619. package/dist/esm/services/db/currency-exchange-rates-db-service.js +35 -35
  620. package/dist/esm/services/db/custom-measures-db-service.d.ts +14 -14
  621. package/dist/esm/services/db/custom-measures-db-service.js +44 -44
  622. package/dist/esm/services/db/destinations-db-service.d.ts +13 -13
  623. package/dist/esm/services/db/destinations-db-service.js +70 -70
  624. package/dist/esm/services/db/identity-cache-db-service.d.ts +28 -28
  625. package/dist/esm/services/db/identity-cache-db-service.js +313 -313
  626. package/dist/esm/services/db/identity-cache-dynamodb-service.d.ts +44 -44
  627. package/dist/esm/services/db/identity-cache-dynamodb-service.js +727 -727
  628. package/dist/esm/services/db/identity-cache-dynamodb-service.js.map +1 -1
  629. package/dist/esm/services/db/index.d.ts +19 -19
  630. package/dist/esm/services/db/index.js +19 -19
  631. package/dist/esm/services/db/log-events-db-service.d.ts +11 -11
  632. package/dist/esm/services/db/log-events-db-service.js +177 -177
  633. package/dist/esm/services/db/pixels-db-service.d.ts +8 -8
  634. package/dist/esm/services/db/pixels-db-service.js +31 -31
  635. package/dist/esm/services/db/products-db-service-types.d.ts +10 -10
  636. package/dist/esm/services/db/products-db-service-types.js +1 -1
  637. package/dist/esm/services/db/products-db-service.d.ts +19 -19
  638. package/dist/esm/services/db/products-db-service.js +277 -277
  639. package/dist/esm/services/db/purchasable-contacts-db-service.d.ts +9 -9
  640. package/dist/esm/services/db/purchasable-contacts-db-service.js +39 -39
  641. package/dist/esm/services/db/purchased-contacts/index.d.ts +2 -2
  642. package/dist/esm/services/db/purchased-contacts/index.js +2 -2
  643. package/dist/esm/services/db/purchased-contacts/purchased-contacts-db-service.d.ts +18 -18
  644. package/dist/esm/services/db/purchased-contacts/purchased-contacts-db-service.js +148 -148
  645. package/dist/esm/services/db/purchased-contacts/types.d.ts +11 -11
  646. package/dist/esm/services/db/purchased-contacts/types.js +1 -1
  647. package/dist/esm/services/db/shopify-app-installs-db-service.d.ts +10 -10
  648. package/dist/esm/services/db/shopify-app-installs-db-service.js +48 -48
  649. package/dist/esm/services/db/shopify-products-cache-db-service.d.ts +16 -16
  650. package/dist/esm/services/db/shopify-products-cache-db-service.js +66 -66
  651. package/dist/esm/services/db/subscriptions-db-service.d.ts +11 -11
  652. package/dist/esm/services/db/subscriptions-db-service.js +34 -34
  653. package/dist/esm/services/db/tracking-events-db-service.d.ts +21 -21
  654. package/dist/esm/services/db/tracking-events-db-service.js +184 -184
  655. package/dist/esm/services/db/user-accounts-db-service.d.ts +7 -7
  656. package/dist/esm/services/db/user-accounts-db-service.js +13 -13
  657. package/dist/esm/services/email-verification/contact-email-verification-service.d.ts +7 -7
  658. package/dist/esm/services/email-verification/contact-email-verification-service.js +97 -97
  659. package/dist/esm/services/email-verification/email-verification-service.d.ts +19 -19
  660. package/dist/esm/services/email-verification/email-verification-service.js +127 -127
  661. package/dist/esm/services/email-verification/index.d.ts +2 -2
  662. package/dist/esm/services/email-verification/index.js +2 -2
  663. package/dist/esm/services/eventbridge-integration-service.d.ts +9 -9
  664. package/dist/esm/services/eventbridge-integration-service.js +24 -24
  665. package/dist/esm/services/events/index.d.ts +3 -3
  666. package/dist/esm/services/events/index.js +3 -3
  667. package/dist/esm/services/events/log-event-service.d.ts +19 -19
  668. package/dist/esm/services/events/log-event-service.js +73 -73
  669. package/dist/esm/services/events/metric-event-service.d.ts +9 -9
  670. package/dist/esm/services/events/metric-event-service.js +45 -45
  671. package/dist/esm/services/events/tracking-event-sqs-service.d.ts +8 -8
  672. package/dist/esm/services/events/tracking-event-sqs-service.js +30 -30
  673. package/dist/esm/services/generic-cache-service.d.ts +7 -7
  674. package/dist/esm/services/generic-cache-service.js +29 -29
  675. package/dist/esm/services/index.d.ts +11 -11
  676. package/dist/esm/services/index.js +11 -11
  677. package/dist/esm/services/ipdata-lookup-service.d.ts +20 -20
  678. package/dist/esm/services/ipdata-lookup-service.js +108 -108
  679. package/dist/esm/services/shopify/index.d.ts +2 -2
  680. package/dist/esm/services/shopify/index.js +2 -2
  681. package/dist/esm/services/shopify/products/index.d.ts +1 -1
  682. package/dist/esm/services/shopify/products/index.js +1 -1
  683. package/dist/esm/services/shopify/products/shopify-products-serviceV2.d.ts +17 -17
  684. package/dist/esm/services/shopify/products/shopify-products-serviceV2.js +108 -108
  685. package/dist/esm/services/shopify/shopify-graphql-transformer.d.ts +8 -8
  686. package/dist/esm/services/shopify/shopify-graphql-transformer.js +138 -138
  687. package/dist/esm/types/acuity-types.d.ts +74 -74
  688. package/dist/esm/types/acuity-types.js +1 -1
  689. package/dist/esm/types/api-response.d.ts +6 -6
  690. package/dist/esm/types/api-response.js +1 -1
  691. package/dist/esm/types/index.d.ts +4 -4
  692. package/dist/esm/types/index.js +4 -4
  693. package/dist/esm/types/internal-events/event-detail-types.d.ts +20 -20
  694. package/dist/esm/types/internal-events/event-detail-types.js +24 -24
  695. package/dist/esm/types/internal-events/index.d.ts +1 -1
  696. package/dist/esm/types/internal-events/index.js +1 -1
  697. package/dist/esm/types/shopify-graphql-types/admin.generated.d.ts +123 -123
  698. package/dist/esm/types/shopify-graphql-types/admin.generated.js +1 -1
  699. package/dist/esm/types/shopify-graphql-types/admin.types.d.ts +26289 -26289
  700. package/dist/esm/types/shopify-graphql-types/admin.types.js +5299 -5299
  701. package/dist/esm/types/shopify-graphql-types/index.d.ts +2 -2
  702. package/dist/esm/types/shopify-graphql-types/index.js +2 -2
  703. package/dist/esm/types/shopify-rest-types.d.ts +767 -767
  704. package/dist/esm/types/shopify-rest-types.js +1 -1
  705. package/dist/esm/utils/compression.d.ts +36 -36
  706. package/dist/esm/utils/compression.js +187 -187
  707. package/dist/esm/utils/custom-measure-formula-utils.d.ts +6 -6
  708. package/dist/esm/utils/custom-measure-formula-utils.js +201 -201
  709. package/dist/esm/utils/index.d.ts +4 -4
  710. package/dist/esm/utils/index.js +4 -4
  711. package/dist/esm/utils/retry-envelope.d.ts +12 -12
  712. package/dist/esm/utils/retry-envelope.js +22 -22
  713. package/dist/esm/utils/size.d.ts +2 -2
  714. package/dist/esm/utils/size.js +44 -44
  715. package/package.json +134 -134
@@ -1,735 +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('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;
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.debug(`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;
735
735
  //# sourceMappingURL=identity-cache-dynamodb-service.js.map