I am trying to make middleware for different types of users in my Laravel 5.2 application. So what I'm doing is creating different intermediaries for different users.
As far as I know, Auth :: check () will not work without using the intermediate website here .
So what I did -
routes.php
Route::group(['middleware' => ['web','admin']], function ()
{
Route::get('users', [
'uses' => 'AdminController@users',
'as' => 'users'
]);
Route::get('articles', [
'uses' => 'AdminController@articles',
'as' => 'articles'
]);
});
Adminminiddleware.php
<?php
namespace App\Http\Middleware;
use Closure;
use Auth;
class AdminMiddleware
{
public function handle($request, Closure $next)
{
if (Auth::check())
{
return "asd";
}
else
{
return redirect('login');
}
return $next($request);
}
}
Kernel.php
protected $routeMiddleware = [
'auth' => \App\Http\Middleware\Authenticate::class,
'admin' => \App\Http\Middleware\AdminMiddleware::class,
'user' => \App\Http\Middleware\UserMiddleware::class,
'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
];
AdminController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class AdminController extends Controller
{
public function users()
{
return view('admin.users');
}
public function articles()
{
return view('admin.articles');
}
}
But I get this error -

when " returns Auth :: user (); " called inside the middleware, "return Auth :: user ();" works elsewhere (viewer and controllers), but doesn't work like older versions of Laravel.
Can anybody help?