| <?php |
|
|
| namespace Kanboard\Core\Security; |
|
|
| use Kanboard\Core\Base; |
|
|
| |
| |
| |
| |
| |
| |
| class Token extends Base |
| { |
| protected static $KEY_LENGTH = 32; |
| protected static $NONCE_LENGTH = 16; |
| protected static $HMAC_ALGO = 'sha256'; |
| protected static $HMAC_LENGTH = 16; |
|
|
| |
| |
| |
| |
| |
| |
| |
| public static function getToken($length = 30) |
| { |
| return bin2hex(random_bytes($length)); |
| } |
|
|
| |
| |
| |
| |
| |
| |
| public function getCSRFToken() |
| { |
| return $this->createSessionToken('csrf'); |
| } |
|
|
| |
| |
| |
| |
| |
| |
| public function getReusableCSRFToken() |
| { |
| return $this->createSessionToken('pcsrf'); |
| } |
|
|
| |
| |
| |
| |
| |
| |
| |
| public function validateCSRFToken($token) |
| { |
| return $this->validateSessionToken('csrf', $token); |
| } |
|
|
| |
| |
| |
| |
| |
| |
| |
| public function validateReusableCSRFToken($token) |
| { |
| return $this->validateSessionToken('pcsrf', $token); |
| } |
|
|
| |
| |
| |
| |
| |
| |
| |
| protected function createSessionToken($type) |
| { |
| $nonce = self::getToken(self::$NONCE_LENGTH); |
| return $nonce . $this->signSessionToken($type, $nonce); |
| } |
|
|
| |
| |
| |
| |
| |
| |
| |
| |
| protected function validateSessionToken($type, $token) |
| { |
| if (!is_string($token)) { |
| return false; |
| } |
|
|
| if (strlen($token) != (self::$NONCE_LENGTH + self::$HMAC_LENGTH) * 2) { |
| return false; |
| } |
|
|
| $nonce = substr($token, 0, self::$NONCE_LENGTH * 2); |
| $hmac = substr($token, self::$NONCE_LENGTH * 2, self::$HMAC_LENGTH * 2); |
|
|
| return hash_equals($this->signSessionToken($type, $nonce), $hmac); |
| } |
|
|
| |
| |
| |
| |
| |
| |
| |
| |
| protected function signSessionToken($type, $nonce) |
| { |
| if (!session_exists($type . '_key')) { |
| session_set($type . '_key', self::getToken(self::$KEY_LENGTH)); |
| } |
|
|
| $data = $nonce . '-' . session_id(); |
| $key = session_get($type . '_key'); |
| $hmac = hash_hmac(self::$HMAC_ALGO, $data, $key, true); |
|
|
| return bin2hex(substr($hmac, 0, self::$HMAC_LENGTH)); |
| } |
| } |
|
|