コード例 #1
0
 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);
 }