add form events
This commit is contained in:
		| @ -0,0 +1,86 @@ | |||||||
|  | Form Events | ||||||
|  | =========== | ||||||
|  |  | ||||||
|  | The following is the list of the form events and where they happen:  | ||||||
|  |  | ||||||
|  | On Controllers | ||||||
|  | -------------- | ||||||
|  |  | ||||||
|  | - **RecoveryController** | ||||||
|  |     - **FormEvent::EVENT_BEFORE_REQUEST**: Occurs before a password recovery request | ||||||
|  |     - **FormEvent::EVENT_AFTER_REQUEST**: Occurs after a password recovery request | ||||||
|  |  | ||||||
|  |  | ||||||
|  | - **RegistrationController** | ||||||
|  |     - **FormEvent::EVENT_BEFORE_RESEND**: Occurs before a confirmation message is being sent via email | ||||||
|  |     - **FormEvent::EVENT_AFTER_RESEND**: Occurs after a confirmation message is being sent via email | ||||||
|  |  | ||||||
|  |  | ||||||
|  | - **SecurityController** | ||||||
|  |     - **FormEvent::EVENT_BEFORE_LOGIN**: Occurs before a user logs into the system | ||||||
|  |     - **FormEvent::EVENT_AFTER_LOGIN**: Occurs after a user logs into the system | ||||||
|  |  | ||||||
|  | How to Work With Form Events | ||||||
|  | ---------------------------- | ||||||
|  |  | ||||||
|  | All these events received an instance of a `Da\User\Event\FormEvent`. The event receives an instance of a form  | ||||||
|  | depending on where its being called. The following is the list of the forms accessible via `FormEvent::getForm()`:  | ||||||
|  |  | ||||||
|  | - **FormEvent::EVENT_BEFORE_LOGIN|EVENT_AFTER_LOGIN**: It will contain a `Da\User\Form\LoginForm` instance with the  | ||||||
|  |     submitted data | ||||||
|  | - **FormEvent::EVENT_BEFORE_RESEND|EVENT_AFTER_RESEND**: It will contain a `Da\User\Form\ResendForm` instance with the  | ||||||
|  |     submitted data | ||||||
|  | - **FormEvent::EVENT_BEFORE_REQUEST|EVENT_AFTER_REQUEST**: It will contain a `Da\User\Form\RecoveryForm` instance with  | ||||||
|  |     the submitted data | ||||||
|  |  | ||||||
|  | The recommended way to make use of events is by creating a new file in your config folder (i.e. `events.php`), configure  | ||||||
|  | there all your events and then include that file on your  | ||||||
|  | [`entry script`](http://www.yiiframework.com/doc-2.0/guide-structure-entry-scripts.html). | ||||||
|  |  | ||||||
|  | Here is an example of setting an event for the `RecoveryController`:  | ||||||
|  |  | ||||||
|  | ```php  | ||||||
|  | <?php  | ||||||
|  | // events.php file | ||||||
|  |  | ||||||
|  | use Da\Controller\RecoveryController; | ||||||
|  | use Da\Event\FormEvent; | ||||||
|  | use yii\base\Event; | ||||||
|  |  | ||||||
|  | Event::on(RecoveryController::class, FormEvent::EVENT_BEFORE_REQUEST, function (FormEvent $event) { | ||||||
|  |     $form = $event->getForm(); | ||||||
|  |      | ||||||
|  |     // ... your logic here | ||||||
|  | } | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Now, include `events.php` file to your entry script (i.e. `index.php`). The following is taken from the Yii 2 Advanced  | ||||||
|  | Application Template: | ||||||
|  |  | ||||||
|  | ```php  | ||||||
|  | <?php | ||||||
|  | defined('YII_DEBUG') or define('YII_DEBUG', true); | ||||||
|  | defined('YII_ENV') or define('YII_ENV', 'dev'); | ||||||
|  |  | ||||||
|  | require(__DIR__ . '/../../vendor/autoload.php'); | ||||||
|  | require(__DIR__ . '/../../vendor/yiisoft/yii2/Yii.php'); | ||||||
|  | require(__DIR__ . '/../../common/config/bootstrap.php'); | ||||||
|  | require(__DIR__ . '/../config/bootstrap.php'); | ||||||
|  |  | ||||||
|  | require(__DIR__ . '/../config/events.php'); // <--- adding events here! :) | ||||||
|  |  | ||||||
|  | $config = yii\helpers\ArrayHelper::merge( | ||||||
|  |     require(__DIR__ . '/../../common/config/main.php'), | ||||||
|  |     require(__DIR__ . '/../../common/config/main-local.php'), | ||||||
|  |     require(__DIR__ . '/../config/main.php'), | ||||||
|  |     require(__DIR__ . '/../config/main-local.php') | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | $application = new yii\web\Application($config); | ||||||
|  | $application->run(); | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | © [2amigos](http://www.2amigos.us/) 2013-2017 | ||||||
|  |  | ||||||
|  | |||||||
| @ -17,20 +17,20 @@ On Controllers | |||||||
|     - **UserEvent::EVENT_AFTER_BLOCK**: Occurs after a user is being blocked (forbid access to app) |     - **UserEvent::EVENT_AFTER_BLOCK**: Occurs after a user is being blocked (forbid access to app) | ||||||
|     - **UserEvent::EVENT_BEFORE_UNBLOCK**: Occurs before a user is being un-blocked |     - **UserEvent::EVENT_BEFORE_UNBLOCK**: Occurs before a user is being un-blocked | ||||||
|     - **UserEvent::EVENT_AFTER_UNBLOCK**: Occurs after a user is being un-blocked |     - **UserEvent::EVENT_AFTER_UNBLOCK**: Occurs after a user is being un-blocked | ||||||
|      |  | ||||||
|      |  | ||||||
| - **RegistrationController** | - **RegistrationController** | ||||||
|     - **UserEvent::EVENT_BEFORE_REGISTER**: Occurs before user registration |     - **UserEvent::EVENT_BEFORE_REGISTER**: Occurs before user registration | ||||||
|     - **UserEvent::EVENT_AFTER_REGISTER**: Occurs after user registration |     - **UserEvent::EVENT_AFTER_REGISTER**: Occurs after user registration | ||||||
|     - **UserEvent::EVENT_BEFORE_CONFIRMATION** |     - **UserEvent::EVENT_BEFORE_CONFIRMATION** | ||||||
|     - **UserEvent::EVENT_AFTER_CONFIRMATION** |     - **UserEvent::EVENT_AFTER_CONFIRMATION** | ||||||
|      |  | ||||||
|      |  | ||||||
| - **SecurityController** | - **SecurityController** | ||||||
|     - **UserEvent::EVENT_BEFORE_LOGOUT**: Occurs before user logs out of the app |     - **UserEvent::EVENT_BEFORE_LOGOUT**: Occurs before user logs out of the app | ||||||
|     - **UserEvent::EVENT_AFTER_LOGOUT**: Occurs after user logs out of the app |     - **UserEvent::EVENT_AFTER_LOGOUT**: Occurs after user logs out of the app | ||||||
|      |  | ||||||
|      |  | ||||||
| - **SettingsController** | - **SettingsController** | ||||||
|     - **UserEvent::EVENT_BEFORE_PROFILE_UPDATE** |     - **UserEvent::EVENT_BEFORE_PROFILE_UPDATE** | ||||||
|     - **UserEvent::EVENT_AFTER_PROFILE_UPDATE** |     - **UserEvent::EVENT_AFTER_PROFILE_UPDATE** | ||||||
| @ -38,7 +38,7 @@ On Controllers | |||||||
|     - **UserEvent::EVENT_AFTER_ACCOUNT_UPDATE**: Occurs after the user account is updated |     - **UserEvent::EVENT_AFTER_ACCOUNT_UPDATE**: Occurs after the user account is updated | ||||||
|     - **UserEvent::EVENT_BEFORE_DELETE**: Occurs before the user account is deleted |     - **UserEvent::EVENT_BEFORE_DELETE**: Occurs before the user account is deleted | ||||||
|     - **UserEvent::EVENT_AFTER_DELETE**: Occurs after the user account is deleted |     - **UserEvent::EVENT_AFTER_DELETE**: Occurs after the user account is deleted | ||||||
|      |  | ||||||
| On Models | On Models | ||||||
| --------- | --------- | ||||||
|  |  | ||||||
| @ -69,6 +69,7 @@ Here is an example of setting an event for the `AdminController` and the `User` | |||||||
| // events.php file | // events.php file | ||||||
|  |  | ||||||
| use Da\Controller\AdminController; | use Da\Controller\AdminController; | ||||||
|  | use Da\Event\UserEvent; | ||||||
| use Da\Model\User; | use Da\Model\User; | ||||||
| use yii\base\Event; | use yii\base\Event; | ||||||
|  |  | ||||||
|  | |||||||
| @ -101,7 +101,8 @@ class SecurityController extends Controller | |||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Controller action responsible for handling login page and actions. |      * Controller action responsible for handling login page and actions. | ||||||
|      * @return string|Response |      * | ||||||
|  |      * @return array|string|Response | ||||||
|      */ |      */ | ||||||
|     public function actionLogin() |     public function actionLogin() | ||||||
|     { |     { | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user