beblife / schema-validation-laravel
Validate HTTP-requests using JSON-schema objects
Installs: 10 750
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/beblife/schema-validation-laravel
Requires
- php: ^7.4|^8.0
- guzzlehttp/psr7: ^1.8 || ^2.0
- league/openapi-psr7-validator: ^0.18
- spatie/laravel-package-tools: ^1.11
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.18 || ^3.1
- mockery/mockery: ^1.4
- orchestra/testbench: ^6.14
- phpunit/phpunit: ^9.5
README
Validate HTTP-requests using OpenAPI specification files or JSON-schema objects in Laravel.
Installation
This package can be installed through Composer:
composer require beblife/schema-validation-laravel
After that can publish the configuration file with this command:
php artisan vendor:publish --provider="Beblife\SchemaValidation\SchemaValidationServiceProvider"
Once published you will have a config/schema-validation.php file that looks like this:
return [ 'spec_path' => env('SCHEMA_VALIDATION_SPEC_PATH', ''), 'response' => [ 'status' => 400, ], ];
You can define the spec path as a .env variable or hardcode the absolute path in the configuration file itself.
The status code when a validation exception is thrown can also be customised here.
Usage
Validating Requests
This package provides a macro on the Illumnite\Http\Request::class that will validate the request's schema.
use Illuminate\Http\Request; class UserRegistrationRequestHandler extends Controller { public function __invoke(Request $request) { $request = $request->validateSchema(); // Validate any additional rules (if any) with $request->validate(...) // Process the valid request ... } }
When the validateSchema() method is called the package will search for a matching path defined in the configured OpenAPI specification file and validate the request against the schema.
There are two possible exceptions that can occur when the validation takes place:
UnableToValidateSchema
When a path can't be found in the specification file this exception is thrown.
InvalidSchema
When the request does not match the schema defined in the specification file this exception is thrown.
This exception extends the Laravel ValidationException which results in a 400 : Bad Request with the following format:
{
    "message": "The given data is invalid.",
    "errors": {
        "property": [
            "The validation message",
        ]
    }
}
The package also provides a trait that can be added on a form request to validate the schema. Behind the scenes this trait hooks into the prepareForValidation() method to start validating the request's schema. Afterwards any additional validation defined in the rules() method will be handled by the Laravel framework.
use Beblife\SchemaValidation\ValidateSchema; use Illuminate\Foundation\Http\FormRequest; class UserRegistrationRequest extends FormRequest { use ValidateSchema; public function rules(): array { return [ // Your other validation rules ... ]; } }
The schema to use for validation will be resolved automatically from the configured OpenAPI specification file.
This can be overwritten by defining a schema() on the FormRequest::class.
use Beblife\SchemaValidation\Schema; use Beblife\SchemaValidation\ValidateSchema; use Illuminate\Foundation\Http\FormRequest; class UserRegistrationRequest extends FormRequest { use ValidateSchema; public function schema(): Schema { return // Your custom defined schema ... } public function rules(): array { return [ // Your other validation rules ... ]; } }
Defining Schema's
By default the package will use the schema's defined the configured specification when validating requests.
There is also the option to pass a Beblife\SchemaValidation\Schema::class to the validateSchema() method using the provided facade:
From array
$schema = Beblife\SchemaValidation\Facades\Schema::fromArray([ 'type' => 'object', 'properties' => [ 'field' => [ 'type' => 'string', 'enum' => [ 'option 1', 'option 2', ] ] ] ]);
From File
// from a JSON-file $schema = Beblife\SchemaValidation\Facades\Schema::fromFile('/path/to/a/schema/file.json')); // from a YAML-file $schema = Beblife\SchemaValidation\Facades\Schema::fromFile('/path/to/a/schema/file.yaml'));
From Class
use Beblife\SchemaValidation\Schema; class MyCustomSchema implements Schema { public function toArray(): array { return [ 'type' => 'object', 'properties' => [ // ... ] ]; } }
License
The MIT License (MIT). Please see License File for more information.