d4nd3v / auth
Laravel 5 Auth Generator
dev-master
2017-08-11 16:12 UTC
Requires
- php: >=5.6.4
- laravel/framework: >=5.3
This package is not auto-updated.
Last update: 2025-02-02 02:41:00 UTC
README
Usage
Install Through Composer
composer require d4nd3v/auth:dev-master
Add the Service Provider
Add the provider in app/Providers/AppServiceProvider.php
public function register() { ... if ($this->app->environment() !== 'production') { $this->app->register('D4nd3v\Auth\AuthServiceProvider'); } }
Generate Auth
php artisan generate:auth
Create Tables
php artisan migrate --path=/database/migrations/auth/
This will create users
, password_resets
and activations
tables.
If you use API Auth:
https://github.com/tymondesigns/jwt-auth/wiki/Installation
In header must be set: Accept: application/json
Set the Model:
Go to config/auth.php
and change App\User:class
to App\Models\User::class
.
Routes
For 'middleware' => 'guest'
, in \app\Http\Middleware\RedirectIfAuthenticated.php
set return redirect(route('home'));
Web routes
Route::group(['middleware' => 'guest'], function () {
Route::get('register', 'AuthController@showRegisterForm')->name('registerForm');
Route::post('register', 'AuthController@register')->name('register');
Route::get('login', 'AuthController@showLoginForm')->name('loginForm');
Route::post('login', 'AuthController@authenticate')->name('login');
});
Route::get('account/activate/', 'AuthController@showActivateMessage')->name('activate');
Route::get('account/activate/{token}', 'AuthController@activate');
Route::get('account/reactivate/', 'AuthController@showResendActivationCode')->name('reactivateForm');
Route::post('account/reactivate/', 'AuthController@resendActivationCode')->name('reactivate');
Route::get('logout', 'AuthController@logout')->name('logout');
Route::get('password/reset', 'AuthController@showLinkRequestForm');
Route::post('password/email', 'AuthController@sendEmailWithResetPasswordLink');
Route::get('password/reset/{token}', 'AuthController@showResetForm')->name('password.reset');
Route::post('password/reset', 'AuthController@resetPassword');
Route::group(['middleware' => 'auth'], function () {
Route::get('password/change', 'AuthController@showChangePasswordForm')->name('showChangePasswordForm');
Route::post('password/change', 'AuthController@changePassword')->name('changePassword');
});
API route
Route::post('login', 'AuthController@authenticate');
Route::get('logout', 'AuthController@logout');
Route::post('register', 'AuthController@register');
Route::post('password/forgot', 'AuthController@sendEmailWithResetPasswordLink');
Route::post('password/reset', 'AuthController@resetPassword');
Route::post('activate/send', 'AuthController@resendActivationCode');
Route::group(['middleware' => 'auth.jwt'], function () {
Route::post('password/change', 'AuthController@changePassword');
});
API Exceptions
In \app\Exceptions\Handler.php
.....
public function render($request, Exception $exception)
{
if ($exception instanceof APIException) {
return $exception->apiExceptionResponse;
}
.....
protected function unauthenticated($request, AuthenticationException $exception)
{
if ($request->expectsJson()) {
throw new ApiException("unauthenticated");
}
.....
Flow:
> Register (/register)
> ActivateAccount Notification (Send Mail)
> Activate (From Mail) (GET /account/activate/token)
> Forgot password? (GET /password/reset)
> PasswordReset Notification (Send Mail)
> Change password form (From Mail) (GET /password/reset/token)
> Action change password (/password/reset)
> Login Form (GET /login)
> Login (POST /login)
> Form Resend activation code (GET /account/reactivate/)
> Action Resend activation code (POST /account/reactivate/)
> Change Password (GET /password/change)
> Set New Password (POST /password/change)
> Logout (GET /logout)
Utile
Test users:
<a href="javascript:;" onclick="$('#email').val('test@test.test'); $('#password').val('xxx');">test@test.test</a>