$response = $request->send(); if (!$response->getIsOk()) { $statusCode = (int)$response->getStatusCode(); if ($statusCode >= 400 && $statusCode < 500) { $exceptionClass = 'yii\\authclient\\ClientErrorResponseException'; } else { $exceptionClass = 'yii\\authclient\\InvalidResponseException'; } throw new $exceptionClass( $response, 'Request failed with code: ' . $statusCode . ', message: ' . $response->getContent(), $statusCode ); } if (stripos($response->headers->get('content-type', ''), 'application/jwt') !== false) { return $response->getContent(); } else {
->setMethod($this->requestTokenMethod) ->setUrl($this->requestTokenUrl) ->setData(array_merge($defaultParams, $params)); $this->signRequest($request); $response = $this->sendRequest($request); $token = $this->createToken([ 'params' => $response ]); $this->setState('requestToken', $token);
// Upgrade to access token. $client->fetchAccessToken($oauthToken); return $this->authSuccess($client); } // Get request token. $requestToken = $client->fetchRequestToken(); // Get authorization URL. $url = $client->buildAuthUrl($requestToken, $authUrlParams); // Redirect to authorization URL. return Yii::$app->getResponse()->redirect($url); }
*/ protected function auth($client, $authUrlParams = []) { if ($client instanceof OAuth2) { return $this->authOAuth2($client, $authUrlParams); } elseif ($client instanceof OAuth1) { return $this->authOAuth1($client, $authUrlParams); } elseif ($client instanceof OpenId) { return $this->authOpenId($client); } throw new NotSupportedException('Provider "' . get_class($client) . '" is not supported.'); }
Yii::$app->session->set('loginRememberMe', $rememberMe); if ($client instanceof StandaloneAuthClient) { return $client->authAction($this); } return parent::auth($client, $authUrlParams); } /** * @inheritdoc */ public function authSuccess($client)
$collection = Yii::$app->get($this->clientCollection); if (!$collection->hasClient($clientId)) { throw new NotFoundHttpException("Unknown auth client '{$clientId}'"); } $client = $collection->getClient($clientId); return $this->auth($client); } throw new NotFoundHttpException(); } /**
$args = $this->controller->bindActionParams($this, $params); Yii::debug('Running action: ' . get_class($this) . '::run(), invoked by ' . get_class($this->controller), __METHOD__); if (Yii::$app->requestedParams === null) { Yii::$app->requestedParams = $args; } if ($this->beforeRun()) { $result = call_user_func_array([$this, 'run'], $args); $this->afterRun(); return $result; } return null;
} $result = null; if ($runAction && $this->beforeAction($action)) { // run the action $result = $action->runWithParams($params); $result = $this->afterAction($action, $result); // call afterAction on modules foreach ($modules as $module) { /* @var $module Module */
$parts = $this->createController($route); if (is_array($parts)) { /* @var $controller Controller */ list($controller, $actionID) = $parts; $oldController = Yii::$app->controller; Yii::$app->controller = $controller; $result = $controller->runAction($actionID, $params); if ($oldController !== null) { Yii::$app->controller = $oldController; } return $result; }
$params = $this->catchAll; unset($params[0]); } try { Yii::debug("Route requested: '$route'", __METHOD__); $this->requestedRoute = $route; $result = $this->runAction($route, $params); if ($result instanceof Response) { return $result; } $response = $this->getResponse(); if ($result !== null) {
{ try { $this->state = self::STATE_BEFORE_REQUEST; $this->trigger(self::EVENT_BEFORE_REQUEST); $this->state = self::STATE_HANDLING_REQUEST; $response = $this->handleRequest($this->getRequest()); $this->state = self::STATE_AFTER_REQUEST; $this->trigger(self::EVENT_AFTER_REQUEST); $this->state = self::STATE_SENDING_RESPONSE; $response->send();
require(__DIR__ . '/protected/humhub/config/web.php'), (is_readable(__DIR__ . '/protected/config/dynamic.php')) ? require(__DIR__ . '/protected/config/dynamic.php') : [], require(__DIR__ . '/protected/config/common.php'), require(__DIR__ . '/protected/config/web.php') ); (new humhub\components\Application($config))->run();
$_GET = [ 'r' => 'user/auth/external', 'authclient' => 'twitter', ]; $_SESSION = [ '__flash' => [], 'security-script-src-nonce' => 'WvaxKAn/kEj6JB0jb5IJfpa/', 'loginRememberMe' => false, 'humhubContrib\\auth\\twitter\\authclient\\TwitterAuth_twitter_token' => null, ];