@zenginehq/backend-webhooks
v1.2.1
Published
Helper library for working with Webhooks in Zengine backend plugins.
Downloads
24
Readme
Backend Webhooks
Helper module for working with Webhooks in Zengine backend Plugins.
Installation
npm i @zenginehq/backend-webhooks --save
Usage
var $webhook = require('@zenginehq/backend-webhooks');
var $firebase = require('@zenginehq/backend-firebase');
var $api = require('@zenginehq/backend-http');
var workspaceId; // from eventData
var activity; // from eventData
// Load settings from firebase.
$firebase.load(workspaceId).then(function (settings) {
if (!$webhook.validateSecret(settings, eventData.request)) {
return eventData.response.status(403).send('Invalid Webhook Key');
}
// Load activity.
return $api.getActivity(activity.id).then(function (fullActivity) {
if ($webhook.activityToFolder(fullActivity, settings.submittedFolder)) {
// Do something.
}
// You can also make sure the activity didn't come from a specific folder.
if (!$webhook.activityFromFolder(fullActivity, settings.submittedFolder)) {
// Do something else.
// $api.moveToFolder(approcvedfolder);
}
});
});
Methods
validateSecret(settings, request)
Returns whether the webhook id and secret match what's stored in settings.
Out of the box expects the id to be stored in settings.webhookId
and the key in settings.webhookKey
.
You can customize this by calling $webhook.setIdField('myIdField)
and $webhook.setKeyField('myKeyField')
.
activityToFolder(activity, toFolder)
Returns whether the given activity is a move to the specified folder (ie: record moved from a folder into this one)
activityFromFolder(activity, toFolder)
Returns whether the given activity is a move from the specified folder (ie: record moved from this folder this another one)