yate-wireless / api
Yate core products API wrapper for PHP
Requires
- php: ^7.4|^8.0|^8.1|^8.2|^8.3
- psr/http-client-implementation: ^1.0
- psr/http-factory-implementation: ^1.0
- psr/http-message-implementation: ^1.0
Requires (Dev)
- guzzlehttp/guzzle: ^7.2
- phpunit/phpunit: ^9.6
This package is auto-updated.
Last update: 2025-01-03 17:33:30 UTC
README
Purpose
This package intended to simplify communication to Yate core products API. Build for composer with PSR-4 autoload, only depends from PSR standard implementations and a good to integrate with DI containers.
It is decoupled from most of depenencies, requiring standart PSR interfaces instead of exact implementations. It uses:
- PSR-7 standard interfaces used for Request, Response and Stream
- PSR-17 standard interfaces used for RequestFactory and StreamFactory to create PSR-7 objects
- PSR-18 standard interface for HTTP clients used
Usage
Start with simple usage example, check ApiGen docs. This lib may make communications to the core components much simpler, but you still need deep knowledge of architecture, entities and logics. Use Yate API docs.
Mostly, you only need to:
- Create
Config
object, which carry Yate core product location and credentials - Configure
Api
class instance with Config and other dependencies (manually, autowire, container, whatever) - Use
call()
method to send api requests to proper nodes and gotApiResponse
object - Access response fields as associated array or properties
More complex scenario: instead of use call()
you may use prepareRequest()
method to convert you functional request to API to PSR-7 standard request object, send it, got PSR-7 Response object and thet process it with static Api::parseResult()
to ApiResponse
object.
This could be useful for async and bulk operations which are not supported by PSR-18 client interface.
For example, you need to complete 1000 independent calls as soon as possible, so you use above methods combined with Guzzle concurrent requests feature, so Guzzle do it's job for concurent call while this lib provides API request to PSR-7 request and PSR-7 response to functional result.
Also, prepareRequest()
and Api::parseResult()
should work fine in Async calls/promises and may be used in extra promise layer to implement async call to Yate API.
Installation
In the Composer storage. Just add proper require section:
"require": {
"yate-wireless/api": "^0.1"
}
Please, review the changelog before to change used version.
Dependencies
Composer dependencies:
- php: ^7.4|^8.0|^8.1|^8.2|^8.3
- psr/http-message-implementation: ^1.0
- psr/http-factory-implementation: ^1.0
- psr/http-client-implementation: ^1.0
Testing
Tested with PHPUnit 9.6 on php 7.4 to 8.3, 100% coverage, which does not mean everything will work as intended. Guzzle PSR-7 used for unit tests.
Current testing and compatibility status check on Github flows
To test, install in dev mode and use:
composer test
command from library root for run all modular tests