mirror of
https://github.com/yiisoft/yii2.git
synced 2026-03-22 23:17:12 +01:00
Refactored auth methods.
This commit is contained in:
52
framework/rest/QueryParamAuth.php
Normal file
52
framework/rest/QueryParamAuth.php
Normal file
@@ -0,0 +1,52 @@
|
||||
<?php
|
||||
/**
|
||||
* @link http://www.yiiframework.com/
|
||||
* @copyright Copyright (c) 2008 Yii Software LLC
|
||||
* @license http://www.yiiframework.com/license/
|
||||
*/
|
||||
|
||||
namespace yii\rest;
|
||||
|
||||
use Yii;
|
||||
use yii\base\Component;
|
||||
use yii\web\UnauthorizedHttpException;
|
||||
|
||||
/**
|
||||
* QueryParamAuth implements the authentication method based on the access token passed through a query parameter.
|
||||
*
|
||||
* @author Qiang Xue <qiang.xue@gmail.com>
|
||||
* @since 2.0
|
||||
*/
|
||||
class QueryParamAuth extends Component implements AuthInterface
|
||||
{
|
||||
/**
|
||||
* @var string the parameter name for passing the access token
|
||||
*/
|
||||
public $tokenParam = 'access-token';
|
||||
|
||||
/**
|
||||
* @inheritdoc
|
||||
*/
|
||||
public function authenticate($user, $request, $response)
|
||||
{
|
||||
$accessToken = $request->get($this->tokenParam);
|
||||
if (is_string($accessToken)) {
|
||||
$identity = $user->loginByAccessToken($accessToken);
|
||||
if ($identity !== null) {
|
||||
return $identity;
|
||||
}
|
||||
}
|
||||
if ($accessToken !== null) {
|
||||
$this->handleFailure($response);
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* @inheritdoc
|
||||
*/
|
||||
public function handleFailure($response)
|
||||
{
|
||||
throw new UnauthorizedHttpException('You are requesting with an invalid access token.');
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user