. */ declare(strict_types=1); namespace FireflyIII\Http\Middleware; use Closure; use FireflyIII\User; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; use Session; /** * Class IsDemoUser. */ class IsDemoUser { /** * Handle an incoming request. May not be a limited user (ie. Sandstorm env. or demo user). * * @param \Illuminate\Http\Request $request * @param \Closure $next * @param string|null $guard * * @return mixed */ public function handle(Request $request, Closure $next, $guard = null) { if (Auth::guard($guard)->guest()) { // don't care when not logged in, usual stuff applies: return $next($request); } /** @var User $user */ $user = auth()->user(); if ($user->hasRole('demo')) { Session::flash('info', strval(trans('firefly.not_available_demo_user'))); return redirect($request->session()->previousUrl()); } return $next($request); } }