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 1 commit
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
5 changes: 4 additions & 1 deletion 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.5",
"version": "4.1.0",
"engine": ">=6.0.0",
"changelog": {
"1.0.0": [
Expand Down Expand Up @@ -57,6 +57,9 @@
"4.0.5": [
"Removed webhook subscribing when using AuthHub.",
"Fixed an issue when HubSpot webhook was not automatically created when using own API key."
],
"4.1.0": [
"Added caching of Contact and Deal properties, which can be further configured in the connector settings."
]
}
}
32 changes: 31 additions & 1 deletion src/appmixer/hubspot/commons.js
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,37 @@ 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') {

const cacheKeyPrefix = 'hubspot_properties_' + objectType;
let lock;
try {
lock = await context.lock('hubspot_properties');
Copy link
Preview

Copilot AI Mar 27, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[nitpick] Using a static lock key ('hubspot_properties') for all object types could lead to collisions when getObjectProperties is called concurrently for different object types. Consider incorporating the objectType into the lock key.

Copilot is powered by AI, so mistakes are possible. Review output carefully before use.

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, context.config.objectPropertiesCacheTTL || (20 * 1000));
await context.staticCache.set(cacheKeyPrefix + '_names', properties, context.config.objectPropertiesCacheTTL || (20 * 1000));

// 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
2 changes: 1 addition & 1 deletion 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
Original file line number Diff line number Diff line change
@@ -1,15 +1,16 @@
'use strict';
const Hubspot = require('../../Hubspot');
const { getObjectProperties } = require('../../commons');

module.exports = {

async receive(context) {

const { auth } = context;
const hs = new Hubspot(auth.accessToken, context.config);
const { data } = await hs.call('get', 'crm/v3/properties/contacts');
const properties = await getObjectProperties(context, hs, 'contacts', 'all');

return context.sendJson(data.results, 'out');
return context.sendJson(properties, 'out');
},

contactsPropertiesToContactInspector(contactsProperties) {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,16 @@
'use strict';
const Hubspot = require('../../Hubspot');
const { getObjectProperties } = require('../../commons');

module.exports = {

async receive(context) {

const { auth } = context;
const hs = new Hubspot(auth.accessToken, context.config);
const { data } = await hs.call('get', 'crm/v3/properties/deals');
const properties = await getObjectProperties(context, hs, 'deals', 'all');

return context.sendJson(data.results, 'out');
return context.sendJson(properties, 'out');
},

dealsPropertiesToDealInspector(dealsProperties) {
Expand Down
Loading