Browse Source

added new crypter class to replace static crypt methods.

Taylor Otwell 13 years ago
parent
commit
4c4ffa1d40
4 changed files with 60 additions and 18 deletions
  1. 1 1
      application/config/aliases.php
  2. 2 1
      changelog.md
  3. 38 13
      system/crypter.php
  4. 19 3
      system/session/cookie.php

+ 1 - 1
application/config/aliases.php

@@ -24,7 +24,7 @@ return array(
 	'Cache' => 'System\\Cache',
 	'Cache' => 'System\\Cache',
 	'Config' => 'System\\Config',
 	'Config' => 'System\\Config',
 	'Cookie' => 'System\\Cookie',
 	'Cookie' => 'System\\Cookie',
-	'Crypt' => 'System\\Crypt',
+	'Crypter' => 'System\\Crypter',
 	'DB' => 'System\\DB',
 	'DB' => 'System\\DB',
 	'Eloquent' => 'System\\DB\\Eloquent\\Model',
 	'Eloquent' => 'System\\DB\\Eloquent\\Model',
 	'File' => 'System\\File',
 	'File' => 'System\\File',

+ 2 - 1
changelog.md

@@ -3,4 +3,5 @@
 ## Version 1.6.0
 ## Version 1.6.0
 
 
 - Moved **system/db/manager.php** to **system/db.php**. Updated alias appropriately.
 - Moved **system/db/manager.php** to **system/db.php**. Updated alias appropriately.
-- Unspecified optional parameters will be removed from URLs generated using route names.
+- Unspecified optional parameters will be removed from URLs generated using route names.
+- Fixed bug in Config::set that prevented it from digging deep into arrays.

+ 38 - 13
system/crypt.php → system/crypter.php

@@ -1,20 +1,45 @@
 <?php namespace System;
 <?php namespace System;
 
 
-class Crypt {
+class Crypter {
 
 
 	/**
 	/**
 	 * The encryption cipher.
 	 * The encryption cipher.
 	 *
 	 *
 	 * @var string
 	 * @var string
 	 */
 	 */
-	public static $cipher = 'rijndael-256';
+	public $cipher;
 
 
 	/**
 	/**
 	 * The encryption mode.
 	 * The encryption mode.
 	 *
 	 *
 	 * @var string
 	 * @var string
 	 */
 	 */
-	public static $mode = 'cbc';
+	public $mode;
+
+	/**
+	 * Create a new Crypter instance.
+	 *
+	 * @param  string  $cipher
+	 * @param  string  $mode
+	 * @return void
+	 */
+	public function __construct($cipher = 'rijndael-256', $mode = 'cbc')
+	{
+		$this->cipher = $cipher;
+		$this->mode = $mode;
+	}
+
+	/**
+	 * Create a new Crypter instance.
+	 *
+	 * @param  string  $cipher
+	 * @param  string  $mode
+	 * @return Crypt
+	 */
+	public static function make($cipher = 'rijndael-256', $mode = 'cbc')
+	{
+		return new static($cipher, $mode);
+	}
 
 
 	/**
 	/**
 	 * Encrypt a value using the MCrypt library.
 	 * Encrypt a value using the MCrypt library.
@@ -22,11 +47,11 @@ class Crypt {
 	 * @param  string  $value
 	 * @param  string  $value
 	 * @return string
 	 * @return string
 	 */
 	 */
-	public static function encrypt($value)
+	public function encrypt($value)
 	{
 	{
-		$iv = mcrypt_create_iv(static::iv_size(), static::randomizer());
+		$iv = mcrypt_create_iv($this->iv_size(), $this->randomizer());
 
 
-		return base64_encode($iv.mcrypt_encrypt(static::$cipher, static::key(), $value, static::$mode, $iv));
+		return base64_encode($iv.mcrypt_encrypt($this->cipher, $this->key(), $value, $this->mode, $iv));
 	}
 	}
 
 
 	/**
 	/**
@@ -34,7 +59,7 @@ class Crypt {
 	 *
 	 *
 	 * @return int
 	 * @return int
 	 */
 	 */
-	protected static function randomizer()
+	protected function randomizer()
 	{
 	{
 		if (defined('MCRYPT_DEV_URANDOM'))
 		if (defined('MCRYPT_DEV_URANDOM'))
 		{
 		{
@@ -54,16 +79,16 @@ class Crypt {
 	 * @param  string  $value
 	 * @param  string  $value
 	 * @return string
 	 * @return string
 	 */
 	 */
-	public static function decrypt($value)
+	public function decrypt($value)
 	{
 	{
 		if ( ! is_string($value = base64_decode($value, true)))
 		if ( ! is_string($value = base64_decode($value, true)))
 		{
 		{
 			throw new \Exception('Decryption error. Input value is not valid base64 data.');
 			throw new \Exception('Decryption error. Input value is not valid base64 data.');
 		}
 		}
 
 
-		list($iv, $value) = array(substr($value, 0, static::iv_size()), substr($value, static::iv_size()));
+		list($iv, $value) = array(substr($value, 0, $this->iv_size()), substr($value, $this->iv_size()));
 
 
-		return rtrim(mcrypt_decrypt(static::$cipher, static::key(), $value, static::$mode, $iv), "\0");
+		return rtrim(mcrypt_decrypt($this->cipher, $this->key(), $value, $this->mode, $iv), "\0");
 	}
 	}
 
 
 	/**
 	/**
@@ -71,7 +96,7 @@ class Crypt {
 	 *
 	 *
 	 * @return string
 	 * @return string
 	 */
 	 */
-	private static function key()
+	private function key()
 	{
 	{
 		if ( ! is_null($key = Config::get('application.key')) and $key !== '') return $key;
 		if ( ! is_null($key = Config::get('application.key')) and $key !== '') return $key;
 
 
@@ -85,9 +110,9 @@ class Crypt {
 	 *
 	 *
 	 * @return int
 	 * @return int
 	 */
 	 */
-	private static function iv_size()
+	private function iv_size()
 	{
 	{
-		return mcrypt_get_iv_size(static::$cipher, static::$mode);
+		return mcrypt_get_iv_size($this->cipher, $this->mode);
 	}
 	}
 
 
 }
 }

+ 19 - 3
system/session/cookie.php

@@ -1,12 +1,26 @@
 <?php namespace System\Session;
 <?php namespace System\Session;
 
 
-use System\Crypt;
 use System\Config;
 use System\Config;
+use System\Crypter;
 
 
 class Cookie implements Driver {
 class Cookie implements Driver {
 
 
+	/**
+	 * The Crypter instance.
+	 *
+	 * @var Crypter
+	 */
+	private $crypter;
+
+	/**
+	 * Create a new Cookie session driver instance.
+	 *
+	 * @return void
+	 */
 	public function __construct()
 	public function __construct()
 	{
 	{
+		$this->crypter = new Crypter;
+
 		if (Config::get('application.key') == '')
 		if (Config::get('application.key') == '')
 		{
 		{
 			throw new \Exception("You must set an application key before using the Cookie session driver.");
 			throw new \Exception("You must set an application key before using the Cookie session driver.");
@@ -23,7 +37,7 @@ class Cookie implements Driver {
 	{
 	{
 		if (\System\Cookie::has('session_payload'))
 		if (\System\Cookie::has('session_payload'))
 		{
 		{
-			return unserialize(Crypt::decrypt(\System\Cookie::get('session_payload')));
+			return unserialize($this->crypter->decrypt(\System\Cookie::get('session_payload')));
 		}
 		}
 	}
 	}
 
 
@@ -39,7 +53,9 @@ class Cookie implements Driver {
 		{
 		{
 			extract(Config::get('session'));
 			extract(Config::get('session'));
 
 
-			\System\Cookie::put('session_payload', Crypt::encrypt(serialize($session)), $lifetime, $path, $domain, $https, $http_only);
+			$payload = $this->crypter->encrypt(serialize($session));
+
+			\System\Cookie::put('session_payload', $payload, $lifetime, $path, $domain, $https, $http_only);
 		}
 		}
 	}
 	}