當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Server::handleTokenRequest方法代碼示例

本文整理匯總了PHP中OAuth2\Server::handleTokenRequest方法的典型用法代碼示例。如果您正苦於以下問題:PHP Server::handleTokenRequest方法的具體用法?PHP Server::handleTokenRequest怎麽用?PHP Server::handleTokenRequest使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在OAuth2\Server的用法示例。


在下文中一共展示了Server::handleTokenRequest方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: token

 public function token()
 {
     $request = Request::createFromGlobals();
     // Handle a request for an OAuth2.0 Access Token and send the response to the client
     $tr = $this->server->handleTokenRequest($request);
     $tr->send();
 }
開發者ID:paliari,項目名稱:oauth2-server-facade,代碼行數:7,代碼來源:Oauth2Facade.php

示例2: handleTokenRequest

 public function handleTokenRequest(HttpRequest $httpRequest, HttpResponse $httpResponse)
 {
     $oauthRequest = $this->buildRequest($httpRequest);
     $oauthResponse = $this->server->handleTokenRequest($oauthRequest);
     $format = $this->determineFormat($httpRequest);
     return $this->buildResponse($format, $httpResponse, $oauthResponse);
 }
開發者ID:zource,項目名稱:zource,代碼行數:7,代碼來源:OAuth.php

示例3: handleTokenRequest

 public function handleTokenRequest(\OAuth2\RequestInterface $request = null, \OAuth2\ResponseInterface $response = null)
 {
     if ($request === null) {
         $request = $this->module->getRequest();
     }
     return parent::handleTokenRequest($request, $response);
 }
開發者ID:hosannahighertech,項目名稱:yii2-oauth2-server,代碼行數:7,代碼來源:Server.php

示例4: providerAction

 public function providerAction()
 {
     $services = $this->getServiceLocator()->get('ServiceManager');
     $config = $services->get('Configuration');
     // Make sure the provider is enabled, else 404
     $provider = $this->params('provider');
     if (!in_array(strtolower($provider), $this->getEnabledProviders($config))) {
         return $this->notFoundAction();
     }
     try {
         // try to authenticate with the selected provider
         $adapter = $this->hybrid->authenticate($provider);
         // then grab the user profile
         $user_profile = $adapter->getUserProfile();
         // then grab the user profile
         $access_token = $adapter->getAccessToken();
     } catch (Exception $e) {
         echo "Error: please try again!";
         echo "Original error message: " . $e->getMessage();
     }
     $pdo = $services->get('ZF\\OAuth2\\Adapter\\PdoAdapter');
     $user = $pdo->getUser($user_profile->displayName);
     if (!$user) {
         $pdo->setUser($user_profile->displayName, $this->generatePassword(), $user_profile->firstName, $user_profile->lastName);
         $pdo->setUserProvider($provider, $user_profile->identifier, $user_profile->displayName);
     } else {
         $pdo->setUserProvider($provider, $user_profile->identifier, $user_profile->displayName);
         $pdo->setUserProviderAccessToken($access_token['access_token'], $provider, $user_profile->identifier, $user_profile->displayName);
     }
     //from here on it is oauth time
     if (!isset($config['zf-oauth2']['storage']) || empty($config['zf-oauth2']['storage'])) {
         throw new Exception\RuntimeException('The storage configuration [\'zf-oauth2\'][\'storage\'] for OAuth2 is missing');
     }
     $oauth2request = $this->getOAuth2Request($user_profile->displayName, $provider, $user_profile->identifier, $access_token['access_token']);
     $response = $this->server->handleTokenRequest($oauth2request);
     if ($response->isClientError()) {
         $parameters = $response->getParameters();
         $errorUri = isset($parameters['error_uri']) ? $parameters['error_uri'] : null;
         return new ApiProblemResponse(new ApiProblem($response->getStatusCode(), $parameters['error_description'], $errorUri, $parameters['error']));
     }
     //Get Access token from OAuth response
     $parameters = $response->getParameters();
     $access_token = $parameters['access_token'];
     return $this->redirect()->toUrl($config['social-oauth2']['redirect_endpoint'] . '/' . $user_profile->displayName . '?access_token=' . $access_token);
 }
開發者ID:hounddog,項目名稱:hd-social-oauth2,代碼行數:45,代碼來源:AuthController.php

示例5: getOAuth2Token

 /**
  * This is the client authorize endpoint.
  * Requires a route like so:
  * {
  *      "url":			"/api/authorize",
  *      "controller":	"<NameOfYourController>",
  *      "action":		"getOAuth2Token"
  * }
  * 
  * Then the client would post to http(s)://<yourdomain.com>/api/authorize/ 
  * with data appropriate for the grant type to get an access_token for use 
  * in subsequent calls (defined in your controller).
  * 
  * @see initOAth2
  * @documen nodoc
  */
 public function getOAuth2Token()
 {
     if ($this->oauthServer === null) {
         $this->respondError("OAuth2 is not enabled for this web service.");
     } else {
         // Respond with a new token
         $this->oauthServer->handleTokenRequest(\OAuth2\Request::createFromGlobals())->send();
     }
 }
