@adtrackify/at-service-common 3.5.27 → 3.5.29

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 (557) hide show
  1. package/dist/cjs/__tests__/helpers/account-users-helper.spec.d.ts +1 -1
  2. package/dist/cjs/__tests__/helpers/account-users-helper.spec.js +220 -200
  3. package/dist/cjs/__tests__/helpers/account-users-helper.spec.js.map +1 -1
  4. package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.d.ts +1 -1
  5. package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.js +674 -674
  6. package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.js.map +1 -1
  7. package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.d.ts +1 -1
  8. package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.js +588 -586
  9. package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.js.map +1 -1
  10. package/dist/cjs/__tests__/libs/compress-decompress.spec.d.ts +1 -1
  11. package/dist/cjs/__tests__/libs/compress-decompress.spec.js +16 -16
  12. package/dist/cjs/__tests__/libs/compress-decompress.spec.js.map +1 -1
  13. package/dist/cjs/__tests__/libs/currency.spec.d.ts +1 -1
  14. package/dist/cjs/__tests__/libs/currency.spec.js +220 -220
  15. package/dist/cjs/__tests__/libs/currency.spec.js.map +1 -1
  16. package/dist/cjs/__tests__/libs/dates.spec.d.ts +1 -1
  17. package/dist/cjs/__tests__/libs/dates.spec.js +130 -132
  18. package/dist/cjs/__tests__/libs/dates.spec.js.map +1 -1
  19. package/dist/cjs/__tests__/libs/domain.spec.d.ts +1 -1
  20. package/dist/cjs/__tests__/libs/domain.spec.js +107 -107
  21. package/dist/cjs/__tests__/libs/numbers.spec.d.ts +1 -1
  22. package/dist/cjs/__tests__/libs/numbers.spec.js +261 -261
  23. package/dist/cjs/__tests__/s3-client/s3-client.spec.d.ts +1 -1
  24. package/dist/cjs/__tests__/s3-client/s3-client.spec.js +33 -26
  25. package/dist/cjs/__tests__/s3-client/s3-client.spec.js.map +1 -1
  26. package/dist/cjs/__tests__/shopify/shopify-graphql-transformer.spec.d.ts +1 -1
  27. package/dist/cjs/__tests__/shopify/shopify-graphql-transformer.spec.js +35 -35
  28. package/dist/cjs/__tests__/shopify/shopify-graphql-transformer.spec.js.map +1 -1
  29. package/dist/cjs/clients/generic/cognito-client.d.ts +23 -23
  30. package/dist/cjs/clients/generic/cognito-client.js +209 -209
  31. package/dist/cjs/clients/generic/cognito-client.js.map +1 -1
  32. package/dist/cjs/clients/generic/dynamodb-client.d.ts +17 -17
  33. package/dist/cjs/clients/generic/dynamodb-client.js +170 -170
  34. package/dist/cjs/clients/generic/dynamodb-client.js.map +1 -1
  35. package/dist/cjs/clients/generic/eventbridge-client.d.ts +14 -14
  36. package/dist/cjs/clients/generic/eventbridge-client.js +51 -49
  37. package/dist/cjs/clients/generic/eventbridge-client.js.map +1 -1
  38. package/dist/cjs/clients/generic/http-client.d.ts +14 -14
  39. package/dist/cjs/clients/generic/http-client.js +61 -61
  40. package/dist/cjs/clients/generic/http-client.js.map +1 -1
  41. package/dist/cjs/clients/generic/index.d.ts +10 -10
  42. package/dist/cjs/clients/generic/index.js +26 -26
  43. package/dist/cjs/clients/generic/lambda-invoke-client.d.ts +10 -10
  44. package/dist/cjs/clients/generic/lambda-invoke-client.js +35 -35
  45. package/dist/cjs/clients/generic/lambda-invoke-client.js.map +1 -1
  46. package/dist/cjs/clients/generic/location-client.d.ts +8 -8
  47. package/dist/cjs/clients/generic/location-client.js +31 -31
  48. package/dist/cjs/clients/generic/location-client.js.map +1 -1
  49. package/dist/cjs/clients/generic/redis-client.d.ts +18 -18
  50. package/dist/cjs/clients/generic/redis-client.js +128 -128
  51. package/dist/cjs/clients/generic/redis-client.js.map +1 -1
  52. package/dist/cjs/clients/generic/s3-client.d.ts +23 -23
  53. package/dist/cjs/clients/generic/s3-client.js +216 -198
  54. package/dist/cjs/clients/generic/s3-client.js.map +1 -1
  55. package/dist/cjs/clients/generic/singlestore-db-client.d.ts +14 -14
  56. package/dist/cjs/clients/generic/singlestore-db-client.js +67 -67
  57. package/dist/cjs/clients/generic/sqs-client.d.ts +20 -20
  58. package/dist/cjs/clients/generic/sqs-client.js +36 -36
  59. package/dist/cjs/clients/generic/sqs-client.js.map +1 -1
  60. package/dist/cjs/clients/index.d.ts +3 -3
  61. package/dist/cjs/clients/index.js +19 -19
  62. package/dist/cjs/clients/internal-api/accounts-client.d.ts +83 -83
  63. package/dist/cjs/clients/internal-api/accounts-client.js +129 -107
  64. package/dist/cjs/clients/internal-api/accounts-client.js.map +1 -1
  65. package/dist/cjs/clients/internal-api/cache-lambda-client.d.ts +25 -25
  66. package/dist/cjs/clients/internal-api/cache-lambda-client.js +87 -79
  67. package/dist/cjs/clients/internal-api/cache-lambda-client.js.map +1 -1
  68. package/dist/cjs/clients/internal-api/db-management-client.d.ts +18 -18
  69. package/dist/cjs/clients/internal-api/db-management-client.js +36 -36
  70. package/dist/cjs/clients/internal-api/destinations-client.d.ts +33 -27
  71. package/dist/cjs/clients/internal-api/destinations-client.js +72 -51
  72. package/dist/cjs/clients/internal-api/destinations-client.js.map +1 -1
  73. package/dist/cjs/clients/internal-api/event-collector-client.d.ts +20 -20
  74. package/dist/cjs/clients/internal-api/event-collector-client.js +36 -36
  75. package/dist/cjs/clients/internal-api/event-collector-client.js.map +1 -1
  76. package/dist/cjs/clients/internal-api/identity-client.d.ts +31 -31
  77. package/dist/cjs/clients/internal-api/identity-client.js +91 -83
  78. package/dist/cjs/clients/internal-api/identity-client.js.map +1 -1
  79. package/dist/cjs/clients/internal-api/index.d.ts +9 -9
  80. package/dist/cjs/clients/internal-api/index.js +25 -25
  81. package/dist/cjs/clients/internal-api/shopify-app-install-client.d.ts +37 -37
  82. package/dist/cjs/clients/internal-api/shopify-app-install-client.js +81 -73
  83. package/dist/cjs/clients/internal-api/shopify-app-install-client.js.map +1 -1
  84. package/dist/cjs/clients/internal-api/subscriptions-client.d.ts +26 -26
  85. package/dist/cjs/clients/internal-api/subscriptions-client.js +77 -73
  86. package/dist/cjs/clients/internal-api/subscriptions-client.js.map +1 -1
  87. package/dist/cjs/clients/internal-api/users-auth-client.d.ts +35 -35
  88. package/dist/cjs/clients/internal-api/users-auth-client.js +110 -110
  89. package/dist/cjs/clients/internal-api/users-auth-client.js.map +1 -1
  90. package/dist/cjs/clients/third-party/emailable-client.d.ts +7 -7
  91. package/dist/cjs/clients/third-party/emailable-client.js +25 -25
  92. package/dist/cjs/clients/third-party/emailable-client.js.map +1 -1
  93. package/dist/cjs/clients/third-party/exchange-rate-api-client.d.ts +17 -17
  94. package/dist/cjs/clients/third-party/exchange-rate-api-client.js +19 -19
  95. package/dist/cjs/clients/third-party/exchange-rate-api-client.js.map +1 -1
  96. package/dist/cjs/clients/third-party/index.d.ts +3 -3
  97. package/dist/cjs/clients/third-party/index.js +19 -19
  98. package/dist/cjs/clients/third-party/loops-client.d.ts +10 -10
  99. package/dist/cjs/clients/third-party/loops-client.js +30 -30
  100. package/dist/cjs/clients/third-party/shopify/graphql-product-queries.d.ts +2 -2
  101. package/dist/cjs/clients/third-party/shopify/graphql-product-queries.js +5 -5
  102. package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.d.ts +9 -9
  103. package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.js +115 -95
  104. package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.js.map +1 -1
  105. package/dist/cjs/clients/third-party/shopify-client.d.ts +29 -29
  106. package/dist/cjs/clients/third-party/shopify-client.js +146 -144
  107. package/dist/cjs/clients/third-party/shopify-client.js.map +1 -1
  108. package/dist/cjs/helpers/account-users-helper.d.ts +2 -2
  109. package/dist/cjs/helpers/account-users-helper.js +22 -22
  110. package/dist/cjs/helpers/account-users-helper.js.map +1 -1
  111. package/dist/cjs/helpers/identity-cache-helper.d.ts +21 -21
  112. package/dist/cjs/helpers/identity-cache-helper.js +156 -157
  113. package/dist/cjs/helpers/identity-cache-helper.js.map +1 -1
  114. package/dist/cjs/helpers/index.d.ts +8 -6
  115. package/dist/cjs/helpers/index.js +24 -22
  116. package/dist/cjs/helpers/index.js.map +1 -1
  117. package/dist/cjs/helpers/input-validation-helper.d.ts +3 -3
  118. package/dist/cjs/helpers/input-validation-helper.js +22 -22
  119. package/dist/cjs/helpers/logging-helper.d.ts +16 -16
  120. package/dist/cjs/helpers/logging-helper.js +84 -84
  121. package/dist/cjs/helpers/logging-helper.js.map +1 -1
  122. package/dist/cjs/helpers/response-helper.d.ts +18 -18
  123. package/dist/cjs/helpers/response-helper.js +43 -43
  124. package/dist/cjs/helpers/response-helper.js.map +1 -1
  125. package/dist/cjs/helpers/shopify-helper.d.ts +9 -9
  126. package/dist/cjs/helpers/shopify-helper.js +26 -28
  127. package/dist/cjs/helpers/shopify-helper.js.map +1 -1
  128. package/dist/cjs/helpers/sqs-utils.d.ts +6 -0
  129. package/dist/cjs/helpers/sqs-utils.js +15 -0
  130. package/dist/cjs/helpers/sqs-utils.js.map +1 -0
  131. package/dist/cjs/helpers/trend-utils.d.ts +3 -0
  132. package/dist/cjs/helpers/trend-utils.js +22 -0
  133. package/dist/cjs/helpers/trend-utils.js.map +1 -0
  134. package/dist/cjs/index.d.ts +5 -5
  135. package/dist/cjs/index.js +21 -21
  136. package/dist/cjs/libs/click-id-parser.d.ts +23 -23
  137. package/dist/cjs/libs/click-id-parser.js +49 -49
  138. package/dist/cjs/libs/click-id-parser.js.map +1 -1
  139. package/dist/cjs/libs/compression.d.ts +2 -2
  140. package/dist/cjs/libs/compression.js +33 -33
  141. package/dist/cjs/libs/compression.js.map +1 -1
  142. package/dist/cjs/libs/cookie.d.ts +12 -12
  143. package/dist/cjs/libs/cookie.js +70 -68
  144. package/dist/cjs/libs/cookie.js.map +1 -1
  145. package/dist/cjs/libs/crypto.d.ts +3 -3
  146. package/dist/cjs/libs/crypto.js +20 -20
  147. package/dist/cjs/libs/csv.d.ts +2 -2
  148. package/dist/cjs/libs/csv.js +35 -35
  149. package/dist/cjs/libs/csv.js.map +1 -1
  150. package/dist/cjs/libs/currency.d.ts +1 -1
  151. package/dist/cjs/libs/currency.js +29 -24
  152. package/dist/cjs/libs/currency.js.map +1 -1
  153. package/dist/cjs/libs/dates.d.ts +12 -12
  154. package/dist/cjs/libs/dates.js +96 -96
  155. package/dist/cjs/libs/dates.js.map +1 -1
  156. package/dist/cjs/libs/domain.d.ts +2 -2
  157. package/dist/cjs/libs/domain.js +38 -38
  158. package/dist/cjs/libs/emails.d.ts +6 -6
  159. package/dist/cjs/libs/emails.js +122 -122
  160. package/dist/cjs/libs/emails.js.map +1 -1
  161. package/dist/cjs/libs/http-error.d.ts +21 -21
  162. package/dist/cjs/libs/http-error.js +63 -59
  163. package/dist/cjs/libs/http-error.js.map +1 -1
  164. package/dist/cjs/libs/http-status-codes.d.ts +58 -58
  165. package/dist/cjs/libs/http-status-codes.js +62 -62
  166. package/dist/cjs/libs/index.d.ts +17 -17
  167. package/dist/cjs/libs/index.js +33 -33
  168. package/dist/cjs/libs/numbers.d.ts +1 -1
  169. package/dist/cjs/libs/numbers.js +15 -15
  170. package/dist/cjs/libs/referrer-parser/index.d.ts +2 -2
  171. package/dist/cjs/libs/referrer-parser/index.js +18 -18
  172. package/dist/cjs/libs/referrer-parser/referrer-data.d.ts +9 -9
  173. package/dist/cjs/libs/referrer-parser/referrer-data.js +3307 -4712
  174. package/dist/cjs/libs/referrer-parser/referrer-data.js.map +1 -1
  175. package/dist/cjs/libs/referrer-parser/referrer-parser-util.d.ts +20 -20
  176. package/dist/cjs/libs/referrer-parser/referrer-parser-util.js +131 -128
  177. package/dist/cjs/libs/referrer-parser/referrer-parser-util.js.map +1 -1
  178. package/dist/cjs/libs/strings.d.ts +3 -3
  179. package/dist/cjs/libs/strings.js +46 -46
  180. package/dist/cjs/libs/strings.js.map +1 -1
  181. package/dist/cjs/libs/traits.d.ts +6 -6
  182. package/dist/cjs/libs/traits.js +65 -65
  183. package/dist/cjs/libs/traits.js.map +1 -1
  184. package/dist/cjs/libs/url.d.ts +1 -1
  185. package/dist/cjs/libs/url.js +13 -13
  186. package/dist/cjs/libs/url.js.map +1 -1
  187. package/dist/cjs/services/cache/generic-cached-object.d.ts +5 -5
  188. package/dist/cjs/services/cache/generic-cached-object.js +2 -2
  189. package/dist/cjs/services/cache/index.d.ts +1 -1
  190. package/dist/cjs/services/cache/index.js +17 -17
  191. package/dist/cjs/services/cache/product-cache-service.d.ts +21 -21
  192. package/dist/cjs/services/cache/product-cache-service.js +76 -68
  193. package/dist/cjs/services/cache/product-cache-service.js.map +1 -1
  194. package/dist/cjs/services/currency-exchange-rate-lookup-service.d.ts +11 -11
  195. package/dist/cjs/services/currency-exchange-rate-lookup-service.js +66 -50
  196. package/dist/cjs/services/currency-exchange-rate-lookup-service.js.map +1 -1
  197. package/dist/cjs/services/db/currency-exchange-rates-db-service.d.ts +21 -21
  198. package/dist/cjs/services/db/currency-exchange-rates-db-service.js +39 -39
  199. package/dist/cjs/services/db/currency-exchange-rates-db-service.js.map +1 -1
  200. package/dist/cjs/services/db/destinations-db-service.d.ts +12 -11
  201. package/dist/cjs/services/db/destinations-db-service.js +76 -64
  202. package/dist/cjs/services/db/destinations-db-service.js.map +1 -1
  203. package/dist/cjs/services/db/identity-cache-db-service.d.ts +28 -28
  204. package/dist/cjs/services/db/identity-cache-db-service.js +320 -278
  205. package/dist/cjs/services/db/identity-cache-db-service.js.map +1 -1
  206. package/dist/cjs/services/db/index.d.ts +9 -9
  207. package/dist/cjs/services/db/index.js +25 -25
  208. package/dist/cjs/services/db/log-events-db-service.d.ts +11 -11
  209. package/dist/cjs/services/db/log-events-db-service.js +181 -172
  210. package/dist/cjs/services/db/log-events-db-service.js.map +1 -1
  211. package/dist/cjs/services/db/purchasable-contacts-db-service.d.ts +9 -9
  212. package/dist/cjs/services/db/purchasable-contacts-db-service.js +43 -43
  213. package/dist/cjs/services/db/purchasable-contacts-db-service.js.map +1 -1
  214. package/dist/cjs/services/db/purchased-contacts-db-service.d.ts +17 -17
  215. package/dist/cjs/services/db/purchased-contacts-db-service.js +143 -143
  216. package/dist/cjs/services/db/purchased-contacts-db-service.js.map +1 -1
  217. package/dist/cjs/services/db/shopify-app-installs-db-service.d.ts +7 -7
  218. package/dist/cjs/services/db/shopify-app-installs-db-service.js +47 -47
  219. package/dist/cjs/services/db/shopify-app-installs-db-service.js.map +1 -1
  220. package/dist/cjs/services/db/shopify-products-cache-db-service.d.ts +16 -16
  221. package/dist/cjs/services/db/shopify-products-cache-db-service.js +73 -65
  222. package/dist/cjs/services/db/shopify-products-cache-db-service.js.map +1 -1
  223. package/dist/cjs/services/db/tracking-events-db-service.d.ts +20 -20
  224. package/dist/cjs/services/db/tracking-events-db-service.js +165 -162
  225. package/dist/cjs/services/db/tracking-events-db-service.js.map +1 -1
  226. package/dist/cjs/services/eventbridge-integration-service.d.ts +9 -9
  227. package/dist/cjs/services/eventbridge-integration-service.js +28 -28
  228. package/dist/cjs/services/eventbridge-integration-service.js.map +1 -1
  229. package/dist/cjs/services/events/index.d.ts +3 -3
  230. package/dist/cjs/services/events/index.js +19 -19
  231. package/dist/cjs/services/events/log-event-service.d.ts +9 -9
  232. package/dist/cjs/services/events/log-event-service.js +56 -56
  233. package/dist/cjs/services/events/log-event-service.js.map +1 -1
  234. package/dist/cjs/services/events/metric-event-service.d.ts +9 -9
  235. package/dist/cjs/services/events/metric-event-service.js +49 -49
  236. package/dist/cjs/services/events/metric-event-service.js.map +1 -1
  237. package/dist/cjs/services/events/tracking-event-sqs-service.d.ts +8 -8
  238. package/dist/cjs/services/events/tracking-event-sqs-service.js +34 -29
  239. package/dist/cjs/services/events/tracking-event-sqs-service.js.map +1 -1
  240. package/dist/cjs/services/generic-cache-service.d.ts +7 -7
  241. package/dist/cjs/services/generic-cache-service.js +33 -33
  242. package/dist/cjs/services/generic-cache-service.js.map +1 -1
  243. package/dist/cjs/services/index.d.ts +8 -8
  244. package/dist/cjs/services/index.js +24 -24
  245. package/dist/cjs/services/ipdata-lookup-service.d.ts +19 -19
  246. package/dist/cjs/services/ipdata-lookup-service.js +77 -77
  247. package/dist/cjs/services/ipdata-lookup-service.js.map +1 -1
  248. package/dist/cjs/services/shopify/index.d.ts +3 -3
  249. package/dist/cjs/services/shopify/index.js +19 -19
  250. package/dist/cjs/services/shopify/products/index.d.ts +1 -1
  251. package/dist/cjs/services/shopify/products/index.js +17 -17
  252. package/dist/cjs/services/shopify/products/shopify-products-serviceV2.d.ts +17 -17
  253. package/dist/cjs/services/shopify/products/shopify-products-serviceV2.js +114 -103
  254. package/dist/cjs/services/shopify/products/shopify-products-serviceV2.js.map +1 -1
  255. package/dist/cjs/services/shopify/shopify-graphql-transformer.d.ts +9 -9
  256. package/dist/cjs/services/shopify/shopify-graphql-transformer.js +141 -137
  257. package/dist/cjs/services/shopify/shopify-graphql-transformer.js.map +1 -1
  258. package/dist/cjs/services/shopify/types/index.d.ts +1 -1
  259. package/dist/cjs/services/shopify/types/index.js +17 -17
  260. package/dist/cjs/services/shopify/types/product.d.ts +115 -115
  261. package/dist/cjs/services/shopify/types/product.js +9 -9
  262. package/dist/cjs/services/shopify/types/product.js.map +1 -1
  263. package/dist/cjs/types/api-response.d.ts +6 -6
  264. package/dist/cjs/types/api-response.js +2 -2
  265. package/dist/cjs/types/index.d.ts +1 -2
  266. package/dist/cjs/types/index.js +17 -18
  267. package/dist/cjs/types/index.js.map +1 -1
  268. package/dist/cjs/types/internal-events/event-detail-types.d.ts +20 -20
  269. package/dist/cjs/types/internal-events/event-detail-types.js +27 -27
  270. package/dist/cjs/types/internal-events/index.d.ts +1 -1
  271. package/dist/cjs/types/internal-events/index.js +17 -17
  272. package/dist/cjs/types/shopify-graphql-types/admin.generated.d.ts +105 -105
  273. package/dist/cjs/types/shopify-graphql-types/admin.generated.js +2 -2
  274. package/dist/cjs/types/shopify-graphql-types/admin.types.d.ts +26289 -26289
  275. package/dist/cjs/types/shopify-graphql-types/admin.types.js +5311 -5311
  276. package/dist/cjs/types/shopify-graphql-types/index.d.ts +2 -2
  277. package/dist/cjs/types/shopify-graphql-types/index.js +18 -18
  278. package/dist/cjs/types/shopify-graphql-types/index.js.map +1 -1
  279. package/dist/esm/__tests__/helpers/account-users-helper.spec.d.ts +1 -1
  280. package/dist/esm/__tests__/helpers/account-users-helper.spec.js +218 -198
  281. package/dist/esm/__tests__/helpers/account-users-helper.spec.js.map +1 -1
  282. package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.d.ts +1 -1
  283. package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.js +672 -672
  284. package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.js.map +1 -1
  285. package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.d.ts +1 -1
  286. package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.js +586 -584
  287. package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.js.map +1 -1
  288. package/dist/esm/__tests__/libs/compress-decompress.spec.d.ts +1 -1
  289. package/dist/esm/__tests__/libs/compress-decompress.spec.js +14 -14
  290. package/dist/esm/__tests__/libs/compress-decompress.spec.js.map +1 -1
  291. package/dist/esm/__tests__/libs/currency.spec.d.ts +1 -1
  292. package/dist/esm/__tests__/libs/currency.spec.js +218 -218
  293. package/dist/esm/__tests__/libs/currency.spec.js.map +1 -1
  294. package/dist/esm/__tests__/libs/dates.spec.d.ts +1 -1
  295. package/dist/esm/__tests__/libs/dates.spec.js +128 -130
  296. package/dist/esm/__tests__/libs/dates.spec.js.map +1 -1
  297. package/dist/esm/__tests__/libs/domain.spec.d.ts +1 -1
  298. package/dist/esm/__tests__/libs/domain.spec.js +105 -105
  299. package/dist/esm/__tests__/libs/numbers.spec.d.ts +1 -1
  300. package/dist/esm/__tests__/libs/numbers.spec.js +259 -259
  301. package/dist/esm/__tests__/s3-client/s3-client.spec.d.ts +1 -1
  302. package/dist/esm/__tests__/s3-client/s3-client.spec.js +31 -24
  303. package/dist/esm/__tests__/s3-client/s3-client.spec.js.map +1 -1
  304. package/dist/esm/__tests__/shopify/shopify-graphql-transformer.spec.d.ts +1 -1
  305. package/dist/esm/__tests__/shopify/shopify-graphql-transformer.spec.js +33 -33
  306. package/dist/esm/__tests__/shopify/shopify-graphql-transformer.spec.js.map +1 -1
  307. package/dist/esm/clients/generic/cognito-client.d.ts +23 -23
  308. package/dist/esm/clients/generic/cognito-client.js +204 -204
  309. package/dist/esm/clients/generic/cognito-client.js.map +1 -1
  310. package/dist/esm/clients/generic/dynamodb-client.d.ts +17 -17
  311. package/dist/esm/clients/generic/dynamodb-client.js +166 -166
  312. package/dist/esm/clients/generic/dynamodb-client.js.map +1 -1
  313. package/dist/esm/clients/generic/eventbridge-client.d.ts +14 -14
  314. package/dist/esm/clients/generic/eventbridge-client.js +47 -45
  315. package/dist/esm/clients/generic/eventbridge-client.js.map +1 -1
  316. package/dist/esm/clients/generic/http-client.d.ts +14 -14
  317. package/dist/esm/clients/generic/http-client.js +53 -53
  318. package/dist/esm/clients/generic/http-client.js.map +1 -1
  319. package/dist/esm/clients/generic/index.d.ts +10 -10
  320. package/dist/esm/clients/generic/index.js +10 -10
  321. package/dist/esm/clients/generic/lambda-invoke-client.d.ts +10 -10
  322. package/dist/esm/clients/generic/lambda-invoke-client.js +31 -31
  323. package/dist/esm/clients/generic/lambda-invoke-client.js.map +1 -1
  324. package/dist/esm/clients/generic/location-client.d.ts +8 -8
  325. package/dist/esm/clients/generic/location-client.js +27 -27
  326. package/dist/esm/clients/generic/location-client.js.map +1 -1
  327. package/dist/esm/clients/generic/redis-client.d.ts +18 -18
  328. package/dist/esm/clients/generic/redis-client.js +121 -121
  329. package/dist/esm/clients/generic/redis-client.js.map +1 -1
  330. package/dist/esm/clients/generic/s3-client.d.ts +23 -23
  331. package/dist/esm/clients/generic/s3-client.js +209 -191
  332. package/dist/esm/clients/generic/s3-client.js.map +1 -1
  333. package/dist/esm/clients/generic/singlestore-db-client.d.ts +14 -14
  334. package/dist/esm/clients/generic/singlestore-db-client.js +40 -40
  335. package/dist/esm/clients/generic/sqs-client.d.ts +20 -20
  336. package/dist/esm/clients/generic/sqs-client.js +32 -32
  337. package/dist/esm/clients/generic/sqs-client.js.map +1 -1
  338. package/dist/esm/clients/index.d.ts +3 -3
  339. package/dist/esm/clients/index.js +3 -3
  340. package/dist/esm/clients/internal-api/accounts-client.d.ts +83 -83
  341. package/dist/esm/clients/internal-api/accounts-client.js +125 -103
  342. package/dist/esm/clients/internal-api/accounts-client.js.map +1 -1
  343. package/dist/esm/clients/internal-api/cache-lambda-client.d.ts +25 -25
  344. package/dist/esm/clients/internal-api/cache-lambda-client.js +83 -75
  345. package/dist/esm/clients/internal-api/cache-lambda-client.js.map +1 -1
  346. package/dist/esm/clients/internal-api/db-management-client.d.ts +18 -18
  347. package/dist/esm/clients/internal-api/db-management-client.js +32 -32
  348. package/dist/esm/clients/internal-api/destinations-client.d.ts +33 -27
  349. package/dist/esm/clients/internal-api/destinations-client.js +68 -47
  350. package/dist/esm/clients/internal-api/destinations-client.js.map +1 -1
  351. package/dist/esm/clients/internal-api/event-collector-client.d.ts +20 -20
  352. package/dist/esm/clients/internal-api/event-collector-client.js +32 -32
  353. package/dist/esm/clients/internal-api/event-collector-client.js.map +1 -1
  354. package/dist/esm/clients/internal-api/identity-client.d.ts +31 -31
  355. package/dist/esm/clients/internal-api/identity-client.js +87 -79
  356. package/dist/esm/clients/internal-api/identity-client.js.map +1 -1
  357. package/dist/esm/clients/internal-api/index.d.ts +9 -9
  358. package/dist/esm/clients/internal-api/index.js +9 -9
  359. package/dist/esm/clients/internal-api/shopify-app-install-client.d.ts +37 -37
  360. package/dist/esm/clients/internal-api/shopify-app-install-client.js +77 -69
  361. package/dist/esm/clients/internal-api/shopify-app-install-client.js.map +1 -1
  362. package/dist/esm/clients/internal-api/subscriptions-client.d.ts +26 -26
  363. package/dist/esm/clients/internal-api/subscriptions-client.js +73 -69
  364. package/dist/esm/clients/internal-api/subscriptions-client.js.map +1 -1
  365. package/dist/esm/clients/internal-api/users-auth-client.d.ts +35 -35
  366. package/dist/esm/clients/internal-api/users-auth-client.js +106 -106
  367. package/dist/esm/clients/internal-api/users-auth-client.js.map +1 -1
  368. package/dist/esm/clients/third-party/emailable-client.d.ts +7 -7
  369. package/dist/esm/clients/third-party/emailable-client.js +21 -21
  370. package/dist/esm/clients/third-party/emailable-client.js.map +1 -1
  371. package/dist/esm/clients/third-party/exchange-rate-api-client.d.ts +17 -17
  372. package/dist/esm/clients/third-party/exchange-rate-api-client.js +15 -15
  373. package/dist/esm/clients/third-party/exchange-rate-api-client.js.map +1 -1
  374. package/dist/esm/clients/third-party/index.d.ts +3 -3
  375. package/dist/esm/clients/third-party/index.js +3 -3
  376. package/dist/esm/clients/third-party/loops-client.d.ts +10 -10
  377. package/dist/esm/clients/third-party/loops-client.js +26 -26
  378. package/dist/esm/clients/third-party/shopify/graphql-product-queries.d.ts +2 -2
  379. package/dist/esm/clients/third-party/shopify/graphql-product-queries.js +2 -2
  380. package/dist/esm/clients/third-party/shopify/shopify-graphql-client.d.ts +9 -9
  381. package/dist/esm/clients/third-party/shopify/shopify-graphql-client.js +111 -91
  382. package/dist/esm/clients/third-party/shopify/shopify-graphql-client.js.map +1 -1
  383. package/dist/esm/clients/third-party/shopify-client.d.ts +29 -29
  384. package/dist/esm/clients/third-party/shopify-client.js +142 -140
  385. package/dist/esm/clients/third-party/shopify-client.js.map +1 -1
  386. package/dist/esm/helpers/account-users-helper.d.ts +2 -2
  387. package/dist/esm/helpers/account-users-helper.js +18 -18
  388. package/dist/esm/helpers/account-users-helper.js.map +1 -1
  389. package/dist/esm/helpers/identity-cache-helper.d.ts +21 -21
  390. package/dist/esm/helpers/identity-cache-helper.js +151 -152
  391. package/dist/esm/helpers/identity-cache-helper.js.map +1 -1
  392. package/dist/esm/helpers/index.d.ts +8 -6
  393. package/dist/esm/helpers/index.js +8 -6
  394. package/dist/esm/helpers/index.js.map +1 -1
  395. package/dist/esm/helpers/input-validation-helper.d.ts +3 -3
  396. package/dist/esm/helpers/input-validation-helper.js +18 -18
  397. package/dist/esm/helpers/logging-helper.d.ts +16 -16
  398. package/dist/esm/helpers/logging-helper.js +56 -56
  399. package/dist/esm/helpers/logging-helper.js.map +1 -1
  400. package/dist/esm/helpers/response-helper.d.ts +18 -18
  401. package/dist/esm/helpers/response-helper.js +37 -37
  402. package/dist/esm/helpers/response-helper.js.map +1 -1
  403. package/dist/esm/helpers/shopify-helper.d.ts +9 -9
  404. package/dist/esm/helpers/shopify-helper.js +21 -23
  405. package/dist/esm/helpers/shopify-helper.js.map +1 -1
  406. package/dist/esm/helpers/sqs-utils.d.ts +6 -0
  407. package/dist/esm/helpers/sqs-utils.js +10 -0
  408. package/dist/esm/helpers/sqs-utils.js.map +1 -0
  409. package/dist/esm/helpers/trend-utils.d.ts +3 -0
  410. package/dist/esm/helpers/trend-utils.js +17 -0
  411. package/dist/esm/helpers/trend-utils.js.map +1 -0
  412. package/dist/esm/index.d.ts +5 -5
  413. package/dist/esm/index.js +5 -5
  414. package/dist/esm/libs/click-id-parser.d.ts +23 -23
  415. package/dist/esm/libs/click-id-parser.js +45 -45
  416. package/dist/esm/libs/click-id-parser.js.map +1 -1
  417. package/dist/esm/libs/compression.d.ts +2 -2
  418. package/dist/esm/libs/compression.js +25 -25
  419. package/dist/esm/libs/compression.js.map +1 -1
  420. package/dist/esm/libs/cookie.d.ts +12 -12
  421. package/dist/esm/libs/cookie.js +64 -62
  422. package/dist/esm/libs/cookie.js.map +1 -1
  423. package/dist/esm/libs/crypto.d.ts +3 -3
  424. package/dist/esm/libs/crypto.js +11 -11
  425. package/dist/esm/libs/csv.d.ts +2 -2
  426. package/dist/esm/libs/csv.js +30 -30
  427. package/dist/esm/libs/csv.js.map +1 -1
  428. package/dist/esm/libs/currency.d.ts +1 -1
  429. package/dist/esm/libs/currency.js +22 -17
  430. package/dist/esm/libs/currency.js.map +1 -1
  431. package/dist/esm/libs/dates.d.ts +12 -12
  432. package/dist/esm/libs/dates.js +83 -83
  433. package/dist/esm/libs/dates.js.map +1 -1
  434. package/dist/esm/libs/domain.d.ts +2 -2
  435. package/dist/esm/libs/domain.js +33 -33
  436. package/dist/esm/libs/emails.d.ts +6 -6
  437. package/dist/esm/libs/emails.js +115 -115
  438. package/dist/esm/libs/emails.js.map +1 -1
  439. package/dist/esm/libs/http-error.d.ts +21 -21
  440. package/dist/esm/libs/http-error.js +59 -55
  441. package/dist/esm/libs/http-error.js.map +1 -1
  442. package/dist/esm/libs/http-status-codes.d.ts +58 -58
  443. package/dist/esm/libs/http-status-codes.js +59 -59
  444. package/dist/esm/libs/index.d.ts +17 -17
  445. package/dist/esm/libs/index.js +17 -17
  446. package/dist/esm/libs/numbers.d.ts +1 -1
  447. package/dist/esm/libs/numbers.js +11 -11
  448. package/dist/esm/libs/referrer-parser/index.d.ts +2 -2
  449. package/dist/esm/libs/referrer-parser/index.js +2 -2
  450. package/dist/esm/libs/referrer-parser/referrer-data.d.ts +9 -9
  451. package/dist/esm/libs/referrer-parser/referrer-data.js +3304 -4709
  452. package/dist/esm/libs/referrer-parser/referrer-data.js.map +1 -1
  453. package/dist/esm/libs/referrer-parser/referrer-parser-util.d.ts +20 -20
  454. package/dist/esm/libs/referrer-parser/referrer-parser-util.js +124 -121
  455. package/dist/esm/libs/referrer-parser/referrer-parser-util.js.map +1 -1
  456. package/dist/esm/libs/strings.d.ts +3 -3
  457. package/dist/esm/libs/strings.js +40 -40
  458. package/dist/esm/libs/strings.js.map +1 -1
  459. package/dist/esm/libs/traits.d.ts +6 -6
  460. package/dist/esm/libs/traits.js +54 -54
  461. package/dist/esm/libs/traits.js.map +1 -1
  462. package/dist/esm/libs/url.d.ts +1 -1
  463. package/dist/esm/libs/url.js +9 -9
  464. package/dist/esm/libs/url.js.map +1 -1
  465. package/dist/esm/services/cache/generic-cached-object.d.ts +5 -5
  466. package/dist/esm/services/cache/generic-cached-object.js +1 -1
  467. package/dist/esm/services/cache/index.d.ts +1 -1
  468. package/dist/esm/services/cache/index.js +1 -1
  469. package/dist/esm/services/cache/product-cache-service.d.ts +21 -21
  470. package/dist/esm/services/cache/product-cache-service.js +68 -60
  471. package/dist/esm/services/cache/product-cache-service.js.map +1 -1
  472. package/dist/esm/services/currency-exchange-rate-lookup-service.d.ts +11 -11
  473. package/dist/esm/services/currency-exchange-rate-lookup-service.js +62 -46
  474. package/dist/esm/services/currency-exchange-rate-lookup-service.js.map +1 -1
  475. package/dist/esm/services/db/currency-exchange-rates-db-service.d.ts +21 -21
  476. package/dist/esm/services/db/currency-exchange-rates-db-service.js +35 -35
  477. package/dist/esm/services/db/currency-exchange-rates-db-service.js.map +1 -1
  478. package/dist/esm/services/db/destinations-db-service.d.ts +12 -11
  479. package/dist/esm/services/db/destinations-db-service.js +72 -60
  480. package/dist/esm/services/db/destinations-db-service.js.map +1 -1
  481. package/dist/esm/services/db/identity-cache-db-service.d.ts +28 -28
  482. package/dist/esm/services/db/identity-cache-db-service.js +313 -271
  483. package/dist/esm/services/db/identity-cache-db-service.js.map +1 -1
  484. package/dist/esm/services/db/index.d.ts +9 -9
  485. package/dist/esm/services/db/index.js +9 -9
  486. package/dist/esm/services/db/log-events-db-service.d.ts +11 -11
  487. package/dist/esm/services/db/log-events-db-service.js +177 -168
  488. package/dist/esm/services/db/log-events-db-service.js.map +1 -1
  489. package/dist/esm/services/db/purchasable-contacts-db-service.d.ts +9 -9
  490. package/dist/esm/services/db/purchasable-contacts-db-service.js +39 -39
  491. package/dist/esm/services/db/purchasable-contacts-db-service.js.map +1 -1
  492. package/dist/esm/services/db/purchased-contacts-db-service.d.ts +17 -17
  493. package/dist/esm/services/db/purchased-contacts-db-service.js +139 -139
  494. package/dist/esm/services/db/purchased-contacts-db-service.js.map +1 -1
  495. package/dist/esm/services/db/shopify-app-installs-db-service.d.ts +7 -7
  496. package/dist/esm/services/db/shopify-app-installs-db-service.js +43 -43
  497. package/dist/esm/services/db/shopify-app-installs-db-service.js.map +1 -1
  498. package/dist/esm/services/db/shopify-products-cache-db-service.d.ts +16 -16
  499. package/dist/esm/services/db/shopify-products-cache-db-service.js +66 -58
  500. package/dist/esm/services/db/shopify-products-cache-db-service.js.map +1 -1
  501. package/dist/esm/services/db/tracking-events-db-service.d.ts +20 -20
  502. package/dist/esm/services/db/tracking-events-db-service.js +161 -158
  503. package/dist/esm/services/db/tracking-events-db-service.js.map +1 -1
  504. package/dist/esm/services/eventbridge-integration-service.d.ts +9 -9
  505. package/dist/esm/services/eventbridge-integration-service.js +24 -24
  506. package/dist/esm/services/eventbridge-integration-service.js.map +1 -1
  507. package/dist/esm/services/events/index.d.ts +3 -3
  508. package/dist/esm/services/events/index.js +3 -3
  509. package/dist/esm/services/events/log-event-service.d.ts +9 -9
  510. package/dist/esm/services/events/log-event-service.js +52 -52
  511. package/dist/esm/services/events/log-event-service.js.map +1 -1
  512. package/dist/esm/services/events/metric-event-service.d.ts +9 -9
  513. package/dist/esm/services/events/metric-event-service.js +45 -45
  514. package/dist/esm/services/events/metric-event-service.js.map +1 -1
  515. package/dist/esm/services/events/tracking-event-sqs-service.d.ts +8 -8
  516. package/dist/esm/services/events/tracking-event-sqs-service.js +30 -25
  517. package/dist/esm/services/events/tracking-event-sqs-service.js.map +1 -1
  518. package/dist/esm/services/generic-cache-service.d.ts +7 -7
  519. package/dist/esm/services/generic-cache-service.js +29 -29
  520. package/dist/esm/services/generic-cache-service.js.map +1 -1
  521. package/dist/esm/services/index.d.ts +8 -8
  522. package/dist/esm/services/index.js +8 -8
  523. package/dist/esm/services/ipdata-lookup-service.d.ts +19 -19
  524. package/dist/esm/services/ipdata-lookup-service.js +73 -73
  525. package/dist/esm/services/ipdata-lookup-service.js.map +1 -1
  526. package/dist/esm/services/shopify/index.d.ts +3 -3
  527. package/dist/esm/services/shopify/index.js +3 -3
  528. package/dist/esm/services/shopify/products/index.d.ts +1 -1
  529. package/dist/esm/services/shopify/products/index.js +1 -1
  530. package/dist/esm/services/shopify/products/shopify-products-serviceV2.d.ts +17 -17
  531. package/dist/esm/services/shopify/products/shopify-products-serviceV2.js +110 -99
  532. package/dist/esm/services/shopify/products/shopify-products-serviceV2.js.map +1 -1
  533. package/dist/esm/services/shopify/shopify-graphql-transformer.d.ts +9 -9
  534. package/dist/esm/services/shopify/shopify-graphql-transformer.js +138 -134
  535. package/dist/esm/services/shopify/shopify-graphql-transformer.js.map +1 -1
  536. package/dist/esm/services/shopify/types/index.d.ts +1 -1
  537. package/dist/esm/services/shopify/types/index.js +1 -1
  538. package/dist/esm/services/shopify/types/product.d.ts +115 -115
  539. package/dist/esm/services/shopify/types/product.js +6 -6
  540. package/dist/esm/services/shopify/types/product.js.map +1 -1
  541. package/dist/esm/types/api-response.d.ts +6 -6
  542. package/dist/esm/types/api-response.js +1 -1
  543. package/dist/esm/types/index.d.ts +1 -2
  544. package/dist/esm/types/index.js +1 -2
  545. package/dist/esm/types/index.js.map +1 -1
  546. package/dist/esm/types/internal-events/event-detail-types.d.ts +20 -20
  547. package/dist/esm/types/internal-events/event-detail-types.js +24 -24
  548. package/dist/esm/types/internal-events/index.d.ts +1 -1
  549. package/dist/esm/types/internal-events/index.js +1 -1
  550. package/dist/esm/types/shopify-graphql-types/admin.generated.d.ts +105 -105
  551. package/dist/esm/types/shopify-graphql-types/admin.generated.js +1 -1
  552. package/dist/esm/types/shopify-graphql-types/admin.types.d.ts +26289 -26289
  553. package/dist/esm/types/shopify-graphql-types/admin.types.js +5299 -5299
  554. package/dist/esm/types/shopify-graphql-types/index.d.ts +2 -2
  555. package/dist/esm/types/shopify-graphql-types/index.js +2 -2
  556. package/dist/esm/types/shopify-graphql-types/index.js.map +1 -1
  557. package/package.json +5 -4
