olegf13 / jivochat-webhooks-api
Library for Jivochat (Jivosite) Webhooks API integration.
Installs: 11 964
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 2
Forks: 9
Open Issues: 2
Requires
- php: >=7.0.0
Requires (Dev)
- ext-mongodb: *
- ext-pdo: *
- fzaninotto/faker: ^1.6
- mongodb/mongodb: 1.1.*
- monolog/monolog: 1.9.*
- phpunit/phpunit: ~6.1
Suggests
- ext-mongodb: Allow logging of Webhooks requests/response data to a MongoDB server
- ext-pdo: Allow logging of Webhooks requests/response data to a MySQL server
- mongodb/mongodb: Allow logging of Webhooks requests/response data to a MongoDB server via PHP Driver
- monolog/monolog: Allow logging of Webhooks requests/response using Monolog
This package is not auto-updated.
Last update: 2024-11-15 23:17:59 UTC
README
Library for Jivochat (Jivosite) Webhooks API integration.
This library allows you to integrate with Jivosite Webhooks API and:
- handle API calls in event-based manner;
- convert API requests JSON data in particular event objects;
- generate API responses;
- save original request (and generated response) data into MySQL or MongoDB server, and log it via Monolog.
For Russian documentation see README-ru.md.
Requirements
The library requires PHP 7.0 or above for basic usage.
Optional requirements:
- PDO extension allows logging of Webhooks request/response data to a MySQL server;
- Monolog library allows logging of Webhooks request/response using Monolog;
- MongoDB library allows logging of Webhooks request/response data to a MongoDB server.
It is strongly recommended to have at least one of above loggers installed to hold a "backup" of original requests sent via Webhooks API.
Installation
The preferred way to install this library is through Composer. To install the latest version, run:
composer require olegf13/jivochat-webhooks-api
Basic usage
<?php use Olegf13\Jivochat\Webhooks\Log\MySQLLog; use Olegf13\Jivochat\Webhooks\Event\Event; // create MySQL logger $dbLogger = new MySQLLog(new PDO('mysql:dbname=test;host=127.0.0.1', 'root', 'root')); // create Callback API event listener $listener = new Olegf13\Jivochat\Webhooks\EventListener([$dbLogger]); // bind listener for `chat_accepted` event $listener->on(Event::EVENT_CHAT_ACCEPTED, function (Olegf13\Jivochat\Webhooks\Event\ChatAccepted $event) { // here you do your stuff - find user in your database, etc $user = User::getByEmail($event->visitor->email); // generate response on Callback API $response = new Olegf13\Jivochat\Webhooks\Response(); $response->setCRMLink(...); $response->setContactInfo(...); $response->setCustomData(...); // event handler must return Response object return $response; }); // bind listener for `chat_accepted` event $listener->on(Event::EVENT_CHAT_FINISHED, function (Olegf13\Jivochat\Webhooks\Event\ChatFinished $event) { /** @var int Timestamp of the chat's first message. */ $chatBeginAt = $event->chat->messages[0]->timestamp; // ... return new Olegf13\Jivochat\Webhooks\Response(); }); // execute event listener $listener->listen();
Documentation
- Jivochat Webhooks API official documentation
License
This library is licensed under the MIT License - see the LICENSE file for details.
Acknowledgements
Thanks to this Jivosite Webhook handler library.