@adtrackify/at-service-common 4.0.4 → 4.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/__tests__/clients/acuity-client.spec.d.ts +1 -1
- package/dist/cjs/__tests__/clients/acuity-client.spec.js +43 -43
- package/dist/cjs/__tests__/clients/cross-platform-compression.spec.d.ts +1 -1
- package/dist/cjs/__tests__/clients/cross-platform-compression.spec.js +354 -354
- package/dist/cjs/__tests__/clients/dynamodb-client.spec.d.ts +1 -1
- package/dist/cjs/__tests__/clients/dynamodb-client.spec.js +194 -194
- package/dist/cjs/__tests__/clients/sqs-bundled-client.spec.d.ts +1 -1
- package/dist/cjs/__tests__/clients/sqs-bundled-client.spec.js +931 -931
- package/dist/cjs/__tests__/clients/sqs-bundling-contracts.spec.d.ts +1 -1
- package/dist/cjs/__tests__/clients/sqs-bundling-contracts.spec.js +563 -563
- package/dist/cjs/__tests__/clients/sqs-client.spec.d.ts +1 -1
- package/dist/cjs/__tests__/clients/sqs-client.spec.js +191 -191
- package/dist/cjs/__tests__/clients/sqs-unbundle.spec.d.ts +1 -1
- package/dist/cjs/__tests__/clients/sqs-unbundle.spec.js +1357 -1357
- package/dist/cjs/__tests__/db/contact-enrichments-db-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/db/contact-enrichments-db-service.spec.js +68 -68
- package/dist/cjs/__tests__/db/destinations-db-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/db/destinations-db-service.spec.js +125 -125
- package/dist/cjs/__tests__/db/products-db-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/db/products-db-service.spec.js +89 -89
- package/dist/cjs/__tests__/db/shared-read-db-services.spec.d.ts +1 -1
- package/dist/cjs/__tests__/db/shared-read-db-services.spec.js +89 -89
- package/dist/cjs/__tests__/db/shopify-app-installs-db-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/db/shopify-app-installs-db-service.spec.js +104 -104
- package/dist/cjs/__tests__/db/subscriptions-db-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/db/subscriptions-db-service.spec.js +95 -95
- package/dist/cjs/__tests__/db/user-accounts-db-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/db/user-accounts-db-service.spec.js +76 -76
- package/dist/cjs/__tests__/helpers/account-users-helper.spec.d.ts +1 -1
- package/dist/cjs/__tests__/helpers/account-users-helper.spec.js +220 -220
- package/dist/cjs/__tests__/helpers/acuity-helper.spec.d.ts +1 -1
- package/dist/cjs/__tests__/helpers/acuity-helper.spec.js +69 -69
- package/dist/cjs/__tests__/helpers/api-key-auth-helper.spec.d.ts +1 -1
- package/dist/cjs/__tests__/helpers/api-key-auth-helper.spec.js +82 -82
- package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/identity-cache/identity-cache-db-service.spec.js +676 -676
- package/dist/cjs/__tests__/identity-cache/identity-cache-dynamodb-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js +1140 -1140
- package/dist/cjs/__tests__/identity-cache/identity-cache-tier-routing.spec.d.ts +1 -1
- package/dist/cjs/__tests__/identity-cache/identity-cache-tier-routing.spec.js +851 -851
- package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.d.ts +1 -1
- package/dist/cjs/__tests__/identity-cache/trait-merging-and-staleness.spec.js +1060 -1060
- package/dist/cjs/__tests__/identity-cache/volatile-traits-optimization.spec.d.ts +1 -1
- package/dist/cjs/__tests__/identity-cache/volatile-traits-optimization.spec.js +818 -818
- package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.d.ts +1 -1
- package/dist/cjs/__tests__/integration/sqs-bundling-roundtrip.spec.js +584 -584
- package/dist/cjs/__tests__/libs/compress-decompress.spec.d.ts +1 -1
- package/dist/cjs/__tests__/libs/compress-decompress.spec.js +16 -16
- package/dist/cjs/__tests__/libs/contacts.spec.d.ts +1 -1
- package/dist/cjs/__tests__/libs/contacts.spec.js +294 -294
- package/dist/cjs/__tests__/libs/currency.spec.d.ts +1 -1
- package/dist/cjs/__tests__/libs/currency.spec.js +220 -220
- package/dist/cjs/__tests__/libs/dates.spec.d.ts +1 -1
- package/dist/cjs/__tests__/libs/dates.spec.js +130 -130
- package/dist/cjs/__tests__/libs/domain.spec.d.ts +1 -1
- package/dist/cjs/__tests__/libs/domain.spec.js +107 -107
- package/dist/cjs/__tests__/libs/numbers.spec.d.ts +1 -1
- package/dist/cjs/__tests__/libs/numbers.spec.js +261 -261
- package/dist/cjs/__tests__/s3-client/s3-client.spec.d.ts +1 -1
- package/dist/cjs/__tests__/s3-client/s3-client.spec.js +33 -33
- package/dist/cjs/__tests__/services/acuity-api-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/services/acuity-api-service.spec.js +71 -71
- package/dist/cjs/__tests__/services/cost/cost-calculation-types.spec.d.ts +1 -1
- package/dist/cjs/__tests__/services/cost/cost-calculation-types.spec.js +23 -23
- package/dist/cjs/__tests__/services/cost/cost-calculator-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/services/cost/cost-calculator-service.spec.js +3319 -3319
- package/dist/cjs/__tests__/services/cost/cost-currency-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/services/cost/cost-currency-service.spec.js +114 -114
- package/dist/cjs/__tests__/services/cost/cost-filter-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/services/cost/cost-filter-service.spec.js +468 -468
- package/dist/cjs/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.js +206 -206
- package/dist/cjs/__tests__/services/currency-exchange-rate-lookup-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/services/currency-exchange-rate-lookup-service.spec.js +34 -34
- package/dist/cjs/__tests__/services/email-verification/contact-email-verification-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/services/email-verification/contact-email-verification-service.spec.js +93 -93
- package/dist/cjs/__tests__/services/email-verification/email-verification-service.spec.d.ts +1 -1
- package/dist/cjs/__tests__/services/email-verification/email-verification-service.spec.js +57 -57
- package/dist/cjs/__tests__/shopify/shopify-graphql-transformer.spec.d.ts +1 -1
- package/dist/cjs/__tests__/shopify/shopify-graphql-transformer.spec.js +35 -35
- package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.d.ts +1 -1
- package/dist/cjs/__tests__/unit/libs/api-router/public-api-router.spec.js +181 -181
- package/dist/cjs/__tests__/unit/libs/api-router/route-matcher.spec.d.ts +1 -1
- package/dist/cjs/__tests__/unit/libs/api-router/route-matcher.spec.js +69 -69
- package/dist/cjs/__tests__/utils/custom-measure-formula-utils.spec.d.ts +1 -1
- package/dist/cjs/__tests__/utils/custom-measure-formula-utils.spec.js +139 -139
- package/dist/cjs/clients/generic/cognito-client.d.ts +23 -23
- package/dist/cjs/clients/generic/cognito-client.js +209 -209
- package/dist/cjs/clients/generic/dynamodb-client.d.ts +20 -20
- package/dist/cjs/clients/generic/dynamodb-client.js +235 -235
- package/dist/cjs/clients/generic/eventbridge-client.d.ts +14 -14
- package/dist/cjs/clients/generic/eventbridge-client.js +51 -51
- package/dist/cjs/clients/generic/http-client.d.ts +14 -14
- package/dist/cjs/clients/generic/http-client.js +61 -61
- package/dist/cjs/clients/generic/index.d.ts +13 -13
- package/dist/cjs/clients/generic/index.js +29 -29
- package/dist/cjs/clients/generic/lambda-invoke-client.d.ts +10 -10
- package/dist/cjs/clients/generic/lambda-invoke-client.js +39 -39
- package/dist/cjs/clients/generic/location-client.d.ts +8 -8
- package/dist/cjs/clients/generic/location-client.js +31 -31
- package/dist/cjs/clients/generic/redis-client.d.ts +33 -33
- package/dist/cjs/clients/generic/redis-client.js +191 -191
- package/dist/cjs/clients/generic/s3-client.d.ts +23 -23
- package/dist/cjs/clients/generic/s3-client.js +216 -216
- package/dist/cjs/clients/generic/singlestore-db-client.d.ts +14 -14
- package/dist/cjs/clients/generic/singlestore-db-client.js +67 -67
- package/dist/cjs/clients/generic/sqs-bundled-client.d.ts +15 -15
- package/dist/cjs/clients/generic/sqs-bundled-client.js +311 -311
- package/dist/cjs/clients/generic/sqs-bundled-client.types.d.ts +53 -53
- package/dist/cjs/clients/generic/sqs-bundled-client.types.js +17 -17
- package/dist/cjs/clients/generic/sqs-client.d.ts +53 -53
- package/dist/cjs/clients/generic/sqs-client.js +285 -285
- package/dist/cjs/clients/generic/sqs-unbundle.d.ts +32 -32
- package/dist/cjs/clients/generic/sqs-unbundle.js +144 -144
- package/dist/cjs/clients/index.d.ts +3 -3
- package/dist/cjs/clients/index.js +19 -19
- package/dist/cjs/clients/internal-api/accounts-client.d.ts +91 -91
- package/dist/cjs/clients/internal-api/accounts-client.js +129 -129
- package/dist/cjs/clients/internal-api/cache-lambda-client.d.ts +26 -26
- package/dist/cjs/clients/internal-api/cache-lambda-client.js +89 -89
- package/dist/cjs/clients/internal-api/db-management-client.d.ts +18 -18
- package/dist/cjs/clients/internal-api/db-management-client.js +36 -36
- package/dist/cjs/clients/internal-api/destinations-client.d.ts +34 -34
- package/dist/cjs/clients/internal-api/destinations-client.js +79 -79
- package/dist/cjs/clients/internal-api/event-collector-client.d.ts +20 -20
- package/dist/cjs/clients/internal-api/event-collector-client.js +36 -36
- package/dist/cjs/clients/internal-api/identity-client.d.ts +31 -31
- package/dist/cjs/clients/internal-api/identity-client.js +91 -91
- package/dist/cjs/clients/internal-api/index.d.ts +9 -9
- package/dist/cjs/clients/internal-api/index.js +25 -25
- package/dist/cjs/clients/internal-api/shopify-app-install-client.d.ts +37 -37
- package/dist/cjs/clients/internal-api/shopify-app-install-client.js +81 -81
- package/dist/cjs/clients/internal-api/subscriptions-client.d.ts +26 -26
- package/dist/cjs/clients/internal-api/subscriptions-client.js +77 -77
- package/dist/cjs/clients/internal-api/users-auth-client.d.ts +35 -35
- package/dist/cjs/clients/internal-api/users-auth-client.js +110 -110
- package/dist/cjs/clients/third-party/acuity-client.d.ts +10 -10
- package/dist/cjs/clients/third-party/acuity-client.js +40 -40
- package/dist/cjs/clients/third-party/emailable-client.d.ts +7 -7
- package/dist/cjs/clients/third-party/emailable-client.js +25 -25
- package/dist/cjs/clients/third-party/exchange-rate-api-client.d.ts +17 -17
- package/dist/cjs/clients/third-party/exchange-rate-api-client.js +19 -19
- package/dist/cjs/clients/third-party/index.d.ts +5 -5
- package/dist/cjs/clients/third-party/index.js +21 -21
- package/dist/cjs/clients/third-party/loops-client.d.ts +10 -10
- package/dist/cjs/clients/third-party/loops-client.js +30 -30
- package/dist/cjs/clients/third-party/shopify/graphql-order-queries.d.ts +25 -25
- package/dist/cjs/clients/third-party/shopify/graphql-order-queries.js +4 -4
- package/dist/cjs/clients/third-party/shopify/graphql-product-queries.d.ts +2 -2
- package/dist/cjs/clients/third-party/shopify/graphql-product-queries.js +5 -5
- package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.d.ts +10 -10
- package/dist/cjs/clients/third-party/shopify/shopify-graphql-client.js +161 -161
- package/dist/cjs/clients/third-party/shopify-client.d.ts +29 -29
- package/dist/cjs/clients/third-party/shopify-client.js +146 -146
- package/dist/cjs/constants/index.d.ts +1 -1
- package/dist/cjs/constants/index.js +17 -17
- package/dist/cjs/constants/sqs.d.ts +20 -20
- package/dist/cjs/constants/sqs.js +26 -26
- package/dist/cjs/helpers/account-users-helper.d.ts +2 -2
- package/dist/cjs/helpers/account-users-helper.js +22 -22
- package/dist/cjs/helpers/acuity-helper.d.ts +4 -4
- package/dist/cjs/helpers/acuity-helper.js +56 -56
- package/dist/cjs/helpers/api-key-auth-helper.d.ts +9 -9
- package/dist/cjs/helpers/api-key-auth-helper.js +40 -40
- package/dist/cjs/helpers/api-key-authorizer-helper.d.ts +36 -36
- package/dist/cjs/helpers/api-key-authorizer-helper.js +87 -87
- package/dist/cjs/helpers/identity-cache-helper.d.ts +30 -30
- package/dist/cjs/helpers/identity-cache-helper.js +253 -253
- package/dist/cjs/helpers/index.d.ts +10 -10
- package/dist/cjs/helpers/index.js +26 -26
- package/dist/cjs/helpers/input-validation-helper.d.ts +3 -3
- package/dist/cjs/helpers/input-validation-helper.js +22 -22
- package/dist/cjs/helpers/logging-helper.d.ts +16 -16
- package/dist/cjs/helpers/logging-helper.js +84 -84
- package/dist/cjs/helpers/response-helper.d.ts +18 -18
- package/dist/cjs/helpers/response-helper.js +43 -43
- package/dist/cjs/helpers/shopify-helper.d.ts +9 -9
- package/dist/cjs/helpers/shopify-helper.js +26 -26
- package/dist/cjs/helpers/sqs-utils.d.ts +6 -6
- package/dist/cjs/helpers/sqs-utils.js +14 -14
- package/dist/cjs/index.d.ts +7 -7
- package/dist/cjs/index.js +23 -23
- package/dist/cjs/libs/api-router/index.d.ts +2 -2
- package/dist/cjs/libs/api-router/index.js +18 -18
- package/dist/cjs/libs/api-router/public-api-router.d.ts +3 -3
- package/dist/cjs/libs/api-router/public-api-router.js +36 -36
- package/dist/cjs/libs/api-router/route-matcher.d.ts +21 -21
- package/dist/cjs/libs/api-router/route-matcher.js +36 -36
- package/dist/cjs/libs/click-id-parser.d.ts +23 -23
- package/dist/cjs/libs/click-id-parser.js +49 -49
- package/dist/cjs/libs/compression.d.ts +2 -2
- package/dist/cjs/libs/compression.js +33 -33
- package/dist/cjs/libs/contacts.d.ts +7 -7
- package/dist/cjs/libs/contacts.js +152 -152
- package/dist/cjs/libs/cookie.d.ts +17 -17
- package/dist/cjs/libs/cookie.js +76 -76
- package/dist/cjs/libs/crypto.d.ts +4 -4
- package/dist/cjs/libs/crypto.js +25 -25
- package/dist/cjs/libs/csv.d.ts +2 -2
- package/dist/cjs/libs/csv.js +35 -35
- package/dist/cjs/libs/currency.d.ts +1 -1
- package/dist/cjs/libs/currency.js +29 -29
- package/dist/cjs/libs/dates.d.ts +12 -12
- package/dist/cjs/libs/dates.js +96 -96
- package/dist/cjs/libs/domain.d.ts +2 -2
- package/dist/cjs/libs/domain.js +38 -38
- package/dist/cjs/libs/emails.d.ts +8 -8
- package/dist/cjs/libs/emails.js +154 -154
- package/dist/cjs/libs/http-error.d.ts +21 -21
- package/dist/cjs/libs/http-error.js +63 -63
- package/dist/cjs/libs/http-status-codes.d.ts +58 -58
- package/dist/cjs/libs/http-status-codes.js +62 -62
- package/dist/cjs/libs/index.d.ts +19 -19
- package/dist/cjs/libs/index.js +35 -35
- package/dist/cjs/libs/numbers.d.ts +1 -1
- package/dist/cjs/libs/numbers.js +15 -15
- package/dist/cjs/libs/referrer-parser/index.d.ts +2 -2
- package/dist/cjs/libs/referrer-parser/index.js +18 -18
- package/dist/cjs/libs/referrer-parser/referrer-data.d.ts +9 -9
- package/dist/cjs/libs/referrer-parser/referrer-data.js +3307 -3307
- package/dist/cjs/libs/referrer-parser/referrer-parser-util.d.ts +20 -20
- package/dist/cjs/libs/referrer-parser/referrer-parser-util.js +131 -131
- package/dist/cjs/libs/strings.d.ts +3 -3
- package/dist/cjs/libs/strings.js +46 -46
- package/dist/cjs/libs/traits.d.ts +6 -6
- package/dist/cjs/libs/traits.js +65 -65
- package/dist/cjs/libs/url.d.ts +1 -1
- package/dist/cjs/libs/url.js +13 -13
- package/dist/cjs/services/acuity-api-service.d.ts +9 -9
- package/dist/cjs/services/acuity-api-service.js +73 -73
- package/dist/cjs/services/cache/generic-cached-object.d.ts +5 -5
- package/dist/cjs/services/cache/generic-cached-object.js +2 -2
- package/dist/cjs/services/cache/index.d.ts +1 -1
- package/dist/cjs/services/cache/index.js +17 -17
- package/dist/cjs/services/cache/product-cache-service.d.ts +21 -21
- package/dist/cjs/services/cache/product-cache-service.js +76 -76
- package/dist/cjs/services/cost/cost-calculation-types.d.ts +69 -69
- package/dist/cjs/services/cost/cost-calculation-types.js +19 -19
- package/dist/cjs/services/cost/cost-calculator-service.d.ts +24 -24
- package/dist/cjs/services/cost/cost-calculator-service.js +456 -456
- package/dist/cjs/services/cost/cost-currency-service.d.ts +6 -6
- package/dist/cjs/services/cost/cost-currency-service.js +87 -87
- package/dist/cjs/services/cost/cost-filter-service.d.ts +10 -10
- package/dist/cjs/services/cost/cost-filter-service.js +121 -121
- package/dist/cjs/services/cost/index.d.ts +5 -5
- package/dist/cjs/services/cost/index.js +21 -21
- package/dist/cjs/services/cost/order-cost/index.d.ts +2 -2
- package/dist/cjs/services/cost/order-cost/index.js +18 -18
- package/dist/cjs/services/cost/order-cost/order-cost-resolution-service.d.ts +23 -23
- package/dist/cjs/services/cost/order-cost/order-cost-resolution-service.js +361 -361
- package/dist/cjs/services/cost/order-cost/order-cost-resolution-types.d.ts +37 -37
- package/dist/cjs/services/cost/order-cost/order-cost-resolution-types.js +2 -2
- package/dist/cjs/services/currency-exchange-rate-lookup-service.d.ts +12 -12
- package/dist/cjs/services/currency-exchange-rate-lookup-service.js +94 -94
- package/dist/cjs/services/db/accounts-db-service.d.ts +9 -9
- package/dist/cjs/services/db/accounts-db-service.js +33 -33
- package/dist/cjs/services/db/api-keys-db-service.d.ts +10 -10
- package/dist/cjs/services/db/api-keys-db-service.js +36 -36
- package/dist/cjs/services/db/contact-enrichments-db-service.d.ts +15 -15
- package/dist/cjs/services/db/contact-enrichments-db-service.js +94 -94
- package/dist/cjs/services/db/currency-exchange-rates-db-service.d.ts +21 -21
- package/dist/cjs/services/db/currency-exchange-rates-db-service.js +39 -39
- package/dist/cjs/services/db/custom-measures-db-service.d.ts +14 -14
- package/dist/cjs/services/db/custom-measures-db-service.js +48 -48
- package/dist/cjs/services/db/destinations-db-service.d.ts +13 -13
- package/dist/cjs/services/db/destinations-db-service.js +74 -74
- package/dist/cjs/services/db/identity-cache-db-service.d.ts +28 -28
- package/dist/cjs/services/db/identity-cache-db-service.js +320 -320
- package/dist/cjs/services/db/identity-cache-dynamodb-service.d.ts +44 -44
- package/dist/cjs/services/db/identity-cache-dynamodb-service.js +734 -734
- package/dist/cjs/services/db/identity-cache-dynamodb-service.js.map +1 -1
- package/dist/cjs/services/db/index.d.ts +19 -19
- package/dist/cjs/services/db/index.js +35 -35
- package/dist/cjs/services/db/log-events-db-service.d.ts +11 -11
- package/dist/cjs/services/db/log-events-db-service.js +181 -181
- package/dist/cjs/services/db/pixels-db-service.d.ts +8 -8
- package/dist/cjs/services/db/pixels-db-service.js +35 -35
- package/dist/cjs/services/db/products-db-service-types.d.ts +10 -10
- package/dist/cjs/services/db/products-db-service-types.js +2 -2
- package/dist/cjs/services/db/products-db-service.d.ts +19 -19
- package/dist/cjs/services/db/products-db-service.js +281 -281
- package/dist/cjs/services/db/purchasable-contacts-db-service.d.ts +9 -9
- package/dist/cjs/services/db/purchasable-contacts-db-service.js +43 -43
- package/dist/cjs/services/db/purchased-contacts/index.d.ts +2 -2
- package/dist/cjs/services/db/purchased-contacts/index.js +18 -18
- package/dist/cjs/services/db/purchased-contacts/purchased-contacts-db-service.d.ts +18 -18
- package/dist/cjs/services/db/purchased-contacts/purchased-contacts-db-service.js +152 -152
- package/dist/cjs/services/db/purchased-contacts/types.d.ts +11 -11
- package/dist/cjs/services/db/purchased-contacts/types.js +2 -2
- package/dist/cjs/services/db/shopify-app-installs-db-service.d.ts +10 -10
- package/dist/cjs/services/db/shopify-app-installs-db-service.js +52 -52
- package/dist/cjs/services/db/shopify-products-cache-db-service.d.ts +16 -16
- package/dist/cjs/services/db/shopify-products-cache-db-service.js +73 -73
- package/dist/cjs/services/db/subscriptions-db-service.d.ts +11 -11
- package/dist/cjs/services/db/subscriptions-db-service.js +38 -38
- package/dist/cjs/services/db/tracking-events-db-service.d.ts +21 -21
- package/dist/cjs/services/db/tracking-events-db-service.js +188 -188
- package/dist/cjs/services/db/user-accounts-db-service.d.ts +7 -7
- package/dist/cjs/services/db/user-accounts-db-service.js +17 -17
- package/dist/cjs/services/email-verification/contact-email-verification-service.d.ts +7 -7
- package/dist/cjs/services/email-verification/contact-email-verification-service.js +101 -101
- package/dist/cjs/services/email-verification/email-verification-service.d.ts +19 -19
- package/dist/cjs/services/email-verification/email-verification-service.js +131 -131
- package/dist/cjs/services/email-verification/index.d.ts +2 -2
- package/dist/cjs/services/email-verification/index.js +18 -18
- package/dist/cjs/services/eventbridge-integration-service.d.ts +9 -9
- package/dist/cjs/services/eventbridge-integration-service.js +28 -28
- package/dist/cjs/services/events/index.d.ts +3 -3
- package/dist/cjs/services/events/index.js +19 -19
- package/dist/cjs/services/events/log-event-service.d.ts +19 -19
- package/dist/cjs/services/events/log-event-service.js +77 -77
- package/dist/cjs/services/events/metric-event-service.d.ts +9 -9
- package/dist/cjs/services/events/metric-event-service.js +49 -49
- package/dist/cjs/services/events/tracking-event-sqs-service.d.ts +8 -8
- package/dist/cjs/services/events/tracking-event-sqs-service.js +34 -34
- package/dist/cjs/services/generic-cache-service.d.ts +7 -7
- package/dist/cjs/services/generic-cache-service.js +33 -33
- package/dist/cjs/services/index.d.ts +11 -11
- package/dist/cjs/services/index.js +27 -27
- package/dist/cjs/services/ipdata-lookup-service.d.ts +20 -20
- package/dist/cjs/services/ipdata-lookup-service.js +112 -112
- package/dist/cjs/services/shopify/index.d.ts +2 -2
- package/dist/cjs/services/shopify/index.js +18 -18
- package/dist/cjs/services/shopify/products/index.d.ts +1 -1
- package/dist/cjs/services/shopify/products/index.js +17 -17
- package/dist/cjs/services/shopify/products/shopify-products-serviceV2.d.ts +17 -17
- package/dist/cjs/services/shopify/products/shopify-products-serviceV2.js +112 -112
- package/dist/cjs/services/shopify/shopify-graphql-transformer.d.ts +8 -8
- package/dist/cjs/services/shopify/shopify-graphql-transformer.js +141 -141
- package/dist/cjs/types/acuity-types.d.ts +74 -74
- package/dist/cjs/types/acuity-types.js +2 -2
- package/dist/cjs/types/api-response.d.ts +6 -6
- package/dist/cjs/types/api-response.js +2 -2
- package/dist/cjs/types/index.d.ts +4 -4
- package/dist/cjs/types/index.js +33 -33
- package/dist/cjs/types/internal-events/event-detail-types.d.ts +20 -20
- package/dist/cjs/types/internal-events/event-detail-types.js +27 -27
- package/dist/cjs/types/internal-events/index.d.ts +1 -1
- package/dist/cjs/types/internal-events/index.js +17 -17
- package/dist/cjs/types/shopify-graphql-types/admin.generated.d.ts +123 -123
- package/dist/cjs/types/shopify-graphql-types/admin.generated.js +2 -2
- package/dist/cjs/types/shopify-graphql-types/admin.types.d.ts +26289 -26289
- package/dist/cjs/types/shopify-graphql-types/admin.types.js +5311 -5311
- package/dist/cjs/types/shopify-graphql-types/index.d.ts +2 -2
- package/dist/cjs/types/shopify-graphql-types/index.js +18 -18
- package/dist/cjs/types/shopify-rest-types.d.ts +767 -767
- package/dist/cjs/types/shopify-rest-types.js +2 -2
- package/dist/cjs/utils/compression.d.ts +36 -36
- package/dist/cjs/utils/compression.js +198 -198
- package/dist/cjs/utils/custom-measure-formula-utils.d.ts +6 -6
- package/dist/cjs/utils/custom-measure-formula-utils.js +209 -209
- package/dist/cjs/utils/index.d.ts +4 -4
- package/dist/cjs/utils/index.js +20 -20
- package/dist/cjs/utils/retry-envelope.d.ts +12 -12
- package/dist/cjs/utils/retry-envelope.js +28 -28
- package/dist/cjs/utils/size.d.ts +2 -2
- package/dist/cjs/utils/size.js +49 -49
- package/dist/esm/__tests__/clients/acuity-client.spec.d.ts +1 -1
- package/dist/esm/__tests__/clients/acuity-client.spec.js +41 -41
- package/dist/esm/__tests__/clients/cross-platform-compression.spec.d.ts +1 -1
- package/dist/esm/__tests__/clients/cross-platform-compression.spec.js +329 -329
- package/dist/esm/__tests__/clients/dynamodb-client.spec.d.ts +1 -1
- package/dist/esm/__tests__/clients/dynamodb-client.spec.js +192 -192
- package/dist/esm/__tests__/clients/sqs-bundled-client.spec.d.ts +1 -1
- package/dist/esm/__tests__/clients/sqs-bundled-client.spec.js +906 -906
- package/dist/esm/__tests__/clients/sqs-bundling-contracts.spec.d.ts +1 -1
- package/dist/esm/__tests__/clients/sqs-bundling-contracts.spec.js +538 -538
- package/dist/esm/__tests__/clients/sqs-client.spec.d.ts +1 -1
- package/dist/esm/__tests__/clients/sqs-client.spec.js +189 -189
- package/dist/esm/__tests__/clients/sqs-unbundle.spec.d.ts +1 -1
- package/dist/esm/__tests__/clients/sqs-unbundle.spec.js +1355 -1355
- package/dist/esm/__tests__/db/contact-enrichments-db-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/db/contact-enrichments-db-service.spec.js +66 -66
- package/dist/esm/__tests__/db/destinations-db-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/db/destinations-db-service.spec.js +123 -123
- package/dist/esm/__tests__/db/products-db-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/db/products-db-service.spec.js +87 -87
- package/dist/esm/__tests__/db/shared-read-db-services.spec.d.ts +1 -1
- package/dist/esm/__tests__/db/shared-read-db-services.spec.js +87 -87
- package/dist/esm/__tests__/db/shopify-app-installs-db-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/db/shopify-app-installs-db-service.spec.js +102 -102
- package/dist/esm/__tests__/db/subscriptions-db-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/db/subscriptions-db-service.spec.js +93 -93
- package/dist/esm/__tests__/db/user-accounts-db-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/db/user-accounts-db-service.spec.js +74 -74
- package/dist/esm/__tests__/helpers/account-users-helper.spec.d.ts +1 -1
- package/dist/esm/__tests__/helpers/account-users-helper.spec.js +218 -218
- package/dist/esm/__tests__/helpers/acuity-helper.spec.d.ts +1 -1
- package/dist/esm/__tests__/helpers/acuity-helper.spec.js +67 -67
- package/dist/esm/__tests__/helpers/api-key-auth-helper.spec.d.ts +1 -1
- package/dist/esm/__tests__/helpers/api-key-auth-helper.spec.js +80 -80
- package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/identity-cache/identity-cache-db-service.spec.js +674 -674
- package/dist/esm/__tests__/identity-cache/identity-cache-dynamodb-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/identity-cache/identity-cache-dynamodb-service.spec.js +1138 -1138
- package/dist/esm/__tests__/identity-cache/identity-cache-tier-routing.spec.d.ts +1 -1
- package/dist/esm/__tests__/identity-cache/identity-cache-tier-routing.spec.js +849 -849
- package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.d.ts +1 -1
- package/dist/esm/__tests__/identity-cache/trait-merging-and-staleness.spec.js +1058 -1058
- package/dist/esm/__tests__/identity-cache/volatile-traits-optimization.spec.d.ts +1 -1
- package/dist/esm/__tests__/identity-cache/volatile-traits-optimization.spec.js +816 -816
- package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.d.ts +1 -1
- package/dist/esm/__tests__/integration/sqs-bundling-roundtrip.spec.js +582 -582
- package/dist/esm/__tests__/libs/compress-decompress.spec.d.ts +1 -1
- package/dist/esm/__tests__/libs/compress-decompress.spec.js +14 -14
- package/dist/esm/__tests__/libs/contacts.spec.d.ts +1 -1
- package/dist/esm/__tests__/libs/contacts.spec.js +292 -292
- package/dist/esm/__tests__/libs/currency.spec.d.ts +1 -1
- package/dist/esm/__tests__/libs/currency.spec.js +218 -218
- package/dist/esm/__tests__/libs/dates.spec.d.ts +1 -1
- package/dist/esm/__tests__/libs/dates.spec.js +128 -128
- package/dist/esm/__tests__/libs/domain.spec.d.ts +1 -1
- package/dist/esm/__tests__/libs/domain.spec.js +105 -105
- package/dist/esm/__tests__/libs/numbers.spec.d.ts +1 -1
- package/dist/esm/__tests__/libs/numbers.spec.js +259 -259
- package/dist/esm/__tests__/s3-client/s3-client.spec.d.ts +1 -1
- package/dist/esm/__tests__/s3-client/s3-client.spec.js +31 -31
- package/dist/esm/__tests__/services/acuity-api-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/services/acuity-api-service.spec.js +69 -69
- package/dist/esm/__tests__/services/cost/cost-calculation-types.spec.d.ts +1 -1
- package/dist/esm/__tests__/services/cost/cost-calculation-types.spec.js +21 -21
- package/dist/esm/__tests__/services/cost/cost-calculator-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/services/cost/cost-calculator-service.spec.js +3317 -3317
- package/dist/esm/__tests__/services/cost/cost-currency-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/services/cost/cost-currency-service.spec.js +112 -112
- package/dist/esm/__tests__/services/cost/cost-filter-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/services/cost/cost-filter-service.spec.js +466 -466
- package/dist/esm/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/services/cost/order-cost/order-cost-resolution-service.spec.js +204 -204
- package/dist/esm/__tests__/services/currency-exchange-rate-lookup-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/services/currency-exchange-rate-lookup-service.spec.js +32 -32
- package/dist/esm/__tests__/services/email-verification/contact-email-verification-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/services/email-verification/contact-email-verification-service.spec.js +91 -91
- package/dist/esm/__tests__/services/email-verification/email-verification-service.spec.d.ts +1 -1
- package/dist/esm/__tests__/services/email-verification/email-verification-service.spec.js +55 -55
- package/dist/esm/__tests__/shopify/shopify-graphql-transformer.spec.d.ts +1 -1
- package/dist/esm/__tests__/shopify/shopify-graphql-transformer.spec.js +33 -33
- package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.d.ts +1 -1
- package/dist/esm/__tests__/unit/libs/api-router/public-api-router.spec.js +156 -156
- package/dist/esm/__tests__/unit/libs/api-router/route-matcher.spec.d.ts +1 -1
- package/dist/esm/__tests__/unit/libs/api-router/route-matcher.spec.js +67 -67
- package/dist/esm/__tests__/utils/custom-measure-formula-utils.spec.d.ts +1 -1
- package/dist/esm/__tests__/utils/custom-measure-formula-utils.spec.js +137 -137
- package/dist/esm/clients/generic/cognito-client.d.ts +23 -23
- package/dist/esm/clients/generic/cognito-client.js +204 -204
- package/dist/esm/clients/generic/dynamodb-client.d.ts +20 -20
- package/dist/esm/clients/generic/dynamodb-client.js +231 -231
- package/dist/esm/clients/generic/eventbridge-client.d.ts +14 -14
- package/dist/esm/clients/generic/eventbridge-client.js +47 -47
- package/dist/esm/clients/generic/http-client.d.ts +14 -14
- package/dist/esm/clients/generic/http-client.js +53 -53
- package/dist/esm/clients/generic/index.d.ts +13 -13
- package/dist/esm/clients/generic/index.js +13 -13
- package/dist/esm/clients/generic/lambda-invoke-client.d.ts +10 -10
- package/dist/esm/clients/generic/lambda-invoke-client.js +35 -35
- package/dist/esm/clients/generic/location-client.d.ts +8 -8
- package/dist/esm/clients/generic/location-client.js +27 -27
- package/dist/esm/clients/generic/redis-client.d.ts +33 -33
- package/dist/esm/clients/generic/redis-client.js +184 -184
- package/dist/esm/clients/generic/s3-client.d.ts +23 -23
- package/dist/esm/clients/generic/s3-client.js +209 -209
- package/dist/esm/clients/generic/singlestore-db-client.d.ts +14 -14
- package/dist/esm/clients/generic/singlestore-db-client.js +40 -40
- package/dist/esm/clients/generic/sqs-bundled-client.d.ts +15 -15
- package/dist/esm/clients/generic/sqs-bundled-client.js +307 -307
- package/dist/esm/clients/generic/sqs-bundled-client.types.d.ts +53 -53
- package/dist/esm/clients/generic/sqs-bundled-client.types.js +14 -14
- package/dist/esm/clients/generic/sqs-client.d.ts +53 -53
- package/dist/esm/clients/generic/sqs-client.js +281 -281
- package/dist/esm/clients/generic/sqs-unbundle.d.ts +32 -32
- package/dist/esm/clients/generic/sqs-unbundle.js +137 -137
- package/dist/esm/clients/index.d.ts +3 -3
- package/dist/esm/clients/index.js +3 -3
- package/dist/esm/clients/internal-api/accounts-client.d.ts +91 -91
- package/dist/esm/clients/internal-api/accounts-client.js +125 -125
- package/dist/esm/clients/internal-api/cache-lambda-client.d.ts +26 -26
- package/dist/esm/clients/internal-api/cache-lambda-client.js +85 -85
- package/dist/esm/clients/internal-api/db-management-client.d.ts +18 -18
- package/dist/esm/clients/internal-api/db-management-client.js +32 -32
- package/dist/esm/clients/internal-api/destinations-client.d.ts +34 -34
- package/dist/esm/clients/internal-api/destinations-client.js +75 -75
- package/dist/esm/clients/internal-api/event-collector-client.d.ts +20 -20
- package/dist/esm/clients/internal-api/event-collector-client.js +32 -32
- package/dist/esm/clients/internal-api/identity-client.d.ts +31 -31
- package/dist/esm/clients/internal-api/identity-client.js +87 -87
- package/dist/esm/clients/internal-api/index.d.ts +9 -9
- package/dist/esm/clients/internal-api/index.js +9 -9
- package/dist/esm/clients/internal-api/shopify-app-install-client.d.ts +37 -37
- package/dist/esm/clients/internal-api/shopify-app-install-client.js +77 -77
- package/dist/esm/clients/internal-api/subscriptions-client.d.ts +26 -26
- package/dist/esm/clients/internal-api/subscriptions-client.js +73 -73
- package/dist/esm/clients/internal-api/users-auth-client.d.ts +35 -35
- package/dist/esm/clients/internal-api/users-auth-client.js +106 -106
- package/dist/esm/clients/third-party/acuity-client.d.ts +10 -10
- package/dist/esm/clients/third-party/acuity-client.js +36 -36
- package/dist/esm/clients/third-party/emailable-client.d.ts +7 -7
- package/dist/esm/clients/third-party/emailable-client.js +21 -21
- package/dist/esm/clients/third-party/exchange-rate-api-client.d.ts +17 -17
- package/dist/esm/clients/third-party/exchange-rate-api-client.js +15 -15
- package/dist/esm/clients/third-party/index.d.ts +5 -5
- package/dist/esm/clients/third-party/index.js +5 -5
- package/dist/esm/clients/third-party/loops-client.d.ts +10 -10
- package/dist/esm/clients/third-party/loops-client.js +26 -26
- package/dist/esm/clients/third-party/shopify/graphql-order-queries.d.ts +25 -25
- package/dist/esm/clients/third-party/shopify/graphql-order-queries.js +1 -1
- package/dist/esm/clients/third-party/shopify/graphql-product-queries.d.ts +2 -2
- package/dist/esm/clients/third-party/shopify/graphql-product-queries.js +2 -2
- package/dist/esm/clients/third-party/shopify/shopify-graphql-client.d.ts +10 -10
- package/dist/esm/clients/third-party/shopify/shopify-graphql-client.js +157 -157
- package/dist/esm/clients/third-party/shopify-client.d.ts +29 -29
- package/dist/esm/clients/third-party/shopify-client.js +142 -142
- package/dist/esm/constants/index.d.ts +1 -1
- package/dist/esm/constants/index.js +1 -1
- package/dist/esm/constants/sqs.d.ts +20 -20
- package/dist/esm/constants/sqs.js +22 -22
- package/dist/esm/helpers/account-users-helper.d.ts +2 -2
- package/dist/esm/helpers/account-users-helper.js +18 -18
- package/dist/esm/helpers/acuity-helper.d.ts +4 -4
- package/dist/esm/helpers/acuity-helper.js +51 -51
- package/dist/esm/helpers/api-key-auth-helper.d.ts +9 -9
- package/dist/esm/helpers/api-key-auth-helper.js +35 -35
- package/dist/esm/helpers/api-key-authorizer-helper.d.ts +36 -36
- package/dist/esm/helpers/api-key-authorizer-helper.js +83 -83
- package/dist/esm/helpers/identity-cache-helper.d.ts +30 -30
- package/dist/esm/helpers/identity-cache-helper.js +248 -248
- package/dist/esm/helpers/index.d.ts +10 -10
- package/dist/esm/helpers/index.js +10 -10
- package/dist/esm/helpers/input-validation-helper.d.ts +3 -3
- package/dist/esm/helpers/input-validation-helper.js +18 -18
- package/dist/esm/helpers/logging-helper.d.ts +16 -16
- package/dist/esm/helpers/logging-helper.js +56 -56
- package/dist/esm/helpers/response-helper.d.ts +18 -18
- package/dist/esm/helpers/response-helper.js +37 -37
- package/dist/esm/helpers/shopify-helper.d.ts +9 -9
- package/dist/esm/helpers/shopify-helper.js +21 -21
- package/dist/esm/helpers/sqs-utils.d.ts +6 -6
- package/dist/esm/helpers/sqs-utils.js +9 -9
- package/dist/esm/index.d.ts +7 -7
- package/dist/esm/index.js +7 -7
- package/dist/esm/libs/api-router/index.d.ts +2 -2
- package/dist/esm/libs/api-router/index.js +2 -2
- package/dist/esm/libs/api-router/public-api-router.d.ts +3 -3
- package/dist/esm/libs/api-router/public-api-router.js +32 -32
- package/dist/esm/libs/api-router/route-matcher.d.ts +21 -21
- package/dist/esm/libs/api-router/route-matcher.js +30 -30
- package/dist/esm/libs/click-id-parser.d.ts +23 -23
- package/dist/esm/libs/click-id-parser.js +45 -45
- package/dist/esm/libs/compression.d.ts +2 -2
- package/dist/esm/libs/compression.js +25 -25
- package/dist/esm/libs/contacts.d.ts +7 -7
- package/dist/esm/libs/contacts.js +143 -143
- package/dist/esm/libs/cookie.d.ts +17 -17
- package/dist/esm/libs/cookie.js +70 -70
- package/dist/esm/libs/crypto.d.ts +4 -4
- package/dist/esm/libs/crypto.js +15 -15
- package/dist/esm/libs/csv.d.ts +2 -2
- package/dist/esm/libs/csv.js +30 -30
- package/dist/esm/libs/currency.d.ts +1 -1
- package/dist/esm/libs/currency.js +22 -22
- package/dist/esm/libs/dates.d.ts +12 -12
- package/dist/esm/libs/dates.js +83 -83
- package/dist/esm/libs/domain.d.ts +2 -2
- package/dist/esm/libs/domain.js +33 -33
- package/dist/esm/libs/emails.d.ts +8 -8
- package/dist/esm/libs/emails.js +146 -146
- package/dist/esm/libs/http-error.d.ts +21 -21
- package/dist/esm/libs/http-error.js +59 -59
- package/dist/esm/libs/http-status-codes.d.ts +58 -58
- package/dist/esm/libs/http-status-codes.js +59 -59
- package/dist/esm/libs/index.d.ts +19 -19
- package/dist/esm/libs/index.js +19 -19
- package/dist/esm/libs/numbers.d.ts +1 -1
- package/dist/esm/libs/numbers.js +11 -11
- package/dist/esm/libs/referrer-parser/index.d.ts +2 -2
- package/dist/esm/libs/referrer-parser/index.js +2 -2
- package/dist/esm/libs/referrer-parser/referrer-data.d.ts +9 -9
- package/dist/esm/libs/referrer-parser/referrer-data.js +3304 -3304
- package/dist/esm/libs/referrer-parser/referrer-parser-util.d.ts +20 -20
- package/dist/esm/libs/referrer-parser/referrer-parser-util.js +124 -124
- package/dist/esm/libs/strings.d.ts +3 -3
- package/dist/esm/libs/strings.js +40 -40
- package/dist/esm/libs/traits.d.ts +6 -6
- package/dist/esm/libs/traits.js +54 -54
- package/dist/esm/libs/url.d.ts +1 -1
- package/dist/esm/libs/url.js +9 -9
- package/dist/esm/services/acuity-api-service.d.ts +9 -9
- package/dist/esm/services/acuity-api-service.js +69 -69
- package/dist/esm/services/cache/generic-cached-object.d.ts +5 -5
- package/dist/esm/services/cache/generic-cached-object.js +1 -1
- package/dist/esm/services/cache/index.d.ts +1 -1
- package/dist/esm/services/cache/index.js +1 -1
- package/dist/esm/services/cache/product-cache-service.d.ts +21 -21
- package/dist/esm/services/cache/product-cache-service.js +68 -68
- package/dist/esm/services/cost/cost-calculation-types.d.ts +69 -69
- package/dist/esm/services/cost/cost-calculation-types.js +15 -15
- package/dist/esm/services/cost/cost-calculator-service.d.ts +24 -24
- package/dist/esm/services/cost/cost-calculator-service.js +450 -450
- package/dist/esm/services/cost/cost-currency-service.d.ts +6 -6
- package/dist/esm/services/cost/cost-currency-service.js +84 -84
- package/dist/esm/services/cost/cost-filter-service.d.ts +10 -10
- package/dist/esm/services/cost/cost-filter-service.js +118 -118
- package/dist/esm/services/cost/index.d.ts +5 -5
- package/dist/esm/services/cost/index.js +5 -5
- package/dist/esm/services/cost/order-cost/index.d.ts +2 -2
- package/dist/esm/services/cost/order-cost/index.js +2 -2
- package/dist/esm/services/cost/order-cost/order-cost-resolution-service.d.ts +23 -23
- package/dist/esm/services/cost/order-cost/order-cost-resolution-service.js +355 -355
- package/dist/esm/services/cost/order-cost/order-cost-resolution-types.d.ts +37 -37
- package/dist/esm/services/cost/order-cost/order-cost-resolution-types.js +1 -1
- package/dist/esm/services/currency-exchange-rate-lookup-service.d.ts +12 -12
- package/dist/esm/services/currency-exchange-rate-lookup-service.js +90 -90
- package/dist/esm/services/db/accounts-db-service.d.ts +9 -9
- package/dist/esm/services/db/accounts-db-service.js +29 -29
- package/dist/esm/services/db/api-keys-db-service.d.ts +10 -10
- package/dist/esm/services/db/api-keys-db-service.js +32 -32
- package/dist/esm/services/db/contact-enrichments-db-service.d.ts +15 -15
- package/dist/esm/services/db/contact-enrichments-db-service.js +90 -90
- package/dist/esm/services/db/currency-exchange-rates-db-service.d.ts +21 -21
- package/dist/esm/services/db/currency-exchange-rates-db-service.js +35 -35
- package/dist/esm/services/db/custom-measures-db-service.d.ts +14 -14
- package/dist/esm/services/db/custom-measures-db-service.js +44 -44
- package/dist/esm/services/db/destinations-db-service.d.ts +13 -13
- package/dist/esm/services/db/destinations-db-service.js +70 -70
- package/dist/esm/services/db/identity-cache-db-service.d.ts +28 -28
- package/dist/esm/services/db/identity-cache-db-service.js +313 -313
- package/dist/esm/services/db/identity-cache-dynamodb-service.d.ts +44 -44
- package/dist/esm/services/db/identity-cache-dynamodb-service.js +727 -727
- package/dist/esm/services/db/identity-cache-dynamodb-service.js.map +1 -1
- package/dist/esm/services/db/index.d.ts +19 -19
- package/dist/esm/services/db/index.js +19 -19
- package/dist/esm/services/db/log-events-db-service.d.ts +11 -11
- package/dist/esm/services/db/log-events-db-service.js +177 -177
- package/dist/esm/services/db/pixels-db-service.d.ts +8 -8
- package/dist/esm/services/db/pixels-db-service.js +31 -31
- package/dist/esm/services/db/products-db-service-types.d.ts +10 -10
- package/dist/esm/services/db/products-db-service-types.js +1 -1
- package/dist/esm/services/db/products-db-service.d.ts +19 -19
- package/dist/esm/services/db/products-db-service.js +277 -277
- package/dist/esm/services/db/purchasable-contacts-db-service.d.ts +9 -9
- package/dist/esm/services/db/purchasable-contacts-db-service.js +39 -39
- package/dist/esm/services/db/purchased-contacts/index.d.ts +2 -2
- package/dist/esm/services/db/purchased-contacts/index.js +2 -2
- package/dist/esm/services/db/purchased-contacts/purchased-contacts-db-service.d.ts +18 -18
- package/dist/esm/services/db/purchased-contacts/purchased-contacts-db-service.js +148 -148
- package/dist/esm/services/db/purchased-contacts/types.d.ts +11 -11
- package/dist/esm/services/db/purchased-contacts/types.js +1 -1
- package/dist/esm/services/db/shopify-app-installs-db-service.d.ts +10 -10
- package/dist/esm/services/db/shopify-app-installs-db-service.js +48 -48
- package/dist/esm/services/db/shopify-products-cache-db-service.d.ts +16 -16
- package/dist/esm/services/db/shopify-products-cache-db-service.js +66 -66
- package/dist/esm/services/db/subscriptions-db-service.d.ts +11 -11
- package/dist/esm/services/db/subscriptions-db-service.js +34 -34
- package/dist/esm/services/db/tracking-events-db-service.d.ts +21 -21
- package/dist/esm/services/db/tracking-events-db-service.js +184 -184
- package/dist/esm/services/db/user-accounts-db-service.d.ts +7 -7
- package/dist/esm/services/db/user-accounts-db-service.js +13 -13
- package/dist/esm/services/email-verification/contact-email-verification-service.d.ts +7 -7
- package/dist/esm/services/email-verification/contact-email-verification-service.js +97 -97
- package/dist/esm/services/email-verification/email-verification-service.d.ts +19 -19
- package/dist/esm/services/email-verification/email-verification-service.js +127 -127
- package/dist/esm/services/email-verification/index.d.ts +2 -2
- package/dist/esm/services/email-verification/index.js +2 -2
- package/dist/esm/services/eventbridge-integration-service.d.ts +9 -9
- package/dist/esm/services/eventbridge-integration-service.js +24 -24
- package/dist/esm/services/events/index.d.ts +3 -3
- package/dist/esm/services/events/index.js +3 -3
- package/dist/esm/services/events/log-event-service.d.ts +19 -19
- package/dist/esm/services/events/log-event-service.js +73 -73
- package/dist/esm/services/events/metric-event-service.d.ts +9 -9
- package/dist/esm/services/events/metric-event-service.js +45 -45
- package/dist/esm/services/events/tracking-event-sqs-service.d.ts +8 -8
- package/dist/esm/services/events/tracking-event-sqs-service.js +30 -30
- package/dist/esm/services/generic-cache-service.d.ts +7 -7
- package/dist/esm/services/generic-cache-service.js +29 -29
- package/dist/esm/services/index.d.ts +11 -11
- package/dist/esm/services/index.js +11 -11
- package/dist/esm/services/ipdata-lookup-service.d.ts +20 -20
- package/dist/esm/services/ipdata-lookup-service.js +108 -108
- package/dist/esm/services/shopify/index.d.ts +2 -2
- package/dist/esm/services/shopify/index.js +2 -2
- package/dist/esm/services/shopify/products/index.d.ts +1 -1
- package/dist/esm/services/shopify/products/index.js +1 -1
- package/dist/esm/services/shopify/products/shopify-products-serviceV2.d.ts +17 -17
- package/dist/esm/services/shopify/products/shopify-products-serviceV2.js +108 -108
- package/dist/esm/services/shopify/shopify-graphql-transformer.d.ts +8 -8
- package/dist/esm/services/shopify/shopify-graphql-transformer.js +138 -138
- package/dist/esm/types/acuity-types.d.ts +74 -74
- package/dist/esm/types/acuity-types.js +1 -1
- package/dist/esm/types/api-response.d.ts +6 -6
- package/dist/esm/types/api-response.js +1 -1
- package/dist/esm/types/index.d.ts +4 -4
- package/dist/esm/types/index.js +4 -4
- package/dist/esm/types/internal-events/event-detail-types.d.ts +20 -20
- package/dist/esm/types/internal-events/event-detail-types.js +24 -24
- package/dist/esm/types/internal-events/index.d.ts +1 -1
- package/dist/esm/types/internal-events/index.js +1 -1
- package/dist/esm/types/shopify-graphql-types/admin.generated.d.ts +123 -123
- package/dist/esm/types/shopify-graphql-types/admin.generated.js +1 -1
- package/dist/esm/types/shopify-graphql-types/admin.types.d.ts +26289 -26289
- package/dist/esm/types/shopify-graphql-types/admin.types.js +5299 -5299
- package/dist/esm/types/shopify-graphql-types/index.d.ts +2 -2
- package/dist/esm/types/shopify-graphql-types/index.js +2 -2
- package/dist/esm/types/shopify-rest-types.d.ts +767 -767
- package/dist/esm/types/shopify-rest-types.js +1 -1
- package/dist/esm/utils/compression.d.ts +36 -36
- package/dist/esm/utils/compression.js +187 -187
- package/dist/esm/utils/custom-measure-formula-utils.d.ts +6 -6
- package/dist/esm/utils/custom-measure-formula-utils.js +201 -201
- package/dist/esm/utils/index.d.ts +4 -4
- package/dist/esm/utils/index.js +4 -4
- package/dist/esm/utils/retry-envelope.d.ts +12 -12
- package/dist/esm/utils/retry-envelope.js +22 -22
- package/dist/esm/utils/size.d.ts +2 -2
- package/dist/esm/utils/size.js +44 -44
- package/package.json +134 -134
|
@@ -1,330 +1,330 @@
|
|
|
1
|
-
import * as zlib from 'zlib';
|
|
2
|
-
import { promisify } from 'util';
|
|
3
|
-
import { unbundleRecords } from '../../clients/generic/sqs-unbundle';
|
|
4
|
-
import { decompressFromBase64 } from '../../utils/compression';
|
|
5
|
-
import { CompressionAlgorithm } from '../../clients/generic/sqs-bundled-client.types';
|
|
6
|
-
const gzip = promisify(zlib.gzip);
|
|
7
|
-
const gunzip = promisify(zlib.gunzip);
|
|
8
|
-
async function cfWorkerCompress(data) {
|
|
9
|
-
const stream = new CompressionStream('gzip');
|
|
10
|
-
const writer = stream.writable.getWriter();
|
|
11
|
-
await writer.write(data);
|
|
12
|
-
await writer.close();
|
|
13
|
-
const chunks = [];
|
|
14
|
-
const reader = stream.readable.getReader();
|
|
15
|
-
for (;;) {
|
|
16
|
-
const { done, value } = await reader.read();
|
|
17
|
-
if (done)
|
|
18
|
-
break;
|
|
19
|
-
chunks.push(value);
|
|
20
|
-
}
|
|
21
|
-
const totalLength = chunks.reduce((sum, chunk) => sum + chunk.length, 0);
|
|
22
|
-
const result = new Uint8Array(totalLength);
|
|
23
|
-
let offset = 0;
|
|
24
|
-
for (const chunk of chunks) {
|
|
25
|
-
result.set(chunk, offset);
|
|
26
|
-
offset += chunk.length;
|
|
27
|
-
}
|
|
28
|
-
return result;
|
|
29
|
-
}
|
|
30
|
-
function cfWorkerToBase64(bytes) {
|
|
31
|
-
let binary = '';
|
|
32
|
-
for (let i = 0; i < bytes.length; i++) {
|
|
33
|
-
binary += String.fromCharCode(bytes[i]);
|
|
34
|
-
}
|
|
35
|
-
return btoa(binary);
|
|
36
|
-
}
|
|
37
|
-
async function createCfWorkerBundledMessage(messageType, items) {
|
|
38
|
-
const json = JSON.stringify(items);
|
|
39
|
-
const encoder = new TextEncoder();
|
|
40
|
-
const uncompressed = encoder.encode(json);
|
|
41
|
-
const compressed = await cfWorkerCompress(uncompressed);
|
|
42
|
-
const base64 = cfWorkerToBase64(compressed);
|
|
43
|
-
const envelope = {
|
|
44
|
-
v: 1,
|
|
45
|
-
c: 'gzip',
|
|
46
|
-
n: items.length,
|
|
47
|
-
p: base64,
|
|
48
|
-
s: json.length,
|
|
49
|
-
};
|
|
50
|
-
return {
|
|
51
|
-
messageId: crypto.randomUUID(),
|
|
52
|
-
messageType,
|
|
53
|
-
messageTime: new Date().toISOString(),
|
|
54
|
-
messageBody: envelope,
|
|
55
|
-
};
|
|
56
|
-
}
|
|
57
|
-
function createSQSRecord(body, messageId) {
|
|
58
|
-
return {
|
|
59
|
-
messageId: messageId ?? crypto.randomUUID(),
|
|
60
|
-
receiptHandle: 'test-receipt-handle',
|
|
61
|
-
body,
|
|
62
|
-
attributes: {
|
|
63
|
-
ApproximateReceiveCount: '1',
|
|
64
|
-
SentTimestamp: Date.now().toString(),
|
|
65
|
-
SenderId: 'test-sender',
|
|
66
|
-
ApproximateFirstReceiveTimestamp: Date.now().toString(),
|
|
67
|
-
},
|
|
68
|
-
messageAttributes: {},
|
|
69
|
-
md5OfBody: 'test-md5',
|
|
70
|
-
eventSource: 'aws:sqs',
|
|
71
|
-
eventSourceARN: 'arn:aws:sqs:us-east-1:123456789:test-queue',
|
|
72
|
-
awsRegion: 'us-east-1',
|
|
73
|
-
};
|
|
74
|
-
}
|
|
75
|
-
const GOLDEN_ITEMS = [
|
|
76
|
-
{ pixelId: 'px_golden_001', event: 'page_view', data: { url: 'https://example.com/test' } },
|
|
77
|
-
{ pixelId: 'px_golden_002', event: 'purchase', data: { amount: 99.99, currency: 'USD' } },
|
|
78
|
-
];
|
|
79
|
-
const GOLDEN_GZIP_BASE64 = 'H4sIAAAAAAAACnXMvQrDIBhG4Xt5Z4lpN527dC6dShHRjyTgH0ZTS/DeS7YsXc+B57UjLY3c3UIiNTVFZymocbyAgTYK5eh6IrUt9AGD1UVD7qjZQWIuJa2Sc2raJ0eDiZ4XWgt6Z//k61mu2cx6pROsfazHE2IQgsHUnCmYLySejxt6f/8AfIEZO7MAAAA=';
|
|
80
|
-
describe('Cross-Platform Compression Compatibility', () => {
|
|
81
|
-
describe('CompressionStream (CF Worker) → zlib.gunzip (Lambda)', () => {
|
|
82
|
-
it('basic payload round-trips correctly', async () => {
|
|
83
|
-
const originalData = { pixelId: 'px_test', event: 'page_view' };
|
|
84
|
-
const json = JSON.stringify([originalData]);
|
|
85
|
-
const compressed = await cfWorkerCompress(new TextEncoder().encode(json));
|
|
86
|
-
expect(compressed[0]).toBe(0x1f);
|
|
87
|
-
expect(compressed[1]).toBe(0x8b);
|
|
88
|
-
const decompressed = await gunzip(Buffer.from(compressed));
|
|
89
|
-
const parsed = JSON.parse(decompressed.toString('utf8'));
|
|
90
|
-
expect(parsed).toEqual([originalData]);
|
|
91
|
-
});
|
|
92
|
-
it('CompressionStream output is valid GZIP decompressible by at-service-common', async () => {
|
|
93
|
-
const items = [{ pixelId: 'px_001' }, { pixelId: 'px_002' }];
|
|
94
|
-
const json = JSON.stringify(items);
|
|
95
|
-
const compressed = await cfWorkerCompress(new TextEncoder().encode(json));
|
|
96
|
-
const base64 = cfWorkerToBase64(compressed);
|
|
97
|
-
const result = await decompressFromBase64(base64, CompressionAlgorithm.GZIP);
|
|
98
|
-
expect(result).toEqual(items);
|
|
99
|
-
});
|
|
100
|
-
it('unbundleRecords handles CF Worker compressed messages', async () => {
|
|
101
|
-
const items = [
|
|
102
|
-
{ pixelId: 'px_cfworker_001', event: 'PageView' },
|
|
103
|
-
{ pixelId: 'px_cfworker_002', event: 'AddToCart' },
|
|
104
|
-
];
|
|
105
|
-
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', items);
|
|
106
|
-
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
107
|
-
const result = await unbundleRecords([sqsRecord]);
|
|
108
|
-
expect(result.items).toHaveLength(2);
|
|
109
|
-
expect(result.failedMessageIds).toHaveLength(0);
|
|
110
|
-
expect(result.items).toEqual(items);
|
|
111
|
-
});
|
|
112
|
-
});
|
|
113
|
-
describe('Node zlib.gzip → zlib.gunzip (baseline)', () => {
|
|
114
|
-
it('Node gzip/gunzip round-trips correctly', async () => {
|
|
115
|
-
const original = { test: 'data', number: 123 };
|
|
116
|
-
const json = JSON.stringify(original);
|
|
117
|
-
const compressed = await gzip(Buffer.from(json, 'utf8'));
|
|
118
|
-
const decompressed = await gunzip(compressed);
|
|
119
|
-
expect(JSON.parse(decompressed.toString('utf8'))).toEqual(original);
|
|
120
|
-
});
|
|
121
|
-
it('Node gzip output is decompressible by at-service-common', async () => {
|
|
122
|
-
const items = [{ id: 1 }, { id: 2 }];
|
|
123
|
-
const json = JSON.stringify(items);
|
|
124
|
-
const compressed = await gzip(Buffer.from(json, 'utf8'));
|
|
125
|
-
const base64 = compressed.toString('base64');
|
|
126
|
-
const result = await decompressFromBase64(base64, CompressionAlgorithm.GZIP);
|
|
127
|
-
expect(result).toEqual(items);
|
|
128
|
-
});
|
|
129
|
-
});
|
|
130
|
-
describe('Golden Payload Compatibility', () => {
|
|
131
|
-
it('golden payload from at-cf-tracking-api is decompressible', async () => {
|
|
132
|
-
const result = await decompressFromBase64(GOLDEN_GZIP_BASE64, CompressionAlgorithm.GZIP);
|
|
133
|
-
expect(result).toEqual(GOLDEN_ITEMS);
|
|
134
|
-
});
|
|
135
|
-
it('golden payload works through full unbundleRecords path', async () => {
|
|
136
|
-
const envelope = {
|
|
137
|
-
v: 1,
|
|
138
|
-
c: 'gzip',
|
|
139
|
-
n: GOLDEN_ITEMS.length,
|
|
140
|
-
p: GOLDEN_GZIP_BASE64,
|
|
141
|
-
s: 179,
|
|
142
|
-
};
|
|
143
|
-
const wrapped = {
|
|
144
|
-
messageId: 'golden-test-id',
|
|
145
|
-
messageType: 'TRACKING_EVENT_COLLECT',
|
|
146
|
-
messageTime: new Date().toISOString(),
|
|
147
|
-
messageBody: envelope,
|
|
148
|
-
};
|
|
149
|
-
const sqsRecord = createSQSRecord(JSON.stringify(wrapped));
|
|
150
|
-
const result = await unbundleRecords([sqsRecord]);
|
|
151
|
-
expect(result.items).toEqual(GOLDEN_ITEMS);
|
|
152
|
-
expect(result.stats.bundledSqsRecords).toBe(1);
|
|
153
|
-
});
|
|
154
|
-
it('CompressionStream output matches zlib output content', async () => {
|
|
155
|
-
const json = JSON.stringify(GOLDEN_ITEMS);
|
|
156
|
-
const cfCompressed = await cfWorkerCompress(new TextEncoder().encode(json));
|
|
157
|
-
const nodeCompressed = await gzip(Buffer.from(json, 'utf8'));
|
|
158
|
-
const cfDecompressed = await gunzip(Buffer.from(cfCompressed));
|
|
159
|
-
const nodeDecompressed = await gunzip(nodeCompressed);
|
|
160
|
-
expect(cfDecompressed.toString('utf8')).toBe(json);
|
|
161
|
-
expect(nodeDecompressed.toString('utf8')).toBe(json);
|
|
162
|
-
expect(cfDecompressed.toString('utf8')).toBe(nodeDecompressed.toString('utf8'));
|
|
163
|
-
});
|
|
164
|
-
});
|
|
165
|
-
describe('Unicode and Special Characters', () => {
|
|
166
|
-
it('emoji and CJK characters survive CF Worker compression round-trip', async () => {
|
|
167
|
-
const unicodeItems = [
|
|
168
|
-
{ pixelId: 'px_emoji', event: '🎉_celebration', data: { message: 'Success! 🚀✨' } },
|
|
169
|
-
{ pixelId: 'px_cjk', event: 'page_view', data: { title: '中文页面标题', description: '日本語の説明' } },
|
|
170
|
-
{ pixelId: 'px_rtl', event: 'page_view', data: { title: 'مرحبا بالعالم', content: 'שלום עולם' } },
|
|
171
|
-
];
|
|
172
|
-
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', unicodeItems);
|
|
173
|
-
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
174
|
-
const result = await unbundleRecords([sqsRecord]);
|
|
175
|
-
expect(result.items).toHaveLength(3);
|
|
176
|
-
expect(result.items).toEqual(unicodeItems);
|
|
177
|
-
const item0 = result.items[0];
|
|
178
|
-
const item1 = result.items[1];
|
|
179
|
-
const item2 = result.items[2];
|
|
180
|
-
expect(item0.event).toBe('🎉_celebration');
|
|
181
|
-
expect(item0.data.message).toBe('Success! 🚀✨');
|
|
182
|
-
expect(item1.data.title).toBe('中文页面标题');
|
|
183
|
-
expect(item2.data.title).toBe('مرحبا بالعالم');
|
|
184
|
-
});
|
|
185
|
-
it('special characters in JSON survive round-trip', async () => {
|
|
186
|
-
const specialItems = [
|
|
187
|
-
{ pixelId: 'px_special', data: { name: 'O\'Brien & Co.', note: 'Line1\nLine2\tTabbed' } },
|
|
188
|
-
{ pixelId: 'px_quotes', data: { text: 'He said "hello"', escaped: '\\backslash' } },
|
|
189
|
-
];
|
|
190
|
-
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', specialItems);
|
|
191
|
-
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
192
|
-
const result = await unbundleRecords([sqsRecord]);
|
|
193
|
-
expect(result.items).toEqual(specialItems);
|
|
194
|
-
});
|
|
195
|
-
});
|
|
196
|
-
describe('Large Payload Handling', () => {
|
|
197
|
-
it('100 items compressed by CF Worker decompresses correctly', async () => {
|
|
198
|
-
const items = Array.from({ length: 100 }, (_, i) => ({
|
|
199
|
-
pixelId: `px_${i.toString().padStart(4, '0')}`,
|
|
200
|
-
event: i % 2 === 0 ? 'page_view' : 'purchase',
|
|
201
|
-
timestamp: new Date(Date.now() - i * 1000).toISOString(),
|
|
202
|
-
}));
|
|
203
|
-
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', items);
|
|
204
|
-
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
205
|
-
const result = await unbundleRecords([sqsRecord]);
|
|
206
|
-
expect(result.items).toHaveLength(100);
|
|
207
|
-
expect(result.items).toEqual(items);
|
|
208
|
-
});
|
|
209
|
-
it('deeply nested objects survive compression', async () => {
|
|
210
|
-
const nestedItems = [
|
|
211
|
-
{
|
|
212
|
-
pixelId: 'px_nested',
|
|
213
|
-
data: {
|
|
214
|
-
level1: {
|
|
215
|
-
level2: {
|
|
216
|
-
level3: {
|
|
217
|
-
level4: {
|
|
218
|
-
value: 'deep value',
|
|
219
|
-
array: [1, 2, 3, { nested: true }],
|
|
220
|
-
},
|
|
221
|
-
},
|
|
222
|
-
},
|
|
223
|
-
},
|
|
224
|
-
},
|
|
225
|
-
},
|
|
226
|
-
];
|
|
227
|
-
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', nestedItems);
|
|
228
|
-
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
229
|
-
const result = await unbundleRecords([sqsRecord]);
|
|
230
|
-
expect(result.items).toEqual(nestedItems);
|
|
231
|
-
const item = result.items[0];
|
|
232
|
-
expect(item.data.level1.level2.level3.level4.value).toBe('deep value');
|
|
233
|
-
});
|
|
234
|
-
});
|
|
235
|
-
describe('Edge Cases', () => {
|
|
236
|
-
it('empty array compresses/decompresses correctly', async () => {
|
|
237
|
-
const items = [];
|
|
238
|
-
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', items);
|
|
239
|
-
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
240
|
-
const result = await unbundleRecords([sqsRecord]);
|
|
241
|
-
expect(result.items).toHaveLength(0);
|
|
242
|
-
expect(result.failedMessageIds).toHaveLength(0);
|
|
243
|
-
});
|
|
244
|
-
it('single item compresses/decompresses correctly', async () => {
|
|
245
|
-
const items = [{ pixelId: 'px_single' }];
|
|
246
|
-
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', items);
|
|
247
|
-
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
248
|
-
const result = await unbundleRecords([sqsRecord]);
|
|
249
|
-
expect(result.items).toEqual(items);
|
|
250
|
-
});
|
|
251
|
-
it('null and undefined values in objects preserved', async () => {
|
|
252
|
-
const items = [
|
|
253
|
-
{ pixelId: 'px_nulls', value: null, nested: { alsoNull: null } },
|
|
254
|
-
{ pixelId: 'px_zero', count: 0, price: 0.0 },
|
|
255
|
-
{ pixelId: 'px_empty', name: '', items: [] },
|
|
256
|
-
{ pixelId: 'px_bool', enabled: false, disabled: true },
|
|
257
|
-
];
|
|
258
|
-
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', items);
|
|
259
|
-
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
260
|
-
const result = await unbundleRecords([sqsRecord]);
|
|
261
|
-
expect(result.items).toEqual(items);
|
|
262
|
-
const item0 = result.items[0];
|
|
263
|
-
const item1 = result.items[1];
|
|
264
|
-
const item2 = result.items[2];
|
|
265
|
-
const item3 = result.items[3];
|
|
266
|
-
expect(item0.value).toBeNull();
|
|
267
|
-
expect(item0?.nested?.alsoNull).toBeNull();
|
|
268
|
-
expect(item1.count).toBe(0);
|
|
269
|
-
expect(item1.price).toBe(0.0);
|
|
270
|
-
expect(item2.name).toBe('');
|
|
271
|
-
expect(item2.items).toEqual([]);
|
|
272
|
-
expect(item3.enabled).toBe(false);
|
|
273
|
-
expect(item3.disabled).toBe(true);
|
|
274
|
-
});
|
|
275
|
-
});
|
|
276
|
-
describe('GZIP Header Validation', () => {
|
|
277
|
-
it('CF Worker compression produces valid GZIP header', async () => {
|
|
278
|
-
const data = new TextEncoder().encode('test data');
|
|
279
|
-
const compressed = await cfWorkerCompress(data);
|
|
280
|
-
expect(compressed[0]).toBe(0x1f);
|
|
281
|
-
expect(compressed[1]).toBe(0x8b);
|
|
282
|
-
expect(compressed[2]).toBe(8);
|
|
283
|
-
});
|
|
284
|
-
it('Node zlib compression produces valid GZIP header', async () => {
|
|
285
|
-
const compressed = await gzip(Buffer.from('test data', 'utf8'));
|
|
286
|
-
expect(compressed[0]).toBe(0x1f);
|
|
287
|
-
expect(compressed[1]).toBe(0x8b);
|
|
288
|
-
expect(compressed[2]).toBe(8);
|
|
289
|
-
});
|
|
290
|
-
});
|
|
291
|
-
describe('Mixed Batch Processing', () => {
|
|
292
|
-
it('handles mix of CF Worker compressed and Node compressed records', async () => {
|
|
293
|
-
const cfItems = [{ pixelId: 'px_cf_001' }, { pixelId: 'px_cf_002' }];
|
|
294
|
-
const cfMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', cfItems);
|
|
295
|
-
const nodeItems = [{ pixelId: 'px_node_001' }];
|
|
296
|
-
const nodeJson = JSON.stringify(nodeItems);
|
|
297
|
-
const nodeCompressed = await gzip(Buffer.from(nodeJson, 'utf8'));
|
|
298
|
-
const nodeEnvelope = {
|
|
299
|
-
v: 1,
|
|
300
|
-
c: 'gzip',
|
|
301
|
-
n: 1,
|
|
302
|
-
p: nodeCompressed.toString('base64'),
|
|
303
|
-
s: nodeJson.length,
|
|
304
|
-
};
|
|
305
|
-
const nodeMessage = {
|
|
306
|
-
messageId: crypto.randomUUID(),
|
|
307
|
-
messageType: 'TRACKING_EVENT_COLLECT',
|
|
308
|
-
messageTime: new Date().toISOString(),
|
|
309
|
-
messageBody: nodeEnvelope,
|
|
310
|
-
};
|
|
311
|
-
const legacyItem = { pixelId: 'px_legacy' };
|
|
312
|
-
const records = [
|
|
313
|
-
createSQSRecord(JSON.stringify(cfMessage), 'msg-cf'),
|
|
314
|
-
createSQSRecord(JSON.stringify(nodeMessage), 'msg-node'),
|
|
315
|
-
createSQSRecord(JSON.stringify(legacyItem), 'msg-legacy'),
|
|
316
|
-
];
|
|
317
|
-
const result = await unbundleRecords(records);
|
|
318
|
-
expect(result.items).toHaveLength(4);
|
|
319
|
-
expect(result.failedMessageIds).toHaveLength(0);
|
|
320
|
-
expect(result.stats.bundledSqsRecords).toBe(2);
|
|
321
|
-
expect(result.stats.legacySqsRecords).toBe(1);
|
|
322
|
-
const pixelIds = result.items.map((item) => item.pixelId);
|
|
323
|
-
expect(pixelIds).toContain('px_cf_001');
|
|
324
|
-
expect(pixelIds).toContain('px_cf_002');
|
|
325
|
-
expect(pixelIds).toContain('px_node_001');
|
|
326
|
-
expect(pixelIds).toContain('px_legacy');
|
|
327
|
-
});
|
|
328
|
-
});
|
|
329
|
-
});
|
|
1
|
+
import * as zlib from 'zlib';
|
|
2
|
+
import { promisify } from 'util';
|
|
3
|
+
import { unbundleRecords } from '../../clients/generic/sqs-unbundle';
|
|
4
|
+
import { decompressFromBase64 } from '../../utils/compression';
|
|
5
|
+
import { CompressionAlgorithm } from '../../clients/generic/sqs-bundled-client.types';
|
|
6
|
+
const gzip = promisify(zlib.gzip);
|
|
7
|
+
const gunzip = promisify(zlib.gunzip);
|
|
8
|
+
async function cfWorkerCompress(data) {
|
|
9
|
+
const stream = new CompressionStream('gzip');
|
|
10
|
+
const writer = stream.writable.getWriter();
|
|
11
|
+
await writer.write(data);
|
|
12
|
+
await writer.close();
|
|
13
|
+
const chunks = [];
|
|
14
|
+
const reader = stream.readable.getReader();
|
|
15
|
+
for (;;) {
|
|
16
|
+
const { done, value } = await reader.read();
|
|
17
|
+
if (done)
|
|
18
|
+
break;
|
|
19
|
+
chunks.push(value);
|
|
20
|
+
}
|
|
21
|
+
const totalLength = chunks.reduce((sum, chunk) => sum + chunk.length, 0);
|
|
22
|
+
const result = new Uint8Array(totalLength);
|
|
23
|
+
let offset = 0;
|
|
24
|
+
for (const chunk of chunks) {
|
|
25
|
+
result.set(chunk, offset);
|
|
26
|
+
offset += chunk.length;
|
|
27
|
+
}
|
|
28
|
+
return result;
|
|
29
|
+
}
|
|
30
|
+
function cfWorkerToBase64(bytes) {
|
|
31
|
+
let binary = '';
|
|
32
|
+
for (let i = 0; i < bytes.length; i++) {
|
|
33
|
+
binary += String.fromCharCode(bytes[i]);
|
|
34
|
+
}
|
|
35
|
+
return btoa(binary);
|
|
36
|
+
}
|
|
37
|
+
async function createCfWorkerBundledMessage(messageType, items) {
|
|
38
|
+
const json = JSON.stringify(items);
|
|
39
|
+
const encoder = new TextEncoder();
|
|
40
|
+
const uncompressed = encoder.encode(json);
|
|
41
|
+
const compressed = await cfWorkerCompress(uncompressed);
|
|
42
|
+
const base64 = cfWorkerToBase64(compressed);
|
|
43
|
+
const envelope = {
|
|
44
|
+
v: 1,
|
|
45
|
+
c: 'gzip',
|
|
46
|
+
n: items.length,
|
|
47
|
+
p: base64,
|
|
48
|
+
s: json.length,
|
|
49
|
+
};
|
|
50
|
+
return {
|
|
51
|
+
messageId: crypto.randomUUID(),
|
|
52
|
+
messageType,
|
|
53
|
+
messageTime: new Date().toISOString(),
|
|
54
|
+
messageBody: envelope,
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
function createSQSRecord(body, messageId) {
|
|
58
|
+
return {
|
|
59
|
+
messageId: messageId ?? crypto.randomUUID(),
|
|
60
|
+
receiptHandle: 'test-receipt-handle',
|
|
61
|
+
body,
|
|
62
|
+
attributes: {
|
|
63
|
+
ApproximateReceiveCount: '1',
|
|
64
|
+
SentTimestamp: Date.now().toString(),
|
|
65
|
+
SenderId: 'test-sender',
|
|
66
|
+
ApproximateFirstReceiveTimestamp: Date.now().toString(),
|
|
67
|
+
},
|
|
68
|
+
messageAttributes: {},
|
|
69
|
+
md5OfBody: 'test-md5',
|
|
70
|
+
eventSource: 'aws:sqs',
|
|
71
|
+
eventSourceARN: 'arn:aws:sqs:us-east-1:123456789:test-queue',
|
|
72
|
+
awsRegion: 'us-east-1',
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
const GOLDEN_ITEMS = [
|
|
76
|
+
{ pixelId: 'px_golden_001', event: 'page_view', data: { url: 'https://example.com/test' } },
|
|
77
|
+
{ pixelId: 'px_golden_002', event: 'purchase', data: { amount: 99.99, currency: 'USD' } },
|
|
78
|
+
];
|
|
79
|
+
const GOLDEN_GZIP_BASE64 = 'H4sIAAAAAAAACnXMvQrDIBhG4Xt5Z4lpN527dC6dShHRjyTgH0ZTS/DeS7YsXc+B57UjLY3c3UIiNTVFZymocbyAgTYK5eh6IrUt9AGD1UVD7qjZQWIuJa2Sc2raJ0eDiZ4XWgt6Z//k61mu2cx6pROsfazHE2IQgsHUnCmYLySejxt6f/8AfIEZO7MAAAA=';
|
|
80
|
+
describe('Cross-Platform Compression Compatibility', () => {
|
|
81
|
+
describe('CompressionStream (CF Worker) → zlib.gunzip (Lambda)', () => {
|
|
82
|
+
it('basic payload round-trips correctly', async () => {
|
|
83
|
+
const originalData = { pixelId: 'px_test', event: 'page_view' };
|
|
84
|
+
const json = JSON.stringify([originalData]);
|
|
85
|
+
const compressed = await cfWorkerCompress(new TextEncoder().encode(json));
|
|
86
|
+
expect(compressed[0]).toBe(0x1f);
|
|
87
|
+
expect(compressed[1]).toBe(0x8b);
|
|
88
|
+
const decompressed = await gunzip(Buffer.from(compressed));
|
|
89
|
+
const parsed = JSON.parse(decompressed.toString('utf8'));
|
|
90
|
+
expect(parsed).toEqual([originalData]);
|
|
91
|
+
});
|
|
92
|
+
it('CompressionStream output is valid GZIP decompressible by at-service-common', async () => {
|
|
93
|
+
const items = [{ pixelId: 'px_001' }, { pixelId: 'px_002' }];
|
|
94
|
+
const json = JSON.stringify(items);
|
|
95
|
+
const compressed = await cfWorkerCompress(new TextEncoder().encode(json));
|
|
96
|
+
const base64 = cfWorkerToBase64(compressed);
|
|
97
|
+
const result = await decompressFromBase64(base64, CompressionAlgorithm.GZIP);
|
|
98
|
+
expect(result).toEqual(items);
|
|
99
|
+
});
|
|
100
|
+
it('unbundleRecords handles CF Worker compressed messages', async () => {
|
|
101
|
+
const items = [
|
|
102
|
+
{ pixelId: 'px_cfworker_001', event: 'PageView' },
|
|
103
|
+
{ pixelId: 'px_cfworker_002', event: 'AddToCart' },
|
|
104
|
+
];
|
|
105
|
+
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', items);
|
|
106
|
+
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
107
|
+
const result = await unbundleRecords([sqsRecord]);
|
|
108
|
+
expect(result.items).toHaveLength(2);
|
|
109
|
+
expect(result.failedMessageIds).toHaveLength(0);
|
|
110
|
+
expect(result.items).toEqual(items);
|
|
111
|
+
});
|
|
112
|
+
});
|
|
113
|
+
describe('Node zlib.gzip → zlib.gunzip (baseline)', () => {
|
|
114
|
+
it('Node gzip/gunzip round-trips correctly', async () => {
|
|
115
|
+
const original = { test: 'data', number: 123 };
|
|
116
|
+
const json = JSON.stringify(original);
|
|
117
|
+
const compressed = await gzip(Buffer.from(json, 'utf8'));
|
|
118
|
+
const decompressed = await gunzip(compressed);
|
|
119
|
+
expect(JSON.parse(decompressed.toString('utf8'))).toEqual(original);
|
|
120
|
+
});
|
|
121
|
+
it('Node gzip output is decompressible by at-service-common', async () => {
|
|
122
|
+
const items = [{ id: 1 }, { id: 2 }];
|
|
123
|
+
const json = JSON.stringify(items);
|
|
124
|
+
const compressed = await gzip(Buffer.from(json, 'utf8'));
|
|
125
|
+
const base64 = compressed.toString('base64');
|
|
126
|
+
const result = await decompressFromBase64(base64, CompressionAlgorithm.GZIP);
|
|
127
|
+
expect(result).toEqual(items);
|
|
128
|
+
});
|
|
129
|
+
});
|
|
130
|
+
describe('Golden Payload Compatibility', () => {
|
|
131
|
+
it('golden payload from at-cf-tracking-api is decompressible', async () => {
|
|
132
|
+
const result = await decompressFromBase64(GOLDEN_GZIP_BASE64, CompressionAlgorithm.GZIP);
|
|
133
|
+
expect(result).toEqual(GOLDEN_ITEMS);
|
|
134
|
+
});
|
|
135
|
+
it('golden payload works through full unbundleRecords path', async () => {
|
|
136
|
+
const envelope = {
|
|
137
|
+
v: 1,
|
|
138
|
+
c: 'gzip',
|
|
139
|
+
n: GOLDEN_ITEMS.length,
|
|
140
|
+
p: GOLDEN_GZIP_BASE64,
|
|
141
|
+
s: 179,
|
|
142
|
+
};
|
|
143
|
+
const wrapped = {
|
|
144
|
+
messageId: 'golden-test-id',
|
|
145
|
+
messageType: 'TRACKING_EVENT_COLLECT',
|
|
146
|
+
messageTime: new Date().toISOString(),
|
|
147
|
+
messageBody: envelope,
|
|
148
|
+
};
|
|
149
|
+
const sqsRecord = createSQSRecord(JSON.stringify(wrapped));
|
|
150
|
+
const result = await unbundleRecords([sqsRecord]);
|
|
151
|
+
expect(result.items).toEqual(GOLDEN_ITEMS);
|
|
152
|
+
expect(result.stats.bundledSqsRecords).toBe(1);
|
|
153
|
+
});
|
|
154
|
+
it('CompressionStream output matches zlib output content', async () => {
|
|
155
|
+
const json = JSON.stringify(GOLDEN_ITEMS);
|
|
156
|
+
const cfCompressed = await cfWorkerCompress(new TextEncoder().encode(json));
|
|
157
|
+
const nodeCompressed = await gzip(Buffer.from(json, 'utf8'));
|
|
158
|
+
const cfDecompressed = await gunzip(Buffer.from(cfCompressed));
|
|
159
|
+
const nodeDecompressed = await gunzip(nodeCompressed);
|
|
160
|
+
expect(cfDecompressed.toString('utf8')).toBe(json);
|
|
161
|
+
expect(nodeDecompressed.toString('utf8')).toBe(json);
|
|
162
|
+
expect(cfDecompressed.toString('utf8')).toBe(nodeDecompressed.toString('utf8'));
|
|
163
|
+
});
|
|
164
|
+
});
|
|
165
|
+
describe('Unicode and Special Characters', () => {
|
|
166
|
+
it('emoji and CJK characters survive CF Worker compression round-trip', async () => {
|
|
167
|
+
const unicodeItems = [
|
|
168
|
+
{ pixelId: 'px_emoji', event: '🎉_celebration', data: { message: 'Success! 🚀✨' } },
|
|
169
|
+
{ pixelId: 'px_cjk', event: 'page_view', data: { title: '中文页面标题', description: '日本語の説明' } },
|
|
170
|
+
{ pixelId: 'px_rtl', event: 'page_view', data: { title: 'مرحبا بالعالم', content: 'שלום עולם' } },
|
|
171
|
+
];
|
|
172
|
+
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', unicodeItems);
|
|
173
|
+
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
174
|
+
const result = await unbundleRecords([sqsRecord]);
|
|
175
|
+
expect(result.items).toHaveLength(3);
|
|
176
|
+
expect(result.items).toEqual(unicodeItems);
|
|
177
|
+
const item0 = result.items[0];
|
|
178
|
+
const item1 = result.items[1];
|
|
179
|
+
const item2 = result.items[2];
|
|
180
|
+
expect(item0.event).toBe('🎉_celebration');
|
|
181
|
+
expect(item0.data.message).toBe('Success! 🚀✨');
|
|
182
|
+
expect(item1.data.title).toBe('中文页面标题');
|
|
183
|
+
expect(item2.data.title).toBe('مرحبا بالعالم');
|
|
184
|
+
});
|
|
185
|
+
it('special characters in JSON survive round-trip', async () => {
|
|
186
|
+
const specialItems = [
|
|
187
|
+
{ pixelId: 'px_special', data: { name: 'O\'Brien & Co.', note: 'Line1\nLine2\tTabbed' } },
|
|
188
|
+
{ pixelId: 'px_quotes', data: { text: 'He said "hello"', escaped: '\\backslash' } },
|
|
189
|
+
];
|
|
190
|
+
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', specialItems);
|
|
191
|
+
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
192
|
+
const result = await unbundleRecords([sqsRecord]);
|
|
193
|
+
expect(result.items).toEqual(specialItems);
|
|
194
|
+
});
|
|
195
|
+
});
|
|
196
|
+
describe('Large Payload Handling', () => {
|
|
197
|
+
it('100 items compressed by CF Worker decompresses correctly', async () => {
|
|
198
|
+
const items = Array.from({ length: 100 }, (_, i) => ({
|
|
199
|
+
pixelId: `px_${i.toString().padStart(4, '0')}`,
|
|
200
|
+
event: i % 2 === 0 ? 'page_view' : 'purchase',
|
|
201
|
+
timestamp: new Date(Date.now() - i * 1000).toISOString(),
|
|
202
|
+
}));
|
|
203
|
+
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', items);
|
|
204
|
+
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
205
|
+
const result = await unbundleRecords([sqsRecord]);
|
|
206
|
+
expect(result.items).toHaveLength(100);
|
|
207
|
+
expect(result.items).toEqual(items);
|
|
208
|
+
});
|
|
209
|
+
it('deeply nested objects survive compression', async () => {
|
|
210
|
+
const nestedItems = [
|
|
211
|
+
{
|
|
212
|
+
pixelId: 'px_nested',
|
|
213
|
+
data: {
|
|
214
|
+
level1: {
|
|
215
|
+
level2: {
|
|
216
|
+
level3: {
|
|
217
|
+
level4: {
|
|
218
|
+
value: 'deep value',
|
|
219
|
+
array: [1, 2, 3, { nested: true }],
|
|
220
|
+
},
|
|
221
|
+
},
|
|
222
|
+
},
|
|
223
|
+
},
|
|
224
|
+
},
|
|
225
|
+
},
|
|
226
|
+
];
|
|
227
|
+
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', nestedItems);
|
|
228
|
+
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
229
|
+
const result = await unbundleRecords([sqsRecord]);
|
|
230
|
+
expect(result.items).toEqual(nestedItems);
|
|
231
|
+
const item = result.items[0];
|
|
232
|
+
expect(item.data.level1.level2.level3.level4.value).toBe('deep value');
|
|
233
|
+
});
|
|
234
|
+
});
|
|
235
|
+
describe('Edge Cases', () => {
|
|
236
|
+
it('empty array compresses/decompresses correctly', async () => {
|
|
237
|
+
const items = [];
|
|
238
|
+
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', items);
|
|
239
|
+
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
240
|
+
const result = await unbundleRecords([sqsRecord]);
|
|
241
|
+
expect(result.items).toHaveLength(0);
|
|
242
|
+
expect(result.failedMessageIds).toHaveLength(0);
|
|
243
|
+
});
|
|
244
|
+
it('single item compresses/decompresses correctly', async () => {
|
|
245
|
+
const items = [{ pixelId: 'px_single' }];
|
|
246
|
+
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', items);
|
|
247
|
+
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
248
|
+
const result = await unbundleRecords([sqsRecord]);
|
|
249
|
+
expect(result.items).toEqual(items);
|
|
250
|
+
});
|
|
251
|
+
it('null and undefined values in objects preserved', async () => {
|
|
252
|
+
const items = [
|
|
253
|
+
{ pixelId: 'px_nulls', value: null, nested: { alsoNull: null } },
|
|
254
|
+
{ pixelId: 'px_zero', count: 0, price: 0.0 },
|
|
255
|
+
{ pixelId: 'px_empty', name: '', items: [] },
|
|
256
|
+
{ pixelId: 'px_bool', enabled: false, disabled: true },
|
|
257
|
+
];
|
|
258
|
+
const bundledMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', items);
|
|
259
|
+
const sqsRecord = createSQSRecord(JSON.stringify(bundledMessage));
|
|
260
|
+
const result = await unbundleRecords([sqsRecord]);
|
|
261
|
+
expect(result.items).toEqual(items);
|
|
262
|
+
const item0 = result.items[0];
|
|
263
|
+
const item1 = result.items[1];
|
|
264
|
+
const item2 = result.items[2];
|
|
265
|
+
const item3 = result.items[3];
|
|
266
|
+
expect(item0.value).toBeNull();
|
|
267
|
+
expect(item0?.nested?.alsoNull).toBeNull();
|
|
268
|
+
expect(item1.count).toBe(0);
|
|
269
|
+
expect(item1.price).toBe(0.0);
|
|
270
|
+
expect(item2.name).toBe('');
|
|
271
|
+
expect(item2.items).toEqual([]);
|
|
272
|
+
expect(item3.enabled).toBe(false);
|
|
273
|
+
expect(item3.disabled).toBe(true);
|
|
274
|
+
});
|
|
275
|
+
});
|
|
276
|
+
describe('GZIP Header Validation', () => {
|
|
277
|
+
it('CF Worker compression produces valid GZIP header', async () => {
|
|
278
|
+
const data = new TextEncoder().encode('test data');
|
|
279
|
+
const compressed = await cfWorkerCompress(data);
|
|
280
|
+
expect(compressed[0]).toBe(0x1f);
|
|
281
|
+
expect(compressed[1]).toBe(0x8b);
|
|
282
|
+
expect(compressed[2]).toBe(8);
|
|
283
|
+
});
|
|
284
|
+
it('Node zlib compression produces valid GZIP header', async () => {
|
|
285
|
+
const compressed = await gzip(Buffer.from('test data', 'utf8'));
|
|
286
|
+
expect(compressed[0]).toBe(0x1f);
|
|
287
|
+
expect(compressed[1]).toBe(0x8b);
|
|
288
|
+
expect(compressed[2]).toBe(8);
|
|
289
|
+
});
|
|
290
|
+
});
|
|
291
|
+
describe('Mixed Batch Processing', () => {
|
|
292
|
+
it('handles mix of CF Worker compressed and Node compressed records', async () => {
|
|
293
|
+
const cfItems = [{ pixelId: 'px_cf_001' }, { pixelId: 'px_cf_002' }];
|
|
294
|
+
const cfMessage = await createCfWorkerBundledMessage('TRACKING_EVENT_COLLECT', cfItems);
|
|
295
|
+
const nodeItems = [{ pixelId: 'px_node_001' }];
|
|
296
|
+
const nodeJson = JSON.stringify(nodeItems);
|
|
297
|
+
const nodeCompressed = await gzip(Buffer.from(nodeJson, 'utf8'));
|
|
298
|
+
const nodeEnvelope = {
|
|
299
|
+
v: 1,
|
|
300
|
+
c: 'gzip',
|
|
301
|
+
n: 1,
|
|
302
|
+
p: nodeCompressed.toString('base64'),
|
|
303
|
+
s: nodeJson.length,
|
|
304
|
+
};
|
|
305
|
+
const nodeMessage = {
|
|
306
|
+
messageId: crypto.randomUUID(),
|
|
307
|
+
messageType: 'TRACKING_EVENT_COLLECT',
|
|
308
|
+
messageTime: new Date().toISOString(),
|
|
309
|
+
messageBody: nodeEnvelope,
|
|
310
|
+
};
|
|
311
|
+
const legacyItem = { pixelId: 'px_legacy' };
|
|
312
|
+
const records = [
|
|
313
|
+
createSQSRecord(JSON.stringify(cfMessage), 'msg-cf'),
|
|
314
|
+
createSQSRecord(JSON.stringify(nodeMessage), 'msg-node'),
|
|
315
|
+
createSQSRecord(JSON.stringify(legacyItem), 'msg-legacy'),
|
|
316
|
+
];
|
|
317
|
+
const result = await unbundleRecords(records);
|
|
318
|
+
expect(result.items).toHaveLength(4);
|
|
319
|
+
expect(result.failedMessageIds).toHaveLength(0);
|
|
320
|
+
expect(result.stats.bundledSqsRecords).toBe(2);
|
|
321
|
+
expect(result.stats.legacySqsRecords).toBe(1);
|
|
322
|
+
const pixelIds = result.items.map((item) => item.pixelId);
|
|
323
|
+
expect(pixelIds).toContain('px_cf_001');
|
|
324
|
+
expect(pixelIds).toContain('px_cf_002');
|
|
325
|
+
expect(pixelIds).toContain('px_node_001');
|
|
326
|
+
expect(pixelIds).toContain('px_legacy');
|
|
327
|
+
});
|
|
328
|
+
});
|
|
329
|
+
});
|
|
330
330
|
//# sourceMappingURL=cross-platform-compression.spec.js.map
|