@@ -1,585 +1,587 @@
1
- import { mergeIdentityTraits } from '@adtrackify/at-shared-utils';
2
- import { isIdentityCacheStale, isClickInfosStale, } from '../../helpers/identity-cache-helper';
3
- describe('Identity Trait Merging Tests', () => {
4
- afterEach(() => {
5
- jest.resetModules();
6
- });
7
- describe('mergeIdentityTraits function', () => {
8
- it('should merge simple string arrays correctly', () => {
9
- const incomingTraits = {
10
- emails: ['new@email.com'],
11
- userIds: ['user1', 'user2']
12
- };
13
- const cachedTraits = {
14
- emails: ['existing@email.com'],
15
- userIds: ['user2', 'user3'],
16
- phones: ['+1234567890']
17
- };
18
- const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
19
- expect(merged.emails).toEqual(['new@email.com', 'existing@email.com']);
20
- expect(merged.userIds).toEqual(['user1', 'user2', 'user3']);
21
- expect(merged.phones).toEqual(['+1234567890']);
22
- });
23
- it('should handle null and undefined values in arrays', () => {
24
- const incomingTraits = {
25
- emails: ['test@email.com', null, undefined],
26
- userIds: ['user1']
27
- };
28
- const cachedTraits = {
29
- emails: [null, 'cached@email.com', undefined],
30
- userIds: null
31
- };
32
- const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
33
- expect(merged.emails).toContain('test@email.com');
34
- expect(merged.emails).toContain('cached@email.com');
35
- expect(merged.userIds).toEqual(['user1']);
36
- });
37
- it('should merge addresses correctly', () => {
38
- const incomingTraits = {
39
- addresses: [
40
- {
41
- city: 'New York',
42
- country: 'USA',
43
- countryCode: 'US',
44
- province: 'NY',
45
- provinceCode: '10001'
46
- }
47
- ]
48
- };
49
- const cachedTraits = {
50
- addresses: [
51
- {
52
- city: 'Los Angeles',
53
- country: 'USA',
54
- countryCode: 'US',
55
- province: 'CA',
56
- provinceCode: '90210'
57
- }
58
- ]
59
- };
60
- const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
61
- expect(merged.addresses).toHaveLength(2);
62
- expect(merged.addresses).toEqual(expect.arrayContaining([
63
- expect.objectContaining({ city: 'New York' }),
64
- expect.objectContaining({ city: 'Los Angeles' })
65
- ]));
66
- });
67
- it('should merge click information correctly', () => {
68
- const incomingTraits = {
69
- click: {
70
- fbp: 'fb.new.123',
71
- fbpCollectedAt: '2024-01-01T00:00:00.000Z',
72
- gclid: 'new_gclid'
73
- }
74
- };
75
- const cachedTraits = {
76
- click: {
77
- fbp: 'fb.old.456',
78
- fbpCollectedAt: '2023-12-01T00:00:00.000Z',
79
- fbclid: 'cached_fbclid'
80
- }
81
- };
82
- const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
83
- expect(merged.click?.fbp).toBe('fb.new.123');
84
- expect(merged.click?.gclid).toBe('new_gclid');
85
- expect(merged.click?.fbpCollectedAt).toBe('2024-01-01T00:00:00.000Z');
86
- expect(merged.click?.fbclid).toBeUndefined();
87
- });
88
- it('should handle empty traits correctly', () => {
89
- const incomingTraits = {};
90
- const cachedTraits = {
91
- emails: ['cached@email.com'],
92
- userIds: ['user1']
93
- };
94
- const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
95
- expect(merged.emails).toEqual(['cached@email.com']);
96
- expect(merged.userIds).toEqual(['user1']);
97
- });
98
- it('should handle undefined traits correctly', () => {
99
- const merged1 = mergeIdentityTraits(undefined, { emails: ['test@email.com'] });
100
- expect(merged1.emails).toEqual(['test@email.com']);
101
- const merged2 = mergeIdentityTraits({ emails: ['test@email.com'] }, undefined);
102
- expect(merged2.emails).toEqual(['test@email.com']);
103
- const merged3 = mergeIdentityTraits(undefined, undefined);
104
- expect(merged3).toEqual({});
105
- });
106
- it('should preserve version information', () => {
107
- const incomingTraits = {
108
- version: '3',
109
- emails: ['new@email.com']
110
- };
111
- const cachedTraits = {
112
- version: '2',
113
- emails: ['old@email.com']
114
- };
115
- const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
116
- expect(merged.version).toBe('3');
117
- expect(merged.emails).toEqual(['new@email.com', 'old@email.com']);
118
- });
119
- it('should handle complex nested objects', () => {
120
- const incomingTraits = {
121
- click: {
122
- googleClientInfos: [
123
- { id: 'new1', clickId: 'click1', sessionId: 'session1' }
124
- ]
125
- }
126
- };
127
- const cachedTraits = {
128
- click: {
129
- googleClientInfos: [
130
- { id: 'cached1', clickId: 'click2', sessionId: 'session2' }
131
- ]
132
- }
133
- };
134
- const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
135
- expect(merged.click?.googleClientInfos).toBeDefined();
136
- expect(Array.isArray(merged.click?.googleClientInfos)).toBe(true);
137
- expect(merged.click?.googleClientInfos).toEqual([
138
- { id: 'cached1', clickId: 'click2', sessionId: 'session2' }
139
- ]);
140
- });
141
- });
142
- describe('Integration: Merging + Staleness Checking', () => {
143
- it('should not be stale when merged identity matches cached identity', () => {
144
- const cachedIdentity = {
145
- identityId: 'test-id-123',
146
- traits: {
147
- emails: ['cached@email.com', 'shared@email.com'],
148
- userIds: ['user1', 'user2'],
149
- addresses: [{
150
- city: 'New York',
151
- country: 'USA',
152
- countryCode: 'US'
153
- }],
154
- version: '2'
155
- }
156
- };
157
- const incomingIdentity = {
158
- identityId: 'test-id-123',
159
- traits: {
160
- emails: ['shared@email.com'],
161
- userIds: ['user1'],
162
- version: '2'
163
- }
164
- };
165
- const mergedTraits = mergeIdentityTraits(incomingIdentity.traits, cachedIdentity.traits);
166
- const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
167
- const staleTracker = isIdentityCacheStale(cachedIdentity, mergedIdentity);
168
- expect(staleTracker.isCacheStale).toBe(false);
169
- expect(mergedIdentity.traits?.emails).toEqual(['shared@email.com', 'cached@email.com']);
170
- });
171
- it('should be stale when merged identity has new traits', () => {
172
- const cachedIdentity = {
173
- identityId: 'test-id-123',
174
- traits: {
175
- emails: ['cached@email.com'],
176
- version: '2'
177
- }
178
- };
179
- const incomingIdentity = {
180
- identityId: 'test-id-123',
181
- traits: {
182
- emails: ['cached@email.com', 'new@email.com'],
183
- version: '2'
184
- }
185
- };
186
- const mergedTraits = mergeIdentityTraits(incomingIdentity.traits, cachedIdentity.traits);
187
- const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
188
- const staleTracker = isIdentityCacheStale(cachedIdentity, mergedIdentity);
189
- expect(staleTracker.isCacheStale).toBe(true);
190
- expect(staleTracker.isEmailsStale).toBe(true);
191
- });
192
- });
193
- });
194
- describe('Identity Cache Staleness Tests', () => {
195
- afterEach(() => {
196
- jest.resetModules();
197
- });
198
- describe('isIdentityCacheStale function', () => {
199
- it('should detect identity ID changes', () => {
200
- const cachedIdentity = {
201
- identityId: 'old-id',
202
- traits: { emails: ['test@email.com'] }
203
- };
204
- const incomingIdentity = {
205
- identityId: 'new-id',
206
- traits: { emails: ['test@email.com'] }
207
- };
208
- const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
209
- expect(result.isCacheStale).toBe(true);
210
- expect(result.isIdentityIdStale).toBe(true);
211
- });
212
- it('should detect new emails', () => {
213
- const cachedIdentity = {
214
- identityId: 'test-id',
215
- traits: { emails: ['old@email.com'] }
216
- };
217
- const incomingIdentity = {
218
- identityId: 'test-id',
219
- traits: { emails: ['old@email.com', 'new@email.com'] }
220
- };
221
- const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
222
- expect(result.isCacheStale).toBe(true);
223
- expect(result.isEmailsStale).toBe(true);
224
- });
225
- it('should detect new user IDs', () => {
226
- const cachedIdentity = {
227
- identityId: 'test-id',
228
- traits: { userIds: ['user1'] }
229
- };
230
- const incomingIdentity = {
231
- identityId: 'test-id',
232
- traits: { userIds: ['user1', 'user2'] }
233
- };
234
- const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
235
- expect(result.isCacheStale).toBe(true);
236
- expect(result.isUserIdsStale).toBe(true);
237
- });
238
- it('should detect new phones', () => {
239
- const cachedIdentity = {
240
- identityId: 'test-id',
241
- traits: { phones: ['+1234567890'] }
242
- };
243
- const incomingIdentity = {
244
- identityId: 'test-id',
245
- traits: { phones: ['+1234567890', '+9876543210'] }
246
- };
247
- const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
248
- expect(result.isCacheStale).toBe(true);
249
- expect(result.isPhonesStale).toBe(true);
250
- });
251
- it('should detect new addresses', () => {
252
- const cachedIdentity = {
253
- identityId: 'test-id',
254
- traits: {
255
- addresses: [{
256
- city: 'New York',
257
- country: 'USA'
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 = 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 = 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 = 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 = 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 = 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 = 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 = 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 = 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 = 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 = 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 = isClickInfosStale(cachedClick, incomingClick);
406
- expect(result).toBe(false);
407
- });
408
- it('should handle empty click info', () => {
409
- const result = 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 = 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 = 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 = 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 = 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 = 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
- city: 'New York',
483
- country: 'USA',
484
- countryCode: 'US',
485
- province: 'NY',
486
- provinceCode: '10001'
487
- }],
488
- click: {
489
- fbp: 'fb.2.1715603578424.5068754021',
490
- fbpCollectedAt: '2024-05-13T12:32:58.424Z',
491
- gclid: 'original_gclid'
492
- },
493
- ipAddress: '192.168.1.100',
494
- version: '2'
495
- }
496
- };
497
- const incomingIdentity = {
498
- identityId: '01HXRZ27H4TXWBBTRK09Q7APDP',
499
- traits: {
500
- emails: ['user@domain.com', 'user.secondary@domain.com'],
501
- phones: ['+1234567890'],
502
- addresses: [{
503
- city: 'New York',
504
- country: 'USA',
505
- countryCode: 'US',
506
- province: 'NY',
507
- provinceCode: '10001'
508
- }],
509
- click: {
510
- fbp: 'fb.2.1715603578424.5068754021',
511
- fbpCollectedAt: '2024-05-13T15:30:00.000Z',
512
- gclid: 'updated_gclid'
513
- },
514
- ipAddress: '192.168.1.100',
515
- version: '2'
516
- }
517
- };
518
- const mergedTraits = mergeIdentityTraits(cachedIdentity.traits, incomingIdentity.traits);
519
- const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
520
- const result = isIdentityCacheStale(cachedIdentity, mergedIdentity);
521
- expect(result.isCacheStale).toBe(true);
522
- expect(result.isEmailsStale).toBe(true);
523
- expect(result.isPhonesStale).toBe(true);
524
- expect(result.isClickInfosStale).toBe(true);
525
- expect(result.isAddressesStale).toBe(false);
526
- expect(result.isIpAddressStale).toBe(false);
527
- expect(mergedIdentity.traits?.emails).toEqual(['user@domain.com', 'user.secondary@domain.com']);
528
- expect(mergedIdentity.traits?.phones).toEqual(['+1234567890']);
529
- expect(mergedIdentity.traits?.userIds).toEqual(['shopify_123']);
530
- expect(mergedIdentity.traits?.click?.gclid).toEqual('updated_gclid');
531
- });
532
- it('should properly detect click staleness when click info actually differs', () => {
533
- const cachedIdentity = {
534
- identityId: 'test-id',
535
- traits: {
536
- click: {
537
- gclid: 'original_gclid',
538
- gclidCollectedAt: '2024-05-15T12:32:58.424Z'
539
- }
540
- }
541
- };
542
- const incomingIdentity = {
543
- identityId: 'test-id',
544
- traits: {
545
- click: {
546
- gclid: 'completely_different_gclid',
547
- gclidCollectedAt: '2024-05-13T12:32:58.424Z'
548
- }
549
- }
550
- };
551
- const mergedTraits = mergeIdentityTraits(cachedIdentity.traits, incomingIdentity.traits);
552
- const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
553
- const result = isIdentityCacheStale(cachedIdentity, mergedIdentity);
554
- expect(mergedTraits?.click?.gclid).toEqual('original_gclid');
555
- expect(result.isCacheStale).toBe(false);
556
- });
557
- it('should handle scenario where cache is fresh', () => {
558
- const cachedIdentity = {
559
- identityId: 'test-id',
560
- traits: {
561
- emails: ['user@domain.com', 'secondary@domain.com'],
562
- userIds: ['user1', 'user2'],
563
- phones: ['+1234567890'],
564
- version: '2'
565
- }
566
- };
567
- const incomingIdentity = {
568
- identityId: 'test-id',
569
- traits: {
570
- emails: ['user@domain.com'],
571
- userIds: ['user1'],
572
- version: '2'
573
- }
574
- };
575
- const mergedTraits = mergeIdentityTraits(cachedIdentity.traits, incomingIdentity.traits);
576
- const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
577
- const result = isIdentityCacheStale(cachedIdentity, mergedIdentity);
578
- expect(result.isCacheStale).toBe(false);
579
- expect(mergedIdentity.traits?.emails).toEqual(['user@domain.com', 'secondary@domain.com']);
580
- expect(mergedIdentity.traits?.userIds).toEqual(['user1', 'user2']);
581
- expect(mergedIdentity.traits?.phones).toEqual(['+1234567890']);
582
- });
583
- });
584
- });
1
+ import { mergeIdentityTraits } from '@adtrackify/at-shared-utils';
2
+ import { isIdentityCacheStale, isClickInfosStale } from '../../helpers/identity-cache-helper';
3
+ describe('Identity Trait Merging Tests', () => {
4
+ afterEach(() => {
5
+ jest.resetModules();
6
+ });
7
+ describe('mergeIdentityTraits function', () => {
8
+ it('should merge simple string arrays correctly', () => {
9
+ const incomingTraits = {
10
+ emails: ['new@email.com'],
11
+ userIds: ['user1', 'user2'],
12
+ };
13
+ const cachedTraits = {
14
+ emails: ['existing@email.com'],
15
+ userIds: ['user2', 'user3'],
16
+ phones: ['+1234567890'],
17
+ };
18
+ const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
19
+ expect(merged.emails).toEqual(['new@email.com', 'existing@email.com']);
20
+ expect(merged.userIds).toEqual(['user1', 'user2', 'user3']);
21
+ expect(merged.phones).toEqual(['+1234567890']);
22
+ });
23
+ it('should handle null and undefined values in arrays', () => {
24
+ const incomingTraits = {
25
+ emails: ['test@email.com', null, undefined],
26
+ userIds: ['user1'],
27
+ };
28
+ const cachedTraits = {
29
+ emails: [null, 'cached@email.com', undefined],
30
+ userIds: null,
31
+ };
32
+ const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
33
+ expect(merged.emails).toContain('test@email.com');
34
+ expect(merged.emails).toContain('cached@email.com');
35
+ expect(merged.userIds).toEqual(['user1']);
36
+ });
37
+ it('should merge addresses correctly', () => {
38
+ const incomingTraits = {
39
+ addresses: [
40
+ {
41
+ city: 'New York',
42
+ country: 'USA',
43
+ countryCode: 'US',
44
+ province: 'NY',
45
+ provinceCode: '10001',
46
+ },
47
+ ],
48
+ };
49
+ const cachedTraits = {
50
+ addresses: [
51
+ {
52
+ city: 'Los Angeles',
53
+ country: 'USA',
54
+ countryCode: 'US',
55
+ province: 'CA',
56
+ provinceCode: '90210',
57
+ },
58
+ ],
59
+ };
60
+ const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
61
+ expect(merged.addresses).toHaveLength(2);
62
+ expect(merged.addresses).toEqual(expect.arrayContaining([
63
+ expect.objectContaining({ city: 'New York' }),
64
+ expect.objectContaining({ city: 'Los Angeles' }),
65
+ ]));
66
+ });
67
+ it('should merge click information correctly', () => {
68
+ const incomingTraits = {
69
+ click: {
70
+ fbp: 'fb.new.123',
71
+ fbpCollectedAt: '2024-01-01T00:00:00.000Z',
72
+ gclid: 'new_gclid',
73
+ },
74
+ };
75
+ const cachedTraits = {
76
+ click: {
77
+ fbp: 'fb.old.456',
78
+ fbpCollectedAt: '2023-12-01T00:00:00.000Z',
79
+ fbclid: 'cached_fbclid',
80
+ },
81
+ };
82
+ const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
83
+ expect(merged.click?.fbp).toBe('fb.new.123');
84
+ expect(merged.click?.gclid).toBe('new_gclid');
85
+ expect(merged.click?.fbpCollectedAt).toBe('2024-01-01T00:00:00.000Z');
86
+ expect(merged.click?.fbclid).toBeUndefined();
87
+ });
88
+ it('should handle empty traits correctly', () => {
89
+ const incomingTraits = {};
90
+ const cachedTraits = {
91
+ emails: ['cached@email.com'],
92
+ userIds: ['user1'],
93
+ };
94
+ const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
95
+ expect(merged.emails).toEqual(['cached@email.com']);
96
+ expect(merged.userIds).toEqual(['user1']);
97
+ });
98
+ it('should handle undefined traits correctly', () => {
99
+ const merged1 = mergeIdentityTraits(undefined, { emails: ['test@email.com'] });
100
+ expect(merged1.emails).toEqual(['test@email.com']);
101
+ const merged2 = mergeIdentityTraits({ emails: ['test@email.com'] }, undefined);
102
+ expect(merged2.emails).toEqual(['test@email.com']);
103
+ const merged3 = mergeIdentityTraits(undefined, undefined);
104
+ expect(merged3).toEqual({});
105
+ });
106
+ it('should preserve version information', () => {
107
+ const incomingTraits = {
108
+ version: '3',
109
+ emails: ['new@email.com'],
110
+ };
111
+ const cachedTraits = {
112
+ version: '2',
113
+ emails: ['old@email.com'],
114
+ };
115
+ const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
116
+ expect(merged.version).toBe('3');
117
+ expect(merged.emails).toEqual(['new@email.com', 'old@email.com']);
118
+ });
119
+ it('should handle complex nested objects', () => {
120
+ const incomingTraits = {
121
+ click: {
122
+ googleClientInfos: [{ id: 'new1', clickId: 'click1', sessionId: 'session1' }],
123
+ },
124
+ };
125
+ const cachedTraits = {
126
+ click: {
127
+ googleClientInfos: [{ id: 'cached1', clickId: 'click2', sessionId: 'session2' }],
128
+ },
129
+ };
130
+ const merged = mergeIdentityTraits(incomingTraits, cachedTraits);
131
+ expect(merged.click?.googleClientInfos).toBeDefined();
132
+ expect(Array.isArray(merged.click?.googleClientInfos)).toBe(true);
133
+ expect(merged.click?.googleClientInfos).toEqual([{ id: 'cached1', clickId: 'click2', sessionId: 'session2' }]);
134
+ });
135
+ });
136
+ describe('Integration: Merging + Staleness Checking', () => {
137
+ it('should not be stale when merged identity matches cached identity', () => {
138
+ const cachedIdentity = {
139
+ identityId: 'test-id-123',
140
+ traits: {
141
+ emails: ['cached@email.com', 'shared@email.com'],
142
+ userIds: ['user1', 'user2'],
143
+ addresses: [
144
+ {
145
+ city: 'New York',
146
+ country: 'USA',
147
+ countryCode: 'US',
148
+ },
149
+ ],
150
+ version: '2',
151
+ },
152
+ };
153
+ const incomingIdentity = {
154
+ identityId: 'test-id-123',
155
+ traits: {
156
+ emails: ['shared@email.com'],
157
+ userIds: ['user1'],
158
+ version: '2',
159
+ },
160
+ };
161
+ const mergedTraits = mergeIdentityTraits(incomingIdentity.traits, cachedIdentity.traits);
162
+ const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
163
+ const staleTracker = isIdentityCacheStale(cachedIdentity, mergedIdentity);
164
+ expect(staleTracker.isCacheStale).toBe(false);
165
+ expect(mergedIdentity.traits?.emails).toEqual(['shared@email.com', 'cached@email.com']);
166
+ });
167
+ it('should be stale when merged identity has new traits', () => {
168
+ const cachedIdentity = {
169
+ identityId: 'test-id-123',
170
+ traits: {
171
+ emails: ['cached@email.com'],
172
+ version: '2',
173
+ },
174
+ };
175
+ const incomingIdentity = {
176
+ identityId: 'test-id-123',
177
+ traits: {
178
+ emails: ['cached@email.com', 'new@email.com'],
179
+ version: '2',
180
+ },
181
+ };
182
+ const mergedTraits = mergeIdentityTraits(incomingIdentity.traits, cachedIdentity.traits);
183
+ const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
184
+ const staleTracker = isIdentityCacheStale(cachedIdentity, mergedIdentity);
185
+ expect(staleTracker.isCacheStale).toBe(true);
186
+ expect(staleTracker.isEmailsStale).toBe(true);
187
+ });
188
+ });
189
+ });
190
+ describe('Identity Cache Staleness Tests', () => {
191
+ afterEach(() => {
192
+ jest.resetModules();
193
+ });
194
+ describe('isIdentityCacheStale function', () => {
195
+ it('should detect identity ID changes', () => {
196
+ const cachedIdentity = {
197
+ identityId: 'old-id',
198
+ traits: { emails: ['test@email.com'] },
199
+ };
200
+ const incomingIdentity = {
201
+ identityId: 'new-id',
202
+ traits: { emails: ['test@email.com'] },
203
+ };
204
+ const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
205
+ expect(result.isCacheStale).toBe(true);
206
+ expect(result.isIdentityIdStale).toBe(true);
207
+ });
208
+ it('should detect new emails', () => {
209
+ const cachedIdentity = {
210
+ identityId: 'test-id',
211
+ traits: { emails: ['old@email.com'] },
212
+ };
213
+ const incomingIdentity = {
214
+ identityId: 'test-id',
215
+ traits: { emails: ['old@email.com', 'new@email.com'] },
216
+ };
217
+ const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
218
+ expect(result.isCacheStale).toBe(true);
219
+ expect(result.isEmailsStale).toBe(true);
220
+ });
221
+ it('should detect new user IDs', () => {
222
+ const cachedIdentity = {
223
+ identityId: 'test-id',
224
+ traits: { userIds: ['user1'] },
225
+ };
226
+ const incomingIdentity = {
227
+ identityId: 'test-id',
228
+ traits: { userIds: ['user1', 'user2'] },
229
+ };
230
+ const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
231
+ expect(result.isCacheStale).toBe(true);
232
+ expect(result.isUserIdsStale).toBe(true);
233
+ });
234
+ it('should detect new phones', () => {
235
+ const cachedIdentity = {
236
+ identityId: 'test-id',
237
+ traits: { phones: ['+1234567890'] },
238
+ };
239
+ const incomingIdentity = {
240
+ identityId: 'test-id',
241
+ traits: { phones: ['+1234567890', '+9876543210'] },
242
+ };
243
+ const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
244
+ expect(result.isCacheStale).toBe(true);
245
+ expect(result.isPhonesStale).toBe(true);
246
+ });
247
+ it('should detect new addresses', () => {
248
+ const cachedIdentity = {
249
+ identityId: 'test-id',
250
+ traits: {
251
+ addresses: [
252
+ {
253
+ city: 'New York',
254
+ country: 'USA',
255
+ },
256
+ ],
257
+ },
258
+ };
259
+ const incomingIdentity = {
260
+ identityId: 'test-id',
261
+ traits: {
262
+ addresses: [
263
+ { city: 'New York', country: 'USA' },
264
+ { city: 'Los Angeles', country: 'USA' },
265
+ ],
266
+ },
267
+ };
268
+ const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
269
+ expect(result.isCacheStale).toBe(true);
270
+ expect(result.isAddressesStale).toBe(true);
271
+ });
272
+ it('should detect IP address changes', () => {
273
+ const cachedIdentity = {
274
+ identityId: 'test-id',
275
+ traits: { ipAddress: '192.168.1.1' },
276
+ };
277
+ const incomingIdentity = {
278
+ identityId: 'test-id',
279
+ traits: { ipAddress: '10.0.0.1' },
280
+ };
281
+ const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
282
+ expect(result.isCacheStale).toBe(true);
283
+ expect(result.isIpAddressStale).toBe(true);
284
+ });
285
+ it('should detect user agent changes', () => {
286
+ const cachedIdentity = {
287
+ identityId: 'test-id',
288
+ traits: { userAgent: 'Mozilla/5.0 (old browser)' },
289
+ };
290
+ const incomingIdentity = {
291
+ identityId: 'test-id',
292
+ traits: { userAgent: 'Mozilla/5.0 (new browser)' },
293
+ };
294
+ const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
295
+ expect(result.isCacheStale).toBe(true);
296
+ expect(result.isUserAgentStale).toBe(true);
297
+ });
298
+ it('should not be stale when no new information is provided', () => {
299
+ const cachedIdentity = {
300
+ identityId: 'test-id',
301
+ traits: {
302
+ emails: ['test@email.com'],
303
+ userIds: ['user1'],
304
+ phones: ['+1234567890'],
305
+ },
306
+ };
307
+ const incomingIdentity = {
308
+ identityId: 'test-id',
309
+ traits: {
310
+ emails: ['test@email.com'],
311
+ userIds: ['user1'],
312
+ },
313
+ };
314
+ const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
315
+ expect(result.isCacheStale).toBe(false);
316
+ });
317
+ it('should handle empty traits gracefully', () => {
318
+ const cachedIdentity = {
319
+ identityId: 'test-id',
320
+ traits: {},
321
+ };
322
+ const incomingIdentity = {
323
+ identityId: 'test-id',
324
+ traits: {},
325
+ };
326
+ const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
327
+ expect(result.isCacheStale).toBe(false);
328
+ });
329
+ it('should handle undefined traits gracefully', () => {
330
+ const cachedIdentity = {
331
+ identityId: 'test-id',
332
+ };
333
+ const incomingIdentity = {
334
+ identityId: 'test-id',
335
+ };
336
+ const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
337
+ expect(result.isCacheStale).toBe(false);
338
+ });
339
+ it('should detect multiple stale conditions', () => {
340
+ const cachedIdentity = {
341
+ identityId: 'test-id',
342
+ traits: {
343
+ emails: ['old@email.com'],
344
+ userIds: ['user1'],
345
+ ipAddress: '192.168.1.1',
346
+ },
347
+ };
348
+ const incomingIdentity = {
349
+ identityId: 'test-id',
350
+ traits: {
351
+ emails: ['old@email.com', 'new@email.com'],
352
+ userIds: ['user1', 'user2'],
353
+ ipAddress: '10.0.0.1',
354
+ },
355
+ };
356
+ const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
357
+ expect(result.isCacheStale).toBe(true);
358
+ expect(result.isEmailsStale).toBe(true);
359
+ expect(result.isUserIdsStale).toBe(true);
360
+ expect(result.isIpAddressStale).toBe(true);
361
+ });
362
+ });
363
+ describe('isClickInfosStale function', () => {
364
+ it('should detect new FBC values', () => {
365
+ const cachedClick = {
366
+ fbc: 'fb.1.123.old_fbclid',
367
+ };
368
+ const incomingClick = {
369
+ fbc: 'fb.1.123.new_fbclid',
370
+ };
371
+ const result = isClickInfosStale(cachedClick, incomingClick);
372
+ expect(result).toBe(true);
373
+ });
374
+ it('should detect new click IDs', () => {
375
+ const cachedClick = {
376
+ gclid: 'old_gclid',
377
+ };
378
+ const incomingClick = {
379
+ gclid: 'new_gclid',
380
+ };
381
+ const result = isClickInfosStale(cachedClick, incomingClick);
382
+ expect(result).toBe(true);
383
+ });
384
+ it('should ignore collection timestamps', () => {
385
+ const cachedClick = {
386
+ fbp: 'fb.2.123.456',
387
+ fbpCollectedAt: '2023-01-01T00:00:00.000Z',
388
+ };
389
+ const incomingClick = {
390
+ fbp: 'fb.2.123.456',
391
+ fbpCollectedAt: '2024-01-01T00:00:00.000Z',
392
+ };
393
+ const result = isClickInfosStale(cachedClick, incomingClick);
394
+ expect(result).toBe(false);
395
+ });
396
+ it('should ignore googleClientInfos', () => {
397
+ const cachedClick = {
398
+ googleClientInfos: [{ id: 'old', clickId: 'old_click' }],
399
+ };
400
+ const incomingClick = {
401
+ googleClientInfos: [{ id: 'new', clickId: 'new_click' }],
402
+ };
403
+ const result = isClickInfosStale(cachedClick, incomingClick);
404
+ expect(result).toBe(false);
405
+ });
406
+ it('should handle empty click info', () => {
407
+ const result = isClickInfosStale({}, {});
408
+ expect(result).toBe(false);
409
+ });
410
+ it('should detect when incoming has new click info but cached is empty', () => {
411
+ const cachedClick = {};
412
+ const incomingClick = {
413
+ fbp: 'fb.2.123.456',
414
+ };
415
+ const result = isClickInfosStale(cachedClick, incomingClick);
416
+ expect(result).toBe(true);
417
+ });
418
+ });
419
+ describe('Edge Cases and Error Handling', () => {
420
+ it('should handle malformed FBC values gracefully', () => {
421
+ const cachedClick = {
422
+ fbc: 'malformed_fbc',
423
+ };
424
+ const incomingClick = {
425
+ fbc: 'also_malformed',
426
+ };
427
+ const result = isClickInfosStale(cachedClick, incomingClick);
428
+ expect(result).toBe(true);
429
+ });
430
+ it('should handle null/undefined arrays in traits', () => {
431
+ const cachedIdentity = {
432
+ identityId: 'test-id',
433
+ traits: {
434
+ emails: null,
435
+ userIds: undefined,
436
+ },
437
+ };
438
+ const incomingIdentity = {
439
+ identityId: 'test-id',
440
+ traits: {
441
+ emails: ['new@email.com'],
442
+ userIds: ['user1'],
443
+ },
444
+ };
445
+ const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
446
+ expect(result.isCacheStale).toBe(true);
447
+ expect(result.isEmailsStale).toBe(true);
448
+ expect(result.isUserIdsStale).toBe(true);
449
+ });
450
+ it('should handle arrays with null/undefined elements', () => {
451
+ const cachedIdentity = {
452
+ identityId: 'test-id',
453
+ traits: {
454
+ emails: ['valid@email.com', null, undefined],
455
+ },
456
+ };
457
+ const incomingIdentity = {
458
+ identityId: 'test-id',
459
+ traits: {
460
+ emails: ['valid@email.com', null, undefined, 'new@email.com'],
461
+ },
462
+ };
463
+ const result = isIdentityCacheStale(cachedIdentity, incomingIdentity);
464
+ expect(result.isCacheStale).toBe(true);
465
+ expect(result.isEmailsStale).toBe(true);
466
+ });
467
+ it('should handle error conditions gracefully', () => {
468
+ const result = isIdentityCacheStale(null, undefined);
469
+ expect(result.isCacheStale).toBe(false);
470
+ });
471
+ });
472
+ describe('Comprehensive Scenario Tests', () => {
473
+ it('should handle complex real-world scenario', () => {
474
+ const cachedIdentity = {
475
+ identityId: '01HXRZ27H4TXWBBTRK09Q7APDP',
476
+ traits: {
477
+ emails: ['user@domain.com'],
478
+ userIds: ['shopify_123'],
479
+ addresses: [
480
+ {
481
+ city: 'New York',
482
+ country: 'USA',
483
+ countryCode: 'US',
484
+ province: 'NY',
485
+ provinceCode: '10001',
486
+ },
487
+ ],
488
+ click: {
489
+ fbp: 'fb.2.1715603578424.5068754021',
490
+ fbpCollectedAt: '2024-05-13T12:32:58.424Z',
491
+ gclid: 'original_gclid',
492
+ },
493
+ ipAddress: '192.168.1.100',
494
+ version: '2',
495
+ },
496
+ };
497
+ const incomingIdentity = {
498
+ identityId: '01HXRZ27H4TXWBBTRK09Q7APDP',
499
+ traits: {
500
+ emails: ['user@domain.com', 'user.secondary@domain.com'],
501
+ phones: ['+1234567890'],
502
+ addresses: [
503
+ {
504
+ city: 'New York',
505
+ country: 'USA',
506
+ countryCode: 'US',
507
+ province: 'NY',
508
+ provinceCode: '10001',
509
+ },
510
+ ],
511
+ click: {
512
+ fbp: 'fb.2.1715603578424.5068754021',
513
+ fbpCollectedAt: '2024-05-13T15:30:00.000Z',
514
+ gclid: 'updated_gclid',
515
+ },
516
+ ipAddress: '192.168.1.100',
517
+ version: '2',
518
+ },
519
+ };
520
+ const mergedTraits = mergeIdentityTraits(cachedIdentity.traits, incomingIdentity.traits);
521
+ const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
522
+ const result = isIdentityCacheStale(cachedIdentity, mergedIdentity);
523
+ expect(result.isCacheStale).toBe(true);
524
+ expect(result.isEmailsStale).toBe(true);
525
+ expect(result.isPhonesStale).toBe(true);
526
+ expect(result.isClickInfosStale).toBe(true);
527
+ expect(result.isAddressesStale).toBe(false);
528
+ expect(result.isIpAddressStale).toBe(false);
529
+ expect(mergedIdentity.traits?.emails).toEqual(['user@domain.com', 'user.secondary@domain.com']);
530
+ expect(mergedIdentity.traits?.phones).toEqual(['+1234567890']);
531
+ expect(mergedIdentity.traits?.userIds).toEqual(['shopify_123']);
532
+ expect(mergedIdentity.traits?.click?.gclid).toEqual('updated_gclid');
533
+ });
534
+ it('should properly detect click staleness when click info actually differs', () => {
535
+ const cachedIdentity = {
536
+ identityId: 'test-id',
537
+ traits: {
538
+ click: {
539
+ gclid: 'original_gclid',
540
+ gclidCollectedAt: '2024-05-15T12:32:58.424Z',
541
+ },
542
+ },
543
+ };
544
+ const incomingIdentity = {
545
+ identityId: 'test-id',
546
+ traits: {
547
+ click: {
548
+ gclid: 'completely_different_gclid',
549
+ gclidCollectedAt: '2024-05-13T12:32:58.424Z',
550
+ },
551
+ },
552
+ };
553
+ const mergedTraits = mergeIdentityTraits(cachedIdentity.traits, incomingIdentity.traits);
554
+ const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
555
+ const result = isIdentityCacheStale(cachedIdentity, mergedIdentity);
556
+ expect(mergedTraits?.click?.gclid).toEqual('original_gclid');
557
+ expect(result.isCacheStale).toBe(false);
558
+ });
559
+ it('should handle scenario where cache is fresh', () => {
560
+ const cachedIdentity = {
561
+ identityId: 'test-id',
562
+ traits: {
563
+ emails: ['user@domain.com', 'secondary@domain.com'],
564
+ userIds: ['user1', 'user2'],
565
+ phones: ['+1234567890'],
566
+ version: '2',
567
+ },
568
+ };
569
+ const incomingIdentity = {
570
+ identityId: 'test-id',
571
+ traits: {
572
+ emails: ['user@domain.com'],
573
+ userIds: ['user1'],
574
+ version: '2',
575
+ },
576
+ };
577
+ const mergedTraits = mergeIdentityTraits(cachedIdentity.traits, incomingIdentity.traits);
578
+ const mergedIdentity = { ...incomingIdentity, traits: mergedTraits };
579
+ const result = isIdentityCacheStale(cachedIdentity, mergedIdentity);
580
+ expect(result.isCacheStale).toBe(false);
581
+ expect(mergedIdentity.traits?.emails).toEqual(['user@domain.com', 'secondary@domain.com']);
582
+ expect(mergedIdentity.traits?.userIds).toEqual(['user1', 'user2']);
583
+ expect(mergedIdentity.traits?.phones).toEqual(['+1234567890']);
584
+ });
585
+ });
586
+ });
585
587
  //# sourceMappingURL=trait-merging-and-staleness.spec.js.map