user(); if (!$user) $user = User::getDefault(); // Share variables with views view()->share('signedIn', auth()->check()); view()->share('currentUser', $user); // Share variables with controllers $this->currentUser = $user; $this->signedIn = auth()->check(); } /** * Adds the page title into the view. * @param $title */ public function setPageTitle($title) { view()->share('pageTitle', $title); } /** * Checks for a permission. * * @param $permissionName * @return bool|\Illuminate\Http\RedirectResponse */ protected function checkPermission($permissionName) { if (!$this->currentUser || !$this->currentUser->can($permissionName)) { Session::flash('error', trans('errors.permission')); throw new HttpResponseException( redirect('/') ); } return true; } protected function checkPermissionOr($permissionName, $callback) { $callbackResult = $callback(); if ($callbackResult === false) $this->checkPermission($permissionName); return true; } }