znojil / http
đĒļ Lightweight PSR-7, PSR-17 and PSR-18 implementation.
Installs: 102
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/znojil/http
Requires
- php: ^8.1
- psr/http-client: ^1.0
- psr/http-factory: ^1.1
- psr/http-message: ^2.0
Requires (Dev)
- nette/tester: ^2.5
- phpstan/phpstan: ^2.1
Provides
README
Lightweight, strict, and robust implementation of PSR-7, PSR-17, and PSR-18 standards.
This library provides a clean HTTP Client (wrapper around cURL) and a complete set of HTTP Message objects (Request, Response, Stream, URI, etc.) strictly following PHP standards. It is designed to be lightweight with zero unnecessary dependencies.
đĻ Features
- PSR-7 Implementation (HTTP Message interfaces)
- PSR-17 Implementation (HTTP Factories)
- PSR-18 Implementation (HTTP Client)
- Zero dependencies (production)
- Strict types & PHPStan Level Max compatible
- Immutable objects design
đ Installation
Install via Composer:
composer require znojil/http
đ Usage
1. Sending a Request (Client)
The Client automatically detects the provided ResponseFactory (PSR-17). If none is provided, it uses the internal implementation.
use Znojil\Http\Client; use Znojil\Http\RequestFactory; $client = new Client; $factory = new RequestFactory; // Create a PSR-7 Request $request = $factory->postJson('https://api.example.com/users', [ 'name' => 'John Doe', 'role' => 'admin' ]); // Send Request (PSR-18) $response = $client->sendRequest($request); echo $response->getStatusCode(); // 201 echo (string) $response->getBody(); // {"id": 1, ...}
Client Configuration
The Client constructor accepts optional parameters for configuring base URI, default headers, and cURL options:
use Znojil\Http\Client; $client = new Client( 'https://api.example.com/v1', [ 'Authorization' => 'Bearer token123', 'Accept' => 'application/json' ], [ CURLOPT_TIMEOUT => 30, CURLOPT_CONNECTTIMEOUT => 5 ] ); // Now you can use relative URLs - base URI will be automatically combined $response = $client->sendRequest($factory->get('/users?limit=10')); // Requests: https://api.example.com/v1/users?limit=10
RequestFactory Helper Methods
The RequestFactory provides convenient methods for common HTTP operations:
use Znojil\Http\RequestFactory; $factory = new RequestFactory; // GET request with query parameters $request = $factory->get('https://api.example.com/users', ['page' => 1, 'limit' => 10]); // POST with JSON body $request = $factory->postJson('https://api.example.com/users', ['name' => 'John']); // POST with form data $request = $factory->post('https://api.example.com/login', [ 'username' => 'john', 'password' => 'secret' ], ['Content-Type' => 'application/x-www-form-urlencoded']); // PUT, PATCH, DELETE $request = $factory->putJson('https://api.example.com/users/1', ['name' => 'Jane']); $request = $factory->patchJson('https://api.example.com/users/1', ['status' => 'active']); $request = $factory->delete('https://api.example.com/users/1');
File Upload (Multipart)
For file uploads with additional form fields, use cURL's native CURLFile via CURLOPT_POSTFIELDS:
use Znojil\Http\Client; use Znojil\Http\RequestFactory; $client = new Client; $factory = new RequestFactory; $request = $factory->post('https://api.example.com/upload'); $response = $client->sendRequest($request, [ CURLOPT_POSTFIELDS => [ 'title' => 'My Document', 'category' => 'reports', 'file' => new \CURLFile('/path/to/document.pdf', 'application/pdf', 'document.pdf') ] ]);
2. Handling Incoming Request (Server)
Ideal for API endpoints or webhook processing.
use Znojil\Http\Message\ServerRequest; // Create request from PHP globals ($_GET, $_POST, $_FILES...) $request = ServerRequest::fromGlobals(); $method = $request->getMethod(); $queryParams = $request->getQueryParams(); $body = $request->getParsedBody(); // Working with Uploaded Files $files = $request->getUploadedFiles(); if(isset($files['document']) && $files['document']->isOk()){ $files['document']->moveTo('/storage/uploads/doc.pdf'); }
3. Using Factories (PSR-17)
You can use the factories to create any PSR-7 object manually.
use Znojil\Http\Psr17Factory; $factory = new Psr17Factory; $uri = $factory->createUri('https://example.com'); $stream = $factory->createStream('Hello World'); $response = $factory->createResponse(200)->withBody($stream);
â ī¸ Error Handling
The library throws PSR-18 compliant exceptions:
use Znojil\Http\Client; use Znojil\Http\Exception\NetworkException; use Znojil\Http\Exception\ClientException; $client = new Client; try{ $response = $client->sendRequest($request); }catch(NetworkException $e){ // Network-level errors (DNS failure, connection timeout, etc.) echo 'Network error: ' . $e->getMessage(); $failedRequest = $e->getRequest(); // Access the original request }catch(ClientException $e){ // Client initialization errors echo 'Client error: ' . $e->getMessage(); }
đ License
This library is open-source software licensed under the MIT license.