Please be sure of your agent type and version and pick the right documentation accordingly.
Node.js Ruby on Rails Python PHP
This is the documentation of the forest-express-sequelize
and forest-express-mongoose
Node.js agents that will soon reach end-of-support.
forest-express-sequelize
v9 and forest-express-mongoose
v9 are replaced by @forestadmin/agent
v1.
Please check your agent type and version and read on or switch to the right documentation.
This is still the latest Ruby on Rails documentation of the forest_liana
agent, you’re at the right place, please read on.
This is the documentation of the django-forestadmin
Django agent that will soon reach end-of-support.
If you’re using a Django agent, notice that django-forestadmin
v1 is replaced by forestadmin-agent-django
v1.
If you’re using a Flask agent, go to the forestadmin-agent-flask
v1 documentation.
Please check your agent type and version and read on or switch to the right documentation.
This is the documentation of the forestadmin/laravel-forestadmin
Laravel agent that will soon reach end-of-support.
If you’re using a Laravel agent, notice that forestadmin/laravel-forestadmin
v1 is replaced by forestadmin/laravel-forestadmin
v3.
If you’re using a Symfony agent, go to the forestadmin/symfony-forestadmin
v1 documentation.
Please check your agent type and version and read on or switch to the right documentation.
Bonus: Direct link to Zendesk + change priority of a ticket
Create a Direct Link to Zendesk
The next step is to build a direct link to the Zendesk Ticket using a URL. We are going to implement a smart field for this. To build the URL, we simply use Zendesk's convention: ZENDESK_URL_PREFIX/agent/tickets/ticketId
forest/zendesk_tickets.js
Copy const ZENDESK_URL_PREFIX = `https://${process.env.ZENDESK_SUBDOMAIN}.zendesk.com`;
collection('zendesk_tickets', {
actions: [],
fields: [{
field: 'direct_url',
type: 'String',
get: (ticket) => {
return `${ZENDESK_URL_PREFIX}/agent/tickets/${ticket.id}`;
},
},
...
],
segments: [],
});
Once the smart field is added, just set up the Display Widget in Forest UI to allow the display of the URL as a Link:
Change the priority of a ticket
Let's say your operations team wants to change the priority of Zendesk tickets directly from Forest Admin.
For doing so, let's create a simple Smart Action like this:
forest/zendesk_tickets.js
Copy const { collection } = require('forest-express-sequelize');
const ZENDESK_URL_PREFIX = `https://${process.env.ZENDESK_SUBDOMAIN}.zendesk.com`;
// Search on tickets => https://support.zendesk.com/hc/en-us/articles/203663206-Searching-tickets
collection('zendesk_tickets', {
actions: [{
name: 'Change Priority',
type: 'single',
endpoint: '/forest/actions/zendesk-ticket-change-priority',
fields: [
{
field: 'New Ticket Priority',
description: 'What is the new priority?',
type: 'Enum',
enums: ['urgent', 'high', 'normal', 'low'],
isRequired: true
},
],
}],
fields: [
...
],
segments:[]
}
Implement the updateTicket
service according to the Zendesk API :
services/zendesk-tickets-service.js
Copy async function updateTicket(ticketId, newValues) {
const body = {
ticket: newValues,
};
return axios
.put(`${ZENDESK_URL_PREFIX}/api/v2/tickets/${ticketId}`, body, {
headers: {
Authorization: `Basic ${getToken()}`,
},
})
.then(async (resp) => {
let record = resp.data.ticket;
return record;
});
}
And now, we need to implement the route to handle this Smart Action:
routes/zendesk_tickets.js
Copy const { PermissionMiddlewareCreator } = require('forest-express-sequelize');
const permissionMiddlewareCreator = new PermissionMiddlewareCreator(
'companies'
);
const {
getTickets,
getTicket,
updateTicket,
} = require('../services/zendesk-tickets-service');
router.post(
'/actions/zendesk-ticket-change-priority',
permissionMiddlewareCreator.smartAction(),
(request, response, next) => {
const ticketId = request.body.data.attributes.ids[0];
const newValues = {
priority: request.body.data.attributes.values['New Ticket Priority'],
};
updateTicket(ticketId, newValues)
// eslint-disable-next-line no-unused-vars
.then(async function (recordUpdated) {
response.send({
success: 'Ticket Priority changed!',
});
})
.catch(next);
}
);
You now have full integration with Zendesk!
To go further, please check our Github repository and explore how to :
Get the Assignee, Submitter & Requester users for a Zendesk Ticket
Get the Zendesk User for a User
Get the requested tickets for a Zendesk User
Last updated 11 months ago