helori / laravel-admin
This package allows you to create admin users (different than your application's users)
Installs: 1 124
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Requires
- php: >=7.0.0
README
This package allows you to create admin users (different than your application's users). It uses a custom guard and comes with Laravel auth views : login, register, password reset... It is especially useful when building protected areas (e.g. control panels) without the need to re-build everything.
Installation and setup
On a fresh Laravel (>= v5.4) installation, install the package by running:
composer require helori/laravel-admin
Configure your application (Laravel version < 5.5):
// config/app.php 'providers' => [ ... Helori\LaravelAdmin\AdminServiceProvider::class, ];
Setup the guard, provider and password reset options to handle administrator authentication :
// config/auth.php 'guards' => [ ... 'admin' => [ 'driver' => 'session', 'provider' => 'admins', ], ], 'providers' => [ ... 'admins' => [ 'driver' => 'eloquent', 'model' => Helori\LaravelAdmin\Models\Admin::class, ] ], 'passwords' => [ ... 'admins' => [ 'provider' => 'admins', 'table' => 'admins_resets', 'expire' => 60, ], ],
Configure redirection if an auth exception is raised :
// app/Exceptions/Handler.php use Illuminate\Auth\AuthenticationException; ... protected function unauthenticated($request, AuthenticationException $exception) { if ($request->expectsJson()) { return response()->json(['error' => 'Unauthenticated.'], 401); } $guard = array_get($exception->guards(), 0); if($guard === 'admin'){ return redirect()->guest(route('admin-login')); }else{ return redirect()->guest(route('login')); } }
Configure redirection if an administrator is already authenticated :
// app/Middleware/RedirectIfAuthenticated.php public function handle($request, Closure $next, $guard = null) { if (Auth::guard($guard)->check()) { if($guard === 'admin'){ return redirect()->route('admin-home'); }else{ return redirect('/'); } } return $next($request); }
Run the migrations:
php artisan migrate
Create the first administrator to be able to connect the first time:
php artisan tinker $admin = new \Helori\LaravelAdmin\Models\Admin $admin->name = 'John' $admin->email = 'john@domain.com' $admin->password = bcrypt('john_password') $admin->save() exit
Publish the laravel-admin default assets:
php artisan vendor:publish --tag=laravel-admin-assets
Install the package's font-end dependencies:
npm install jquery@3.* bootstrap@4.* --save-dev
Edit your laravel mix config file :
// webpack.mix.js mix.sass( "./resources/assets/sass/admin.scss", "./public/css/admin.css" ).js( "./resources/assets/js/admin.js", "./public/js/admin.js", "." );
Compile your assets :
npm run dev
Your admin auth should be available at:
http://your-domain.test/admin/login
Start creating protected views :
// routes/web.php ... Route::group(['prefix' => 'admin', 'middleware' => 'auth:admin'], function () { Route::get('/', function(){ return view('your-admin-home'); }); ... });