synerise / php-sdk
SDK allowing basic integration with Synerise API
Installs: 6 129
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 4
Forks: 0
Open Issues: 0
pkg:composer/synerise/php-sdk
Requires
- php: ^8.0 || ^7.4
- ext-json: *
- anik/loguzz: ^2.2 || ^4.0
- microsoft/kiota-abstractions: ^1.4
- microsoft/kiota-http-guzzle: ^1.5
- microsoft/kiota-serialization-json: ^1.5
- microsoft/kiota-serialization-text: ^1.5
- psr/cache: ^1.0 || ^2.0 || ^3.0
- psr/simple-cache: ^1.0 || ^2.0 || ^3.0
Requires (Dev)
- phpunit/phpunit: ^10.5
Suggests
- mobiledetect/mobiledetectlib: Used by default source provider.
- symfony/cache: Recommended PSR cache implementation for token caching
README
About
Synerise SDK for PHP. Allows access to Synerise APIs and overall integration.
Requirements
- A Synerise workspace API Key
- PHP 7.4+
Installing Synerise SDK with Composer
SDK is available over packagist. Some dependencies are optional and can be replaced with custom implementations
- You can install it with the following command:
composer require synerise/php-sdk
- Install suggested dependencies
composer require mobiledetect/mobiledetectlib
Initialization
The repository provides autogenerated api clients that can be utilized on their own.
There's also a single entry point ClientBuilder which helps to initialize and authorized all the apis.
Using ClientBuilder
ClientBuilder requires a Synerise\Sdk\Api\Config implementation, which would contain the set of api settings.
- Initializing the api with ClientBuilder:
use Synerise\Sdk\Api\ClientBuilder; use Synerise\Sdk\Api\Config; /** @var Config $config implementation of Config interface */ $clientBuilder = new ClientBuilder($config);
- Optionally you can also provide your own RequestAdapter:
use Microsoft\Kiota\Abstractions\RequestAdapter; use Synerise\Sdk\Api\ClientBuilder; use Synerise\Sdk\Api\Config; /** * @var Config $config implementation of Config interface * @var RequestAdapter $requestAdapter implementation of RequestAdapter interface */ $clientBuilder = new ClientBuilder($config, $requestAdapter);
Token Caching
The SDK supports token caching to reduce authentication requests:
With PSR Cache (Recommended)
// Install cache implementation composer require symfony/cache use Symfony\Component\Cache\Adapter\RedisAdapter; use Synerise\Sdk\Api\Authentication\TokenProviderFactory; $cache = new RedisAdapter(RedisAdapter::createConnection('redis://localhost')); $tokenProvider = TokenProviderFactory::createWithPsrCache($config, $cache);
Changelog
Changelog can be found here.
Author
Synerise, developer@synerise.com. If you need support please feel free to contact us.