開發者ID:jimgitsit,項目名稱:php-gozer,代碼行數:25,代碼來源:CoreAPI.php

示例6: tokenAction

 /**
  * Token Action (/oauth)
  */
 public function tokenAction()
 {
     $request = $this->getRequest();
     if (!$request instanceof HttpRequest) {
         // not an HTTP request; nothing left to do
         return;
     }
     if ($request->isOptions()) {
         // OPTIONS request.
         // This is most likely a CORS attempt; as such, pass the response on.
         return $this->getResponse();
     }
     $oauth2request = $this->getOAuth2Request();
     $response = $this->server->handleTokenRequest($oauth2request);
     if ($response->isClientError()) {
         $parameters = $response->getParameters();
         $errorUri = isset($parameters['error_uri']) ? $parameters['error_uri'] : null;
         return new ApiProblemResponse(new ApiProblem($response->getStatusCode(), $parameters['error_description'], $errorUri, $parameters['error']));
     }
     return $this->setHttpResponse($response);
 }
開發者ID:alapini,項目名稱:apigility-3hr-tutorial,代碼行數:24,代碼來源:AuthController.php

示例7: create

 /**
  * This method inspects the request and routes the data
  * to the correct method
  *
  * @return void
  */
 public function create($data)
 {
     $usersTable = $this->getUsersTable();
     $user = $usersTable->getByUsername($data['username']);
     $bcrypt = new Bcrypt();
     if (!empty($user) && $bcrypt->verify($data['password'], $user->password)) {
         $storage = new Pdo($usersTable->adapter->getDriver()->getConnection()->getConnectionParameters());
         $server = new Server($storage);
         $server->addGrantType(new ClientCredentials($storage));
         $response = $server->handleTokenRequest(Request::createFromGlobals());
         if (!$response->isSuccessful()) {
             $result = new JsonModel(array('result' => false, 'errors' => 'Invalid oauth'));
         }
         return new JsonModel($response->getParameters());
     } else {
         $result = new JsonModel(array('result' => false, 'errors' => 'Invalid Username or password'));
     }
     return $result;
 }
開發者ID:CPDeutschland,項目名稱:zf2-api-client,代碼行數:25,代碼來源:LoginController.php

示例8: token

 /**
  * Handle an OAuth token request
  *
  * (Implements the "Resource Owner Password Credentials" grant type
  * or Part 3 of the "Authorization Code" grant type)
  *
  * Note: Expects input as POST variables, not JSON request body
  *
  * @link http://tools.ietf.org/html/rfc6749#section-4.3.2 Access Token Request
  * @param  Request $request
  * @return Response
  */
 public function token(Request $request)
 {
     $bridgeResponse = new BridgeResponse();
     $oauthRequest = OAuthRequest::createFromRequest($request);
     $response = $this->server->handleTokenRequest($oauthRequest, $bridgeResponse);
     if ($response->isOk()) {
         $user = $this->userService->findById($response->getParameter('user_id'));
         if (!$user) {
             return $this->createInvalidCredentialResponse();
         }
         if (!$user->getEnabled()) {
             return $this->createInvalidCredentialResponse();
         }
         // If enabled in config, check that user is verified
         if ($this->requireVerification && !$user->getVerified()) {
             return $this->createSimpleResponse(422, 'Unverified user');
         }
         $userId = $response->getParameter('user_id');
         $this->setLastLogin($userId);
         $this->session->set('user', $userId);
     }
     return $response;
 }
開發者ID:bodetree,項目名稱:synapse-base,代碼行數:35,代碼來源:OAuthController.php

示例9: testCustomClientAssertionType

 public function testCustomClientAssertionType()
 {
     $request = TestRequest::createPost(array('grant_type' => 'authorization_code', 'client_id' => 'Test Client ID', 'code' => 'testcode'));
     // verify the mock clientAssertionType was called as expected
     $clientAssertionType = $this->getMock('OAuth2\\ClientAssertionType\\ClientAssertionTypeInterface', array('validateRequest', 'getClientId'));
     $clientAssertionType->expects($this->once())->method('validateRequest')->will($this->returnValue(true));
     $clientAssertionType->expects($this->once())->method('getClientId')->will($this->returnValue('Test Client ID'));
     // create mock storage
     $storage = Bootstrap::getInstance()->getMemoryStorage();
     $server = new Server(array($storage), array(), array(), array(), null, null, $clientAssertionType);
     $server->handleTokenRequest($request, $response = new Response());
 }
