@adtrackify/at-service-common 3.18.11 → 3.18.13

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