ay4t / php-rest-client
Multipurpose PHP rest client for consuming RESTful web services.
1.0.0
2024-10-28 12:52 UTC
Requires
- guzzlehttp/guzzle: 8.0.x-dev
Requires (Dev)
- kint-php/kint: ^5.1
- phpunit/phpunit: ^11.4
- vlucas/phpdotenv: ^v5.6.1
This package is auto-updated.
Last update: 2025-03-11 12:19:34 UTC
README
A flexible and robust PHP REST Client with advanced features for handling API requests.
Features
- 🚀 Simple and intuitive API
- 🔄 Automatic retry mechanism for failed requests
- 📝 Comprehensive logging system
- ⚡ Custom exception handling
- 🔒 Configurable request options
- 🛠 Extensible architecture
Installation
Install via Composer:
composer require ay4t/php-rest-client
Basic Usage
Using Config Object (Recommended)
use Ay4t\RestClient\Client; use Ay4t\RestClient\Config\Config; // Initialize config $config = new Config(); $config->setBaseUri('https://api.example.com') ->setApiKey('your-api-key-here'); $client = new Client($config); // Make a GET request try { $response = $client->cmd('GET', 'users'); print_r($response); } catch (Ay4t\RestClient\Exceptions\ApiException $e) { echo "Error: " . $e->getMessage(); echo "HTTP Status: " . $e->getHttpStatusCode(); echo "Response Body: " . $e->getResponseBody(); }
Using Array Configuration (Alternative)
use Ay4t\RestClient\Client; // Initialize with array config $config = [ 'base_uri' => 'https://api.example.com', 'headers' => [ 'Authorization' => 'Bearer your-api-key-here' ] ]; $client = new Client($config);
Advanced Features
Custom Logging
use Ay4t\RestClient\Logger\DefaultLogger; use Ay4t\RestClient\Config\Config; // Setup configuration $config = new Config(); $config->setBaseUri('https://api.example.com') ->setApiKey('your-api-key-here'); // Custom log file location $logger = new DefaultLogger('/path/to/custom.log'); $client = new Client($config, $logger); // Logs will include: // - Request details (method, URL, options) // - Response status and body // - Any errors that occur
Retry Mechanism
// Configure retry settings $client->setMaxRetries(5) // Maximum number of retry attempts ->setRetryDelay(2000); // Delay between retries in milliseconds // The client will automatically: // - Retry failed requests (except 4xx errors) // - Wait between attempts // - Throw ApiException after all retries fail
Request Options
// Set global request options $client->setRequestOptions([ 'timeout' => 30, 'verify' => false, // Disable SSL verification 'headers' => [ 'User-Agent' => 'My Custom User Agent' ] ]);
Error Handling
use Ay4t\RestClient\Exceptions\ApiException; try { $response = $client->cmd('POST', 'users', [ 'name' => 'John Doe', 'email' => 'john@example.com' ]); } catch (ApiException $e) { // Get detailed error information $statusCode = $e->getHttpStatusCode(); $responseBody = $e->getResponseBody(); $message = $e->getMessage(); // Handle different status codes switch ($statusCode) { case 404: echo "Resource not found"; break; case 401: echo "Unauthorized access"; break; default: echo "An error occurred: $message"; } }
Implementing Custom Logger
You can implement your own logger by implementing the LoggerInterface
:
use Ay4t\RestClient\Interfaces\LoggerInterface; class MyCustomLogger implements LoggerInterface { public function logRequest(string $method, string $url, array $options): void { // Your custom request logging logic } public function logResponse(int $statusCode, string $body): void { // Your custom response logging logic } public function logError(\Throwable $exception): void { // Your custom error logging logic } } // Use your custom logger $client = new Client($config, new MyCustomLogger());
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
This project is licensed under the MIT License - see the LICENSE file for details.