diff options
Diffstat (limited to 'app/Core/Security/Token.php')
| -rw-r--r-- | app/Core/Security/Token.php | 61 | 
1 files changed, 61 insertions, 0 deletions
| diff --git a/app/Core/Security/Token.php b/app/Core/Security/Token.php new file mode 100644 index 00000000..cbd784a8 --- /dev/null +++ b/app/Core/Security/Token.php @@ -0,0 +1,61 @@ +<?php + +namespace Kanboard\Core\Security; + +use Kanboard\Core\Base; + +/** + * Token Handler + * + * @package  security + * @author   Frederic Guillot + */ +class Token extends Base +{ +    /** +     * Generate a random token with different methods: openssl or /dev/urandom or fallback to uniqid() +     * +     * @static +     * @access public +     * @return string  Random token +     */ +    public static function getToken() +    { +        return bin2hex(random_bytes(30)); +    } + +    /** +     * Generate and store a CSRF token in the current session +     * +     * @access public +     * @return string  Random token +     */ +    public function getCSRFToken() +    { +        if (! isset($this->sessionStorage->csrf)) { +            $this->sessionStorage->csrf = array(); +        } + +        $nonce = self::getToken(); +        $this->sessionStorage->csrf[$nonce] = true; + +        return $nonce; +    } + +    /** +     * Check if the token exists for the current session (a token can be used only one time) +     * +     * @access public +     * @param  string   $token   CSRF token +     * @return bool +     */ +    public function validateCSRFToken($token) +    { +        if (isset($this->sessionStorage->csrf[$token])) { +            unset($this->sessionStorage->csrf[$token]); +            return true; +        } + +        return false; +    } +} | 
