Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
| Total | |
0.00% |
0 / 1 |
|
85.71% |
6 / 7 |
CRAP | |
95.00% |
19 / 20 |
| LightManager | |
0.00% |
0 / 1 |
|
85.71% |
6 / 7 |
12 | |
95.00% |
19 / 20 |
| __construct | |
0.00% |
0 / 1 |
2.06 | |
75.00% |
3 / 4 |
|||
| createToken | |
100.00% |
1 / 1 |
1 | |
100.00% |
3 / 3 |
|||
| getToken | |
100.00% |
1 / 1 |
2 | |
100.00% |
3 / 3 |
|||
| 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; | |
| } | |
| } |