otis22 / vetmanager-rest-api
Vetmanager - CRM for veterinary. This is library for conveniently work with Vetmanager REST API.
Requires
- php: >=7.3 || ^8.0
- ext-json: *
- elegant-bro/arrayee: ^0.1.0
- elegant-bro/interfaces: ^1.1
- elegant-bro/stringify: >=0.3.1
- otis22/php-interfaces: ^1.1
- otis22/vetmanager-token: ^0.2.0
Requires (Dev)
- guzzlehttp/guzzle: ^7.0
- otis22/php-coverage-checker: ^1.2
- otis22/vetmanager-url: ^0.3.0
- php-coveralls/php-coveralls: 1.0.1
- phpstan/phpstan: ^1.0
- phpunit/phpcov: ^8.0
- phpunit/phpunit: ^9.1
- squizlabs/php_codesniffer: 3.*
- symfony/deprecation-contracts: ^2.2
README
Vetmanager - veterinary CRM with REST API. vetmanager-rest-api is a library to help working with REST API.
vetmanager REST API in Postman
What for?
- To get full url by providing only domain name (host might change)
- To validate model name by function uri()
- To simplify apiKey and token authorization
- For Sorting, Filtering, etc.
- To get all sorted and filtered records from model
** Example: Get latest invoice for client id=1 or id=2
use GuzzleHttp\Client; use function Otis22\VetmanagerUrl\url; use function Otis22\VetmanagerRestApi\uri; use function Otis22\VetmanagerRestApi\byApiKey; use Otis22\VetmanagerRestApi\Query\Builder; $client = new Client([ 'base_uri' => url("myclinic")->asString() ]); $top = (new Builder()) ->where('client_id', 'in', [1, 2]) ->orderBy('invoice_date', 'desc') ->top(1); $response = $client->request( 'GET', uri("invoice")->asString(), [ 'headers' => byApiKey("myapikey")->asKeyValue(), 'query' => $top->asKeyValue() ] );
Warning! function url
requires "otis22/vetmanager-url" package.
Installation
composer require otis22/vetmanager-rest-api
Usage
- For auth
- For create valid URI
- For filtering and sorting data
- How to get all records
- How to get top n records
- Query Builder
Usage for auth
Api key auth
use Otis22\VetmanagerRestApi\Headers; use Otis22\VetmanagerRestApi\Headers\Auth\ApiKey; $client = new GuzzleHttp\Client(['base_uri' => 'http://some.vetmanager.ru']); $authHeaders = new Headers\WithAuth( new Headers\Auth\ByApiKey( new ApiKey('test-key') ) ); $client->request( 'GET', '/rest/api/user/1', ['headers' => $authHeaders->asKeyValue()] );
or with function
$authHeaders = Otis22\VetmanagerRestApi\byApiKey('test-key'); # use this after ['headers' => $authHeaders->asKeyValue()]
With custom timezone
use Otis22\VetmanagerRestApi\Headers; use Otis22\VetmanagerRestApi\Headers\Auth\ApiKey; $myHeaders = [ 'X-REST-TIME-ZONE' => '+02:00' ]; $allHeaders = new Headers\WithAuthAndParams( new Headers\Auth\ByApiKey( new ApiKey('test-key') ), $myHeaders ); $client = new GuzzleHttp\Client(['base_uri' => 'http://some.vetmanager.ru']); $client->request( 'GET', '/rest/api/user/1', ['headers' => $allHeaders->asKeyValue()] );
Token auth
use Otis22\VetmanagerRestApi\Headers; use Otis22\VetmanagerToken; $authHeaders = new Headers\WithAuth( new Headers\Auth\ByToken( new Credentials\AppName("myapp"), new Token\Concrete("mytoken") ) ); $client = new GuzzleHttp\Client(['base_uri' => 'http://some.vetmanager.ru']); $client->request( 'GET', '/rest/api/user/1', ['headers' => $authHeaders->asKeyValue()] );
or with function
$authHeaders = Otis22\VetmanagerRestApi\byToken('myapp', 'mytoken'); # use this after ['headers' => $authHeaders->asKeyValue()]
Service API key auth
use Otis22\VetmanagerRestApi\Headers; use Otis22\VetmanagerRestApi\Headers\Auth\ServiceName; use Otis22\VetmanagerRestApi\Headers\Auth\ApiKey; $authHeaders = new Headers\WithAuth( new Headers\Auth\ByServiceApiKey( new ServiceName('name') new ApiKey('key') ) ); $client = new GuzzleHttp\Client(['base_uri' => 'http://some.vetmanager.ru']); $client->request( 'GET', '/rest/api/user/1', ['headers' => $authHeaders->asKeyValue()] );
or with function
$authHeaders = Otis22\VetmanagerRestApi\byServiceApiKey('service', 'api key'); # use this after ['headers' => $authHeaders->asKeyValue()]
Usage example to create valid URI
Only model
use Otis22\VetmanagerRestApi\URI; use Otis22\VetmanagerRestApi\Model; $uri = new URI\OnlyModel( new Model('invoice') ); $client = new GuzzleHttp\Client(['base_uri' => 'http://some.vetmanager.ru']); // request to /rest/api/invoice $client->request('GET', $uri->asString());
or with function
$uriString = \Otis22\VetmanagerRestApi\uri('invoice')->asString();
Model with particular id
use Otis22\VetmanagerRestApi\URI; use Otis22\VetmanagerRestApi\Model; $uri = new URI\WithId( new Model('invoice'), 5 ); $client = new GuzzleHttp\Client(['base_uri' => 'http://some.vetmanager.ru']); // request to /rest/api/invoice/5 $client->request('GET', $uri->asString());
or with function
$uriString = \Otis22\VetmanagerRestApi\uri('invoice', 5)->asString();
Usage example for filtering and sorting
How to use Filters
use Otis22\VetmanagerRestApi\Query\Filters; use Otis22\VetmanagerRestApi\Query\Filter\EqualTo; use Otis22\VetmanagerRestApi\Model\Property; use Otis22\VetmanagerRestApi\Query\Filter\Value\StringValue; $filters = new Filters( new EqualTo( new Property('propertyName'), new StringValue('propertyValue') ) # ... we can use mach more filters new Filters($filterOne, $filterTwo, ... ); ); $client = new GuzzleHttp\Client(['base_uri' => 'http://some.vetmanager.ru']); $client->request( 'GET', '/rest/api/user/1', [ 'headers' => $authHeaders->asKeyValue(), 'query' => $filters->asKeyValue() ] );
Full filter list
- Otis22\VetmanagerRestApi\Query\Filter\EqualTo - where property is equal to value
- Otis22\VetmanagerRestApi\Query\Filter\InArray - where property is in list
- Otis22\VetmanagerRestApi\Query\Filter\LessOrEqualThan - where property is less or equal than value
- Otis22\VetmanagerRestApi\Query\Filter\LessThan - where property is less than value
- Otis22\VetmanagerRestApi\Query\Filter\Like - where property is like value(for using MySQL LIKE)
- Otis22\VetmanagerRestApi\Query\Filter\MoreOrEqualThan - where property is more or equal than value
- Otis22\VetmanagerRestApi\Query\Filter\MoreThan - where property more than value
- Otis22\VetmanagerRestApi\Query\Filter\NotEqualTo - where propery is not equal to value
- Otis22\VetmanagerRestApi\Query\Filter\NotInArray - where property is not in list
How to use Sorts
use Otis22\VetmanagerRestApi\Query\Sorts; use Otis22\VetmanagerRestApi\Query\Sort\AscBy; use Otis22\VetmanagerRestApi\Query\Sort\DescBy; use Otis22\VetmanagerRestApi\Model\Property; $sorts = new Sorts( new AscBy( new Property('propertyName') ), new DescBy( new Property('property2Name') ) ); $client = new GuzzleHttp\Client(['base_uri' => 'http://some.vetmanager.ru']); $client->request( 'GET', '/rest/api/user/1', [ 'headers' => $authHeaders->asKeyValue(), 'query' => $sorts->asKeyValue() ] );
How to use both Sorts and Filters
use Otis22\VetmanagerRestApi\Query\Query; ... $query = new Query( new Filters(...), new Sorts(...) ); $client = new GuzzleHttp\Client(['base_uri' => 'http://some.vetmanager.ru']); $client->request( 'GET', '/rest/api/user/1', [ 'headers' => $authHeaders->asKeyValue(), 'query' => $query->asKeyValue() ] );
How to get all records
$paged = PagedQuery::forGettingAll( new Query( // Sorts Required! ) ); $result = []; do { $response = json_decode( strval( $client->request( 'GET', uri('invoice')->asString(), [ 'headers' => $headers->asKeyValue(), 'query' => $paged->asKeyValue() ] )->getBody() ), true ); $paged = $paged->next(); $result = array_merge( $response['data']['invoice'], $result ); } while (count($result) < $response['data']['totalCount']);
How to get top n records
$top1 = PagedQuery::forGettingTop( new Query( // Sorts Required! ), 1 ); $response = json_decode( strval( $client->request( 'GET', uri('invoice')->asString(), [ 'headers' => $headers->asKeyValue(), 'query' => $top1->asKeyValue() ] )->getBody() ), true );
Query Builder
top(n) - return PagedQuery instance for getting top n records by user filter and sort order.
$top = (new Builder()) ->where('client_id', 'in', [1, 2]) ->orderBy('id', 'desc') ->top(1);
paginateAll(): return PagedQuery instance for getting all records by user filter and sort order
$paginateAll = (new Builder()) ->where('client_id', 'in', [1, 2]) ->orderBy('id', 'desc') ->paginateAll();
paginate(limit, offset): return PagedQuery instance for getting records with custom limit and offset by user filter and sort order
$paginate = (new Builder()) ->where('client_id', 'in', [1, 2]) ->orderBy('id', 'desc') ->paginate(10, 20);
You can use filter class string operator instead.
use Otis22\VetmanagerRestApi\Query\Filter; (new Builder()) ->where('client_id', Filter\InArray::class, [1, 2]) ->where('pet_id', Filter\NotEqualTo::class, 5)
Contributing
To run all tests
make all
To connect to terminal
make exec
Default php version is 8.1. Use PHP_VERSION= to use your version. Only versions 8.0 and 8.1 are available for now.
make all PHP_VERSION=8.0 # run both make all PHP_VERSION=8.0 && make all PHP_VERSION=8.1
For integration tests copy .env.example to .env and fill with yours values
all commands
# security check make security # composer install make install # composer install with --no-dev make install-no-dev # check code style make style # run static analyze tools make static-analyze # run unit tests make unit # check coverage make coverage # check integration, .env required make integration