public function __invoke($req, $res, $next) { // setcookie('authorization', '', 1, '/', '', false, true); $authCookie = Container::get('cookie')->get('authorization'); if ($jwt = $this->get_cookie_data($authCookie)) { // If JWT given in cookie is valid, load user infos $user = AuthModel::load_user($jwt->data->userId); $user->is_guest = false; $user->is_admmod = $user->g_id == '1' || $user->g_moderator == '1'; // Refresh cookie to avoid re-logging between idle $expire = $jwt->exp > time() + 1800 ? time() + 1209600 : time() + 1800; $jwt = AuthModel::generate_jwt($user, $expire); AuthModel::feather_setcookie('Bearer ' . $jwt, $expire); } else { $user = AuthModel::load_user(1); $user->is_guest = true; $user->is_admmod = false; } // Add user infos in request attributes and view $req = $req->withAttribute('user', $user); View::setPageInfo(['user' => $user]); return $next($req, $res); }