-
Notifications
You must be signed in to change notification settings - Fork 5.3k
[Components] Drift. Actions + Sources #16553
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
Open
SokolovskyiK
wants to merge
12
commits into
PipedreamHQ:master
Choose a base branch
from
SokolovskyiK:drift
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from all commits
Commits
Show all changes
12 commits
Select commit
Hold shift + click to select a range
29ac629
Initial
SokolovskyiK 21af602
Save just in case
SokolovskyiK 00d7d45
Save just in case2
SokolovskyiK c14d5e4
alpha
SokolovskyiK 466aa07
Test actions
SokolovskyiK f888650
[Components] Drift. Actions + Sources
SokolovskyiK 6f9160a
Fix CodeRabbit
SokolovskyiK 87d0c6f
Fix folder name
SokolovskyiK 097ff38
Fix minor
SokolovskyiK dd9dcbd
minor fix
SokolovskyiK 9aace2c
Major fix
SokolovskyiK e08c621
add new message source
SokolovskyiK File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
83 changes: 83 additions & 0 deletions
83
components/drift/actions/create-contact/create-contact.mjs
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
import drift from "../../drift.app.mjs"; | ||
import { removeNullEntries } from "../../common/utils.mjs"; | ||
|
||
export default { | ||
key: "drift-create-contact", | ||
name: "Create Contact", | ||
description: "Creates a contact in Drift. [See the documentation](https://devdocs.drift.com/docs/creating-a-contact).", | ||
version: "0.0.1", | ||
type: "action", | ||
props: { | ||
drift, | ||
email: { | ||
type: "string", | ||
label: "Email", | ||
description: "The contact's email address", | ||
}, | ||
name: { | ||
type: "string", | ||
label: "Name", | ||
description: "The contact's full name", | ||
optional: true, | ||
}, | ||
phone: { | ||
type: "string", | ||
label: "Phone", | ||
description: "The contact's phone number", | ||
optional: true, | ||
}, | ||
source: { | ||
type: "string", | ||
label: "Lead Source", | ||
description: "The value of the 'lead_create_source' custom attribute to match (case-sensitive).", | ||
optional: true, | ||
}, | ||
customAttributes: { | ||
type: "object", | ||
label: "Custom Attributes", | ||
description: "Additional custom attributes to store on the contact", | ||
optional: true, | ||
}, | ||
}, | ||
|
||
async run({ $ }) { | ||
|
||
const { | ||
drift, email, name, phone, source, | ||
} = this; | ||
|
||
const customAttributes = drift.parseIfJSONString(this.customAttributes); | ||
|
||
const attributes = removeNullEntries({ | ||
email, | ||
name, | ||
phone, | ||
source, | ||
...customAttributes, | ||
}); | ||
|
||
const existingContact = await drift.getContactByEmail({ | ||
$, | ||
params: { | ||
email, | ||
}, | ||
}); | ||
|
||
if (existingContact && existingContact.data.length > 0) { | ||
throw new Error (`Contact ${email} already exists`); | ||
}; | ||
|
||
const response = await drift.createContact({ | ||
$, | ||
data: { | ||
attributes, | ||
}, | ||
}); | ||
|
||
console.log(response.data.id); | ||
|
||
$.export("$summary", `Contact "${email}" has been created successfully.`); | ||
return response; | ||
}, | ||
}; | ||
|
41 changes: 41 additions & 0 deletions
41
components/drift/actions/delete-contact/delete-contact.mjs
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
import drift from "../../drift.app.mjs"; | ||
|
||
export default { | ||
key: "drift-delete-contact", | ||
name: "Delete Contact", | ||
description: "Deletes a contact in Drift by ID or email. [See the documentation](https://devdocs.drift.com/docs/removing-a-contact).", | ||
version: "0.0.1", | ||
type: "action", | ||
props: { | ||
drift, | ||
emailOrId: { | ||
type: "string", | ||
label: "Email or Id", | ||
description: "The contact's email address or ID", | ||
}, | ||
}, | ||
|
||
async run({ $ }) { | ||
|
||
const { | ||
drift, emailOrId, | ||
} = this; | ||
|
||
let contact = await drift.getContactByEmailOrId($, emailOrId); | ||
contact = contact.data[0] || contact.data; | ||
|
||
const contactId = contact.id; | ||
const contactEmail = contact.attributes.email; | ||
|
||
const response = await drift.deleteContactById({ | ||
$, | ||
contactId, | ||
}); | ||
|
||
$.export("$summary", `Contact "${contactEmail}" ID "${contactId}" | ||
has been deleted successfully.`); | ||
|
||
return response; | ||
}, | ||
}; | ||
|
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
import drift from "../../drift.app.mjs"; | ||
|
||
export default { | ||
key: "drift-get-contact", | ||
name: "Get Contact", | ||
description: "Retrieves a contact in Drift by ID or email. [See the documentation](https://devdocs.drift.com/docs/retrieving-contact)", | ||
version: "0.0.1", | ||
type: "action", | ||
props: { | ||
drift, | ||
emailOrId: { | ||
type: "string", | ||
label: "Email or Id", | ||
description: "The contact's email address or ID", | ||
}, | ||
}, | ||
|
||
async run({ $ }) { | ||
|
||
const { | ||
drift, emailOrId, | ||
} = this; | ||
|
||
const response = await drift.getContactByEmailOrId($, emailOrId); | ||
|
||
const contact = response.data[0] || response.data; | ||
coderabbitai[bot] marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
if (!contact) { | ||
throw new Error("Failed to get contact"); | ||
}; | ||
|
||
$.export("$summary", `Contact ${contact.attributes.email} ID "${contact.id}"` | ||
+ " has been fetched successfully."); | ||
|
||
return contact; | ||
}, | ||
}; |
85 changes: 85 additions & 0 deletions
85
components/drift/actions/update-contact/update-contact.mjs
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,85 @@ | ||
import drift from "../../drift.app.mjs"; | ||
import { removeNullEntries } from "../../common/utils.mjs"; | ||
|
||
export default { | ||
key: "drift-update-contact", | ||
name: "Update Contact", | ||
description: "Updates a contact in Drift using ID or email. Only changed attributes will be updated. [See Drift API documentation](https://devdocs.drift.com/docs/updating-a-contact)", | ||
version: "0.0.1", | ||
type: "action", | ||
props: { | ||
drift, | ||
emailOrId: { | ||
type: "string", | ||
label: "Email or ID", | ||
description: "The contact’s email address or numeric ID.", | ||
}, | ||
email: { | ||
type: "string", | ||
label: "Email", | ||
description: "The contact’s email address", | ||
optional: true, | ||
}, | ||
name: { | ||
type: "string", | ||
label: "Name", | ||
description: "The contact’s name.", | ||
optional: true, | ||
}, | ||
phone: { | ||
type: "string", | ||
label: "Phone", | ||
description: "The contact’s phone number.", | ||
optional: true, | ||
}, | ||
source: { | ||
type: "string", | ||
label: "Lead Source", | ||
description: "The value of the 'lead_create_source' custom attribute to match (case-sensitive).", | ||
optional: true, | ||
}, | ||
SokolovskyiK marked this conversation as resolved.
Show resolved
Hide resolved
|
||
customAttributes: { | ||
type: "object", | ||
label: "Custom Attributes", | ||
description: "Any custom attributes to update (e.g. company, job title, etc).", | ||
optional: true, | ||
}, | ||
}, | ||
|
||
async run({ $ }) { | ||
const { | ||
drift, name, email, phone, source, emailOrId, | ||
} = this; | ||
|
||
const customAttributes = drift.parseIfJSONString(this.customAttributes); | ||
|
||
const attributes = removeNullEntries({ | ||
name, | ||
phone, | ||
email, | ||
source, | ||
...customAttributes, | ||
}); | ||
|
||
if (!Object.keys(attributes).length) { | ||
throw new Error("No attributes provided to update."); | ||
}; | ||
|
||
let contact = await drift.getContactByEmailOrId($, emailOrId); | ||
SokolovskyiK marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
const contactId = contact.data[0]?.id || contact.data.id; | ||
|
||
const response = await drift.updateContact({ | ||
$, | ||
contactId, | ||
data: { | ||
attributes, | ||
}, | ||
}); | ||
|
||
$.export("$summary", `Contact ID "${contactId}" has been updated successfully.`); | ||
|
||
return response; | ||
}, | ||
}; | ||
|
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
const removeNullEntries = (obj) => | ||
obj && Object.entries(obj).reduce((acc, [ | ||
key, | ||
value, | ||
]) => { | ||
const isNumber = typeof value === "number"; | ||
const isBoolean = typeof value === "boolean"; | ||
const isNotEmpyString = typeof value === "string" && value.trim() !== ""; | ||
const isNotEmptyArray = Array.isArray(value) && value.length; | ||
const isNotEmptyObject = | ||
typeof value === "object" && | ||
value !== null && | ||
!Array.isArray(value) && | ||
Object.keys(value).length !== 0; | ||
isNotEmptyObject && (value = removeNullEntries(value)); | ||
return ((value || value === false) && | ||
(isNotEmpyString || isNotEmptyArray || isNotEmptyObject || isBoolean || isNumber)) | ||
? { | ||
...acc, | ||
[key]: value, | ||
} | ||
: acc; | ||
}, {}); | ||
|
||
function doesContextMatch(inputContext, fetchedContext) { | ||
|
||
if (typeof inputContext !== "object" || inputContext === null || Array.isArray(inputContext)) { | ||
throw new Error ("Message context is not an object"); | ||
}; | ||
|
||
for (const key of Object.keys(inputContext)) { | ||
if (!(key in fetchedContext)) { | ||
console.log(`Invalid context field "${key}", emission skipped` ); | ||
return false; | ||
} | ||
if (fetchedContext[key] !== inputContext[key]) { | ||
console.log(`Context values of "${key}" do not match, emission skipped` ); | ||
return false; | ||
} | ||
} | ||
return true; | ||
}; | ||
|
||
export { | ||
removeNullEntries, | ||
doesContextMatch, | ||
}; | ||
|
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.