Skip to content

davefu/freshdesk-php-sdk

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

80 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Freshdesk PHP SDK API v2

Build Status Scrutinizer Code Quality SensioLabsInsight Packagist

This is a PHP 5.5+ SDK for the Freshdesk API v2.

If you have questions, please contact me or open an issue on GitHub.

Quick Start

require __DIR__ . '/vendor/autoload.php';
use \Freshdesk\Api;

$api = new Api("your_freshdesk_api_key", "your_freshdesk_domain");

$all = $api->tickets->all();
$some = $api->tickets->all(['page' => 2]);
$new = $api->tickets->create($data);
$updated = $api->tickets->update($data);
$api->tickets->delete($id);
$existing = $api->tickets->view($id);

//Responses are simple arrays, e.g.:
$id = $existing['id'];
$first = $all[0];

Framework Integration

Installation

To integrate this library into your application, use Composer.

Add mpclarkson/freshdesk-php-sdk to your composer.json file:

{
    "require": {
        "mpclarkson/freshdesk-php-sdk": "dev-master"
    }
}

Then run:

php composer.phar install

API Overview

Full documentation is available here

Getting started

Creating a new API instance is very easy. All you need is your Freshdesk API key and your Freshdesk domain.

require __DIR__ . '/vendor/autoload.php';
use \Freshdesk\Api;

$api = new Api("your_freshdesk_api_key", "your_freshdesk_domain");

Resources

The available methods for each resource are available via a public property on the api, for example:

//Contacts
$contacts = $api->contacts->update($contactId, $data);

//Agents
$me = $api->agents->current();

//Companies
$company = $api->companies->create($data);

//Groups
$deleted = $api->groups->delete($groupId);

//Tickets
$ticket = $api->tickets->view($filters);

//Time Entries
$time = $api->timeEntries->all($ticket['id']);

//Conversations
$ticket = $api->conversations->note($ticketId, $data);

//Categories
$newCategory = $api->categories->create($data);

//Forums
$forum = $api->forums->create($categoryId, $data);

//Topics
$topics = $api->topics->monitor($topicId, $userId);

//Comments
$comment = $api->comments->create($forumId);

//Email Configs
$configs = $api->emailConfigs->all();

//Products
$product = $api->products->view($productId);

//Business Hours
$hours = $api->businessHours->all();

//SLA Policy
$policies = $api->slaPolicies->all();

Responses

All responses are arrays of data. Please refer to Freshdesk's documentation for further information.

Filtering

All GET requests accept an optional array $query parameter to filter results. For example:

//Page 2 with 50 results per page
$page2 = $this->forums->all(['page' => 2, 'per_page' => 50]);

//Tickets for a specific customer
$tickets = $this->tickets->view(['company_id' => $companyId]);

Please read the Freshdesk documentation for further information on filtering GET requests.

Data with attachments

Format (required only for attachment values) for data value is array of:

  • name: value name
  • contents: value
  • filename (optional): file name of attachment

You can use one of these approaches:

  1. for other values than attachment, you can use same format as for JSON request (array values are automaticaly converted to appropriate format):

    [
    	'valueName' => 'value',
    	...
    ]
  2. single (attachment) value:

    [
    	'attachments' => [
    		'name' => 'attachments[]',
    		'contents' => fopen('pathToFile', 'r'),
    		'filename' => 'fileName.ext'
    	],
    	...
    ]
  3. array of attachements with previous format:

    [
    	'attachments' => [
    		[
    			'name' => 'attachments[]',
    			'contents' => fopen('pathToFile', 'r'),
    			'filename' => 'fileName.ext',
    		],
    		...
    	],
    	...
    ]
  4. you can use JSON format for attachements too, but you lose option to specify filename (only array of file resources works fine!):

    [
    	'attachments' => [
    		fopen('pathToFile', 'r'),
    		...
    	],
    	...
    ]

Contributing

This is a work in progress and PRs are welcome. Please read the contributing guide.

Nearly all api calls are available except for the Solutions and Surveys, which Freshdesk has not yet implemented.

  • Solutions
  • Surveys
  • Uploading files is in beta and only for Tickets
  • More tests. You can never have enough!
  • Nicer documentation

Author

The library was written and maintained by Matthew Clarkson from Hilenium.

Reference

About

Freshdesk API v2 PHP library

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 99.6%
  • Shell 0.4%