238 lines
7.6 KiB
JavaScript
238 lines
7.6 KiB
JavaScript
const subscribeHook = (z, bundle) => {
|
|
// `z.console.log()` is similar to `console.log()`.
|
|
z.console.log('suscribing hook!');
|
|
|
|
// bundle.targetUrl has the Hook URL this app should call when an action is created.
|
|
const data = {
|
|
url: bundle.targetUrl,
|
|
event: bundle.event,
|
|
module: 'ticket',
|
|
action: bundle.inputData.action
|
|
};
|
|
|
|
const url = bundle.authData.url + '/api/index.php/zapier/hook';
|
|
|
|
// You can build requests and our client will helpfully inject all the variables
|
|
// you need to complete. You can also register middleware to control this.
|
|
const options = {
|
|
url: url,
|
|
method: 'POST',
|
|
body: data,
|
|
};
|
|
|
|
// You may return a promise or a normal data structure from any perform method.
|
|
return z.request(options).then((response) => JSON.parse(response.content));
|
|
};
|
|
|
|
const unsubscribeHook = (z, bundle) => {
|
|
// bundle.subscribeData contains the parsed response JSON from the subscribe
|
|
// request made initially.
|
|
z.console.log('unsuscribing hook!');
|
|
|
|
// You can build requests and our client will helpfully inject all the variables
|
|
// you need to complete. You can also register middleware to control this.
|
|
const options = {
|
|
url: bundle.authData.url + '/api/index.php/zapier/hook/' + bundle.subscribeData.id,
|
|
method: 'DELETE',
|
|
};
|
|
|
|
// You may return a promise or a normal data structure from any perform method.
|
|
return z.request(options).then((response) => JSON.parse(response.content));
|
|
};
|
|
|
|
const getTicket = (z, bundle) => {
|
|
// bundle.cleanedRequest will include the parsed JSON object (if it's not a
|
|
// test poll) and also a .querystring property with the URL's query string.
|
|
const ticket = {
|
|
id: bundle.cleanedRequest.id,
|
|
track_id: bundle.cleanedRequest.track_id,
|
|
subject: bundle.cleanedRequest.subject,
|
|
message: bundle.cleanedRequest.message,
|
|
lastname: bundle.cleanedRequest.lastname,
|
|
firstname: bundle.cleanedRequest.firstname,
|
|
address: bundle.cleanedRequest.address,
|
|
zip: bundle.cleanedRequest.zip,
|
|
town: bundle.cleanedRequest.town,
|
|
email_from: bundle.cleanedRequest.email_from,
|
|
login: bundle.cleanedRequest.login,
|
|
authorId: bundle.cleanedRequest.authorId,
|
|
createdAt: bundle.cleanedRequest.createdAt,
|
|
action: bundle.cleanedRequest.action
|
|
};
|
|
|
|
return [ticket];
|
|
};
|
|
|
|
const getFallbackRealTicket = (z, bundle) => {
|
|
// For the test poll, you should get some real data, to aid the setup process.
|
|
const module = bundle.inputData.module;
|
|
const options = {
|
|
url: bundle.authData.url + '/api/index.php/tickets/0',
|
|
};
|
|
|
|
return z.request(options).then((response) => [JSON.parse(response.content)]);
|
|
};
|
|
|
|
// const getModulesChoices = (z/*, bundle*/) => {
|
|
// // For the test poll, you should get some real data, to aid the setup process.
|
|
// const options = {
|
|
// url: bundle.authData.url + '/api/index.php/zapier/getmoduleschoices',
|
|
// };
|
|
|
|
// return z.request(options).then((response) => JSON.parse(response.content));
|
|
// };
|
|
// const getModulesChoices = () => {
|
|
|
|
// return {
|
|
// orders: "Order",
|
|
// invoices: "Invoice",
|
|
// thirdparties: "Thirdparty",
|
|
// users: "User",
|
|
// tickets: "Ticket",
|
|
// contacts: "Contacts"
|
|
// };
|
|
// };
|
|
|
|
// const getActionsChoices = (z, bundle) => {
|
|
// // For the test poll, you should get some real data, to aid the setup process.
|
|
// const module = bundle.inputData.module;
|
|
// const options = {
|
|
// url: url: bundle.authData.url + '/api/index.php/zapier/getactionschoices/thirparty`,
|
|
// };
|
|
|
|
// return z.request(options).then((response) => JSON.parse(response.content));
|
|
// };
|
|
|
|
// We recommend writing your triggers separate like this and rolling them
|
|
// into the App definition at the end.
|
|
module.exports = {
|
|
key: 'ticket',
|
|
|
|
// You'll want to provide some helpful display labels and descriptions
|
|
// for tickets. Zapier will put them into the UX.
|
|
noun: 'Ticket',
|
|
display: {
|
|
label: 'New Ticket',
|
|
description: 'Triggers when a new ticket action is done in Dolibarr.'
|
|
},
|
|
|
|
// `operation` is where the business logic goes.
|
|
operation: {
|
|
|
|
// `inputFields` can define the fields a ticket could provide,
|
|
// we'll pass them in as `bundle.inputData` later.
|
|
inputFields: [
|
|
{
|
|
key: 'action',
|
|
type: 'string',
|
|
required: true,
|
|
helpText: 'Which action of ticket this should trigger on.',
|
|
choices: {
|
|
create: "Create",
|
|
modify: "Modify",
|
|
validate: "Validate",
|
|
}
|
|
}
|
|
],
|
|
|
|
type: 'hook',
|
|
|
|
performSubscribe: subscribeHook,
|
|
performUnsubscribe: unsubscribeHook,
|
|
|
|
perform: getTicket,
|
|
performList: getFallbackRealTicket,
|
|
|
|
// In cases where Zapier needs to show an example record to the user, but we are unable to get a live example
|
|
// from the API, Zapier will fallback to this hard-coded sample. It should reflect the data structure of
|
|
// returned records, and have obviously dummy values that we can show to any user.
|
|
sample: {
|
|
id: 1,
|
|
track_id: 'Xaz123er',
|
|
subject: 'Subject',
|
|
message: 'Message',
|
|
createdAt: 1472069465,
|
|
lastname: 'DOE',
|
|
firstname: 'John',
|
|
email: 'john@doe.com',
|
|
address: 'Park Avenue',
|
|
zip: '12345',
|
|
town: 'NEW-YORK',
|
|
email_from: 'doe.john@example;com',
|
|
authorId: 1,
|
|
action: 'create'
|
|
},
|
|
|
|
// If the resource can have fields that are custom on a per-user basis, define a function to fetch the custom
|
|
// field definitions. The result will be used to augment the sample.
|
|
// outputFields: () => { return []; }
|
|
// Alternatively, a static field definition should be provided, to specify labels for the fields
|
|
outputFields: [
|
|
{
|
|
key: 'id',
|
|
type: "integer",
|
|
label: 'ID'
|
|
},
|
|
{
|
|
key: 'track_id',
|
|
type: "string",
|
|
label: 'TrackID'
|
|
},
|
|
{
|
|
key: 'subject',
|
|
type: "string",
|
|
label: 'Subject'
|
|
},
|
|
{
|
|
key: 'message',
|
|
type: "string",
|
|
label: 'Message'
|
|
},
|
|
{
|
|
key: 'createdAt',
|
|
type: "integer",
|
|
label: 'Created At'
|
|
},
|
|
{
|
|
key: 'lastname',
|
|
label: 'Lastname'
|
|
},
|
|
{
|
|
key: 'firstname',
|
|
label: 'Firstname'
|
|
},
|
|
{
|
|
key: 'email',
|
|
label: 'Email'
|
|
},
|
|
{
|
|
key: 'address',
|
|
label: 'Address'
|
|
},
|
|
{
|
|
key: 'zip',
|
|
label: 'Zip'
|
|
},
|
|
{
|
|
key: 'town',
|
|
label: 'Town'
|
|
},
|
|
{
|
|
key: 'email_from',
|
|
type: 'string',
|
|
label: 'Email from'
|
|
},
|
|
{
|
|
key: 'authorId',
|
|
type: "integer",
|
|
label: 'Author ID'
|
|
},
|
|
{
|
|
key: 'action',
|
|
type: 'string',
|
|
label: 'Action'
|
|
}
|
|
]
|
|
}
|
|
};
|