feat: Implement twilio receive sms trigger
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
import defineApp from '../../helpers/define-app';
|
import defineApp from '../../helpers/define-app';
|
||||||
import addAuthHeader from './common/add-auth-header';
|
import addAuthHeader from './common/add-auth-header';
|
||||||
import auth from './auth';
|
import auth from './auth';
|
||||||
|
import triggers from './triggers';
|
||||||
import actions from './actions';
|
import actions from './actions';
|
||||||
|
|
||||||
export default defineApp({
|
export default defineApp({
|
||||||
@@ -14,5 +15,6 @@ export default defineApp({
|
|||||||
primaryColor: 'e1000f',
|
primaryColor: 'e1000f',
|
||||||
beforeRequest: [addAuthHeader],
|
beforeRequest: [addAuthHeader],
|
||||||
auth,
|
auth,
|
||||||
|
triggers,
|
||||||
actions,
|
actions,
|
||||||
});
|
});
|
||||||
|
3
packages/backend/src/apps/twilio/triggers/index.ts
Normal file
3
packages/backend/src/apps/twilio/triggers/index.ts
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
import receiveSms from './receive-sms';
|
||||||
|
|
||||||
|
export default [receiveSms];
|
@@ -0,0 +1,27 @@
|
|||||||
|
import { IGlobalVariable, IJSONObject } from '@automatisch/types';
|
||||||
|
|
||||||
|
const fetchMessages = async ($: IGlobalVariable) => {
|
||||||
|
const toNumber = $.step.parameters.toNumber as string;
|
||||||
|
|
||||||
|
let response;
|
||||||
|
let requestPath = `/2010-04-01/Accounts/${$.auth.data.accountSid}/Messages.json?To=${toNumber}`;
|
||||||
|
|
||||||
|
do {
|
||||||
|
response = await $.http.get(requestPath);
|
||||||
|
|
||||||
|
response.data.messages.forEach((message: IJSONObject) => {
|
||||||
|
const dataItem = {
|
||||||
|
raw: message,
|
||||||
|
meta: {
|
||||||
|
internalId: message.date_sent as string,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
$.pushTriggerItem(dataItem);
|
||||||
|
});
|
||||||
|
|
||||||
|
requestPath = response.data.next_page_uri;
|
||||||
|
} while (requestPath);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default fetchMessages;
|
@@ -0,0 +1,37 @@
|
|||||||
|
import defineTrigger from '../../../../helpers/define-trigger';
|
||||||
|
import fetchMessages from './fetch-messages';
|
||||||
|
|
||||||
|
export default defineTrigger({
|
||||||
|
name: 'Receive SMS',
|
||||||
|
key: 'receiveSms',
|
||||||
|
pollInterval: 15,
|
||||||
|
description: 'Will be triggered when a new SMS is received.',
|
||||||
|
substeps: [
|
||||||
|
{
|
||||||
|
key: 'chooseConnection',
|
||||||
|
name: 'Choose connection',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'chooseTrigger',
|
||||||
|
name: 'Set up a trigger',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
label: 'To Number',
|
||||||
|
key: 'toNumber',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
description:
|
||||||
|
'The number to receive the SMS on. It should be a Twilio number.',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'testStep',
|
||||||
|
name: 'Test trigger',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
await fetchMessages($);
|
||||||
|
},
|
||||||
|
});
|
Reference in New Issue
Block a user