@adtrackify/at-service-common 3.19.25 → 4.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (761) hide show
  1. package/dist/cjs/__tests__/clients/acuity-client.spec.d.ts +1 -1
  2. package/dist/cjs/__tests__/clients/acuity-client.spec.js +43 -43
  3. package/dist/cjs/__tests__/clients/cross-platform-compression.spec.d.ts +1 -1
  4. package/dist/cjs/__tests__/clients/cross-platform-compression.spec.js +354 -354
  5. package/dist/cjs/__tests__/clients/dynamodb-client.spec.d.ts +1 -1
  6. package/dist/cjs/__tests__/clients/dynamodb-client.spec.js +194 -194
  7. package/dist/cjs/__tests__/clients/sqs-bundled-client.spec.d.ts +1 -1
  8. package/dist/cjs/__tests__/clients/sqs-bundled-client.spec.js +931 -931
  9. package/dist/cjs/__tests__/clients/sqs-bundling-contracts.spec.d.ts +1 -1
  10. package/dist/cjs/__tests__/clients/sqs-bundling-contracts.spec.js +563 -563
  11. package/dist/cjs/__tests__/clients/sqs-client.spec.d.ts +1 -1
  12. package/dist/cjs/__tests__/clients/sqs-client.spec.js +191 -191
  13. package/dist/cjs/__tests__/clients/sqs-unbundle.spec.d.ts +1 -1
  14. package/dist/cjs/__tests__/clients/sqs-unbundle.spec.js +1357 -1357
  15. package/dist/cjs/__tests__/db/contact-enrichments-db-service.spec.d.ts +1 -1
  16. package/dist/cjs/__tests__/db/contact-enrichments-db-service.spec.js +68 -68
  17. package/dist/cjs/__tests__/db/destinations-db-service.spec.d.ts +1 -1
  18. package/dist/cjs/__tests__/db/destinations-db-service.spec.js +125 -125
  19. package/dist/cjs/__tests__/db/shared-read-db-services.spec.d.ts +1 -1
  20. package/dist/cjs/__tests__/db/shared-read-db-services.spec.js +89 -89
  21. package/dist/cjs/__tests__/db/shopify-app-installs-db-service.spec.d.ts +1 -1
  22. package/dist/cjs/__tests__/db/shopify-app-installs-db-service.spec.js +104 -104
  23. package/dist/cjs/__tests__/db/subscriptions-db-service.spec.d.ts +1 -1
  24. package/dist/cjs/__tests__/db/subscriptions-db-service.spec.js +95 -95
  25. package/dist/cjs/__tests__/db/user-accounts-db-service.spec.d.ts +1 -1
  26. package/dist/cjs/__tests__/db/user-accounts-db-service.spec.js +76 -76
  27. package/dist/cjs/__tests__/helpers/account-users-helper.spec.d.ts +1 -1
  28. package/dist/cjs/__tests__/helpers/account-users-helper.spec.js +220 -220
  29. package/dist/cjs/__tests__/helpers/acuity-helper.spec.d.ts +1 -1
  30. package/dist/cjs/__tests__/helpers/acuity-helper.spec.js +69 -69
  31. package/dist/cjs/__tests__/helpers/api-key-auth-helper.spec.d.ts +1 -1
  32. package/dist/cjs/__tests__/helpers/api-key-auth-helper.spec.js +82 -82
  33. package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.d.ts +1 -1
  34. package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.js +676 -674
  35. package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.js.map +1 -1
  36. package/dist/cjs/__tests__/identity-cache/identity-cache-dynamodb-service.spec.d.ts +1 -1
  37. package/dist/cjs/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js +1140 -1140
  38. package/dist/cjs/__tests__/{db/products-db-service.spec.d.ts → identity-cache/identity-cache-tier-routing.spec.d.ts} +1 -1
  39. package/dist/cjs/__tests__/identity-cache/identity-cache-tier-routing.spec.js +852 -0
  40. package/dist/cjs/__tests__/identity-cache/identity-cache-tier-routing.spec.js.map +1 -0
  41. package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.d.ts +1 -1
  42. package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.js +1060 -588
  43. package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.js.map +1 -1
  44. package/dist/cjs/__tests__/{services/cost/cost-calculator-service.spec.d.ts → identity-cache/volatile-traits-optimization.spec.d.ts} +1 -1
  45. package/dist/cjs/__tests__/identity-cache/volatile-traits-optimization.spec.js +819 -0
  46. package/dist/cjs/__tests__/identity-cache/volatile-traits-optimization.spec.js.map +1 -0
  47. package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.d.ts +1 -1
  48. package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.js +584 -584
  49. package/dist/cjs/__tests__/libs/compress-decompress.spec.d.ts +1 -1
  50. package/dist/cjs/__tests__/libs/compress-decompress.spec.js +16 -16
  51. package/dist/cjs/__tests__/libs/contacts.spec.d.ts +1 -1
  52. package/dist/cjs/__tests__/libs/contacts.spec.js +294 -294
  53. package/dist/cjs/__tests__/libs/currency.spec.d.ts +1 -1
  54. package/dist/cjs/__tests__/libs/currency.spec.js +220 -220
  55. package/dist/cjs/__tests__/libs/dates.spec.d.ts +1 -1
  56. package/dist/cjs/__tests__/libs/dates.spec.js +130 -130
  57. package/dist/cjs/__tests__/libs/domain.spec.d.ts +1 -1
  58. package/dist/cjs/__tests__/libs/domain.spec.js +107 -107
  59. package/dist/cjs/__tests__/libs/numbers.spec.d.ts +1 -1
  60. package/dist/cjs/__tests__/libs/numbers.spec.js +261 -261
  61. package/dist/cjs/__tests__/s3-client/s3-client.spec.d.ts +1 -1
  62. package/dist/cjs/__tests__/s3-client/s3-client.spec.js +33 -33
  63. package/dist/cjs/__tests__/services/acuity-api-service.spec.d.ts +1 -1
  64. package/dist/cjs/__tests__/services/acuity-api-service.spec.js +71 -71
  65. package/dist/cjs/__tests__/services/email-verification/contact-email-verification-service.spec.d.ts +1 -1
  66. package/dist/cjs/__tests__/services/email-verification/contact-email-verification-service.spec.js +93 -93
  67. package/dist/cjs/__tests__/services/email-verification/email-verification-service.spec.d.ts +1 -1
  68. package/dist/cjs/__tests__/services/email-verification/email-verification-service.spec.js +57 -57
  69. package/dist/cjs/__tests__/shopify/shopify-graphql-transformer.spec.d.ts +1 -1
  70. package/dist/cjs/__tests__/shopify/shopify-graphql-transformer.spec.js +35 -35
  71. package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.d.ts +1 -1
  72. package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.js +181 -181
  73. package/dist/cjs/__tests__/unit/libs/api-router/route-matcher.spec.d.ts +1 -1
  74. package/dist/cjs/__tests__/unit/libs/api-router/route-matcher.spec.js +69 -69
  75. package/dist/cjs/__tests__/utils/custom-measure-formula-utils.spec.d.ts +1 -1
  76. package/dist/cjs/__tests__/utils/custom-measure-formula-utils.spec.js +139 -139
  77. package/dist/cjs/clients/generic/cognito-client.d.ts +23 -23
  78. package/dist/cjs/clients/generic/cognito-client.js +209 -209
  79. package/dist/cjs/clients/generic/dynamodb-client.d.ts +20 -20
  80. package/dist/cjs/clients/generic/dynamodb-client.js +235 -235
  81. package/dist/cjs/clients/generic/eventbridge-client.d.ts +14 -14
  82. package/dist/cjs/clients/generic/eventbridge-client.js +51 -51
  83. package/dist/cjs/clients/generic/http-client.d.ts +14 -14
  84. package/dist/cjs/clients/generic/http-client.js +61 -61
  85. package/dist/cjs/clients/generic/index.d.ts +13 -13
  86. package/dist/cjs/clients/generic/index.js +29 -29
  87. package/dist/cjs/clients/generic/lambda-invoke-client.d.ts +10 -10
  88. package/dist/cjs/clients/generic/lambda-invoke-client.js +39 -39
  89. package/dist/cjs/clients/generic/location-client.d.ts +8 -8
  90. package/dist/cjs/clients/generic/location-client.js +31 -31
  91. package/dist/cjs/clients/generic/redis-client.d.ts +33 -33
  92. package/dist/cjs/clients/generic/redis-client.js +191 -191
  93. package/dist/cjs/clients/generic/s3-client.d.ts +23 -23
  94. package/dist/cjs/clients/generic/s3-client.js +216 -216
  95. package/dist/cjs/clients/generic/singlestore-db-client.d.ts +14 -14
  96. package/dist/cjs/clients/generic/singlestore-db-client.js +67 -67
  97. package/dist/cjs/clients/generic/sqs-bundled-client.d.ts +15 -15
  98. package/dist/cjs/clients/generic/sqs-bundled-client.js +311 -311
  99. package/dist/cjs/clients/generic/sqs-bundled-client.types.d.ts +53 -53
  100. package/dist/cjs/clients/generic/sqs-bundled-client.types.js +17 -17
  101. package/dist/cjs/clients/generic/sqs-client.d.ts +53 -53
  102. package/dist/cjs/clients/generic/sqs-client.js +285 -285
  103. package/dist/cjs/clients/generic/sqs-unbundle.d.ts +32 -32
  104. package/dist/cjs/clients/generic/sqs-unbundle.js +144 -144
  105. package/dist/cjs/clients/index.d.ts +3 -3
  106. package/dist/cjs/clients/index.js +19 -19
  107. package/dist/cjs/clients/internal-api/accounts-client.d.ts +91 -91
  108. package/dist/cjs/clients/internal-api/accounts-client.js +129 -129
  109. package/dist/cjs/clients/internal-api/cache-lambda-client.d.ts +26 -26
  110. package/dist/cjs/clients/internal-api/cache-lambda-client.js +89 -89
  111. package/dist/cjs/clients/internal-api/db-management-client.d.ts +18 -18
  112. package/dist/cjs/clients/internal-api/db-management-client.js +36 -36
  113. package/dist/cjs/clients/internal-api/destinations-client.d.ts +34 -34
  114. package/dist/cjs/clients/internal-api/destinations-client.js +79 -79
  115. package/dist/cjs/clients/internal-api/event-collector-client.d.ts +20 -20
  116. package/dist/cjs/clients/internal-api/event-collector-client.js +36 -36
  117. package/dist/cjs/clients/internal-api/identity-client.d.ts +31 -31
  118. package/dist/cjs/clients/internal-api/identity-client.js +91 -91
  119. package/dist/cjs/clients/internal-api/index.d.ts +9 -9
  120. package/dist/cjs/clients/internal-api/index.js +25 -25
  121. package/dist/cjs/clients/internal-api/shopify-app-install-client.d.ts +37 -37
  122. package/dist/cjs/clients/internal-api/shopify-app-install-client.js +81 -81
  123. package/dist/cjs/clients/internal-api/subscriptions-client.d.ts +26 -26
  124. package/dist/cjs/clients/internal-api/subscriptions-client.js +77 -77
  125. package/dist/cjs/clients/internal-api/users-auth-client.d.ts +35 -35
  126. package/dist/cjs/clients/internal-api/users-auth-client.js +110 -110
  127. package/dist/cjs/clients/third-party/acuity-client.d.ts +10 -10
  128. package/dist/cjs/clients/third-party/acuity-client.js +40 -40
  129. package/dist/cjs/clients/third-party/emailable-client.d.ts +7 -7
  130. package/dist/cjs/clients/third-party/emailable-client.js +25 -25
  131. package/dist/cjs/clients/third-party/exchange-rate-api-client.d.ts +17 -17
  132. package/dist/cjs/clients/third-party/exchange-rate-api-client.js +19 -19
  133. package/dist/cjs/clients/third-party/index.d.ts +5 -5
  134. package/dist/cjs/clients/third-party/index.js +21 -21
  135. package/dist/cjs/clients/third-party/loops-client.d.ts +10 -10
  136. package/dist/cjs/clients/third-party/loops-client.js +30 -30
  137. package/dist/cjs/clients/third-party/shopify/graphql-order-queries.d.ts +25 -25
  138. package/dist/cjs/clients/third-party/shopify/graphql-order-queries.js +4 -4
  139. package/dist/cjs/clients/third-party/shopify/graphql-product-queries.d.ts +2 -2
  140. package/dist/cjs/clients/third-party/shopify/graphql-product-queries.js +5 -5
  141. package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.d.ts +10 -10
  142. package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.js +161 -161
  143. package/dist/cjs/clients/third-party/shopify-client.d.ts +29 -29
  144. package/dist/cjs/clients/third-party/shopify-client.js +146 -146
  145. package/dist/cjs/constants/index.d.ts +1 -1
  146. package/dist/cjs/constants/index.js +17 -17
  147. package/dist/cjs/constants/sqs.d.ts +20 -20
  148. package/dist/cjs/constants/sqs.js +26 -26
  149. package/dist/cjs/helpers/account-users-helper.d.ts +2 -2
  150. package/dist/cjs/helpers/account-users-helper.js +22 -22
  151. package/dist/cjs/helpers/acuity-helper.d.ts +4 -4
  152. package/dist/cjs/helpers/acuity-helper.js +56 -56
  153. package/dist/cjs/helpers/api-key-auth-helper.d.ts +9 -9
  154. package/dist/cjs/helpers/api-key-auth-helper.js +40 -40
  155. package/dist/cjs/helpers/api-key-authorizer-helper.d.ts +36 -36
  156. package/dist/cjs/helpers/api-key-authorizer-helper.js +87 -87
  157. package/dist/cjs/helpers/identity-cache-helper.d.ts +30 -21
  158. package/dist/cjs/helpers/identity-cache-helper.js +253 -157
  159. package/dist/cjs/helpers/identity-cache-helper.js.map +1 -1
  160. package/dist/cjs/helpers/index.d.ts +10 -10
  161. package/dist/cjs/helpers/index.js +26 -26
  162. package/dist/cjs/helpers/input-validation-helper.d.ts +3 -3
  163. package/dist/cjs/helpers/input-validation-helper.js +22 -22
  164. package/dist/cjs/helpers/logging-helper.d.ts +16 -16
  165. package/dist/cjs/helpers/logging-helper.js +84 -84
  166. package/dist/cjs/helpers/response-helper.d.ts +18 -18
  167. package/dist/cjs/helpers/response-helper.js +43 -43
  168. package/dist/cjs/helpers/shopify-helper.d.ts +9 -9
  169. package/dist/cjs/helpers/shopify-helper.js +26 -26
  170. package/dist/cjs/helpers/sqs-utils.d.ts +6 -6
  171. package/dist/cjs/helpers/sqs-utils.js +14 -14
  172. package/dist/cjs/index.d.ts +7 -7
  173. package/dist/cjs/index.js +23 -23
  174. package/dist/cjs/libs/api-router/index.d.ts +2 -2
  175. package/dist/cjs/libs/api-router/index.js +18 -18
  176. package/dist/cjs/libs/api-router/public-api-router.d.ts +3 -3
  177. package/dist/cjs/libs/api-router/public-api-router.js +36 -36
  178. package/dist/cjs/libs/api-router/route-matcher.d.ts +21 -21
  179. package/dist/cjs/libs/api-router/route-matcher.js +36 -36
  180. package/dist/cjs/libs/click-id-parser.d.ts +23 -23
  181. package/dist/cjs/libs/click-id-parser.js +49 -49
  182. package/dist/cjs/libs/compression.d.ts +2 -2
  183. package/dist/cjs/libs/compression.js +33 -33
  184. package/dist/cjs/libs/contacts.d.ts +7 -7
  185. package/dist/cjs/libs/contacts.js +152 -152
  186. package/dist/cjs/libs/cookie.d.ts +17 -17
  187. package/dist/cjs/libs/cookie.js +76 -76
  188. package/dist/cjs/libs/crypto.d.ts +4 -4
  189. package/dist/cjs/libs/crypto.js +25 -25
  190. package/dist/cjs/libs/csv.d.ts +2 -2
  191. package/dist/cjs/libs/csv.js +35 -35
  192. package/dist/cjs/libs/currency.d.ts +1 -1
  193. package/dist/cjs/libs/currency.js +29 -29
  194. package/dist/cjs/libs/dates.d.ts +12 -12
  195. package/dist/cjs/libs/dates.js +96 -96
  196. package/dist/cjs/libs/domain.d.ts +2 -2
  197. package/dist/cjs/libs/domain.js +38 -38
  198. package/dist/cjs/libs/emails.d.ts +8 -8
  199. package/dist/cjs/libs/emails.js +154 -154
  200. package/dist/cjs/libs/http-error.d.ts +21 -21
  201. package/dist/cjs/libs/http-error.js +63 -63
  202. package/dist/cjs/libs/http-status-codes.d.ts +58 -58
  203. package/dist/cjs/libs/http-status-codes.js +62 -62
  204. package/dist/cjs/libs/index.d.ts +19 -19
  205. package/dist/cjs/libs/index.js +35 -35
  206. package/dist/cjs/libs/numbers.d.ts +1 -1
  207. package/dist/cjs/libs/numbers.js +15 -15
  208. package/dist/cjs/libs/referrer-parser/index.d.ts +2 -2
  209. package/dist/cjs/libs/referrer-parser/index.js +18 -18
  210. package/dist/cjs/libs/referrer-parser/referrer-data.d.ts +9 -9
  211. package/dist/cjs/libs/referrer-parser/referrer-data.js +3307 -3307
  212. package/dist/cjs/libs/referrer-parser/referrer-parser-util.d.ts +20 -20
  213. package/dist/cjs/libs/referrer-parser/referrer-parser-util.js +131 -131
  214. package/dist/cjs/libs/strings.d.ts +3 -3
  215. package/dist/cjs/libs/strings.js +46 -46
  216. package/dist/cjs/libs/traits.d.ts +6 -6
  217. package/dist/cjs/libs/traits.js +65 -65
  218. package/dist/cjs/libs/url.d.ts +1 -1
  219. package/dist/cjs/libs/url.js +13 -13
  220. package/dist/cjs/services/acuity-api-service.d.ts +9 -9
  221. package/dist/cjs/services/acuity-api-service.js +73 -73
  222. package/dist/cjs/services/cache/generic-cached-object.d.ts +5 -5
  223. package/dist/cjs/services/cache/generic-cached-object.js +2 -2
  224. package/dist/cjs/services/cache/index.d.ts +1 -1
  225. package/dist/cjs/services/cache/index.js +17 -17
  226. package/dist/cjs/services/cache/product-cache-service.d.ts +21 -21
  227. package/dist/cjs/services/cache/product-cache-service.js +76 -76
  228. package/dist/cjs/services/currency-exchange-rate-lookup-service.d.ts +11 -12
  229. package/dist/cjs/services/currency-exchange-rate-lookup-service.js +66 -94
  230. package/dist/cjs/services/currency-exchange-rate-lookup-service.js.map +1 -1
  231. package/dist/cjs/services/db/accounts-db-service.d.ts +9 -9
  232. package/dist/cjs/services/db/accounts-db-service.js +33 -33
  233. package/dist/cjs/services/db/api-keys-db-service.d.ts +10 -10
  234. package/dist/cjs/services/db/api-keys-db-service.js +36 -36
  235. package/dist/cjs/services/db/contact-enrichments-db-service.d.ts +15 -15
  236. package/dist/cjs/services/db/contact-enrichments-db-service.js +94 -94
  237. package/dist/cjs/services/db/currency-exchange-rates-db-service.d.ts +21 -21
  238. package/dist/cjs/services/db/currency-exchange-rates-db-service.js +39 -39
  239. package/dist/cjs/services/db/custom-measures-db-service.d.ts +14 -14
  240. package/dist/cjs/services/db/custom-measures-db-service.js +48 -48
  241. package/dist/cjs/services/db/destinations-db-service.d.ts +13 -13
  242. package/dist/cjs/services/db/destinations-db-service.js +74 -74
  243. package/dist/cjs/services/db/identity-cache-db-service.d.ts +28 -28
  244. package/dist/cjs/services/db/identity-cache-db-service.js +320 -320
  245. package/dist/cjs/services/db/identity-cache-dynamodb-service.d.ts +44 -38
  246. package/dist/cjs/services/db/identity-cache-dynamodb-service.js +649 -439
  247. package/dist/cjs/services/db/identity-cache-dynamodb-service.js.map +1 -1
  248. package/dist/cjs/services/db/index.d.ts +17 -19
  249. package/dist/cjs/services/db/index.js +33 -35
  250. package/dist/cjs/services/db/index.js.map +1 -1
  251. package/dist/cjs/services/db/log-events-db-service.d.ts +11 -11
  252. package/dist/cjs/services/db/log-events-db-service.js +181 -181
  253. package/dist/cjs/services/db/pixels-db-service.d.ts +8 -8
  254. package/dist/cjs/services/db/pixels-db-service.js +35 -35
  255. package/dist/cjs/services/db/purchasable-contacts-db-service.d.ts +9 -9
  256. package/dist/cjs/services/db/purchasable-contacts-db-service.js +43 -43
  257. package/dist/cjs/services/db/purchased-contacts/index.d.ts +2 -2
  258. package/dist/cjs/services/db/purchased-contacts/index.js +18 -18
  259. package/dist/cjs/services/db/purchased-contacts/purchased-contacts-db-service.d.ts +18 -18
  260. package/dist/cjs/services/db/purchased-contacts/purchased-contacts-db-service.js +152 -152
  261. package/dist/cjs/services/db/purchased-contacts/types.d.ts +11 -11
  262. package/dist/cjs/services/db/purchased-contacts/types.js +2 -2
  263. package/dist/cjs/services/db/shopify-app-installs-db-service.d.ts +10 -10
  264. package/dist/cjs/services/db/shopify-app-installs-db-service.js +52 -52
  265. package/dist/cjs/services/db/shopify-products-cache-db-service.d.ts +16 -16
  266. package/dist/cjs/services/db/shopify-products-cache-db-service.js +73 -73
  267. package/dist/cjs/services/db/subscriptions-db-service.d.ts +11 -11
  268. package/dist/cjs/services/db/subscriptions-db-service.js +38 -38
  269. package/dist/cjs/services/db/tracking-events-db-service.d.ts +21 -21
  270. package/dist/cjs/services/db/tracking-events-db-service.js +188 -188
  271. package/dist/cjs/services/db/user-accounts-db-service.d.ts +7 -7
  272. package/dist/cjs/services/db/user-accounts-db-service.js +17 -17
  273. package/dist/cjs/services/email-verification/contact-email-verification-service.d.ts +7 -7
  274. package/dist/cjs/services/email-verification/contact-email-verification-service.js +101 -101
  275. package/dist/cjs/services/email-verification/email-verification-service.d.ts +19 -19
  276. package/dist/cjs/services/email-verification/email-verification-service.js +131 -131
  277. package/dist/cjs/services/email-verification/index.d.ts +2 -2
  278. package/dist/cjs/services/email-verification/index.js +18 -18
  279. package/dist/cjs/services/eventbridge-integration-service.d.ts +9 -9
  280. package/dist/cjs/services/eventbridge-integration-service.js +28 -28
  281. package/dist/cjs/services/events/index.d.ts +3 -3
  282. package/dist/cjs/services/events/index.js +19 -19
  283. package/dist/cjs/services/events/log-event-service.d.ts +19 -19
  284. package/dist/cjs/services/events/log-event-service.js +77 -77
  285. package/dist/cjs/services/events/metric-event-service.d.ts +9 -9
  286. package/dist/cjs/services/events/metric-event-service.js +49 -49
  287. package/dist/cjs/services/events/tracking-event-sqs-service.d.ts +8 -8
  288. package/dist/cjs/services/events/tracking-event-sqs-service.js +34 -34
  289. package/dist/cjs/services/generic-cache-service.d.ts +7 -7
  290. package/dist/cjs/services/generic-cache-service.js +33 -33
  291. package/dist/cjs/services/index.d.ts +10 -11
  292. package/dist/cjs/services/index.js +26 -27
  293. package/dist/cjs/services/index.js.map +1 -1
  294. package/dist/cjs/services/ipdata-lookup-service.d.ts +20 -20
  295. package/dist/cjs/services/ipdata-lookup-service.js +112 -112
  296. package/dist/cjs/services/shopify/index.d.ts +2 -2
  297. package/dist/cjs/services/shopify/index.js +18 -18
  298. package/dist/cjs/services/shopify/products/index.d.ts +1 -1
  299. package/dist/cjs/services/shopify/products/index.js +17 -17
  300. package/dist/cjs/services/shopify/products/shopify-products-serviceV2.d.ts +17 -17
  301. package/dist/cjs/services/shopify/products/shopify-products-serviceV2.js +112 -112
  302. package/dist/cjs/services/shopify/shopify-graphql-transformer.d.ts +8 -8
  303. package/dist/cjs/services/shopify/shopify-graphql-transformer.js +141 -141
  304. package/dist/cjs/types/acuity-types.d.ts +74 -74
  305. package/dist/cjs/types/acuity-types.js +2 -2
  306. package/dist/cjs/types/api-response.d.ts +6 -6
  307. package/dist/cjs/types/api-response.js +2 -2
  308. package/dist/cjs/types/index.d.ts +4 -4
  309. package/dist/cjs/types/index.js +33 -33
  310. package/dist/cjs/types/internal-events/event-detail-types.d.ts +20 -20
  311. package/dist/cjs/types/internal-events/event-detail-types.js +27 -27
  312. package/dist/cjs/types/internal-events/index.d.ts +1 -1
  313. package/dist/cjs/types/internal-events/index.js +17 -17
  314. package/dist/cjs/types/shopify-graphql-types/admin.generated.d.ts +123 -123
  315. package/dist/cjs/types/shopify-graphql-types/admin.generated.js +2 -2
  316. package/dist/cjs/types/shopify-graphql-types/admin.types.d.ts +26289 -26289
  317. package/dist/cjs/types/shopify-graphql-types/admin.types.js +5311 -5311
  318. package/dist/cjs/types/shopify-graphql-types/index.d.ts +2 -2
  319. package/dist/cjs/types/shopify-graphql-types/index.js +18 -18
  320. package/dist/cjs/types/shopify-rest-types.d.ts +767 -767
  321. package/dist/cjs/types/shopify-rest-types.js +2 -2
  322. package/dist/cjs/utils/compression.d.ts +36 -36
  323. package/dist/cjs/utils/compression.js +198 -198
  324. package/dist/cjs/utils/custom-measure-formula-utils.d.ts +6 -6
  325. package/dist/cjs/utils/custom-measure-formula-utils.js +209 -209
  326. package/dist/cjs/utils/index.d.ts +4 -4
  327. package/dist/cjs/utils/index.js +20 -20
  328. package/dist/cjs/utils/retry-envelope.d.ts +12 -12
  329. package/dist/cjs/utils/retry-envelope.js +28 -28
  330. package/dist/cjs/utils/size.d.ts +2 -2
  331. package/dist/cjs/utils/size.js +49 -49
  332. package/dist/esm/__tests__/clients/acuity-client.spec.d.ts +1 -1
  333. package/dist/esm/__tests__/clients/acuity-client.spec.js +41 -41
  334. package/dist/esm/__tests__/clients/cross-platform-compression.spec.d.ts +1 -1
  335. package/dist/esm/__tests__/clients/cross-platform-compression.spec.js +329 -329
  336. package/dist/esm/__tests__/clients/dynamodb-client.spec.d.ts +1 -1
  337. package/dist/esm/__tests__/clients/dynamodb-client.spec.js +192 -192
  338. package/dist/esm/__tests__/clients/sqs-bundled-client.spec.d.ts +1 -1
  339. package/dist/esm/__tests__/clients/sqs-bundled-client.spec.js +906 -906
  340. package/dist/esm/__tests__/clients/sqs-bundling-contracts.spec.d.ts +1 -1
  341. package/dist/esm/__tests__/clients/sqs-bundling-contracts.spec.js +538 -538
  342. package/dist/esm/__tests__/clients/sqs-client.spec.d.ts +1 -1
  343. package/dist/esm/__tests__/clients/sqs-client.spec.js +189 -189
  344. package/dist/esm/__tests__/clients/sqs-unbundle.spec.d.ts +1 -1
  345. package/dist/esm/__tests__/clients/sqs-unbundle.spec.js +1355 -1355
  346. package/dist/esm/__tests__/db/contact-enrichments-db-service.spec.d.ts +1 -1
  347. package/dist/esm/__tests__/db/contact-enrichments-db-service.spec.js +66 -66
  348. package/dist/esm/__tests__/db/destinations-db-service.spec.d.ts +1 -1
  349. package/dist/esm/__tests__/db/destinations-db-service.spec.js +123 -123
  350. package/dist/esm/__tests__/db/shared-read-db-services.spec.d.ts +1 -1
  351. package/dist/esm/__tests__/db/shared-read-db-services.spec.js +87 -87
  352. package/dist/esm/__tests__/db/shopify-app-installs-db-service.spec.d.ts +1 -1
  353. package/dist/esm/__tests__/db/shopify-app-installs-db-service.spec.js +102 -102
  354. package/dist/esm/__tests__/db/subscriptions-db-service.spec.d.ts +1 -1
  355. package/dist/esm/__tests__/db/subscriptions-db-service.spec.js +93 -93
  356. package/dist/esm/__tests__/db/user-accounts-db-service.spec.d.ts +1 -1
  357. package/dist/esm/__tests__/db/user-accounts-db-service.spec.js +74 -74
  358. package/dist/esm/__tests__/helpers/account-users-helper.spec.d.ts +1 -1
  359. package/dist/esm/__tests__/helpers/account-users-helper.spec.js +218 -218
  360. package/dist/esm/__tests__/helpers/acuity-helper.spec.d.ts +1 -1
  361. package/dist/esm/__tests__/helpers/acuity-helper.spec.js +67 -67
  362. package/dist/esm/__tests__/helpers/api-key-auth-helper.spec.d.ts +1 -1
  363. package/dist/esm/__tests__/helpers/api-key-auth-helper.spec.js +80 -80
  364. package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.d.ts +1 -1
  365. package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.js +674 -672
  366. package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.js.map +1 -1
  367. package/dist/esm/__tests__/identity-cache/identity-cache-dynamodb-service.spec.d.ts +1 -1
  368. package/dist/esm/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js +1138 -1138
  369. package/dist/{cjs/__tests__/services/cost/cost-currency-service.spec.d.ts → esm/__tests__/identity-cache/identity-cache-tier-routing.spec.d.ts} +1 -1
  370. package/dist/esm/__tests__/identity-cache/identity-cache-tier-routing.spec.js +850 -0
  371. package/dist/esm/__tests__/identity-cache/identity-cache-tier-routing.spec.js.map +1 -0
  372. package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.d.ts +1 -1
  373. package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.js +1058 -586
  374. package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.js.map +1 -1
  375. package/dist/{cjs/__tests__/services/cost/cost-calculation-types.spec.d.ts → esm/__tests__/identity-cache/volatile-traits-optimization.spec.d.ts} +1 -1
  376. package/dist/esm/__tests__/identity-cache/volatile-traits-optimization.spec.js +817 -0
  377. package/dist/esm/__tests__/identity-cache/volatile-traits-optimization.spec.js.map +1 -0
  378. package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.d.ts +1 -1
  379. package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.js +582 -582
  380. package/dist/esm/__tests__/libs/compress-decompress.spec.d.ts +1 -1
  381. package/dist/esm/__tests__/libs/compress-decompress.spec.js +14 -14
  382. package/dist/esm/__tests__/libs/contacts.spec.d.ts +1 -1
  383. package/dist/esm/__tests__/libs/contacts.spec.js +292 -292
  384. package/dist/esm/__tests__/libs/currency.spec.d.ts +1 -1
  385. package/dist/esm/__tests__/libs/currency.spec.js +218 -218
  386. package/dist/esm/__tests__/libs/dates.spec.d.ts +1 -1
  387. package/dist/esm/__tests__/libs/dates.spec.js +128 -128
  388. package/dist/esm/__tests__/libs/domain.spec.d.ts +1 -1
  389. package/dist/esm/__tests__/libs/domain.spec.js +105 -105
  390. package/dist/esm/__tests__/libs/numbers.spec.d.ts +1 -1
  391. package/dist/esm/__tests__/libs/numbers.spec.js +259 -259
  392. package/dist/esm/__tests__/s3-client/s3-client.spec.d.ts +1 -1
  393. package/dist/esm/__tests__/s3-client/s3-client.spec.js +31 -31
  394. package/dist/esm/__tests__/services/acuity-api-service.spec.d.ts +1 -1
  395. package/dist/esm/__tests__/services/acuity-api-service.spec.js +69 -69
  396. package/dist/esm/__tests__/services/email-verification/contact-email-verification-service.spec.d.ts +1 -1
  397. package/dist/esm/__tests__/services/email-verification/contact-email-verification-service.spec.js +91 -91
  398. package/dist/esm/__tests__/services/email-verification/email-verification-service.spec.d.ts +1 -1
  399. package/dist/esm/__tests__/services/email-verification/email-verification-service.spec.js +55 -55
  400. package/dist/esm/__tests__/shopify/shopify-graphql-transformer.spec.d.ts +1 -1
  401. package/dist/esm/__tests__/shopify/shopify-graphql-transformer.spec.js +33 -33
  402. package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.d.ts +1 -1
  403. package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.js +156 -156
  404. package/dist/esm/__tests__/unit/libs/api-router/route-matcher.spec.d.ts +1 -1
  405. package/dist/esm/__tests__/unit/libs/api-router/route-matcher.spec.js +67 -67
  406. package/dist/esm/__tests__/utils/custom-measure-formula-utils.spec.d.ts +1 -1
  407. package/dist/esm/__tests__/utils/custom-measure-formula-utils.spec.js +137 -137
  408. package/dist/esm/clients/generic/cognito-client.d.ts +23 -23
  409. package/dist/esm/clients/generic/cognito-client.js +204 -204
  410. package/dist/esm/clients/generic/dynamodb-client.d.ts +20 -20
  411. package/dist/esm/clients/generic/dynamodb-client.js +231 -231
  412. package/dist/esm/clients/generic/eventbridge-client.d.ts +14 -14
  413. package/dist/esm/clients/generic/eventbridge-client.js +47 -47
  414. package/dist/esm/clients/generic/http-client.d.ts +14 -14
  415. package/dist/esm/clients/generic/http-client.js +53 -53
  416. package/dist/esm/clients/generic/index.d.ts +13 -13
  417. package/dist/esm/clients/generic/index.js +13 -13
  418. package/dist/esm/clients/generic/lambda-invoke-client.d.ts +10 -10
  419. package/dist/esm/clients/generic/lambda-invoke-client.js +35 -35
  420. package/dist/esm/clients/generic/location-client.d.ts +8 -8
  421. package/dist/esm/clients/generic/location-client.js +27 -27
  422. package/dist/esm/clients/generic/redis-client.d.ts +33 -33
  423. package/dist/esm/clients/generic/redis-client.js +184 -184
  424. package/dist/esm/clients/generic/s3-client.d.ts +23 -23
  425. package/dist/esm/clients/generic/s3-client.js +209 -209
  426. package/dist/esm/clients/generic/singlestore-db-client.d.ts +14 -14
  427. package/dist/esm/clients/generic/singlestore-db-client.js +40 -40
  428. package/dist/esm/clients/generic/sqs-bundled-client.d.ts +15 -15
  429. package/dist/esm/clients/generic/sqs-bundled-client.js +307 -307
  430. package/dist/esm/clients/generic/sqs-bundled-client.types.d.ts +53 -53
  431. package/dist/esm/clients/generic/sqs-bundled-client.types.js +14 -14
  432. package/dist/esm/clients/generic/sqs-client.d.ts +53 -53
  433. package/dist/esm/clients/generic/sqs-client.js +281 -281
  434. package/dist/esm/clients/generic/sqs-unbundle.d.ts +32 -32
  435. package/dist/esm/clients/generic/sqs-unbundle.js +137 -137
  436. package/dist/esm/clients/index.d.ts +3 -3
  437. package/dist/esm/clients/index.js +3 -3
  438. package/dist/esm/clients/internal-api/accounts-client.d.ts +91 -91
  439. package/dist/esm/clients/internal-api/accounts-client.js +125 -125
  440. package/dist/esm/clients/internal-api/cache-lambda-client.d.ts +26 -26
  441. package/dist/esm/clients/internal-api/cache-lambda-client.js +85 -85
  442. package/dist/esm/clients/internal-api/db-management-client.d.ts +18 -18
  443. package/dist/esm/clients/internal-api/db-management-client.js +32 -32
  444. package/dist/esm/clients/internal-api/destinations-client.d.ts +34 -34
  445. package/dist/esm/clients/internal-api/destinations-client.js +75 -75
  446. package/dist/esm/clients/internal-api/event-collector-client.d.ts +20 -20
  447. package/dist/esm/clients/internal-api/event-collector-client.js +32 -32
  448. package/dist/esm/clients/internal-api/identity-client.d.ts +31 -31
  449. package/dist/esm/clients/internal-api/identity-client.js +87 -87
  450. package/dist/esm/clients/internal-api/index.d.ts +9 -9
  451. package/dist/esm/clients/internal-api/index.js +9 -9
  452. package/dist/esm/clients/internal-api/shopify-app-install-client.d.ts +37 -37
  453. package/dist/esm/clients/internal-api/shopify-app-install-client.js +77 -77
  454. package/dist/esm/clients/internal-api/subscriptions-client.d.ts +26 -26
  455. package/dist/esm/clients/internal-api/subscriptions-client.js +73 -73
  456. package/dist/esm/clients/internal-api/users-auth-client.d.ts +35 -35
  457. package/dist/esm/clients/internal-api/users-auth-client.js +106 -106
  458. package/dist/esm/clients/third-party/acuity-client.d.ts +10 -10
  459. package/dist/esm/clients/third-party/acuity-client.js +36 -36
  460. package/dist/esm/clients/third-party/emailable-client.d.ts +7 -7
  461. package/dist/esm/clients/third-party/emailable-client.js +21 -21
  462. package/dist/esm/clients/third-party/exchange-rate-api-client.d.ts +17 -17
  463. package/dist/esm/clients/third-party/exchange-rate-api-client.js +15 -15
  464. package/dist/esm/clients/third-party/index.d.ts +5 -5
  465. package/dist/esm/clients/third-party/index.js +5 -5
  466. package/dist/esm/clients/third-party/loops-client.d.ts +10 -10
  467. package/dist/esm/clients/third-party/loops-client.js +26 -26
  468. package/dist/esm/clients/third-party/shopify/graphql-order-queries.d.ts +25 -25
  469. package/dist/esm/clients/third-party/shopify/graphql-order-queries.js +1 -1
  470. package/dist/esm/clients/third-party/shopify/graphql-product-queries.d.ts +2 -2
  471. package/dist/esm/clients/third-party/shopify/graphql-product-queries.js +2 -2
  472. package/dist/esm/clients/third-party/shopify/shopify-graphql-client.d.ts +10 -10
  473. package/dist/esm/clients/third-party/shopify/shopify-graphql-client.js +157 -157
  474. package/dist/esm/clients/third-party/shopify-client.d.ts +29 -29
  475. package/dist/esm/clients/third-party/shopify-client.js +142 -142
  476. package/dist/esm/constants/index.d.ts +1 -1
  477. package/dist/esm/constants/index.js +1 -1
  478. package/dist/esm/constants/sqs.d.ts +20 -20
  479. package/dist/esm/constants/sqs.js +22 -22
  480. package/dist/esm/helpers/account-users-helper.d.ts +2 -2
  481. package/dist/esm/helpers/account-users-helper.js +18 -18
  482. package/dist/esm/helpers/acuity-helper.d.ts +4 -4
  483. package/dist/esm/helpers/acuity-helper.js +51 -51
  484. package/dist/esm/helpers/api-key-auth-helper.d.ts +9 -9
  485. package/dist/esm/helpers/api-key-auth-helper.js +35 -35
  486. package/dist/esm/helpers/api-key-authorizer-helper.d.ts +36 -36
  487. package/dist/esm/helpers/api-key-authorizer-helper.js +83 -83
  488. package/dist/esm/helpers/identity-cache-helper.d.ts +30 -21
  489. package/dist/esm/helpers/identity-cache-helper.js +248 -152
  490. package/dist/esm/helpers/identity-cache-helper.js.map +1 -1
  491. package/dist/esm/helpers/index.d.ts +10 -10
  492. package/dist/esm/helpers/index.js +10 -10
  493. package/dist/esm/helpers/input-validation-helper.d.ts +3 -3
  494. package/dist/esm/helpers/input-validation-helper.js +18 -18
  495. package/dist/esm/helpers/logging-helper.d.ts +16 -16
  496. package/dist/esm/helpers/logging-helper.js +56 -56
  497. package/dist/esm/helpers/response-helper.d.ts +18 -18
  498. package/dist/esm/helpers/response-helper.js +37 -37
  499. package/dist/esm/helpers/shopify-helper.d.ts +9 -9
  500. package/dist/esm/helpers/shopify-helper.js +21 -21
  501. package/dist/esm/helpers/sqs-utils.d.ts +6 -6
  502. package/dist/esm/helpers/sqs-utils.js +9 -9
  503. package/dist/esm/index.d.ts +7 -7
  504. package/dist/esm/index.js +7 -7
  505. package/dist/esm/libs/api-router/index.d.ts +2 -2
  506. package/dist/esm/libs/api-router/index.js +2 -2
  507. package/dist/esm/libs/api-router/public-api-router.d.ts +3 -3
  508. package/dist/esm/libs/api-router/public-api-router.js +32 -32
  509. package/dist/esm/libs/api-router/route-matcher.d.ts +21 -21
  510. package/dist/esm/libs/api-router/route-matcher.js +30 -30
  511. package/dist/esm/libs/click-id-parser.d.ts +23 -23
  512. package/dist/esm/libs/click-id-parser.js +45 -45
  513. package/dist/esm/libs/compression.d.ts +2 -2
  514. package/dist/esm/libs/compression.js +25 -25
  515. package/dist/esm/libs/contacts.d.ts +7 -7
  516. package/dist/esm/libs/contacts.js +143 -143
  517. package/dist/esm/libs/cookie.d.ts +17 -17
  518. package/dist/esm/libs/cookie.js +70 -70
  519. package/dist/esm/libs/crypto.d.ts +4 -4
  520. package/dist/esm/libs/crypto.js +15 -15
  521. package/dist/esm/libs/csv.d.ts +2 -2
  522. package/dist/esm/libs/csv.js +30 -30
  523. package/dist/esm/libs/currency.d.ts +1 -1
  524. package/dist/esm/libs/currency.js +22 -22
  525. package/dist/esm/libs/dates.d.ts +12 -12
  526. package/dist/esm/libs/dates.js +83 -83
  527. package/dist/esm/libs/domain.d.ts +2 -2
  528. package/dist/esm/libs/domain.js +33 -33
  529. package/dist/esm/libs/emails.d.ts +8 -8
  530. package/dist/esm/libs/emails.js +146 -146
  531. package/dist/esm/libs/http-error.d.ts +21 -21
  532. package/dist/esm/libs/http-error.js +59 -59
  533. package/dist/esm/libs/http-status-codes.d.ts +58 -58
  534. package/dist/esm/libs/http-status-codes.js +59 -59
  535. package/dist/esm/libs/index.d.ts +19 -19
  536. package/dist/esm/libs/index.js +19 -19
  537. package/dist/esm/libs/numbers.d.ts +1 -1
  538. package/dist/esm/libs/numbers.js +11 -11
  539. package/dist/esm/libs/referrer-parser/index.d.ts +2 -2
  540. package/dist/esm/libs/referrer-parser/index.js +2 -2
  541. package/dist/esm/libs/referrer-parser/referrer-data.d.ts +9 -9
  542. package/dist/esm/libs/referrer-parser/referrer-data.js +3304 -3304
  543. package/dist/esm/libs/referrer-parser/referrer-parser-util.d.ts +20 -20
  544. package/dist/esm/libs/referrer-parser/referrer-parser-util.js +124 -124
  545. package/dist/esm/libs/strings.d.ts +3 -3
  546. package/dist/esm/libs/strings.js +40 -40
  547. package/dist/esm/libs/traits.d.ts +6 -6
  548. package/dist/esm/libs/traits.js +54 -54
  549. package/dist/esm/libs/url.d.ts +1 -1
  550. package/dist/esm/libs/url.js +9 -9
  551. package/dist/esm/services/acuity-api-service.d.ts +9 -9
  552. package/dist/esm/services/acuity-api-service.js +69 -69
  553. package/dist/esm/services/cache/generic-cached-object.d.ts +5 -5
  554. package/dist/esm/services/cache/generic-cached-object.js +1 -1
  555. package/dist/esm/services/cache/index.d.ts +1 -1
  556. package/dist/esm/services/cache/index.js +1 -1
  557. package/dist/esm/services/cache/product-cache-service.d.ts +21 -21
  558. package/dist/esm/services/cache/product-cache-service.js +68 -68
  559. package/dist/esm/services/currency-exchange-rate-lookup-service.d.ts +11 -12
  560. package/dist/esm/services/currency-exchange-rate-lookup-service.js +62 -90
  561. package/dist/esm/services/currency-exchange-rate-lookup-service.js.map +1 -1
  562. package/dist/esm/services/db/accounts-db-service.d.ts +9 -9
  563. package/dist/esm/services/db/accounts-db-service.js +29 -29
  564. package/dist/esm/services/db/api-keys-db-service.d.ts +10 -10
  565. package/dist/esm/services/db/api-keys-db-service.js +32 -32
  566. package/dist/esm/services/db/contact-enrichments-db-service.d.ts +15 -15
  567. package/dist/esm/services/db/contact-enrichments-db-service.js +90 -90
  568. package/dist/esm/services/db/currency-exchange-rates-db-service.d.ts +21 -21
  569. package/dist/esm/services/db/currency-exchange-rates-db-service.js +35 -35
  570. package/dist/esm/services/db/custom-measures-db-service.d.ts +14 -14
  571. package/dist/esm/services/db/custom-measures-db-service.js +44 -44
  572. package/dist/esm/services/db/destinations-db-service.d.ts +13 -13
  573. package/dist/esm/services/db/destinations-db-service.js +70 -70
  574. package/dist/esm/services/db/identity-cache-db-service.d.ts +28 -28
  575. package/dist/esm/services/db/identity-cache-db-service.js +313 -313
  576. package/dist/esm/services/db/identity-cache-dynamodb-service.d.ts +44 -38
  577. package/dist/esm/services/db/identity-cache-dynamodb-service.js +642 -432
  578. package/dist/esm/services/db/identity-cache-dynamodb-service.js.map +1 -1
  579. package/dist/esm/services/db/index.d.ts +17 -19
  580. package/dist/esm/services/db/index.js +17 -19
  581. package/dist/esm/services/db/index.js.map +1 -1
  582. package/dist/esm/services/db/log-events-db-service.d.ts +11 -11
  583. package/dist/esm/services/db/log-events-db-service.js +177 -177
  584. package/dist/esm/services/db/pixels-db-service.d.ts +8 -8
  585. package/dist/esm/services/db/pixels-db-service.js +31 -31
  586. package/dist/esm/services/db/purchasable-contacts-db-service.d.ts +9 -9
  587. package/dist/esm/services/db/purchasable-contacts-db-service.js +39 -39
  588. package/dist/esm/services/db/purchased-contacts/index.d.ts +2 -2
  589. package/dist/esm/services/db/purchased-contacts/index.js +2 -2
  590. package/dist/esm/services/db/purchased-contacts/purchased-contacts-db-service.d.ts +18 -18
  591. package/dist/esm/services/db/purchased-contacts/purchased-contacts-db-service.js +148 -148
  592. package/dist/esm/services/db/purchased-contacts/types.d.ts +11 -11
  593. package/dist/esm/services/db/purchased-contacts/types.js +1 -1
  594. package/dist/esm/services/db/shopify-app-installs-db-service.d.ts +10 -10
  595. package/dist/esm/services/db/shopify-app-installs-db-service.js +48 -48
  596. package/dist/esm/services/db/shopify-products-cache-db-service.d.ts +16 -16
  597. package/dist/esm/services/db/shopify-products-cache-db-service.js +66 -66
  598. package/dist/esm/services/db/subscriptions-db-service.d.ts +11 -11
  599. package/dist/esm/services/db/subscriptions-db-service.js +34 -34
  600. package/dist/esm/services/db/tracking-events-db-service.d.ts +21 -21
  601. package/dist/esm/services/db/tracking-events-db-service.js +184 -184
  602. package/dist/esm/services/db/user-accounts-db-service.d.ts +7 -7
  603. package/dist/esm/services/db/user-accounts-db-service.js +13 -13
  604. package/dist/esm/services/email-verification/contact-email-verification-service.d.ts +7 -7
  605. package/dist/esm/services/email-verification/contact-email-verification-service.js +97 -97
  606. package/dist/esm/services/email-verification/email-verification-service.d.ts +19 -19
  607. package/dist/esm/services/email-verification/email-verification-service.js +127 -127
  608. package/dist/esm/services/email-verification/index.d.ts +2 -2
  609. package/dist/esm/services/email-verification/index.js +2 -2
  610. package/dist/esm/services/eventbridge-integration-service.d.ts +9 -9
  611. package/dist/esm/services/eventbridge-integration-service.js +24 -24
  612. package/dist/esm/services/events/index.d.ts +3 -3
  613. package/dist/esm/services/events/index.js +3 -3
  614. package/dist/esm/services/events/log-event-service.d.ts +19 -19
  615. package/dist/esm/services/events/log-event-service.js +73 -73
  616. package/dist/esm/services/events/metric-event-service.d.ts +9 -9
  617. package/dist/esm/services/events/metric-event-service.js +45 -45
  618. package/dist/esm/services/events/tracking-event-sqs-service.d.ts +8 -8
  619. package/dist/esm/services/events/tracking-event-sqs-service.js +30 -30
  620. package/dist/esm/services/generic-cache-service.d.ts +7 -7
  621. package/dist/esm/services/generic-cache-service.js +29 -29
  622. package/dist/esm/services/index.d.ts +10 -11
  623. package/dist/esm/services/index.js +10 -11
  624. package/dist/esm/services/index.js.map +1 -1
  625. package/dist/esm/services/ipdata-lookup-service.d.ts +20 -20
  626. package/dist/esm/services/ipdata-lookup-service.js +108 -108
  627. package/dist/esm/services/shopify/index.d.ts +2 -2
  628. package/dist/esm/services/shopify/index.js +2 -2
  629. package/dist/esm/services/shopify/products/index.d.ts +1 -1
  630. package/dist/esm/services/shopify/products/index.js +1 -1
  631. package/dist/esm/services/shopify/products/shopify-products-serviceV2.d.ts +17 -17
  632. package/dist/esm/services/shopify/products/shopify-products-serviceV2.js +108 -108
  633. package/dist/esm/services/shopify/shopify-graphql-transformer.d.ts +8 -8
  634. package/dist/esm/services/shopify/shopify-graphql-transformer.js +138 -138
  635. package/dist/esm/types/acuity-types.d.ts +74 -74
  636. package/dist/esm/types/acuity-types.js +1 -1
  637. package/dist/esm/types/api-response.d.ts +6 -6
  638. package/dist/esm/types/api-response.js +1 -1
  639. package/dist/esm/types/index.d.ts +4 -4
  640. package/dist/esm/types/index.js +4 -4
  641. package/dist/esm/types/internal-events/event-detail-types.d.ts +20 -20
  642. package/dist/esm/types/internal-events/event-detail-types.js +24 -24
  643. package/dist/esm/types/internal-events/index.d.ts +1 -1
  644. package/dist/esm/types/internal-events/index.js +1 -1
  645. package/dist/esm/types/shopify-graphql-types/admin.generated.d.ts +123 -123
  646. package/dist/esm/types/shopify-graphql-types/admin.generated.js +1 -1
  647. package/dist/esm/types/shopify-graphql-types/admin.types.d.ts +26289 -26289
  648. package/dist/esm/types/shopify-graphql-types/admin.types.js +5299 -5299
  649. package/dist/esm/types/shopify-graphql-types/index.d.ts +2 -2
  650. package/dist/esm/types/shopify-graphql-types/index.js +2 -2
  651. package/dist/esm/types/shopify-rest-types.d.ts +767 -767
  652. package/dist/esm/types/shopify-rest-types.js +1 -1
  653. package/dist/esm/utils/compression.d.ts +36 -36
  654. package/dist/esm/utils/compression.js +187 -187
  655. package/dist/esm/utils/custom-measure-formula-utils.d.ts +6 -6
  656. package/dist/esm/utils/custom-measure-formula-utils.js +201 -201
  657. package/dist/esm/utils/index.d.ts +4 -4
  658. package/dist/esm/utils/index.js +4 -4
  659. package/dist/esm/utils/retry-envelope.d.ts +12 -12
  660. package/dist/esm/utils/retry-envelope.js +22 -22
  661. package/dist/esm/utils/size.d.ts +2 -2
  662. package/dist/esm/utils/size.js +44 -44
  663. package/package.json +134 -134
  664. package/dist/cjs/__tests__/db/products-db-service.spec.js +0 -90
  665. package/dist/cjs/__tests__/db/products-db-service.spec.js.map +0 -1
  666. package/dist/cjs/__tests__/services/cost/cost-calculation-types.spec.js +0 -24
  667. package/dist/cjs/__tests__/services/cost/cost-calculation-types.spec.js.map +0 -1
  668. package/dist/cjs/__tests__/services/cost/cost-calculator-service.spec.js +0 -3320
  669. package/dist/cjs/__tests__/services/cost/cost-calculator-service.spec.js.map +0 -1
  670. package/dist/cjs/__tests__/services/cost/cost-currency-service.spec.js +0 -115
  671. package/dist/cjs/__tests__/services/cost/cost-currency-service.spec.js.map +0 -1
  672. package/dist/cjs/__tests__/services/cost/cost-filter-service.spec.d.ts +0 -1
  673. package/dist/cjs/__tests__/services/cost/cost-filter-service.spec.js +0 -469
  674. package/dist/cjs/__tests__/services/cost/cost-filter-service.spec.js.map +0 -1
  675. package/dist/cjs/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.d.ts +0 -1
  676. package/dist/cjs/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.js +0 -207
  677. package/dist/cjs/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.js.map +0 -1
  678. package/dist/cjs/__tests__/services/currency-exchange-rate-lookup-service.spec.d.ts +0 -1
  679. package/dist/cjs/__tests__/services/currency-exchange-rate-lookup-service.spec.js +0 -35
  680. package/dist/cjs/__tests__/services/currency-exchange-rate-lookup-service.spec.js.map +0 -1
  681. package/dist/cjs/services/cost/cost-calculation-types.d.ts +0 -69
  682. package/dist/cjs/services/cost/cost-calculation-types.js +0 -20
  683. package/dist/cjs/services/cost/cost-calculation-types.js.map +0 -1
  684. package/dist/cjs/services/cost/cost-calculator-service.d.ts +0 -24
  685. package/dist/cjs/services/cost/cost-calculator-service.js +0 -457
  686. package/dist/cjs/services/cost/cost-calculator-service.js.map +0 -1
  687. package/dist/cjs/services/cost/cost-currency-service.d.ts +0 -6
  688. package/dist/cjs/services/cost/cost-currency-service.js +0 -88
  689. package/dist/cjs/services/cost/cost-currency-service.js.map +0 -1
  690. package/dist/cjs/services/cost/cost-filter-service.d.ts +0 -10
  691. package/dist/cjs/services/cost/cost-filter-service.js +0 -122
  692. package/dist/cjs/services/cost/cost-filter-service.js.map +0 -1
  693. package/dist/cjs/services/cost/index.d.ts +0 -5
  694. package/dist/cjs/services/cost/index.js +0 -22
  695. package/dist/cjs/services/cost/index.js.map +0 -1
  696. package/dist/cjs/services/cost/order-cost/index.d.ts +0 -2
  697. package/dist/cjs/services/cost/order-cost/index.js +0 -19
  698. package/dist/cjs/services/cost/order-cost/index.js.map +0 -1
  699. package/dist/cjs/services/cost/order-cost/order-cost-resolution-service.d.ts +0 -23
  700. package/dist/cjs/services/cost/order-cost/order-cost-resolution-service.js +0 -362
  701. package/dist/cjs/services/cost/order-cost/order-cost-resolution-service.js.map +0 -1
  702. package/dist/cjs/services/cost/order-cost/order-cost-resolution-types.d.ts +0 -37
  703. package/dist/cjs/services/cost/order-cost/order-cost-resolution-types.js +0 -3
  704. package/dist/cjs/services/cost/order-cost/order-cost-resolution-types.js.map +0 -1
  705. package/dist/cjs/services/db/products-db-service-types.d.ts +0 -10
  706. package/dist/cjs/services/db/products-db-service-types.js +0 -3
  707. package/dist/cjs/services/db/products-db-service-types.js.map +0 -1
  708. package/dist/cjs/services/db/products-db-service.d.ts +0 -19
  709. package/dist/cjs/services/db/products-db-service.js +0 -282
  710. package/dist/cjs/services/db/products-db-service.js.map +0 -1
  711. package/dist/esm/__tests__/db/products-db-service.spec.d.ts +0 -1
  712. package/dist/esm/__tests__/db/products-db-service.spec.js +0 -88
  713. package/dist/esm/__tests__/db/products-db-service.spec.js.map +0 -1
  714. package/dist/esm/__tests__/services/cost/cost-calculation-types.spec.d.ts +0 -1
  715. package/dist/esm/__tests__/services/cost/cost-calculation-types.spec.js +0 -22
  716. package/dist/esm/__tests__/services/cost/cost-calculation-types.spec.js.map +0 -1
  717. package/dist/esm/__tests__/services/cost/cost-calculator-service.spec.d.ts +0 -1
  718. package/dist/esm/__tests__/services/cost/cost-calculator-service.spec.js +0 -3318
  719. package/dist/esm/__tests__/services/cost/cost-calculator-service.spec.js.map +0 -1
  720. package/dist/esm/__tests__/services/cost/cost-currency-service.spec.d.ts +0 -1
  721. package/dist/esm/__tests__/services/cost/cost-currency-service.spec.js +0 -113
  722. package/dist/esm/__tests__/services/cost/cost-currency-service.spec.js.map +0 -1
  723. package/dist/esm/__tests__/services/cost/cost-filter-service.spec.d.ts +0 -1
  724. package/dist/esm/__tests__/services/cost/cost-filter-service.spec.js +0 -467
  725. package/dist/esm/__tests__/services/cost/cost-filter-service.spec.js.map +0 -1
  726. package/dist/esm/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.d.ts +0 -1
  727. package/dist/esm/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.js +0 -205
  728. package/dist/esm/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.js.map +0 -1
  729. package/dist/esm/__tests__/services/currency-exchange-rate-lookup-service.spec.d.ts +0 -1
  730. package/dist/esm/__tests__/services/currency-exchange-rate-lookup-service.spec.js +0 -33
  731. package/dist/esm/__tests__/services/currency-exchange-rate-lookup-service.spec.js.map +0 -1
  732. package/dist/esm/services/cost/cost-calculation-types.d.ts +0 -69
  733. package/dist/esm/services/cost/cost-calculation-types.js +0 -16
  734. package/dist/esm/services/cost/cost-calculation-types.js.map +0 -1
  735. package/dist/esm/services/cost/cost-calculator-service.d.ts +0 -24
  736. package/dist/esm/services/cost/cost-calculator-service.js +0 -451
  737. package/dist/esm/services/cost/cost-calculator-service.js.map +0 -1
  738. package/dist/esm/services/cost/cost-currency-service.d.ts +0 -6
  739. package/dist/esm/services/cost/cost-currency-service.js +0 -85
  740. package/dist/esm/services/cost/cost-currency-service.js.map +0 -1
  741. package/dist/esm/services/cost/cost-filter-service.d.ts +0 -10
  742. package/dist/esm/services/cost/cost-filter-service.js +0 -119
  743. package/dist/esm/services/cost/cost-filter-service.js.map +0 -1
  744. package/dist/esm/services/cost/index.d.ts +0 -5
  745. package/dist/esm/services/cost/index.js +0 -6
  746. package/dist/esm/services/cost/index.js.map +0 -1
  747. package/dist/esm/services/cost/order-cost/index.d.ts +0 -2
  748. package/dist/esm/services/cost/order-cost/index.js +0 -3
  749. package/dist/esm/services/cost/order-cost/index.js.map +0 -1
  750. package/dist/esm/services/cost/order-cost/order-cost-resolution-service.d.ts +0 -23
  751. package/dist/esm/services/cost/order-cost/order-cost-resolution-service.js +0 -356
  752. package/dist/esm/services/cost/order-cost/order-cost-resolution-service.js.map +0 -1
  753. package/dist/esm/services/cost/order-cost/order-cost-resolution-types.d.ts +0 -37
  754. package/dist/esm/services/cost/order-cost/order-cost-resolution-types.js +0 -2
  755. package/dist/esm/services/cost/order-cost/order-cost-resolution-types.js.map +0 -1
  756. package/dist/esm/services/db/products-db-service-types.d.ts +0 -10
  757. package/dist/esm/services/db/products-db-service-types.js +0 -2
  758. package/dist/esm/services/db/products-db-service-types.js.map +0 -1
  759. package/dist/esm/services/db/products-db-service.d.ts +0 -19
  760. package/dist/esm/services/db/products-db-service.js +0 -278
  761. package/dist/esm/services/db/products-db-service.js.map +0 -1
