Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

HubSpot (minor) add custom properties and caching #449

Open
wants to merge 12 commits into
base: dev
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 7 additions & 2 deletions src/appmixer/hubspot/bundle.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "appmixer.hubspot",
"version": "4.0.6",
"version": "4.1.0",
"engine": ">=6.0.0",
"changelog": {
"1.0.0": [
Expand Down Expand Up @@ -60,6 +60,11 @@
],
"4.0.6": [
"Fixed an issue when the `CreateDeal` component was showing error `resource not found`."
]
],
"4.1.0": [
"Added custom properties and additional properties to the following components: `CreateContact`, `CreateDeal`, `UpdateContact` and `UpdateDeal`. Custom properties are new properties that are not part of the default HubSpot properties. Additional properties default HubSpot properties but were not part of the default properties list before.",
"Added caching of Contact and Deal properties, which can be further configured in the connector settings.",
"Improved listing output variables for `GetContact` to make it consistent with the selected properties in the input."
]
}
}
36 changes: 35 additions & 1 deletion src/appmixer/hubspot/commons.js
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,41 @@ module.exports = {
},

WATCHED_PROPERTIES_CONTACT: ['email', 'firstname', 'lastname', 'phone', 'website', 'company', 'address', 'city', 'state', 'zip'],
WATCHED_PROPERTIES_DEAL: ['dealname', 'dealstage', 'pipeline', 'hubSpotOwnerId', 'closedate', 'amount']
WATCHED_PROPERTIES_DEAL: ['dealname', 'dealstage', 'pipeline', 'hubSpotOwnerId', 'closedate', 'amount'],

async getObjectProperties(context, hubspot, objectType, output = 'all') {

// Default cache TTL set to 1 minute as property definitions rarely change
// Can be configured via context.config.objectPropertiesCacheTTL if needed
const objectPropertiesCacheTTL = context.config.objectPropertiesCacheTTL || (60 * 1000);
const cacheKeyPrefix = 'hubspot_properties_' + objectType;
let lock;
try {
lock = await context.lock(`hubspot_properties_${objectType}`);
const cached = await context.staticCache.get(cacheKeyPrefix + '_' + output);
if (cached) {
return cached;
}

// Get all properties from HubSpot.
const { data } = await hubspot.call('get', `crm/v3/properties/${objectType}`);
const properties = data.results.map(property => property.name);

// Save to cache both versions: triggers and actions.
await context.staticCache.set(cacheKeyPrefix + '_all', data.results, objectPropertiesCacheTTL);
await context.staticCache.set(cacheKeyPrefix + '_names', properties, objectPropertiesCacheTTL);

// For triggers return array of names: ['email', 'firstname', ...]
if (output === 'names') {
return properties;
}

// For actions return array of objects: [{ name: 'email', type: 'string', ... }, ...]
return data.results;
} finally {
await lock?.unlock();
}
}
};

/**
Expand Down
13 changes: 11 additions & 2 deletions src/appmixer/hubspot/crm/CreateContact/CreateContact.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,12 @@ module.exports = {
const { auth } = context;
const hs = new Hubspot(auth.accessToken, context.config);

const additionalPropertiesArray = context.messages.in.content.additionalProperties?.AND || [];
const additionalProperties = additionalPropertiesArray.reduce((acc, field) => {
acc[field.name] = field.value;
return acc;
}, {});

const payload = {
properties: {
email,
Expand All @@ -32,7 +38,8 @@ module.exports = {
address: address || '',
city: city || '' ,
state: state || '' ,
zip: zip || ''
zip: zip || '',
...additionalProperties
}
};
const { data } = await hs.call('post', 'crm/v3/objects/contacts', payload);
Expand All @@ -48,7 +55,9 @@ module.exports = {
phone: properties.phone ? properties.phone : '',
state: properties.state ? properties.state : '',
address: properties.address ? properties.address : '',
email: properties.email ? properties.email : ''
email: properties.email ? properties.email : '',
company: properties.company ? properties.company : '',
...additionalProperties
}, 'contact');

}
Expand Down
35 changes: 32 additions & 3 deletions src/appmixer/hubspot/crm/CreateContact/component.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "appmixer.hubspot.crm.CreateContact",
"author": "Zulkafil Tabish <[email protected]>",
"author": "Appmixer <[email protected]>",
"icon": "",
"description": "Create a new contact.",
"private": false,
Expand Down Expand Up @@ -29,7 +29,8 @@
"address": { "type": "string" },
"city": { "type": "string" },
"state": { "type": "string" },
"zip": { "type": "string" }
"zip": { "type": "string" },
"additionalProperties": { "type": "object" }
},
"required": [
"email"
Expand Down Expand Up @@ -96,6 +97,34 @@
"label": "Zip",
"tooltip": "The contact's zip.",
"index": 10
},
"additionalProperties": {
"type": "expression",
"label": "Additional Properties",
"tooltip": "Addition HubSpot or custom properties to add to the contact.",
"exclusiveFields": ["name"],
"index": 11,
"levels": ["AND"],
"fields": {
"name": {
"type": "select",
"label": "Property",
"tooltip": "The property to add to the contact.",
"index": 1,
"source": {
"url": "/component/appmixer/hubspot/crm/GetContactsProperties?outPort=out",
"data": {
"transform": "./GetContactsProperties#additionalFieldsToSelectArray"
}
}
},
"value": {
"type": "text",
"label": "Value",
"tooltip": "The value for the property.",
"index": 2
}
}
}
}
}
Expand All @@ -118,7 +147,7 @@
]
}
],
"version": "1.0.1",
"version": "1.0.2",
"dependencies": {
"service": "1.0.1"
}
Expand Down
Loading