alexanderpoellmann / laravel-zendesk
A Laravel wrapper for the Zendesk API client
Fund package maintenance!
AlexanderPoellmann
Installs: 46
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 1
pkg:composer/alexanderpoellmann/laravel-zendesk
Requires
- php: ^8.4
- illuminate/contracts: ^11.0||^12.0
- spatie/laravel-data: ^4.17
- spatie/laravel-package-tools: ^1.16
- zendesk/zendesk_api_client_php: ^4.1
Requires (Dev)
- larastan/larastan: ^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.8
- orchestra/testbench: ^10.0.0||^9.0.0
- pestphp/pest: ^4.0
- pestphp/pest-plugin-arch: ^4.0
- pestphp/pest-plugin-laravel: ^4.0
- phpstan/extension-installer: ^1.4
- phpstan/phpstan-deprecation-rules: ^2.0
- phpstan/phpstan-phpunit: ^2.0
- spatie/laravel-ray: ^1.35
This package is auto-updated.
Last update: 2025-10-13 03:45:01 UTC
README
Installation
You can install the package via composer:
composer require alexanderpoellmann/laravel-zendesk
You can publish and run the migrations with:
php artisan vendor:publish --tag="laravel-zendesk-migrations"
php artisan migrate
You can publish the config file with:
php artisan vendor:publish --tag="laravel-zendesk-config"
This is the contents of the published config file:
return [ // ];
Don't forget to add the following to your config/services.php
:
return [ 'zendesk' => [ 'subdomain' => env('ZENDESK_SUBDOMAIN', null), 'username' => env('ZENDESK_USERNAME', null), 'token' => env('ZENDESK_TOKEN', null) ], ];
Usage
See also https://github.com/zendesk/zendesk_api_client_php/blob/master/README.md.
// Create or update a user $user = Zendesk::createOrUpdateUser( firstName: 'John', lastName: 'Doe', email: 'john@example.com', ); ray($user); // Upload an attachment. $media = $model->getFirstMedia(); // e.g. spatie/laravel-medialibrary $upload = Zendesk::uploadAttachment( filePath: $media->getPath(), mimeType: $media->mime_type, fileName: $media->file_name, ); ray($upload); // Create an anonymous request $request = Zendesk::createAnonymousRequest( firstName: 'John', lastName: 'Doe', email: 'john@example.com', recipientEmailAddress: 'support@example.com', subject: 'Help!', body: '"My printer is on fire!', uploads: [$upload->token], // optional ); ray($request); // Create a ticket $ticket = Zendesk::createTicket( subject: 'The quick brown fox jumps over the lazy dog', body: 'Lorem ipsum dolor sit amet, consectetur adipisicing elit, ' . 'sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.', priority: Priorities::Normal, uploads: [$upload->token], // optional ]); ray($ticket); // Create a ticket by directly accessing the Zendesk API clients tickets() method $ticket = resolve(Zendesk::class)->authenticate()->tickets()->create([ 'subject' => 'The quick brown fox jumps over the lazy dog', 'comment' => [ 'body' => 'Lorem ipsum dolor sit amet, consectetur adipisicing elit, ' . 'sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.' ], 'priority' => 'normal' ]); ray($ticket);
Through the Zendesk
facade you may access any methods available on the Zendesk\API\Client
class (documentation).
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.