開發者ID:huangzhwork,項目名稱:oauth2-server-php,代碼行數:12,代碼來源:ServerTest.php

示例10: testCanReceiveAccessTokenUsingPasswordGrantTypeWithoutClientSecret

 public function testCanReceiveAccessTokenUsingPasswordGrantTypeWithoutClientSecret()
 {
     // add the test parameters in memory
     $storage = Bootstrap::getInstance()->getMemoryStorage();
     $server = new Server($storage);
     $server->addGrantType(new UserCredentials($storage));
     $request = TestRequest::createPost(array('grant_type' => 'password', 'client_id' => 'Test Client ID For Password Grant', 'username' => 'johndoe', 'password' => 'password'));
     $server->handleTokenRequest($request, $response = new Response());
     $this->assertTrue($response instanceof Response);
     $this->assertEquals(200, $response->getStatusCode(), var_export($response, 1));
     $this->assertNull($response->getParameter('error'));
     $this->assertNull($response->getParameter('error_description'));
     $this->assertNotNull($response->getParameter('access_token'));
     $this->assertNotNull($response->getParameter('expires_in'));
     $this->assertNotNull($response->getParameter('token_type'));
 }
開發者ID:Sorekk,項目名稱:cvillecouncilus,代碼行數:16,代碼來源:TokenControllerTest.php

示例11: testEnforceScope

 public function testEnforceScope()
 {
     $storage = Bootstrap::getInstance()->getMemoryStorage();
     $server = new Server($storage);
     $server->addGrantType(new ClientCredentials($storage));
     $scope = new Scope(array('default_scope' => false, 'supported_scopes' => array('testscope')));
     $server->setScopeUtil($scope);
     $request = TestRequest::createPost(array('grant_type' => 'client_credentials', 'client_id' => 'Test Client ID', 'client_secret' => 'TestSecret'));
     $response = $server->handleTokenRequest($request);
     $this->assertEquals($response->getStatusCode(), 400);
     $this->assertEquals($response->getParameter('error'), 'invalid_scope');
     $this->assertEquals($response->getParameter('error_description'), 'This application requires you specify a scope parameter');
 }
開發者ID:emildev35,項目名稱:processmaker,代碼行數:13,代碼來源:TokenControllerTest.php

示例12: postToken

 /**
  * Handle an OAuth2 Token request.
  * https://github.com/bshaffer/oauth2-demo-php/blob/master/src/OAuth2Demo/Server/Controllers/Token.php
  *
  * @param HttpFoundation\Request $request
  * @return \OAuth2\Response|\OAuth2\ResponseInterface
  */
 public function postToken(HttpFoundation\Request $request)
 {
     $this->log->addDebug(print_r($request, true), ['namespace' => 'HackTheDinos\\Controllers\\OAuth', 'method' => 'postToken', 'type' => 'request']);
     //Make sure to pass in the HttpFoundationBridge\Response otherwise you'll get back 200s instead of 400s
     return $this->server->handleTokenRequest(HttpFoundationBridge\Request::createFromRequest($request), new HttpFoundationBridge\Response());
 }
開發者ID:HackTheDinos,項目名稱:tinder-for-fossils-backend,代碼行數:13,代碼來源:OAuth2.php

示例13: __invoke

 /**
  * Invoke this route callback.
  *
  * @param ServerRequestInterface $request   Represents the current HTTP request.
  * @param ResponseInterface      $response  Represents the current HTTP response.
  * @param array                  $arguments Values for the current route’s named placeholders.
  *
  * @return RequestInterface
  */
 public function __invoke(ServerRequestInterface $request, ResponseInterface $response, array $arguments = [])
 {
     return ResponseBridge::fromOAuth2($this->server->handleTokenRequest(RequestBridge::toOAuth2($request)));
 }
開發者ID:chadicus,項目名稱:slim-oauth2-routes,代碼行數:13,代碼來源:Token.php

示例14: __invoke

 public function __invoke()
 {
     $request = MessageBridge::newOAuth2Request($this->slim->request());
     MessageBridge::mapResponse($this->server->handleTokenRequest($request), $this->slim->response());
 }
開發者ID:tularamaurya,項目名稱:slim-oauth2-routes,代碼行數:5,代碼來源:Token.php

示例15: postGrant

 /**
  * Stage 3: Client directly calls this api to exchange access token
  *
  * It can then use this access token to make calls to protected api
  *
  * @format JsonFormat,UploadFormat
  */
 public function postGrant()
 {
     static::$server->handleTokenRequest(static::$request)->send();
     exit;
 }
開發者ID:raven7,項目名稱:Restler,代碼行數:12,代碼來源:Server.php


注:本文中的OAuth2\Server::handleTokenRequest方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。