, (*1)
Advance Authenticate plugin for CakePHP 3.2+
Feature
- Prevent brute force attack by IP
- Remember/Auto login
Installation
You can install this plugin into your CakePHP application using composer., (*2)
The recommended way to install composer packages is:, (*3)
composer self-update
composer require crabstudio/authenticate
Or add the following lines to your application's composer.json:, (*4)
"require": {
"crabstudio/authenticate": "^1.0"
}
followed by the command:, (*5)
composer update
Load plugin
From command line:, (*6)
bin/cake plugin load Authenticate
Or add this line to the end of file Your_project\config\bootstrap.php, (*7)
Plugin::load('Authenticate');
Config Auth component from AppController.php, (*8)
// All config key as usual FormAuthenticate/BaseAuthenticate
// I list the different config keys only.
$this->loadComponent('Auth', [
'authenticate' => [
'Authenticate.Advance' => [
'lockout' => [
'retries' => 3,
'expires' => '5 minutes',
'file_path' => 'prevent_brute_force',
'message' => [
'locked' => 'You have exceeded the number of allowed login attempts. Please try again in {0}',
'login_fail' => 'Incorrect username or password. {0} retries remain. Please try again',
]
],
'remember' => [
'enable' => true,
'key' => 'RememberMe',
'expires' => '1 months',
],
],
]);
If you want to store login information to the Cookie, login Form required checkbox
RememberMe as bellow, (*9)
Paste this function to the AppController.php, (*10)
// remember to import Event to the AppController.php
use Cake\Event\Event;
public function initialize()
{
parent::initialize();
$this->loadComponent('Cookie');
}
public function beforeFilter(Event $event)
{
//Automaticaly Login.
if (!$this->Auth->user() && $this->Cookie->read('RememberMe')) {
$user = $this->Auth->identify();
if ($user) {
$this->Auth->setUser($user);
} else {
$this->Cookie->delete('RememberMe');
}
}
}
// login.ctp template
=$this->Form->create()?>
=$this->Flash->render()?>
=$this->Form->input('username')?>
=$this->Form->input('password')?>
=$this->Form->input('RememberMe', ['checked' => false, 'type' => 'checkbox'])?>
=$this->Form->input(__('Login'), ['type' => 'submit'])?>
=$this->Form->end()?>