Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/firehed/input

PHP Input Handling
https://github.com/firehed/input

framework input php php-framework php-validation validation

Last synced: 22 days ago
JSON representation

PHP Input Handling

Awesome Lists containing this project

README

        

Input
=====
An input validation framework with a boring name

[![Test](https://github.com/Firehed/input/actions/workflows/test.yml/badge.svg)](https://github.com/Firehed/input/actions/workflows/test.yml)
[![Static analysis](https://github.com/Firehed/input/actions/workflows/static-analysis.yml/badge.svg)](https://github.com/Firehed/input/actions/workflows/static-analysis.yml)
[![Lint](https://github.com/Firehed/input/actions/workflows/lint.yml/badge.svg)](https://github.com/Firehed/input/actions/workflows/lint.yml)
[![codecov](https://codecov.io/gh/Firehed/input/branch/master/graph/badge.svg?token=gTzlnli3QV)](https://codecov.io/gh/Firehed/input)

[Changelog](CHANGELOG.md)

Concept
-----
Input validation is an important task in any web application, but remains an
extremely tedious task. This replaces intermingled checks with a proper data
structure that clearly defines the required and optional inputs.

The design reolves around the idea of API-driven design, where each API
endpoint is its own object, however does not explicitly require this format
- it is capable of validating for any object that defines the input
requirements. What it cannot easily handle is the common pattern of large
controlelrs that are respnsible for many URLs, since each URL has its own
validation requirements. It's certainly possible to structure your code in
a way to make this work, but that is liable to become more complicated than the
benefit it provides.

Data handling steps
-----
Raw input is transformed into safe data in two primary steps:

* Parsing
* Validation

Parsing is responsible for transforming the raw input string into an associative
array. If your application is structured to do so, this step can be skipped
entirely.

Validation is the most useful part of the library - taking a defined set of
optional and required parameters and their types, and comparing the input
values to the spec. The implementation prevents invalid data from being
propagated entirely; it is not possible to create a `SafeInput` object (which
your application will use) from invalid data!

Upon completion of this process, a `SafeInput` object is returned that contains
data in accordance with the spec defined by the object implementing
`ValidationInterface` (missing optional values are null).

Because this library exists to provide trustable data, it will actively prevent
you from second-guessing it; for example, using `isset` or `empty` on the data
structure will throw an exception. It is the author's experience that acting
unable to trust your validated data is an anti-pattern and a code smell; if you
insist on doing so, this is not the right tool for you. Forcing trust like this
tends to prevent documentation from driting apart from reality.

Example
-----

A basic example follows:

`some_controller_file.php`

```php
new O\Text(),
'baz' => (new O\Text())->setDefaultValue('my baz'),
];
}

public function getRequiredInputs() {
return [
'foo' => new O\Text(),
];
}

public function execute(SafeInput $i) {
// ... do some magic
// $i['foo'] will be a string
// $i['bar'] will be a string or null, since it was optional
// $i['baz'] will be a string or 'my baz', since it was an optional with a default value
}
}
```

`index.php`

```php
parse($parser)
->validate($endpoint);
$endpoint->execute($input);
} catch (Firehed\Input\Exceptions\InputException $e) {
// The input contained invalid data
} catch (Exception $e) {
// Do any logging, error responses, etc.
echo $e;
}
```