rpungello / sdk-client
Generic client for creating PHP-based SDKs using Spatie's DTOs for data transfer
Fund package maintenance!
rpungello
Installs: 2 356
Dependents: 1
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 1
Open Issues: 0
Requires
- php: ^8.1
- guzzlehttp/guzzle: ^7.7
- nesbot/carbon: >2.68 <4.0
- spatie/data-transfer-object: ^3.9
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.13
- pestphp/pest: ^1.20
- spatie/ray: ^1.28
README
Generic client for creating PHP-based SDKs using Spatie's DTOs for data transfer.
Installation
You can install the package via composer:
composer require rpungello/sdk-client
Usage
Instantiate the client
$client = new Rpungello\SdkClient('https://example.com');
GET requests
// Returns a Psr\Http\Message\ResponseInterface response $response = $client->get('/api/v1/users'); // Specify a query string $response = $client->get('/api/v1/users', [ 'page' => 1, 'limit' => 10, ]); // Returns a json-decoded array from the response body $response = $client->getJson('/api/v1/users'); // Takes the JSON data returned and wraps it in a DTO for static typing $response = $client->getDto('/api/v1/users/1', UserDto::class); // Takes the JSON data returned and converts it to an array of DTOs for static typing $response = $client->getDtoArray('/api/v1/users', UserDto::class);
PUT/POST/PATCH requests
// Returns a Psr\Http\Message\ResponseInterface response $response = $client->post('/api/v1/users', [ 'name' => 'John Doe', 'email' => 'john@example.com', ]); // Returns a json-decoded array from the response body $response = $client->postJson('/api/v1/users', [ 'name' => 'John Doe', 'email' => 'john@example.com', ]); // Takes the JSON data returned and wraps it in a DTO for static typing $user = new UserDto([ 'name' => 'John Doe', 'email' => 'john@example.com', ]); $response = $client->postDto('/api/v1/users', $user);
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.