Skip to content

Commit

Permalink
Merge branch 'develop' into fix.kafka.response
Browse files Browse the repository at this point in the history
  • Loading branch information
ujjwal-ab authored Oct 5, 2023
2 parents 556641f + e37d693 commit e39560d
Show file tree
Hide file tree
Showing 11 changed files with 447 additions and 59 deletions.
27 changes: 27 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,33 @@

All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.

## [1.44.0](https://github.com/rudderlabs/rudder-transformer/compare/v1.43.1...v1.44.0) (2023-09-29)


### Features

* add geolocation support for python transformations ([#2678](https://github.com/rudderlabs/rudder-transformer/issues/2678)) ([b688c4a](https://github.com/rudderlabs/rudder-transformer/commit/b688c4a6889250bacfd2a81c9de8a1436281daa9))
* add axios mocking to component test-suite ([#2638](https://github.com/rudderlabs/rudder-transformer/issues/2638)) ([100c808](https://github.com/rudderlabs/rudder-transformer/commit/100c80881eb99716198231deb9ec0e69dc3fa2a0))
* add circular reference check in flattern json ([#2650](https://github.com/rudderlabs/rudder-transformer/issues/2650)) ([a21ea3a](https://github.com/rudderlabs/rudder-transformer/commit/a21ea3aaecfc3d10de3f4eaa34425dda388032ff))
* **gaec:** partial failures handling ([#2631](https://github.com/rudderlabs/rudder-transformer/issues/2631)) ([0008277](https://github.com/rudderlabs/rudder-transformer/commit/0008277fe43d20ced4066f8f1f1b0f1d12345f01))
* **iterable:** user deletion support ([#2621](https://github.com/rudderlabs/rudder-transformer/issues/2621)) ([c0ab19a](https://github.com/rudderlabs/rudder-transformer/commit/c0ab19a293a72ea0a7575b863356aea9a0e6762f))
* tslint rules enable ([#2604](https://github.com/rudderlabs/rudder-transformer/issues/2604)) ([4d6c4b8](https://github.com/rudderlabs/rudder-transformer/commit/4d6c4b834de005484dc1099a52c69ab6212273e8))


### Bug Fixes
* add optional chaining for traits ([#2677](https://github.com/rudderlabs/rudder-transformer/issues/2677)) ([b80bfbc](https://github.com/rudderlabs/rudder-transformer/commit/b80bfbc8a6afdef57ad5f2560bb803c8e00bcbfc))
* add auth status inactive category handling to GA in userDeletion flow ([#2669](https://github.com/rudderlabs/rudder-transformer/issues/2669)) ([b784800](https://github.com/rudderlabs/rudder-transformer/commit/b7848004e2679ec7278c8381560cb1a77da6c642))
* add optional chaining for error message in network handler of Intercom ([#2648](https://github.com/rudderlabs/rudder-transformer/issues/2648)) ([10a13bc](https://github.com/rudderlabs/rudder-transformer/commit/10a13bcf7f987de45540b52d414883664e43f9cd))
* bqstream event ordering fix ([#2624](https://github.com/rudderlabs/rudder-transformer/issues/2624)) ([e97e7ca](https://github.com/rudderlabs/rudder-transformer/commit/e97e7caed20ffb007f1c543e15c15c6e89e2dfb7))
* **hubspot:** add validation for hubspotEvents ([#2643](https://github.com/rudderlabs/rudder-transformer/issues/2643)) ([b49d0ee](https://github.com/rudderlabs/rudder-transformer/commit/b49d0ee576f55e5f95e3d02b7111e995fc9b8ada))
* **mixpanel:** batch event ordering ([#2608](https://github.com/rudderlabs/rudder-transformer/issues/2608)) ([36c7f06](https://github.com/rudderlabs/rudder-transformer/commit/36c7f06ccfa534b751ca9b3f5c41e9bb6d2e9f00))
* refactor adjust using optional chaining ([#2671](https://github.com/rudderlabs/rudder-transformer/issues/2671)) ([f63b493](https://github.com/rudderlabs/rudder-transformer/commit/f63b4932d5ba467a82a36d3e8b80578f81f729cf))
* **snyk:** fix dependencies version from snyk ([#2640](https://github.com/rudderlabs/rudder-transformer/issues/2640)) ([8422744](https://github.com/rudderlabs/rudder-transformer/commit/8422744b3af48f71358f7acbe2df7b3688ce04a8))
* **snyk:** removed aws-sdk dependency ([08a3535](https://github.com/rudderlabs/rudder-transformer/commit/08a3535257e5d84566c95cebc701613478f0e039))
* **snyk:** removed the new added dependencies ([364779c](https://github.com/rudderlabs/rudder-transformer/commit/364779ce959d7548e5cf1cc8c718b71331dcb378))
* **snyk:** snyk updated versions merged to oen pr ([16a9b8e](https://github.com/rudderlabs/rudder-transformer/commit/16a9b8e6cc26a8df1331cb1af8774df7cc05c959))
* use promise for prompts in personalize create tracking script ([#2635](https://github.com/rudderlabs/rudder-transformer/issues/2635)) ([5fbddd1](https://github.com/rudderlabs/rudder-transformer/commit/5fbddd1490b16dbda6bca19df4cac5bef6ff78c5))

### [1.43.1](https://github.com/rudderlabs/rudder-transformer/compare/v1.43.0...v1.43.1) (2023-09-26)


Expand Down
4 changes: 2 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "rudder-transformer",
"version": "1.43.1",
"version": "1.44.0",
"description": "",
"homepage": "https://github.com/rudderlabs/rudder-transformer#readme",
"bugs": {
Expand Down
4 changes: 4 additions & 0 deletions src/util/openfaas/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ const FAAS_MAX_INFLIGHT = process.env.FAAS_MAX_INFLIGHT || '4';
const FAAS_EXEC_TIMEOUT = process.env.FAAS_EXEC_TIMEOUT || '4s';
const FAAS_ENABLE_WATCHDOG_ENV_VARS = process.env.FAAS_ENABLE_WATCHDOG_ENV_VARS || 'true';
const CONFIG_BACKEND_URL = process.env.CONFIG_BACKEND_URL || 'https://api.rudderlabs.com';
const GEOLOCATION_URL = process.env.GEOLOCATION_URL || '';
const FAAS_AST_VID = 'ast';
const FAAS_AST_FN_NAME = 'fn-ast';

Expand Down Expand Up @@ -128,6 +129,9 @@ const deployFaasFunction = async (functionName, code, versionId, libraryVersionI
envVars.max_inflight = FAAS_MAX_INFLIGHT;
envVars.exec_timeout = FAAS_EXEC_TIMEOUT;
}
if (GEOLOCATION_URL) {
envVars.geolocation_url = GEOLOCATION_URL;
}
// TODO: investigate and add more required labels and annotations
const payload = {
service: functionName,
Expand Down
2 changes: 1 addition & 1 deletion src/v0/destinations/clevertap/transform.js
Original file line number Diff line number Diff line change
Expand Up @@ -232,7 +232,7 @@ const getClevertapProfile = (message, category) => {
if (message.traits?.overrideFields) {
const { overrideFields } = message.traits;
Object.assign(profile, overrideFields);
} else if (message.context.traits?.overrideFields) {
} else if (message.context?.traits?.overrideFields) {
const { overrideFields } = message.context.traits;
Object.assign(profile, overrideFields);
}
Expand Down
6 changes: 3 additions & 3 deletions src/v0/destinations/ga4/transform.js
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,7 @@ const responseBuilder = (message, { Config }) => {
}
break;
default:
throw ConfigurationError('Invalid type of client');
throw new ConfigurationError('Invalid type of client');
}

let payload = {};
Expand All @@ -119,7 +119,7 @@ const responseBuilder = (message, { Config }) => {
payload.name = evConfigEvent;
payload.params = constructPayload(message, mappingConfig[name]);

const { items, mapRootLevelPropertiesToGA4ItemsArray } = getItemsArray(message, item, itemList)
const { items, mapRootLevelPropertiesToGA4ItemsArray } = getItemsArray(message, item, itemList);

if (items.length > 0) {
payload.params.items = items;
Expand Down Expand Up @@ -233,7 +233,7 @@ const responseBuilder = (message, { Config }) => {
}

// Prepare GA4 user properties
const userProperties = prepareUserProperties(message);
const userProperties = prepareUserProperties(message, Config.piiPropertiesToIgnore);
if (!isEmptyObject(userProperties)) {
rawPayload.user_properties = userProperties;
}
Expand Down
36 changes: 25 additions & 11 deletions src/v0/destinations/ga4/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -166,13 +166,15 @@ const GA4_ITEM_EXCLUSION = [
];

/**
* Remove arrays and objects from transformed payload
* @param {*} params
* @returns
* Remove arrays and objects from transformed payload
* @param {*} params
* @returns
*/
const removeInvalidParams = (params) =>
Object.fromEntries(
Object.entries(params).filter(([key, value]) => key === 'items' || (typeof value !== 'object' && !isEmpty(value))),
Object.entries(params).filter(
([key, value]) => key === 'items' || (typeof value !== 'object' && !isEmpty(value)),
),
);

/**
Expand Down Expand Up @@ -244,10 +246,10 @@ const getItem = (message, isItemsRequired) => {

/**
* Returns items array for ga4 event payload
* @param {*} message
* @param {*} item
* @param {*} itemList
* @returns
* @param {*} message
* @param {*} item
* @param {*} itemList
* @returns
*/
const getItemsArray = (message, item, itemList) => {
let items = [];
Expand All @@ -269,7 +271,7 @@ const getItemsArray = (message, item, itemList) => {
}

return { items, mapRootLevelPropertiesToGA4ItemsArray };
}
};
/**
* get exclusion list for a particular event
* ga4ExclusionList contains the sourceKeys that are already mapped
Expand Down Expand Up @@ -398,13 +400,25 @@ const isValidUserProperty = (key, value) => {
/**
* Function to validate and prepare user_properties
* @param {*} message
* @param {*} piiPropertiesToIgnore
* @returns
*/
const prepareUserProperties = (message) => {
const prepareUserProperties = (message, piiPropertiesToIgnore = []) => {
// Exclude PII user traits
const piiProperties = [];
if (piiPropertiesToIgnore.length > 0) {
piiPropertiesToIgnore.forEach((property) => {
if (typeof property.piiProperty === 'string' && property.piiProperty.trim() !== '') {
piiProperties.push(property.piiProperty.trim());
}
});
}

const userProperties = extractCustomFields(
message,
{},
['properties.user_properties', 'context.traits'],
GA4_RESERVED_USER_PROPERTY_EXCLUSION,
[...GA4_RESERVED_USER_PROPERTY_EXCLUSION, ...piiProperties],
);

const validatedUserProperties = Object.entries(userProperties)
Expand Down
Loading

0 comments on commit e39560d

Please sign in to comment.