GasFreshdesk is a simple Freshdesk API Class for GAS(Google Apps Script)
Github: https://github.com/huan/gas-freshdesk
I made a number of freshdesk API calls in GAS in order to convert emails from my Gmail account to tickets in my daily life. Most of the emails are business plans with attachments.
I found Freshdesk API very hard to use and debug in GAS, especialy with attachments. Writing more code became more complicated. So I decided to modulize it to GasFreshdesk module.
GasFreshdesk is very clean and easy to use.
var MyFreshdesk = new GasFreshdesk('https://mikebo.freshdesk.com', 'Jrg0FQNzX3tzuHbiFjYQ')
var ticket = new MyFreshdesk.Ticket({
description:'A description'
, subject: 'A subject'
, email: 'you@example.com'
, attachments: [ Utilities.newBlob('TEST DATA').setName('test-data.dat') ]
})
ticket.assign(9000658396)
ticket.note({
body: 'Hi tom, Still Angry'
, private: true
})
ticket.reply({
body: 'Hi tom, Still Angry'
, cc_emails: ['you@example.com']
})
ticket.setPriority(2)
ticket.setStatus(2)
ticket.del()
ticket.restore()
Logger.log('ticket #' + ticket.getId() + ' was set!')
It's very clean and easy to use, huh ;-)
To use GasFreshdesk in your GAS script editor, just add the follow lines, then you are set.
if ((typeof GasFreshdesk)==='undefined') { // GasFreshdesk Initialization. (only if not initialized yet.)
eval(UrlFetchApp.fetch('https://raw.githubusercontent.com/zixia/gas-freshdesk/master/src/gas-freshdesk-lib.js').getContentText())
} // Class GasFreshdesk is ready for use now!
Gas Freshdesk Library use API v2 to communicate with freshdesk.
The old version use Freshdesk API v1 is Gas Freshdesk Library v0.2.0.
Return MyFreshdesk for you.
var MyFreshdesk = new GasFreshdesk(
'YOUR_FRESHDESK_URL_HERE' // i.e. https://mikebo.freshdesk.com
, 'YOUR_API_KEY_HERE'
)
List or search for tickets. Return a array of instances of Ticket.
options.email
: email address of requesteroptions.requester_id
: requester_id of requester
if options
is not provided, then listTickets will uses the new_and_my_open filter.
var tickets = MyFreshdesk.listTickets({ email: 'you@example.com' })
var tickets = MyFreshdesk.listTickets({ requester_id: 4312412413 })
Create a new ticket for you.
var ticket = new MyFreshdesk.Ticket({
description:'A totally rad description of a what the problem is'
, subject:'Something like "Cannot log in"'
, email: 'you@example.com'
, attachments: [
Utilities.newBlob('TEST DATA').setName('test-data.dat')
, Utilities.newBlob('TEST2 DATA').setName('test-data2.dat')
]
})
Load a existing ticket for you.
var ticket = new MyFreshdesk.Ticket(1)
ticket.del()
Set ticket to status with parameter.
Has the following shortcut methods:
open()
pend()
resolv()
close()
Note a ticket.
ticket.note({
body: 'Hi tom, Still Angry'
, private: true
})
Reply a ticket.
ticket.reply({
body: 'Hi tom, Still Angry'
, cc_emails: ['you@example.com']
})
var requesterId = ticket.getRequesterId()
var contact = new MyFreshdesk.Contact(requesterId)
Logger.log(contact.getEmail())
Search contacts by email.
var Contact = GasFreshdesk.Contact
var contacts = Contact.list({ email: 'you@example.com' })
Logger.log(contacts[0].getName())
TBW
Search for agent.
- options.email email of agent
var Agent = GasFreshdesk.Agent
var agents = Agent.list({ email: 'you@example.com' })
Logger.log(agents[0].getId())
There is a test suite that comes with GasFreshdesk, which uses GasTap, a tap testing-framework for GAS.
More sample code could be found in the test files if you like to look into it.
GasFreshdesk test suite: https://github.com/zixia/gas-freshdesk/blob/master/src/gas-freshdesk-tests.js
You must run tests inside google apps script editor. Open google script editor, copy/paste gas-freshdesk-tests.js into it, then click Run.
There's also an easier way to do it, you could go to my develop environment(read only) to run and clone. Follow this link: https://script.google.com/a/zixia.net/macros/d/Mta4oea1VMIugfSGRo4QrAnKRT9d30hqB/edit?uiv=2&mid=ACjPJvGt4gnXjJwXnToB0jIMEbSvqKUF6vH-uq-m59SqnjXqTQ03NDn_khlNE6ha_mPnrOAYEnyFk80nHYmt_hppO3AgDkO_vVLrYJXzcPPagwRromd0znfLreNFAu4p0rYTC-Jlo-sAKOM, then click gas-freshdesk-test.gs
in file browser on the left.
The GasFreshdesk source code repository is hosted on GitHub. There you can file bugs on the issue tracker or submit tested pull requests for review. ( https://github.com/zixia/gas-freshdesk/issues )
For real-world examples from open-source projects using GasL, see Projects Using TasL on the wiki. ( https://github.com/zixia/gas-freshdesk/wiki )
- Switch to Freshdesk API v2
- Change library name from
Freshdesk
toGasFreshdesk
- Added new method: Ticket.reply()
To use the v0.3.0 gas-freshdesk library, put the following snip in your gas code.
if ((typeof Freshdesk)==='undefined') { // GasFreshdesk Initialization. (only if not initialized yet.)
eval(UrlFetchApp.fetch('https://raw.githubusercontent.com/zixia/gas-freshdesk/v0.3.0/src/gas-freshdesk-lib.js').getContentText())
} // Class GasFreshdesk is ready for use now!
- Last stable version with Freshdesk API v1
- v0.2.0 README
- v0.2.0 Test Suite
To use the v0.2.0 gas-freshdesk library with freshdesk api v1, put the following snip in your gas code.
if ((typeof Freshdesk)==='undefined') { // GasFreshdesk Initialization. (only if not initialized yet.)
eval(UrlFetchApp.fetch('https://raw.githubusercontent.com/zixia/gas-freshdesk/v0.2.0/src/gas-freshdesk-lib.js').getContentText())
} // Class GasFreshdesk is ready for use now!
- Initial public release.
Huan LI (李卓桓) <zixia@zixia.net>
- Code & Docs © 2015-now Huan LI <zixia@zixia.net>
- Code released under MIT-style license; see LICENSE for details.
- Docs released under Creative Commons