Code Coverage  | 
     ||||||||||
Classes and Traits  | 
      Functions and Methods  | 
      Lines  | 
     ||||||||
| Total |         | 
      0.00%  | 
      0 / 1  | 
              | 
      85.71%  | 
      6 / 7  | 
      CRAP |         | 
      90.91%  | 
      20 / 22  | 
     
| LightManager |         | 
      0.00%  | 
      0 / 1  | 
              | 
      85.71%  | 
      6 / 7  | 
      12.11 |         | 
      90.91%  | 
      20 / 22  | 
     
| __construct |         | 
      0.00%  | 
      0 / 1  | 
      2.26 |         | 
      60.00%  | 
      3 / 5  | 
     |||
| createToken |         | 
      100.00%  | 
      1 / 1  | 
      1 |         | 
      100.00%  | 
      3 / 3  | 
     |||
| getToken |         | 
      100.00%  | 
      1 / 1  | 
      2 |         | 
      100.00%  | 
      4 / 4  | 
     |||
| checkToken |         | 
      100.00%  | 
      1 / 1  | 
      3 |         | 
      100.00%  | 
      3 / 3  | 
     |||
| hasToken |         | 
      100.00%  | 
      1 / 1  | 
      2 |         | 
      100.00%  | 
      3 / 3  | 
     |||
| removeToken |         | 
      100.00%  | 
      1 / 1  | 
      1 |         | 
      100.00%  | 
      2 / 2  | 
     |||
| setSessionKey |         | 
      100.00%  | 
      1 / 1  | 
      1 |         | 
      100.00%  | 
      2 / 2  | 
     |||
| <?php | |
| namespace Puyo\Security\Csrf; | |
| /** | |
| * 簡易的なCSRFマネージャ(非推奨) | |
| * | |
| * これよりも symfony/security 等を使ったほうがよい。 | |
| * 元のアプリが $_SESSION を直接扱っていたり、 | |
| * その他の理由で symfony/security が使えない場合のための簡易的なもの。 | |
| * | |
| * スーパグローバルの $_SESSION を直接扱うことに注意。 | |
| * セッションが開始されている必要がある。 | |
| * | |
| * @deprecated | |
| */ | |
| class LightManager | |
| { | |
| /** | |
| * @var \Puyo\Security\Csrf\Strategy\IStrategy|\Puyo\Security\Csrf\Strategy\SessionId | |
| */ | |
| private $tokenStrategy; | |
| private $sessionKey = '_csrf'; | |
| public function __construct(Strategy\IStrategy $strategy=null) { | |
| if($strategy === null) { | |
| $strategy = new Strategy\SessionId(); | |
| } | |
| $this->tokenStrategy = $strategy; | |
| } | |
| /** | |
| * トークンを作る。 | |
| * | |
| * @return string | |
| */ | |
| public function createToken() { | |
| $token = $this->tokenStrategy->createToken(); | |
| $_SESSION[$this->sessionKey] = $token; | |
| return $token; | |
| } | |
| public function getToken() { | |
| if(!$this->hasToken()) { | |
| $this->createToken(); | |
| } | |
| return $_SESSION[$this->sessionKey]; | |
| } | |
| public function checkToken($token) { | |
| if($this->hasToken() && $token === $_SESSION['_csrf']) { | |
| return true; | |
| } | |
| return false; | |
| } | |
| public function hasToken() { | |
| if(isset($_SESSION[$this->sessionKey])) { | |
| return true; | |
| } | |
| return false; | |
| } | |
| public function removeToken() { | |
| unset($_SESSION[$this->sessionKey]); | |
| } | |
| /** | |
| * トークンの保存先である $_SESSION のkeyを指定する | |
| * | |
| * 複数のトークンを扱う場合に有用。 | |
| * 初期値は '_csrf' | |
| * @param string $sessionKey | |
| */ | |
| public function setSessionKey($sessionKey) { | |
| $this->sessionKey = $sessionKey; | |
| } | |
| } |