%PDF-1.5 %���� ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY
Server IP : 49.231.201.246 / Your IP : 216.73.216.149 Web Server : Apache/2.4.18 (Ubuntu) System : Linux 246 4.4.0-210-generic #242-Ubuntu SMP Fri Apr 16 09:57:56 UTC 2021 x86_64 User : root ( 0) PHP Version : 7.0.33-0ubuntu0.16.04.16 Disable Function : exec,passthru,shell_exec,system,proc_open,popen,pcntl_exec MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /proc/11584/task/11584/cwd/html/water/vendor/yiisoft/yii2/filters/auth/ |
Upload File : |
<?php /** * @link http://www.yiiframework.com/ * @copyright Copyright (c) 2008 Yii Software LLC * @license http://www.yiiframework.com/license/ */ namespace yii\filters\auth; /** * HttpHeaderAuth is an action filter that supports HTTP authentication through HTTP Headers. * * You may use HttpHeaderAuth by attaching it as a behavior to a controller or module, like the following: * * ```php * public function behaviors() * { * return [ * 'basicAuth' => [ * 'class' => \yii\filters\auth\HttpHeaderAuth::className(), * ], * ]; * } * ``` * * The default implementation of HttpHeaderAuth uses the [[\yii\web\User::loginByAccessToken()|loginByAccessToken()]] * method of the `user` application component and passes the value of the `X-Api-Key` header. This implementation is used * for authenticating API clients. * * @author Qiang Xue <qiang.xue@gmail.com> * @author Benoît Boure <benoit.boure@gmail.com> * @since 2.0.14 */ class HttpHeaderAuth extends AuthMethod { /** * @var string the HTTP header name */ public $header = 'X-Api-Key'; /** * @var string a pattern to use to extract the HTTP authentication value */ public $pattern; /** * {@inheritdoc} */ public function authenticate($user, $request, $response) { $authHeader = $request->getHeaders()->get($this->header); if ($authHeader !== null) { if ($this->pattern !== null) { if (preg_match($this->pattern, $authHeader, $matches)) { $authHeader = $matches[1]; } else { return null; } } $identity = $user->loginByAccessToken($authHeader, get_class($this)); if ($identity === null) { $this->challenge($response); $this->handleFailure($response); } return $identity; } return null; } }