2012-11-09 23:18:50 +11:00
|
|
|
<?php defined('SYSPATH') OR die('No direct script access.');
|
2010-08-21 14:43:03 +10:00
|
|
|
/**
|
|
|
|
* Security helper class.
|
|
|
|
*
|
|
|
|
* @package Kohana
|
|
|
|
* @category Security
|
|
|
|
* @author Kohana Team
|
2012-11-09 23:18:50 +11:00
|
|
|
* @copyright (c) 2007-2012 Kohana Team
|
2011-05-13 16:00:25 +10:00
|
|
|
* @license http://kohanaframework.org/license
|
2010-08-21 14:43:03 +10:00
|
|
|
*/
|
|
|
|
class Kohana_Security {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var string key name used for token storage
|
|
|
|
*/
|
|
|
|
public static $token_name = 'security_token';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Generate and store a unique token which can be used to help prevent
|
|
|
|
* [CSRF](http://wikipedia.org/wiki/Cross_Site_Request_Forgery) attacks.
|
|
|
|
*
|
|
|
|
* $token = Security::token();
|
|
|
|
*
|
|
|
|
* You can insert this token into your forms as a hidden field:
|
|
|
|
*
|
|
|
|
* echo Form::hidden('csrf', Security::token());
|
|
|
|
*
|
2011-05-13 16:00:25 +10:00
|
|
|
* And then check it when using [Validation]:
|
2010-08-21 14:43:03 +10:00
|
|
|
*
|
|
|
|
* $array->rules('csrf', array(
|
|
|
|
* 'not_empty' => NULL,
|
|
|
|
* 'Security::check' => NULL,
|
|
|
|
* ));
|
|
|
|
*
|
|
|
|
* This provides a basic, but effective, method of preventing CSRF attacks.
|
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @param boolean $new force a new token to be generated?
|
2010-08-21 14:43:03 +10:00
|
|
|
* @return string
|
|
|
|
* @uses Session::instance
|
|
|
|
*/
|
|
|
|
public static function token($new = FALSE)
|
|
|
|
{
|
|
|
|
$session = Session::instance();
|
|
|
|
|
|
|
|
// Get the current token
|
|
|
|
$token = $session->get(Security::$token_name);
|
|
|
|
|
|
|
|
if ($new === TRUE OR ! $token)
|
|
|
|
{
|
|
|
|
// Generate a new unique token
|
2011-05-13 16:00:25 +10:00
|
|
|
$token = sha1(uniqid(NULL, TRUE));
|
2010-08-21 14:43:03 +10:00
|
|
|
|
|
|
|
// Store the new token
|
|
|
|
$session->set(Security::$token_name, $token);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $token;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check that the given token matches the currently stored security token.
|
|
|
|
*
|
|
|
|
* if (Security::check($token))
|
|
|
|
* {
|
|
|
|
* // Pass
|
|
|
|
* }
|
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @param string $token token to check
|
2010-08-21 14:43:03 +10:00
|
|
|
* @return boolean
|
|
|
|
* @uses Security::token
|
|
|
|
*/
|
|
|
|
public static function check($token)
|
|
|
|
{
|
|
|
|
return Security::token() === $token;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove image tags from a string.
|
|
|
|
*
|
|
|
|
* $str = Security::strip_image_tags($str);
|
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @param string $str string to sanitize
|
2010-08-21 14:43:03 +10:00
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function strip_image_tags($str)
|
|
|
|
{
|
|
|
|
return preg_replace('#<img\s.*?(?:src\s*=\s*["\']?([^"\'<>\s]*)["\']?[^>]*)?>#is', '$1', $str);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Encodes PHP tags in a string.
|
|
|
|
*
|
|
|
|
* $str = Security::encode_php_tags($str);
|
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @param string $str string to sanitize
|
2010-08-21 14:43:03 +10:00
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function encode_php_tags($str)
|
|
|
|
{
|
|
|
|
return str_replace(array('<?', '?>'), array('<?', '?>'), $str);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // End security
|