chaplean / form-handler-bundle
The Bundle base to fork
Installs: 1 174
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- php: >=7.0.8
- doctrine/doctrine-bundle: ^1.6
- doctrine/orm: ^2.5
- friendsofsymfony/rest-bundle: ^2.1
- symfony/config: ^3.0 || ^4.0
- symfony/console: ^3.0 || ^4.0
- symfony/dependency-injection: ^3.0 || ^4.0
- symfony/form: ^3.0 || ^4.0
- symfony/validator: ^3.0 || ^4.0
- symfony/yaml: ^3.0 || ^4.0
Requires (Dev)
- chaplean/coding-standard: ^1.1
- mockery/mockery: dev-master
- phpunit/phpunit: ^7.0 || ^8.0
- symfony/http-kernel: ^3.0 || ^4.0
- symfony/phpunit-bridge: ^4.0
- symfony/serializer: ^3.0 || ^4.2
- symfony/var-dumper: ^3.0 || ^4.0
Conflicts
- chaplean/unit-bundle: <8.0.0
This package is auto-updated.
Last update: 2024-08-09 23:17:00 UTC
README
1. Composer
composer require chaplean/form-handler-bundle
2. AppKernel.php
Add
new Chaplean\Bundle\FormHandlerBundle\ChapleanFormHandlerBundle(),
Usage
Bellow are few fake controller actions to show of what you can do.
<?php namespace App\Bundle\RestBundle\Controller; use FOS\RestBundle\Controller\Annotations; use FOS\RestBundle\Controller\FOSRestController; use Symfony\Component\HttpFoundation\Request; /** * @Annotations\RouteResource("DummyEntity") */ class FakeController extends FOSRestController { /* * Those two first actions uses the defaults behaviours of FormHandler. * On success it will persist the DummyEntity given to handle. * On failure it will convert the form errors to an angular friendly format. * No groups will be used when serializing your entity to create the response on success. * * The first action works with a new DummyEntity. * The second action works with an existing DummyEntity. */ public function postAction(Request $request) { return $this ->get('chaplean_form_handler.form_handler') ->handle(DummyEntityType::class, new DummyEntity(), $request); } public function putAction(Request $request, DummyEntity $dummy) { return $this ->get('chaplean_form_handler.form_handler') ->handle(DummyEntityType::class, $dummy, $request); } /* * This action defines groups to use to serialize the DummyEntity to create the response on success. */ public function postWithGroupsAction(Request $request) { return $this ->get('chaplean_form_handler.form_handler') ->setGroups(['dummy_entity_name']) ->handle(DummyEntityType::class, new DummyEntity(), $request); } /* * The SuccessHandler is the logic that's run when the form submission is valid. * The default behaviour is to persist the entity. * With the successHandler function you can override this default behaviour by giving an * alternative implementation of SuccessHandlerInterface. * * successHandler takes a string that's the name of the class implementing SuccessHandlerInterface * you registered in the container under. * * If the class you gave happens to also implement PreprocessorInterface and / or ValidatorInterface * and you haven't called the preprocessor and / or validator methods, your class will be used * as the preprocessor and / or validator. */ public function postWithCustomSuccessHandler(request $request) { return $this ->get('chaplean_form_handler.form_handler') ->successHandler('your_bundle.form.success_handler.do_something_on_valid_form') ->handle(DummyEntityType::class, new DummyEntity(), $request); } /* * The FailureHandler is the logic that's run when the form submission is invalid. * The default behaviour is to transform the form errors into an angular friendly format. * With the failureHandler function you can override this default behaviour by giving an * alternative implementation of FailureHandlerInterface. * * failureHandler takes a string that's the name of the class implementing FailureHandlerInterface * you registered in the container under. */ public function postWithCustomFailureHandler(request $request) { return $this ->get('chaplean_form_handler.form_handler') ->failureHandler('your_bundle.form.failure_handler.do_something_on_invalid_form') ->handle(DummyEntityType::class, new DummyEntity(), $request); } /* * The Preprocessor is the logic that's run before the form validation logic is run. * The goal of this is to allow you to run custom transformation (like maybe some filters, or coversions) * on the data to submit before it is submited. * With the preprocessor function you can define the behaviour you want by giving an * implementation of PreprocessorInterface. * * preprocessor takes a string that's the name of the class implementing PreprocessorInterface * you registered in the container under. */ public function postWithCustomPreprocessor(request $request) { return $this ->get('chaplean_form_handler.form_handler') ->preprocessor('your_bundle.form.preprocessor.do_custom_preprocessing_on_data') ->handle(DummyEntityType::class, new DummyEntity(), $request); } /* * The Validator allows you to define custom validation logic outside of symfony form validator. * With the preprocessor function you can define the behaviour you want by giving an * implementation of ValidatorInterface. * * preprocessor takes a string that's the name of the class implementing ValidatorInterface * you registered in the container under. */ public function postWithCustomValidator(request $request) { return $this ->get('chaplean_form_handler.form_handler') ->validator('your_bundle.form.validator.do_custom_data_validation') ->handle(DummyEntityType::class, new DummyEntity(), $request); } /* * This last action uses the whole api capabilities just for the sake of showing it off. */ public function postWithFullApiUsageAction(request $request) { return $this ->get('chaplean_form_handler.form_handler') ->successHandler('your_bundle.form.success_handler.do_something_on_valid_form') ->failureHandler('your_bundle.form.failure_handler.do_something_on_invalid_form') ->preprocessor('your_bundle.form.preprocessor.do_custom_preprocessing_on_data') ->validator('your_bundle.form.validator.do_custom_data_validation') ->setGroups(['dummy_entity_name']) ->handle(DummyEntityType::class, new DummyEntity(), $request); } }