@@ -1,589 +1,1061 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const at_shared_utils_1 = require("@adtrackify/at-shared-utils");
4
- const identity_cache_helper_1 = require("../../helpers/identity-cache-helper");
5
- describe('Identity Trait Merging Tests', () => {
6
- afterEach(() => {
7
- jest.resetModules();
8
- });
9
- describe('mergeIdentityTraits function', () => {
10
- it('should merge simple string arrays correctly', () => {
11
- const incomingTraits = {
12
- emails: ['new@email.com'],
13
- userIds: ['user1', 'user2'],
14
- };
15
- const cachedTraits = {
16
- emails: ['existing@email.com'],
17
- userIds: ['user2', 'user3'],
18
- phones: ['+1234567890'],
19
- };
20
- const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
21
- expect(merged.emails).toEqual(['new@email.com', 'existing@email.com']);
22
- expect(merged.userIds).toEqual(['user1', 'user2', 'user3']);
23
- expect(merged.phones).toEqual(['+1234567890']);
24
- });
25
- it('should handle null and undefined values in arrays', () => {
26
- const incomingTraits = {
27
- emails: ['test@email.com', null, undefined],
28
- userIds: ['user1'],
29
- };
30
- const cachedTraits = {
31
- emails: [null, 'cached@email.com', undefined],
32
- userIds: null,
33
- };
34
- const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
35
- expect(merged.emails).toContain('test@email.com');
36
- expect(merged.emails).toContain('cached@email.com');
37
- expect(merged.userIds).toEqual(['user1']);
38
- });
39
- it('should merge addresses correctly', () => {
40
- const incomingTraits = {
41
- addresses: [
42
- {
43
- city: 'New York',
44
- country: 'USA',
45
- countryCode: 'US',
46
- province: 'NY',
47
- provinceCode: '10001',
48
- },
49
- ],
50
- };
51
- const cachedTraits = {
52
- addresses: [
53
- {
54
- city: 'Los Angeles',
55
- country: 'USA',
56
- countryCode: 'US',
57
- province: 'CA',
58
- provinceCode: '90210',
59
- },
60
- ],
61
- };
62
- const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
63
- expect(merged.addresses).toHaveLength(2);
64
- expect(merged.addresses).toEqual(expect.arrayContaining([
65
- expect.objectContaining({ city: 'New York' }),
66
- expect.objectContaining({ city: 'Los Angeles' }),
67
- ]));
68
- });
69
- it('should merge click information correctly', () => {
70
- const incomingTraits = {
71
- click: {
72
- fbp: 'fb.new.123',
73
- fbpCollectedAt: '2024-01-01T00:00:00.000Z',
74
- gclid: 'new_gclid',
75
- },
76
- };
77
- const cachedTraits = {
78
- click: {
79
- fbp: 'fb.old.456',
80
- fbpCollectedAt: '2023-12-01T00:00:00.000Z',
81
- fbclid: 'cached_fbclid',
82
- },
83
- };
84
- const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
85
- expect(merged.click?.fbp).toBe('fb.new.123');
86
- expect(merged.click?.gclid).toBe('new_gclid');
87
- expect(merged.click?.fbpCollectedAt).toBe('2024-01-01T00:00:00.000Z');
88
- expect(merged.click?.fbclid).toBeUndefined();
89
- });
90
- it('should handle empty traits correctly', () => {
91
- const incomingTraits = {};
92
- const cachedTraits = {
93
- emails: ['cached@email.com'],
94
- userIds: ['user1'],
95
- };
96
- const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
97
- expect(merged.emails).toEqual(['cached@email.com']);
98
- expect(merged.userIds).toEqual(['user1']);
99
- });
100
- it('should handle undefined traits correctly', () => {
101
- const merged1 = (0, at_shared_utils_1.mergeIdentityTraits)(undefined, { emails: ['test@email.com'] });
102
- expect(merged1.emails).toEqual(['test@email.com']);
103
- const merged2 = (0, at_shared_utils_1.mergeIdentityTraits)({ emails: ['test@email.com'] }, undefined);
104
- expect(merged2.emails).toEqual(['test@email.com']);
105
- const merged3 = (0, at_shared_utils_1.mergeIdentityTraits)(undefined, undefined);
106
- expect(merged3).toEqual({});
107
- });
108
- it('should preserve version information', () => {
109
- const incomingTraits = {
110
- version: '3',
111
- emails: ['new@email.com'],
112
- };
113
- const cachedTraits = {
114
- version: '2',
115
- emails: ['old@email.com'],
116
- };
117
- const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
118
- expect(merged.version).toBe('3');
119
- expect(merged.emails).toEqual(['new@email.com', 'old@email.com']);
120
- });
121
- it('should handle complex nested objects', () => {
122
- const incomingTraits = {
123
- click: {
124
- googleClientInfos: [{ id: 'new1', clickId: 'click1', sessionId: 'session1' }],
125
- },
126
- };
127
- const cachedTraits = {
128
- click: {
129
- googleClientInfos: [{ id: 'cached1', clickId: 'click2', sessionId: 'session2' }],
130
- },
131
- };
132
- const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
133
- expect(merged.click?.googleClientInfos).toBeDefined();
134
- expect(Array.isArray(merged.click?.googleClientInfos)).toBe(true);
135
- expect(merged.click?.googleClientInfos).toEqual([{ id: 'cached1', clickId: 'click2', sessionId: 'session2' }]);
136
- });
137
- });
138
- describe('Integration: Merging + Staleness Checking', () => {
139
- it('should not be stale when merged identity matches cached identity', () => {
140
- const cachedIdentity = {
141
- identityId: 'test-id-123',
142
- traits: {
143
- emails: ['cached@email.com', 'shared@email.com'],
144
- userIds: ['user1', 'user2'],
145
- addresses: [
146
- {
147
- city: 'New York',
148
- country: 'USA',
149
- countryCode: 'US',
150
- },
151
- ],
152
- version: '2',
153
- },
154
- };
155
- const incomingIdentity = {
156
- identityId: 'test-id-123',
157
- traits: {
158
- emails: ['shared@email.com'],
159
- userIds: ['user1'],
160
- version: '2',
161
- },
162
- };
163
- const mergedTraits = (0, at_shared_utils_1.mergeIdentityTraits)(incomingIdentity.traits, cachedIdentity.traits);
164
- const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
165
- const staleTracker = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, mergedIdentity);
166
- expect(staleTracker.isCacheStale).toBe(false);
167
- expect(mergedIdentity.traits?.emails).toEqual(['shared@email.com', 'cached@email.com']);
168
- });
169
- it('should be stale when merged identity has new traits', () => {
170
- const cachedIdentity = {
171
- identityId: 'test-id-123',
172
- traits: {
173
- emails: ['cached@email.com'],
174
- version: '2',
175
- },
176
- };
177
- const incomingIdentity = {
178
- identityId: 'test-id-123',
179
- traits: {
180
- emails: ['cached@email.com', 'new@email.com'],
181
- version: '2',
182
- },
183
- };
184
- const mergedTraits = (0, at_shared_utils_1.mergeIdentityTraits)(incomingIdentity.traits, cachedIdentity.traits);
185
- const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
186
- const staleTracker = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, mergedIdentity);
187
- expect(staleTracker.isCacheStale).toBe(true);
188
- expect(staleTracker.isEmailsStale).toBe(true);
189
- });
190
- });
191
- });
192
- describe('Identity Cache Staleness Tests', () => {
193
- afterEach(() => {
194
- jest.resetModules();
195
- });
196
- describe('isIdentityCacheStale function', () => {
197
- it('should detect identity ID changes', () => {
198
- const cachedIdentity = {
199
- identityId: 'old-id',
200
- traits: { emails: ['test@email.com'] },
201
- };
202
- const incomingIdentity = {
203
- identityId: 'new-id',
204
- traits: { emails: ['test@email.com'] },
205
- };
206
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
207
- expect(result.isCacheStale).toBe(true);
208
- expect(result.isIdentityIdStale).toBe(true);
209
- });
210
- it('should detect new emails', () => {
211
- const cachedIdentity = {
212
- identityId: 'test-id',
213
- traits: { emails: ['old@email.com'] },
214
- };
215
- const incomingIdentity = {
216
- identityId: 'test-id',
217
- traits: { emails: ['old@email.com', 'new@email.com'] },
218
- };
219
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
220
- expect(result.isCacheStale).toBe(true);
221
- expect(result.isEmailsStale).toBe(true);
222
- });
223
- it('should detect new user IDs', () => {
224
- const cachedIdentity = {
225
- identityId: 'test-id',
226
- traits: { userIds: ['user1'] },
227
- };
228
- const incomingIdentity = {
229
- identityId: 'test-id',
230
- traits: { userIds: ['user1', 'user2'] },
231
- };
232
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
233
- expect(result.isCacheStale).toBe(true);
234
- expect(result.isUserIdsStale).toBe(true);
235
- });
236
- it('should detect new phones', () => {
237
- const cachedIdentity = {
238
- identityId: 'test-id',
239
- traits: { phones: ['+1234567890'] },
240
- };
241
- const incomingIdentity = {
242
- identityId: 'test-id',
243
- traits: { phones: ['+1234567890', '+9876543210'] },
244
- };
245
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
246
- expect(result.isCacheStale).toBe(true);
247
- expect(result.isPhonesStale).toBe(true);
248
- });
249
- it('should detect new addresses', () => {
250
- const cachedIdentity = {
251
- identityId: 'test-id',
252
- traits: {
253
- addresses: [
254
- {
255
- city: 'New York',
256
- country: 'USA',
257
- },
258
- ],
259
- },
260
- };
261
- const incomingIdentity = {
262
- identityId: 'test-id',
263
- traits: {
264
- addresses: [
265
- { city: 'New York', country: 'USA' },
266
- { city: 'Los Angeles', country: 'USA' },
267
- ],
268
- },
269
- };
270
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
271
- expect(result.isCacheStale).toBe(true);
272
- expect(result.isAddressesStale).toBe(true);
273
- });
274
- it('should detect IP address changes', () => {
275
- const cachedIdentity = {
276
- identityId: 'test-id',
277
- traits: { ipAddress: '192.168.1.1' },
278
- };
279
- const incomingIdentity = {
280
- identityId: 'test-id',
281
- traits: { ipAddress: '10.0.0.1' },
282
- };
283
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
284
- expect(result.isCacheStale).toBe(true);
285
- expect(result.isIpAddressStale).toBe(true);
286
- });
287
- it('should detect user agent changes', () => {
288
- const cachedIdentity = {
289
- identityId: 'test-id',
290
- traits: { userAgent: 'Mozilla/5.0 (old browser)' },
291
- };
292
- const incomingIdentity = {
293
- identityId: 'test-id',
294
- traits: { userAgent: 'Mozilla/5.0 (new browser)' },
295
- };
296
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
297
- expect(result.isCacheStale).toBe(true);
298
- expect(result.isUserAgentStale).toBe(true);
299
- });
300
- it('should not be stale when no new information is provided', () => {
301
- const cachedIdentity = {
302
- identityId: 'test-id',
303
- traits: {
304
- emails: ['test@email.com'],
305
- userIds: ['user1'],
306
- phones: ['+1234567890'],
307
- },
308
- };
309
- const incomingIdentity = {
310
- identityId: 'test-id',
311
- traits: {
312
- emails: ['test@email.com'],
313
- userIds: ['user1'],
314
- },
315
- };
316
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
317
- expect(result.isCacheStale).toBe(false);
318
- });
319
- it('should handle empty traits gracefully', () => {
320
- const cachedIdentity = {
321
- identityId: 'test-id',
322
- traits: {},
323
- };
324
- const incomingIdentity = {
325
- identityId: 'test-id',
326
- traits: {},
327
- };
328
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
329
- expect(result.isCacheStale).toBe(false);
330
- });
331
- it('should handle undefined traits gracefully', () => {
332
- const cachedIdentity = {
333
- identityId: 'test-id',
334
- };
335
- const incomingIdentity = {
336
- identityId: 'test-id',
337
- };
338
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
339
- expect(result.isCacheStale).toBe(false);
340
- });
341
- it('should detect multiple stale conditions', () => {
342
- const cachedIdentity = {
343
- identityId: 'test-id',
344
- traits: {
345
- emails: ['old@email.com'],
346
- userIds: ['user1'],
347
- ipAddress: '192.168.1.1',
348
- },
349
- };
350
- const incomingIdentity = {
351
- identityId: 'test-id',
352
- traits: {
353
- emails: ['old@email.com', 'new@email.com'],
354
- userIds: ['user1', 'user2'],
355
- ipAddress: '10.0.0.1',
356
- },
357
- };
358
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
359
- expect(result.isCacheStale).toBe(true);
360
- expect(result.isEmailsStale).toBe(true);
361
- expect(result.isUserIdsStale).toBe(true);
362
- expect(result.isIpAddressStale).toBe(true);
363
- });
364
- });
365
- describe('isClickInfosStale function', () => {
366
- it('should detect new FBC values', () => {
367
- const cachedClick = {
368
- fbc: 'fb.1.123.old_fbclid',
369
- };
370
- const incomingClick = {
371
- fbc: 'fb.1.123.new_fbclid',
372
- };
373
- const result = (0, identity_cache_helper_1.isClickInfosStale)(cachedClick, incomingClick);
374
- expect(result).toBe(true);
375
- });
376
- it('should detect new click IDs', () => {
377
- const cachedClick = {
378
- gclid: 'old_gclid',
379
- };
380
- const incomingClick = {
381
- gclid: 'new_gclid',
382
- };
383
- const result = (0, identity_cache_helper_1.isClickInfosStale)(cachedClick, incomingClick);
384
- expect(result).toBe(true);
385
- });
386
- it('should ignore collection timestamps', () => {
387
- const cachedClick = {
388
- fbp: 'fb.2.123.456',
389
- fbpCollectedAt: '2023-01-01T00:00:00.000Z',
390
- };
391
- const incomingClick = {
392
- fbp: 'fb.2.123.456',
393
- fbpCollectedAt: '2024-01-01T00:00:00.000Z',
394
- };
395
- const result = (0, identity_cache_helper_1.isClickInfosStale)(cachedClick, incomingClick);
396
- expect(result).toBe(false);
397
- });
398
- it('should ignore googleClientInfos', () => {
399
- const cachedClick = {
400
- googleClientInfos: [{ id: 'old', clickId: 'old_click' }],
401
- };
402
- const incomingClick = {
403
- googleClientInfos: [{ id: 'new', clickId: 'new_click' }],
404
- };
405
- const result = (0, identity_cache_helper_1.isClickInfosStale)(cachedClick, incomingClick);
406
- expect(result).toBe(false);
407
- });
408
- it('should handle empty click info', () => {
409
- const result = (0, identity_cache_helper_1.isClickInfosStale)({}, {});
410
- expect(result).toBe(false);
411
- });
412
- it('should detect when incoming has new click info but cached is empty', () => {
413
- const cachedClick = {};
414
- const incomingClick = {
415
- fbp: 'fb.2.123.456',
416
- };
417
- const result = (0, identity_cache_helper_1.isClickInfosStale)(cachedClick, incomingClick);
418
- expect(result).toBe(true);
419
- });
420
- });
421
- describe('Edge Cases and Error Handling', () => {
422
- it('should handle malformed FBC values gracefully', () => {
423
- const cachedClick = {
424
- fbc: 'malformed_fbc',
425
- };
426
- const incomingClick = {
427
- fbc: 'also_malformed',
428
- };
429
- const result = (0, identity_cache_helper_1.isClickInfosStale)(cachedClick, incomingClick);
430
- expect(result).toBe(true);
431
- });
432
- it('should handle null/undefined arrays in traits', () => {
433
- const cachedIdentity = {
434
- identityId: 'test-id',
435
- traits: {
436
- emails: null,
437
- userIds: undefined,
438
- },
439
- };
440
- const incomingIdentity = {
441
- identityId: 'test-id',
442
- traits: {
443
- emails: ['new@email.com'],
444
- userIds: ['user1'],
445
- },
446
- };
447
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
448
- expect(result.isCacheStale).toBe(true);
449
- expect(result.isEmailsStale).toBe(true);
450
- expect(result.isUserIdsStale).toBe(true);
451
- });
452
- it('should handle arrays with null/undefined elements', () => {
453
- const cachedIdentity = {
454
- identityId: 'test-id',
455
- traits: {
456
- emails: ['valid@email.com', null, undefined],
457
- },
458
- };
459
- const incomingIdentity = {
460
- identityId: 'test-id',
461
- traits: {
462
- emails: ['valid@email.com', null, undefined, 'new@email.com'],
463
- },
464
- };
465
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
466
- expect(result.isCacheStale).toBe(true);
467
- expect(result.isEmailsStale).toBe(true);
468
- });
469
- it('should handle error conditions gracefully', () => {
470
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(null, undefined);
471
- expect(result.isCacheStale).toBe(false);
472
- });
473
- });
474
- describe('Comprehensive Scenario Tests', () => {
475
- it('should handle complex real-world scenario', () => {
476
- const cachedIdentity = {
477
- identityId: '01HXRZ27H4TXWBBTRK09Q7APDP',
478
- traits: {
479
- emails: ['user@domain.com'],
480
- userIds: ['shopify_123'],
481
- addresses: [
482
- {
483
- city: 'New York',
484
- country: 'USA',
485
- countryCode: 'US',
486
- province: 'NY',
487
- provinceCode: '10001',
488
- },
489
- ],
490
- click: {
491
- fbp: 'fb.2.1715603578424.5068754021',
492
- fbpCollectedAt: '2024-05-13T12:32:58.424Z',
493
- gclid: 'original_gclid',
494
- },
495
- ipAddress: '192.168.1.100',
496
- version: '2',
497
- },
498
- };
499
- const incomingIdentity = {
500
- identityId: '01HXRZ27H4TXWBBTRK09Q7APDP',
501
- traits: {
502
- emails: ['user@domain.com', 'user.secondary@domain.com'],
503
- phones: ['+1234567890'],
504
- addresses: [
505
- {
506
- city: 'New York',
507
- country: 'USA',
508
- countryCode: 'US',
509
- province: 'NY',
510
- provinceCode: '10001',
511
- },
512
- ],
513
- click: {
514
- fbp: 'fb.2.1715603578424.5068754021',
515
- fbpCollectedAt: '2024-05-13T15:30:00.000Z',
516
- gclid: 'updated_gclid',
517
- },
518
- ipAddress: '192.168.1.100',
519
- version: '2',
520
- },
521
- };
522
- const mergedTraits = (0, at_shared_utils_1.mergeIdentityTraits)(cachedIdentity.traits, incomingIdentity.traits);
523
- const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
524
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, mergedIdentity);
525
- expect(result.isCacheStale).toBe(true);
526
- expect(result.isEmailsStale).toBe(true);
527
- expect(result.isPhonesStale).toBe(true);
528
- expect(result.isClickInfosStale).toBe(true);
529
- expect(result.isAddressesStale).toBe(false);
530
- expect(result.isIpAddressStale).toBe(false);
531
- expect(mergedIdentity.traits?.emails).toEqual(['user@domain.com', 'user.secondary@domain.com']);
532
- expect(mergedIdentity.traits?.phones).toEqual(['+1234567890']);
533
- expect(mergedIdentity.traits?.userIds).toEqual(['shopify_123']);
534
- expect(mergedIdentity.traits?.click?.gclid).toEqual('updated_gclid');
535
- });
536
- it('should properly detect click staleness when click info actually differs', () => {
537
- const cachedIdentity = {
538
- identityId: 'test-id',
539
- traits: {
540
- click: {
541
- gclid: 'original_gclid',
542
- gclidCollectedAt: '2024-05-15T12:32:58.424Z',
543
- },
544
- },
545
- };
546
- const incomingIdentity = {
547
- identityId: 'test-id',
548
- traits: {
549
- click: {
550
- gclid: 'completely_different_gclid',
551
- gclidCollectedAt: '2024-05-13T12:32:58.424Z',
552
- },
553
- },
554
- };
555
- const mergedTraits = (0, at_shared_utils_1.mergeIdentityTraits)(cachedIdentity.traits, incomingIdentity.traits);
556
- const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
557
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, mergedIdentity);
558
- expect(mergedTraits?.click?.gclid).toEqual('original_gclid');
559
- expect(result.isCacheStale).toBe(false);
560
- });
561
- it('should handle scenario where cache is fresh', () => {
562
- const cachedIdentity = {
563
- identityId: 'test-id',
564
- traits: {
565
- emails: ['user@domain.com', 'secondary@domain.com'],
566
- userIds: ['user1', 'user2'],
567
- phones: ['+1234567890'],
568
- version: '2',
569
- },
570
- };
571
- const incomingIdentity = {
572
- identityId: 'test-id',
573
- traits: {
574
- emails: ['user@domain.com'],
575
- userIds: ['user1'],
576
- version: '2',
577
- },
578
- };
579
- const mergedTraits = (0, at_shared_utils_1.mergeIdentityTraits)(cachedIdentity.traits, incomingIdentity.traits);
580
- const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
581
- const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, mergedIdentity);
582
- expect(result.isCacheStale).toBe(false);
583
- expect(mergedIdentity.traits?.emails).toEqual(['user@domain.com', 'secondary@domain.com']);
584
- expect(mergedIdentity.traits?.userIds).toEqual(['user1', 'user2']);
585
- expect(mergedIdentity.traits?.phones).toEqual(['+1234567890']);
586
- });
587
- });
588
- });
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const at_tracking_event_types_1 = require("@adtrackify/at-tracking-event-types");
4
+ const at_shared_utils_1 = require("@adtrackify/at-shared-utils");
5
+ const identity_cache_helper_1 = require("../../helpers/identity-cache-helper");
6
+ describe('Identity Trait Merging Tests', () => {
7
+ afterEach(() => {
8
+ jest.resetModules();
9
+ });
10
+ describe('mergeIdentityTraits function', () => {
11
+ it('should merge simple string arrays correctly', () => {
12
+ const incomingTraits = {
13
+ emails: ['new@email.com'],
14
+ userIds: ['user1', 'user2'],
15
+ };
16
+ const cachedTraits = {
17
+ emails: ['existing@email.com'],
18
+ userIds: ['user2', 'user3'],
19
+ phones: ['+1234567890'],
20
+ };
21
+ const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
22
+ expect(merged.emails).toEqual(['new@email.com', 'existing@email.com']);
23
+ expect(merged.userIds).toEqual(['user1', 'user2', 'user3']);
24
+ expect(merged.phones).toEqual(['+1234567890']);
25
+ });
26
+ it('should handle null and undefined values in arrays', () => {
27
+ const incomingTraits = {
28
+ emails: ['test@email.com', null, undefined],
29
+ userIds: ['user1'],
30
+ };
31
+ const cachedTraits = {
32
+ emails: [null, 'cached@email.com', undefined],
33
+ userIds: null,
34
+ };
35
+ const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
36
+ expect(merged.emails).toContain('test@email.com');
37
+ expect(merged.emails).toContain('cached@email.com');
38
+ expect(merged.userIds).toEqual(['user1']);
39
+ });
40
+ it('should merge addresses correctly', () => {
41
+ const incomingTraits = {
42
+ addresses: [
43
+ {
44
+ city: 'New York',
45
+ country: 'USA',
46
+ countryCode: 'US',
47
+ province: 'NY',
48
+ provinceCode: '10001',
49
+ },
50
+ ],
51
+ };
52
+ const cachedTraits = {
53
+ addresses: [
54
+ {
55
+ city: 'Los Angeles',
56
+ country: 'USA',
57
+ countryCode: 'US',
58
+ province: 'CA',
59
+ provinceCode: '90210',
60
+ },
61
+ ],
62
+ };
63
+ const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
64
+ expect(merged.addresses).toHaveLength(2);
65
+ expect(merged.addresses).toEqual(expect.arrayContaining([
66
+ expect.objectContaining({ city: 'New York' }),
67
+ expect.objectContaining({ city: 'Los Angeles' }),
68
+ ]));
69
+ });
70
+ it('should merge click information correctly', () => {
71
+ const incomingTraits = {
72
+ click: {
73
+ fbp: 'fb.new.123',
74
+ fbpCollectedAt: '2024-01-01T00:00:00.000Z',
75
+ gclid: 'new_gclid',
76
+ },
77
+ };
78
+ const cachedTraits = {
79
+ click: {
80
+ fbp: 'fb.old.456',
81
+ fbpCollectedAt: '2023-12-01T00:00:00.000Z',
82
+ fbclid: 'cached_fbclid',
83
+ },
84
+ };
85
+ const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
86
+ expect(merged.click?.fbp).toBe('fb.new.123');
87
+ expect(merged.click?.gclid).toBe('new_gclid');
88
+ expect(merged.click?.fbpCollectedAt).toBe('2024-01-01T00:00:00.000Z');
89
+ expect(merged.click?.fbclid).toBeUndefined();
90
+ });
91
+ it('should handle empty traits correctly', () => {
92
+ const incomingTraits = {};
93
+ const cachedTraits = {
94
+ emails: ['cached@email.com'],
95
+ userIds: ['user1'],
96
+ };
97
+ const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
98
+ expect(merged.emails).toEqual(['cached@email.com']);
99
+ expect(merged.userIds).toEqual(['user1']);
100
+ });
101
+ it('should handle undefined traits correctly', () => {
102
+ const merged1 = (0, at_shared_utils_1.mergeIdentityTraits)(undefined, { emails: ['test@email.com'] });
103
+ expect(merged1.emails).toEqual(['test@email.com']);
104
+ const merged2 = (0, at_shared_utils_1.mergeIdentityTraits)({ emails: ['test@email.com'] }, undefined);
105
+ expect(merged2.emails).toEqual(['test@email.com']);
106
+ const merged3 = (0, at_shared_utils_1.mergeIdentityTraits)(undefined, undefined);
107
+ expect(merged3).toEqual({});
108
+ });
109
+ it('should preserve version information', () => {
110
+ const incomingTraits = {
111
+ version: '3',
112
+ emails: ['new@email.com'],
113
+ };
114
+ const cachedTraits = {
115
+ version: '2',
116
+ emails: ['old@email.com'],
117
+ };
118
+ const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
119
+ expect(merged.version).toBe('3');
120
+ expect(merged.emails).toEqual(['new@email.com', 'old@email.com']);
121
+ });
122
+ it('should handle complex nested objects', () => {
123
+ const incomingTraits = {
124
+ click: {
125
+ googleClientInfos: [{ id: 'new1', clickId: 'click1', sessionId: 'session1' }],
126
+ },
127
+ };
128
+ const cachedTraits = {
129
+ click: {
130
+ googleClientInfos: [{ id: 'cached1', clickId: 'click2', sessionId: 'session2' }],
131
+ },
132
+ };
133
+ const merged = (0, at_shared_utils_1.mergeIdentityTraits)(incomingTraits, cachedTraits);
134
+ expect(merged.click?.googleClientInfos).toBeDefined();
135
+ expect(Array.isArray(merged.click?.googleClientInfos)).toBe(true);
136
+ expect(merged.click?.googleClientInfos).toEqual([{ id: 'cached1', clickId: 'click2', sessionId: 'session2' }]);
137
+ });
138
+ });
139
+ describe('Integration: Merging + Staleness Checking', () => {
140
+ it('should not be stale when merged identity matches cached identity', () => {
141
+ const cachedIdentity = {
142
+ identityId: 'test-id-123',
143
+ traits: {
144
+ emails: ['cached@email.com', 'shared@email.com'],
145
+ userIds: ['user1', 'user2'],
146
+ addresses: [
147
+ {
148
+ city: 'New York',
149
+ country: 'USA',
150
+ countryCode: 'US',
151
+ },
152
+ ],
153
+ version: '2',
154
+ },
155
+ };
156
+ const incomingIdentity = {
157
+ identityId: 'test-id-123',
158
+ traits: {
159
+ emails: ['shared@email.com'],
160
+ userIds: ['user1'],
161
+ version: '2',
162
+ },
163
+ };
164
+ const mergedTraits = (0, at_shared_utils_1.mergeIdentityTraits)(incomingIdentity.traits, cachedIdentity.traits);
165
+ const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
166
+ const staleTracker = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, mergedIdentity);
167
+ expect(staleTracker.isCacheStale).toBe(false);
168
+ expect(mergedIdentity.traits?.emails).toEqual(['shared@email.com', 'cached@email.com']);
169
+ });
170
+ it('should be stale when merged identity has new traits', () => {
171
+ const cachedIdentity = {
172
+ identityId: 'test-id-123',
173
+ traits: {
174
+ emails: ['cached@email.com'],
175
+ version: '2',
176
+ },
177
+ };
178
+ const incomingIdentity = {
179
+ identityId: 'test-id-123',
180
+ traits: {
181
+ emails: ['cached@email.com', 'new@email.com'],
182
+ version: '2',
183
+ },
184
+ };
185
+ const mergedTraits = (0, at_shared_utils_1.mergeIdentityTraits)(incomingIdentity.traits, cachedIdentity.traits);
186
+ const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
187
+ const staleTracker = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, mergedIdentity);
188
+ expect(staleTracker.isCacheStale).toBe(true);
189
+ expect(staleTracker.isEmailsStale).toBe(true);
190
+ });
191
+ });
192
+ });
193
+ describe('Identity Cache Staleness Tests', () => {
194
+ afterEach(() => {
195
+ jest.resetModules();
196
+ });
197
+ describe('isIdentityCacheStale function', () => {
198
+ it('should detect identity ID changes', () => {
199
+ const cachedIdentity = {
200
+ identityId: 'old-id',
201
+ traits: { emails: ['test@email.com'] },
202
+ };
203
+ const incomingIdentity = {
204
+ identityId: 'new-id',
205
+ traits: { emails: ['test@email.com'] },
206
+ };
207
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
208
+ expect(result.isCacheStale).toBe(true);
209
+ expect(result.isIdentityIdStale).toBe(true);
210
+ });
211
+ it('should detect new emails', () => {
212
+ const cachedIdentity = {
213
+ identityId: 'test-id',
214
+ traits: { emails: ['old@email.com'] },
215
+ };
216
+ const incomingIdentity = {
217
+ identityId: 'test-id',
218
+ traits: { emails: ['old@email.com', 'new@email.com'] },
219
+ };
220
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
221
+ expect(result.isCacheStale).toBe(true);
222
+ expect(result.isEmailsStale).toBe(true);
223
+ });
224
+ it('should detect new user IDs', () => {
225
+ const cachedIdentity = {
226
+ identityId: 'test-id',
227
+ traits: { userIds: ['user1'] },
228
+ };
229
+ const incomingIdentity = {
230
+ identityId: 'test-id',
231
+ traits: { userIds: ['user1', 'user2'] },
232
+ };
233
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
234
+ expect(result.isCacheStale).toBe(true);
235
+ expect(result.isUserIdsStale).toBe(true);
236
+ });
237
+ it('should detect new phones', () => {
238
+ const cachedIdentity = {
239
+ identityId: 'test-id',
240
+ traits: { phones: ['+1234567890'] },
241
+ };
242
+ const incomingIdentity = {
243
+ identityId: 'test-id',
244
+ traits: { phones: ['+1234567890', '+9876543210'] },
245
+ };
246
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
247
+ expect(result.isCacheStale).toBe(true);
248
+ expect(result.isPhonesStale).toBe(true);
249
+ });
250
+ it('should detect new addresses (non-IP sourced)', () => {
251
+ const cachedIdentity = {
252
+ identityId: 'test-id',
253
+ traits: {
254
+ addresses: [
255
+ {
256
+ city: 'New York',
257
+ country: 'USA',
258
+ s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT,
259
+ },
260
+ ],
261
+ },
262
+ };
263
+ const incomingIdentity = {
264
+ identityId: 'test-id',
265
+ traits: {
266
+ addresses: [
267
+ { city: 'New York', country: 'USA', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
268
+ { city: 'Los Angeles', country: 'USA', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
269
+ ],
270
+ },
271
+ };
272
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
273
+ expect(result.isCacheStale).toBe(true);
274
+ expect(result.isAddressesStale).toBe(true);
275
+ expect(result.isNonIpAddressesStale).toBe(true);
276
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.ADDRESS_UPDATE);
277
+ });
278
+ it('should detect IP address changes but NOT mark cache stale (volatile trait)', () => {
279
+ const cachedIdentity = {
280
+ identityId: 'test-id',
281
+ traits: { ipAddress: '192.168.1.1' },
282
+ };
283
+ const incomingIdentity = {
284
+ identityId: 'test-id',
285
+ traits: { ipAddress: '10.0.0.1' },
286
+ };
287
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
288
+ expect(result.isCacheStale).toBe(false);
289
+ expect(result.isIpAddressStale).toBe(true);
290
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.VOLATILE_ONLY);
291
+ });
292
+ it('should detect user agent changes but NOT mark cache stale (volatile trait)', () => {
293
+ const cachedIdentity = {
294
+ identityId: 'test-id',
295
+ traits: { userAgent: 'Mozilla/5.0 (old browser)' },
296
+ };
297
+ const incomingIdentity = {
298
+ identityId: 'test-id',
299
+ traits: { userAgent: 'Mozilla/5.0 (new browser)' },
300
+ };
301
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
302
+ expect(result.isCacheStale).toBe(false);
303
+ expect(result.isUserAgentStale).toBe(true);
304
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.VOLATILE_ONLY);
305
+ });
306
+ it('should not be stale when no new information is provided', () => {
307
+ const cachedIdentity = {
308
+ identityId: 'test-id',
309
+ traits: {
310
+ emails: ['test@email.com'],
311
+ userIds: ['user1'],
312
+ phones: ['+1234567890'],
313
+ },
314
+ };
315
+ const incomingIdentity = {
316
+ identityId: 'test-id',
317
+ traits: {
318
+ emails: ['test@email.com'],
319
+ userIds: ['user1'],
320
+ },
321
+ };
322
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
323
+ expect(result.isCacheStale).toBe(false);
324
+ });
325
+ it('should handle empty traits gracefully', () => {
326
+ const cachedIdentity = {
327
+ identityId: 'test-id',
328
+ traits: {},
329
+ };
330
+ const incomingIdentity = {
331
+ identityId: 'test-id',
332
+ traits: {},
333
+ };
334
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
335
+ expect(result.isCacheStale).toBe(false);
336
+ });
337
+ it('should handle undefined traits gracefully', () => {
338
+ const cachedIdentity = {
339
+ identityId: 'test-id',
340
+ };
341
+ const incomingIdentity = {
342
+ identityId: 'test-id',
343
+ };
344
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
345
+ expect(result.isCacheStale).toBe(false);
346
+ });
347
+ it('should detect multiple stale conditions (identity traits take priority over volatile)', () => {
348
+ const cachedIdentity = {
349
+ identityId: 'test-id',
350
+ traits: {
351
+ emails: ['old@email.com'],
352
+ userIds: ['user1'],
353
+ ipAddress: '192.168.1.1',
354
+ },
355
+ };
356
+ const incomingIdentity = {
357
+ identityId: 'test-id',
358
+ traits: {
359
+ emails: ['old@email.com', 'new@email.com'],
360
+ userIds: ['user1', 'user2'],
361
+ ipAddress: '10.0.0.1',
362
+ },
363
+ };
364
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
365
+ expect(result.isCacheStale).toBe(true);
366
+ expect(result.isEmailsStale).toBe(true);
367
+ expect(result.isUserIdsStale).toBe(true);
368
+ expect(result.isIpAddressStale).toBe(true);
369
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.IDENTITY_STALE);
370
+ });
371
+ });
372
+ describe('isClickInfosStale function', () => {
373
+ it('should detect new FBC values', () => {
374
+ const cachedClick = {
375
+ fbc: 'fb.1.123.old_fbclid',
376
+ };
377
+ const incomingClick = {
378
+ fbc: 'fb.1.123.new_fbclid',
379
+ };
380
+ const result = (0, identity_cache_helper_1.isClickInfosStale)(cachedClick, incomingClick);
381
+ expect(result).toBe(true);
382
+ });
383
+ it('should detect new click IDs', () => {
384
+ const cachedClick = {
385
+ gclid: 'old_gclid',
386
+ };
387
+ const incomingClick = {
388
+ gclid: 'new_gclid',
389
+ };
390
+ const result = (0, identity_cache_helper_1.isClickInfosStale)(cachedClick, incomingClick);
391
+ expect(result).toBe(true);
392
+ });
393
+ it('should ignore collection timestamps', () => {
394
+ const cachedClick = {
395
+ fbp: 'fb.2.123.456',
396
+ fbpCollectedAt: '2023-01-01T00:00:00.000Z',
397
+ };
398
+ const incomingClick = {
399
+ fbp: 'fb.2.123.456',
400
+ fbpCollectedAt: '2024-01-01T00:00:00.000Z',
401
+ };
402
+ const result = (0, identity_cache_helper_1.isClickInfosStale)(cachedClick, incomingClick);
403
+ expect(result).toBe(false);
404
+ });
405
+ it('should ignore googleClientInfos', () => {
406
+ const cachedClick = {
407
+ googleClientInfos: [{ id: 'old', clickId: 'old_click' }],
408
+ };
409
+ const incomingClick = {
410
+ googleClientInfos: [{ id: 'new', clickId: 'new_click' }],
411
+ };
412
+ const result = (0, identity_cache_helper_1.isClickInfosStale)(cachedClick, incomingClick);
413
+ expect(result).toBe(false);
414
+ });
415
+ it('should handle empty click info', () => {
416
+ const result = (0, identity_cache_helper_1.isClickInfosStale)({}, {});
417
+ expect(result).toBe(false);
418
+ });
419
+ it('should detect when incoming has new click info but cached is empty', () => {
420
+ const cachedClick = {};
421
+ const incomingClick = {
422
+ fbp: 'fb.2.123.456',
423
+ };
424
+ const result = (0, identity_cache_helper_1.isClickInfosStale)(cachedClick, incomingClick);
425
+ expect(result).toBe(true);
426
+ });
427
+ });
428
+ describe('Edge Cases and Error Handling', () => {
429
+ it('should handle malformed FBC values gracefully', () => {
430
+ const cachedClick = {
431
+ fbc: 'malformed_fbc',
432
+ };
433
+ const incomingClick = {
434
+ fbc: 'also_malformed',
435
+ };
436
+ const result = (0, identity_cache_helper_1.isClickInfosStale)(cachedClick, incomingClick);
437
+ expect(result).toBe(true);
438
+ });
439
+ it('should handle null/undefined arrays in traits', () => {
440
+ const cachedIdentity = {
441
+ identityId: 'test-id',
442
+ traits: {
443
+ emails: null,
444
+ userIds: undefined,
445
+ },
446
+ };
447
+ const incomingIdentity = {
448
+ identityId: 'test-id',
449
+ traits: {
450
+ emails: ['new@email.com'],
451
+ userIds: ['user1'],
452
+ },
453
+ };
454
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
455
+ expect(result.isCacheStale).toBe(true);
456
+ expect(result.isEmailsStale).toBe(true);
457
+ expect(result.isUserIdsStale).toBe(true);
458
+ });
459
+ it('should handle arrays with null/undefined elements', () => {
460
+ const cachedIdentity = {
461
+ identityId: 'test-id',
462
+ traits: {
463
+ emails: ['valid@email.com', null, undefined],
464
+ },
465
+ };
466
+ const incomingIdentity = {
467
+ identityId: 'test-id',
468
+ traits: {
469
+ emails: ['valid@email.com', null, undefined, 'new@email.com'],
470
+ },
471
+ };
472
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
473
+ expect(result.isCacheStale).toBe(true);
474
+ expect(result.isEmailsStale).toBe(true);
475
+ });
476
+ it('should handle error conditions gracefully', () => {
477
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(null, undefined);
478
+ expect(result.isCacheStale).toBe(false);
479
+ });
480
+ });
481
+ describe('Comprehensive Scenario Tests', () => {
482
+ it('should handle complex real-world scenario', () => {
483
+ const cachedIdentity = {
484
+ identityId: '01HXRZ27H4TXWBBTRK09Q7APDP',
485
+ traits: {
486
+ emails: ['user@domain.com'],
487
+ userIds: ['shopify_123'],
488
+ addresses: [
489
+ {
490
+ city: 'New York',
491
+ country: 'USA',
492
+ countryCode: 'US',
493
+ province: 'NY',
494
+ provinceCode: '10001',
495
+ },
496
+ ],
497
+ click: {
498
+ fbp: 'fb.2.1715603578424.5068754021',
499
+ fbpCollectedAt: '2024-05-13T12:32:58.424Z',
500
+ gclid: 'original_gclid',
501
+ },
502
+ ipAddress: '192.168.1.100',
503
+ version: '2',
504
+ },
505
+ };
506
+ const incomingIdentity = {
507
+ identityId: '01HXRZ27H4TXWBBTRK09Q7APDP',
508
+ traits: {
509
+ emails: ['user@domain.com', 'user.secondary@domain.com'],
510
+ phones: ['+1234567890'],
511
+ addresses: [
512
+ {
513
+ city: 'New York',
514
+ country: 'USA',
515
+ countryCode: 'US',
516
+ province: 'NY',
517
+ provinceCode: '10001',
518
+ },
519
+ ],
520
+ click: {
521
+ fbp: 'fb.2.1715603578424.5068754021',
522
+ fbpCollectedAt: '2024-05-13T15:30:00.000Z',
523
+ gclid: 'updated_gclid',
524
+ },
525
+ ipAddress: '192.168.1.100',
526
+ version: '2',
527
+ },
528
+ };
529
+ const mergedTraits = (0, at_shared_utils_1.mergeIdentityTraits)(cachedIdentity.traits, incomingIdentity.traits);
530
+ const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
531
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, mergedIdentity);
532
+ expect(result.isCacheStale).toBe(true);
533
+ expect(result.isEmailsStale).toBe(true);
534
+ expect(result.isPhonesStale).toBe(true);
535
+ expect(result.isClickInfosStale).toBe(true);
536
+ expect(result.isAddressesStale).toBe(false);
537
+ expect(result.isIpAddressStale).toBe(false);
538
+ expect(mergedIdentity.traits?.emails).toEqual(['user@domain.com', 'user.secondary@domain.com']);
539
+ expect(mergedIdentity.traits?.phones).toEqual(['+1234567890']);
540
+ expect(mergedIdentity.traits?.userIds).toEqual(['shopify_123']);
541
+ expect(mergedIdentity.traits?.click?.gclid).toEqual('updated_gclid');
542
+ });
543
+ it('should properly detect click staleness when click info actually differs', () => {
544
+ const cachedIdentity = {
545
+ identityId: 'test-id',
546
+ traits: {
547
+ click: {
548
+ gclid: 'original_gclid',
549
+ gclidCollectedAt: '2024-05-15T12:32:58.424Z',
550
+ },
551
+ },
552
+ };
553
+ const incomingIdentity = {
554
+ identityId: 'test-id',
555
+ traits: {
556
+ click: {
557
+ gclid: 'completely_different_gclid',
558
+ gclidCollectedAt: '2024-05-13T12:32:58.424Z',
559
+ },
560
+ },
561
+ };
562
+ const mergedTraits = (0, at_shared_utils_1.mergeIdentityTraits)(cachedIdentity.traits, incomingIdentity.traits);
563
+ const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
564
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, mergedIdentity);
565
+ expect(mergedTraits?.click?.gclid).toEqual('original_gclid');
566
+ expect(result.isCacheStale).toBe(false);
567
+ });
568
+ it('should handle scenario where cache is fresh', () => {
569
+ const cachedIdentity = {
570
+ identityId: 'test-id',
571
+ traits: {
572
+ emails: ['user@domain.com', 'secondary@domain.com'],
573
+ userIds: ['user1', 'user2'],
574
+ phones: ['+1234567890'],
575
+ version: '2',
576
+ },
577
+ };
578
+ const incomingIdentity = {
579
+ identityId: 'test-id',
580
+ traits: {
581
+ emails: ['user@domain.com'],
582
+ userIds: ['user1'],
583
+ version: '2',
584
+ },
585
+ };
586
+ const mergedTraits = (0, at_shared_utils_1.mergeIdentityTraits)(cachedIdentity.traits, incomingIdentity.traits);
587
+ const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
588
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, mergedIdentity);
589
+ expect(result.isCacheStale).toBe(false);
590
+ expect(mergedIdentity.traits?.emails).toEqual(['user@domain.com', 'secondary@domain.com']);
591
+ expect(mergedIdentity.traits?.userIds).toEqual(['user1', 'user2']);
592
+ expect(mergedIdentity.traits?.phones).toEqual(['+1234567890']);
593
+ });
594
+ });
595
+ });
596
+ describe('Three-Tier Staleness Model Tests', () => {
597
+ afterEach(() => {
598
+ jest.resetModules();
599
+ });
600
+ describe('TIER 1: VOLATILE_ONLY (no action needed)', () => {
601
+ it('should return VOLATILE_ONLY tier when only ipAddress is stale', () => {
602
+ const cachedIdentity = {
603
+ identityId: 'test-id',
604
+ traits: {
605
+ emails: ['test@email.com'],
606
+ ipAddress: '192.168.1.1',
607
+ },
608
+ };
609
+ const incomingIdentity = {
610
+ identityId: 'test-id',
611
+ traits: {
612
+ emails: ['test@email.com'],
613
+ ipAddress: '10.0.0.1',
614
+ },
615
+ };
616
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
617
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.VOLATILE_ONLY);
618
+ expect(result.isCacheStale).toBe(false);
619
+ expect(result.isIpAddressStale).toBe(true);
620
+ });
621
+ it('should return VOLATILE_ONLY tier when only userAgent is stale', () => {
622
+ const cachedIdentity = {
623
+ identityId: 'test-id',
624
+ traits: {
625
+ emails: ['test@email.com'],
626
+ userAgent: 'Mozilla/5.0 (old)',
627
+ },
628
+ };
629
+ const incomingIdentity = {
630
+ identityId: 'test-id',
631
+ traits: {
632
+ emails: ['test@email.com'],
633
+ userAgent: 'Mozilla/5.0 (new)',
634
+ },
635
+ };
636
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
637
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.VOLATILE_ONLY);
638
+ expect(result.isCacheStale).toBe(false);
639
+ expect(result.isUserAgentStale).toBe(true);
640
+ });
641
+ it('should return VOLATILE_ONLY tier when only IP-sourced addresses are stale', () => {
642
+ const cachedIdentity = {
643
+ identityId: 'test-id',
644
+ traits: {
645
+ emails: ['test@email.com'],
646
+ addresses: [
647
+ { city: 'New York', country: 'USA', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.IP_ADDRESS },
648
+ ],
649
+ },
650
+ };
651
+ const incomingIdentity = {
652
+ identityId: 'test-id',
653
+ traits: {
654
+ emails: ['test@email.com'],
655
+ addresses: [
656
+ { city: 'Los Angeles', country: 'USA', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.IP_ADDRESS },
657
+ ],
658
+ },
659
+ };
660
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
661
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.VOLATILE_ONLY);
662
+ expect(result.isCacheStale).toBe(false);
663
+ expect(result.isIpAddressesStale).toBe(true);
664
+ expect(result.isNonIpAddressesStale).toBe(false);
665
+ });
666
+ it('should return VOLATILE_ONLY tier when multiple volatile traits are stale', () => {
667
+ const cachedIdentity = {
668
+ identityId: 'test-id',
669
+ traits: {
670
+ emails: ['test@email.com'],
671
+ ipAddress: '192.168.1.1',
672
+ userAgent: 'Mozilla/5.0 (old)',
673
+ addresses: [
674
+ { city: 'New York', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.IP_ADDRESS },
675
+ ],
676
+ },
677
+ };
678
+ const incomingIdentity = {
679
+ identityId: 'test-id',
680
+ traits: {
681
+ emails: ['test@email.com'],
682
+ ipAddress: '10.0.0.1',
683
+ userAgent: 'Mozilla/5.0 (new)',
684
+ addresses: [
685
+ { city: 'Chicago', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.IP_ADDRESS },
686
+ ],
687
+ },
688
+ };
689
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
690
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.VOLATILE_ONLY);
691
+ expect(result.isCacheStale).toBe(false);
692
+ expect(result.isIpAddressStale).toBe(true);
693
+ expect(result.isUserAgentStale).toBe(true);
694
+ expect(result.isIpAddressesStale).toBe(true);
695
+ });
696
+ });
697
+ describe('TIER 2: ADDRESS_UPDATE (cache write only, skip Neptune)', () => {
698
+ it('should return ADDRESS_UPDATE tier when non-IP address is new', () => {
699
+ const cachedIdentity = {
700
+ identityId: 'test-id',
701
+ traits: {
702
+ emails: ['test@email.com'],
703
+ addresses: [],
704
+ },
705
+ };
706
+ const incomingIdentity = {
707
+ identityId: 'test-id',
708
+ traits: {
709
+ emails: ['test@email.com'],
710
+ addresses: [
711
+ { city: 'Boston', province: 'MA', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
712
+ ],
713
+ },
714
+ };
715
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
716
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.ADDRESS_UPDATE);
717
+ expect(result.isCacheStale).toBe(true);
718
+ expect(result.isNonIpAddressesStale).toBe(true);
719
+ });
720
+ it('should return ADDRESS_UPDATE tier when new input address added', () => {
721
+ const cachedIdentity = {
722
+ identityId: 'test-id',
723
+ traits: {
724
+ emails: ['test@email.com'],
725
+ addresses: [
726
+ { city: 'New York', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
727
+ ],
728
+ },
729
+ };
730
+ const incomingIdentity = {
731
+ identityId: 'test-id',
732
+ traits: {
733
+ emails: ['test@email.com'],
734
+ addresses: [
735
+ { city: 'New York', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
736
+ { city: 'Boston', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
737
+ ],
738
+ },
739
+ };
740
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
741
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.ADDRESS_UPDATE);
742
+ expect(result.isCacheStale).toBe(true);
743
+ expect(result.isNonIpAddressesStale).toBe(true);
744
+ });
745
+ it('should return ADDRESS_UPDATE tier even when volatile traits are also stale', () => {
746
+ const cachedIdentity = {
747
+ identityId: 'test-id',
748
+ traits: {
749
+ emails: ['test@email.com'],
750
+ ipAddress: '192.168.1.1',
751
+ addresses: [],
752
+ },
753
+ };
754
+ const incomingIdentity = {
755
+ identityId: 'test-id',
756
+ traits: {
757
+ emails: ['test@email.com'],
758
+ ipAddress: '10.0.0.1',
759
+ addresses: [
760
+ { city: 'Boston', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
761
+ ],
762
+ },
763
+ };
764
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
765
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.ADDRESS_UPDATE);
766
+ expect(result.isCacheStale).toBe(true);
767
+ expect(result.isIpAddressStale).toBe(true);
768
+ expect(result.isNonIpAddressesStale).toBe(true);
769
+ });
770
+ });
771
+ describe('TIER 3: IDENTITY_STALE (full Neptune resolution)', () => {
772
+ it('should return IDENTITY_STALE tier when email is new', () => {
773
+ const cachedIdentity = {
774
+ identityId: 'test-id',
775
+ traits: {
776
+ emails: ['old@email.com'],
777
+ },
778
+ };
779
+ const incomingIdentity = {
780
+ identityId: 'test-id',
781
+ traits: {
782
+ emails: ['old@email.com', 'new@email.com'],
783
+ },
784
+ };
785
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
786
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.IDENTITY_STALE);
787
+ expect(result.isCacheStale).toBe(true);
788
+ expect(result.isEmailsStale).toBe(true);
789
+ });
790
+ it('should return IDENTITY_STALE tier when identityId changes', () => {
791
+ const cachedIdentity = {
792
+ identityId: 'old-id',
793
+ traits: { emails: ['test@email.com'] },
794
+ };
795
+ const incomingIdentity = {
796
+ identityId: 'new-id',
797
+ traits: { emails: ['test@email.com'] },
798
+ };
799
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
800
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.IDENTITY_STALE);
801
+ expect(result.isCacheStale).toBe(true);
802
+ expect(result.isIdentityIdStale).toBe(true);
803
+ });
804
+ it('should return IDENTITY_STALE tier when phone is new', () => {
805
+ const cachedIdentity = {
806
+ identityId: 'test-id',
807
+ traits: { phones: ['+1234567890'] },
808
+ };
809
+ const incomingIdentity = {
810
+ identityId: 'test-id',
811
+ traits: { phones: ['+1234567890', '+9876543210'] },
812
+ };
813
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
814
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.IDENTITY_STALE);
815
+ expect(result.isCacheStale).toBe(true);
816
+ expect(result.isPhonesStale).toBe(true);
817
+ });
818
+ it('should return IDENTITY_STALE tier when click info changes', () => {
819
+ const cachedIdentity = {
820
+ identityId: 'test-id',
821
+ traits: {
822
+ click: { gclid: 'old_gclid' },
823
+ },
824
+ };
825
+ const incomingIdentity = {
826
+ identityId: 'test-id',
827
+ traits: {
828
+ click: { gclid: 'new_gclid' },
829
+ },
830
+ };
831
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
832
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.IDENTITY_STALE);
833
+ expect(result.isCacheStale).toBe(true);
834
+ expect(result.isClickInfosStale).toBe(true);
835
+ });
836
+ it('should return IDENTITY_STALE tier when identity trait is stale even with ADDRESS_UPDATE', () => {
837
+ const cachedIdentity = {
838
+ identityId: 'test-id',
839
+ traits: {
840
+ emails: ['old@email.com'],
841
+ addresses: [],
842
+ },
843
+ };
844
+ const incomingIdentity = {
845
+ identityId: 'test-id',
846
+ traits: {
847
+ emails: ['old@email.com', 'new@email.com'],
848
+ addresses: [
849
+ { city: 'Boston', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
850
+ ],
851
+ },
852
+ };
853
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
854
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.IDENTITY_STALE);
855
+ expect(result.isCacheStale).toBe(true);
856
+ expect(result.isEmailsStale).toBe(true);
857
+ expect(result.isNonIpAddressesStale).toBe(true);
858
+ });
859
+ it('should return IDENTITY_STALE tier when identity trait is stale even with VOLATILE_ONLY', () => {
860
+ const cachedIdentity = {
861
+ identityId: 'test-id',
862
+ traits: {
863
+ emails: ['old@email.com'],
864
+ ipAddress: '192.168.1.1',
865
+ },
866
+ };
867
+ const incomingIdentity = {
868
+ identityId: 'test-id',
869
+ traits: {
870
+ emails: ['old@email.com', 'new@email.com'],
871
+ ipAddress: '10.0.0.1',
872
+ },
873
+ };
874
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
875
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.IDENTITY_STALE);
876
+ expect(result.isCacheStale).toBe(true);
877
+ expect(result.isEmailsStale).toBe(true);
878
+ expect(result.isIpAddressStale).toBe(true);
879
+ });
880
+ });
881
+ describe('TIER NONE: No staleness', () => {
882
+ it('should return NONE tier when nothing is stale', () => {
883
+ const cachedIdentity = {
884
+ identityId: 'test-id',
885
+ traits: {
886
+ emails: ['test@email.com'],
887
+ phones: ['+1234567890'],
888
+ ipAddress: '192.168.1.1',
889
+ },
890
+ };
891
+ const incomingIdentity = {
892
+ identityId: 'test-id',
893
+ traits: {
894
+ emails: ['test@email.com'],
895
+ phones: ['+1234567890'],
896
+ ipAddress: '192.168.1.1',
897
+ },
898
+ };
899
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
900
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.NONE);
901
+ expect(result.isCacheStale).toBe(false);
902
+ });
903
+ it('should return NONE tier when incoming is subset of cached', () => {
904
+ const cachedIdentity = {
905
+ identityId: 'test-id',
906
+ traits: {
907
+ emails: ['a@email.com', 'b@email.com'],
908
+ phones: ['+1234567890', '+9876543210'],
909
+ },
910
+ };
911
+ const incomingIdentity = {
912
+ identityId: 'test-id',
913
+ traits: {
914
+ emails: ['a@email.com'],
915
+ },
916
+ };
917
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
918
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.NONE);
919
+ expect(result.isCacheStale).toBe(false);
920
+ });
921
+ });
922
+ describe('Address source filtering', () => {
923
+ it('should correctly identify IP-sourced addresses', () => {
924
+ const cachedIdentity = {
925
+ identityId: 'test-id',
926
+ traits: {
927
+ addresses: [
928
+ { city: 'CachedCity', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.IP_ADDRESS },
929
+ ],
930
+ },
931
+ };
932
+ const incomingIdentity = {
933
+ identityId: 'test-id',
934
+ traits: {
935
+ addresses: [
936
+ { city: 'NewCity', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.IP_ADDRESS },
937
+ ],
938
+ },
939
+ };
940
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
941
+ expect(result.isIpAddressesStale).toBe(true);
942
+ expect(result.isNonIpAddressesStale).toBe(false);
943
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.VOLATILE_ONLY);
944
+ });
945
+ it('should correctly identify INPUT-sourced addresses', () => {
946
+ const cachedIdentity = {
947
+ identityId: 'test-id',
948
+ traits: {
949
+ addresses: [
950
+ { city: 'CachedCity', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
951
+ ],
952
+ },
953
+ };
954
+ const incomingIdentity = {
955
+ identityId: 'test-id',
956
+ traits: {
957
+ addresses: [
958
+ { city: 'CachedCity', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
959
+ { city: 'NewCity', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
960
+ ],
961
+ },
962
+ };
963
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
964
+ expect(result.isIpAddressesStale).toBe(false);
965
+ expect(result.isNonIpAddressesStale).toBe(true);
966
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.ADDRESS_UPDATE);
967
+ });
968
+ it('should handle mixed address sources correctly', () => {
969
+ const cachedIdentity = {
970
+ identityId: 'test-id',
971
+ traits: {
972
+ addresses: [
973
+ { city: 'IPCity', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.IP_ADDRESS },
974
+ { city: 'InputCity', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
975
+ ],
976
+ },
977
+ };
978
+ const incomingIdentity = {
979
+ identityId: 'test-id',
980
+ traits: {
981
+ addresses: [
982
+ { city: 'NewIPCity', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.IP_ADDRESS },
983
+ { city: 'InputCity', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
984
+ { city: 'NewInputCity', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.INPUT },
985
+ ],
986
+ },
987
+ };
988
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
989
+ expect(result.isIpAddressesStale).toBe(true);
990
+ expect(result.isNonIpAddressesStale).toBe(true);
991
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.ADDRESS_UPDATE);
992
+ expect(result.isCacheStale).toBe(true);
993
+ });
994
+ it('should handle addresses without source field (default to IP based on PII)', () => {
995
+ const cachedIdentity = {
996
+ identityId: 'test-id',
997
+ traits: {
998
+ addresses: [],
999
+ },
1000
+ };
1001
+ const incomingIdentity = {
1002
+ identityId: 'test-id',
1003
+ traits: {
1004
+ addresses: [
1005
+ { city: 'NoSourceCity' },
1006
+ ],
1007
+ },
1008
+ };
1009
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
1010
+ expect(result.isIpAddressesStale).toBe(true);
1011
+ expect(result.isNonIpAddressesStale).toBe(false);
1012
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.VOLATILE_ONLY);
1013
+ expect(result.isCacheStale).toBe(false);
1014
+ });
1015
+ it('should treat addresses without source but with PII as non-IP', () => {
1016
+ const cachedIdentity = {
1017
+ identityId: 'test-id',
1018
+ traits: {
1019
+ addresses: [],
1020
+ },
1021
+ };
1022
+ const incomingIdentity = {
1023
+ identityId: 'test-id',
1024
+ traits: {
1025
+ addresses: [
1026
+ { city: 'InputCity', firstName: 'John' },
1027
+ ],
1028
+ },
1029
+ };
1030
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
1031
+ expect(result.isNonIpAddressesStale).toBe(true);
1032
+ expect(result.isIpAddressesStale).toBe(false);
1033
+ expect(result.staleTier).toBe(identity_cache_helper_1.IDENTITY_CACHE_STALENESS_TIER.ADDRESS_UPDATE);
1034
+ expect(result.isCacheStale).toBe(true);
1035
+ });
1036
+ });
1037
+ describe('Backward compatibility', () => {
1038
+ it('should maintain isAddressesStale for any address change', () => {
1039
+ const cachedIdentity = {
1040
+ identityId: 'test-id',
1041
+ traits: {
1042
+ addresses: [
1043
+ { city: 'OldCity', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.IP_ADDRESS },
1044
+ ],
1045
+ },
1046
+ };
1047
+ const incomingIdentity = {
1048
+ identityId: 'test-id',
1049
+ traits: {
1050
+ addresses: [
1051
+ { city: 'NewCity', s: at_tracking_event_types_1.ADDRESS_INFO_SOURCE.IP_ADDRESS },
1052
+ ],
1053
+ },
1054
+ };
1055
+ const result = (0, identity_cache_helper_1.isIdentityCacheStale)(cachedIdentity, incomingIdentity);
1056
+ expect(result.isAddressesStale).toBe(true);
1057
+ expect(result.isCacheStale).toBe(false);
1058
+ });
1059
+ });
1060
+ });
589
1061
  //# sourceMappingURL=trait-merging-and-staleness.spec.js.map