egbosionu / lara-http-enums
A collection of HTTP-related PHP enums for Laravel applications
Requires
- php: ^8.1
- illuminate/support: ^9.0|^10.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.0
- orchestra/testbench: ^8.0
- pestphp/pest: ^2.36
- pestphp/pest-plugin-laravel: ^2.4
- phpstan/phpstan: ^1.10
README
A Laravel package for managing HTTP status codes, methods and other related HTTP enums.
Description
LaraHttpEnums is a simple, easy-to-use package that provides a collection of HTTP status codes, methods and related enums to be used in your Laravel projects. This package helps streamline working with HTTP-related constants, improving readability and consistency in your code.
Installation
You can install the package via Composer:
composer require egbosionu/lara-http-enums
Usage
HTTP Status Codes
use Egbosionu\LaraHttpEnums\StatusCode; // Basic usage $status = StatusCode::OK; // 200 $status = StatusCode::NOT_FOUND; // 404 // Get reason phrase $phrase = StatusCode::OK->getReasonPhrase(); // "OK" // Check status type $status = StatusCode::NOT_FOUND; $status->isClientError(); // true $status->isError(); // true $status->isSuccessful(); // false // Convert from integer $status = StatusCode::fromInt(404); // StatusCode::NOT_FOUND $status = StatusCode::tryFromInt(404); // StatusCode::NOT_FOUND or null if invalid // Convert from name $status = StatusCode::fromName('NOT_FOUND'); // StatusCode::NOT_FOUND $status = StatusCode::tryFromName('NOT_FOUND'); // StatusCode::NOT_FOUND or null if invalid
HTTP Methods
use Egbosionu\LaraHttpEnums\Method; // Basic usage $method = Method::GET; $method = Method::POST; // Check method properties $method = Method::GET; $method->isSafe(); // true - doesn't modify resources $method->isIdempotent(); // true - multiple identical requests have same effect as single request // Convert from string $method = Method::fromName('GET'); // Method::GET $method = Method::tryFromName('GET'); // Method::GET or null if invalid
Reason Phrases
use Egbosionu\LaraHttpEnums\ReasonPhrase; use Egbosionu\LaraHttpEnums\StatusCode; // Get reason phrase from status code $phrase = ReasonPhrase::fromStatusCode(StatusCode::NOT_FOUND); // ReasonPhrase::NOT_FOUND $text = ReasonPhrase::fromStatusCode(StatusCode::NOT_FOUND)->value; // "Not Found" // Try to get reason phrase $phrase = ReasonPhrase::tryFromStatusCode(StatusCode::NOT_FOUND); // ReasonPhrase::NOT_FOUND or null if invalid
Features
-
Type-safe HTTP status codes with integer values
-
Type-safe HTTP methods with string values
-
Standard reason phrases for all status codes
-
Helper methods for checking status code categories
-
Helper methods for checking method properties
-
Case-insensitive method name parsing
-
Null-safe conversion methods
-
Full PSR-4 autoloading support
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
If you discover any security-related issues, please email oegbosionu@gmail.com instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.