@adtrackify/at-service-common 3.17.8 → 3.18.1

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