ray / web-form-module
Web Form module for Ray.Di
Installs: 21 640
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 3
Forks: 3
Open Issues: 0
Requires
- php: >=7.0.0
- aura/filter: ^2.3|3.x-dev
- aura/html: ^2.5
- aura/input: ^1.2
- ray/aura-session-module: ^1.1
- ray/di: ^2.7
Requires (Dev)
- phpunit/phpunit: ^5.7.13
README
An aspect oriented web form module powered by Aura.Input and Ray.Di.
Getting Started
Installation
Composer install
$ composer require web-form-module
Module install
use Ray\Di\AbstractModule; use Ray\WebFormModule\AuraInputModule; class AppModule extends AbstractModule { protected function configure() { $this->install(new AuraInputModule); } }
Usage
Form class
We provide two methods on self-initializing form class, one is init()
method where we add an input field on form and apply fileters and rules. The other method method is submit()
where it submit data. See more detail at Aura.Input self-initializing forms.
use Ray\WebFormModule\AbstractForm; use Ray\WebFormModule\SetAntiCsrfTrait; class MyForm extends AbstractForm { // for anti CSRF use SetAntiCsrfTrait; /** * {@inheritdoc} */ public function init() { $this->setField('name', 'text') ->setAttribs([ 'id' => 'name' ]); $this->filter->validate('name')->is('alnum'); $this->filter->useFieldMessage('name', 'Name must be alphabetic only.'); } /** * {@inheritdoc} */ public function submit() { return $_POST; } /** * {@inheritdoc} */ public function __toString() { $form = $this->form(); // name $form .= $this->helper->tag('div', ['class' => 'form-group']); $form .= $this->helper->tag('label', ['for' => 'name']); $form .= 'Name:'; $form .= $this->helper->tag('/label') . PHP_EOL; $form .= $this->input('name'); $form .= $this->error('name'); $form .= $this->helper->tag('/div') . PHP_EOL; // submit $form .= $this->input('submit'); $form .= $this->helper->tag('/form'); return $form; } }
Controller
We annotate the methods which web form validation is required with @FormValidation
. We can specify form object property name with name
and failiure method name with @onFailure
.
use Ray\Di\Di\Inject; use Ray\Di\Di\Named; use Ray\WebFormModule\Annotation\FormValidation; use Ray\WebFormModule\FormInterface; class MyController { /** * @var FormInterface */ protected $contactForm; /** * @Inject * @Named("contact_form") */ public function setForm(FormInterface $form) { $this->contactForm = $form; } /** * @FormValidation(form="contactForm", onFailure="badRequestAction") */ public function createAction() { // validation success } public function badRequestAction() { // validation faild } }
View
You can render entire form html when __toString
is given.
echo $form; // render entire form html
or render input element basis.
echo $form->input('name'); // <input id="name" type="text" name="name" size="20" maxlength="20" /> echo $form->error('name'); // "Name must be alphabetic only." or blank.
CSRF Protections
use Ray\WebFormModule\SetAntiCsrfTrait; class MyController { use SetAntiCsrfTrait;
You can provide your custom AntiCsrf
class. See more detail at Aura.Input
Validation Exception
When we install Ray\WebFormModule\FormVndErrorModule
as following,
use Ray\Di\AbstractModule; class FakeVndErrorModule extends AbstractModule { protected function configure() { $this->install(new AuraInputModule); $this->override(new FormVndErrorModule); }
A Ray\WebFormModule\Exception\ValidationException
will be thrown.
We can echo catched exception to get application/vnd.error+json media type.
echo $e->error; //{ // "message": "Validation failed", // "path": "/path/to/error", // "validation_messages": { // "name": [ // "Name must be alphabetic only." // ] // } //}
More detail for vnd.error+json
can be add with @VndError
annotation.
/** * @FormValidation(form="contactForm") * @VndError( * message="foo validation failed", * logref="a1000", path="/path/to/error", * href={"_self"="/path/to/error", "help"="/path/to/help"} * ) */
This optional module is handy for API application.
Demo
$ php -S docs/demo/1.csrf/web.php