blob: a46d4f462963d9a35baf7692f2b67199919ab7ed [file] [log] [blame]
Andrey Andreevc5536aa2012-11-01 17:33:58 +02001<?php
Derek Allard2067d1a2008-11-13 22:59:24 +00002/**
3 * CodeIgniter
4 *
Andrey Andreevfe9309d2015-01-09 17:48:58 +02005 * An open source application development framework for PHP
Derek Allard2067d1a2008-11-13 22:59:24 +00006 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +02007 * This content is released under the MIT License (MIT)
Andrey Andreev7c251b32011-12-27 16:37:23 +02008 *
Andrey Andreevfe9309d2015-01-09 17:48:58 +02009 * Copyright (c) 2014 - 2015, British Columbia Institute of Technology
Andrey Andreev7c251b32011-12-27 16:37:23 +020010 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020011 * Permission is hereby granted, free of charge, to any person obtaining a copy
12 * of this software and associated documentation files (the "Software"), to deal
13 * in the Software without restriction, including without limitation the rights
14 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
15 * copies of the Software, and to permit persons to whom the Software is
16 * furnished to do so, subject to the following conditions:
Derek Jonesf4a4bd82011-10-20 12:18:42 -050017 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020018 * The above copyright notice and this permission notice shall be included in
19 * all copies or substantial portions of the Software.
20 *
21 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
22 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
23 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
24 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
25 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
26 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
27 * THE SOFTWARE.
28 *
29 * @package CodeIgniter
30 * @author EllisLab Dev Team
darwinel871754a2014-02-11 17:34:57 +010031 * @copyright Copyright (c) 2008 - 2014, EllisLab, Inc. (http://ellislab.com/)
Andrey Andreevfe9309d2015-01-09 17:48:58 +020032 * @copyright Copyright (c) 2014 - 2015, British Columbia Institute of Technology (http://bcit.ca/)
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020033 * @license http://opensource.org/licenses/MIT MIT License
34 * @link http://codeigniter.com
35 * @since Version 1.0.0
Derek Allard2067d1a2008-11-13 22:59:24 +000036 * @filesource
37 */
Andrey Andreevc5536aa2012-11-01 17:33:58 +020038defined('BASEPATH') OR exit('No direct script access allowed');
Derek Allard2067d1a2008-11-13 22:59:24 +000039
Derek Allard2067d1a2008-11-13 22:59:24 +000040/**
41 * CodeIgniter Encryption Class
42 *
Andrey Andreevfc4db342014-08-27 14:18:19 +030043 * Provides two-way keyed encoding using Mcrypt
Derek Allard2067d1a2008-11-13 22:59:24 +000044 *
45 * @package CodeIgniter
46 * @subpackage Libraries
47 * @category Libraries
Derek Jonesf4a4bd82011-10-20 12:18:42 -050048 * @author EllisLab Dev Team
Derek Allard2067d1a2008-11-13 22:59:24 +000049 * @link http://codeigniter.com/user_guide/libraries/encryption.html
50 */
51class CI_Encrypt {
52
Timothy Warren0688ac92012-04-20 10:25:04 -040053 /**
54 * Reference to the user's encryption key
55 *
56 * @var string
57 */
Andrey Andreev38d0e932012-04-03 19:27:45 +030058 public $encryption_key = '';
Andrey Andreev56454792012-05-17 14:32:19 +030059
Timothy Warren0688ac92012-04-20 10:25:04 -040060 /**
61 * Type of hash operation
Andrey Andreev56454792012-05-17 14:32:19 +030062 *
Timothy Warren0688ac92012-04-20 10:25:04 -040063 * @var string
64 */
Andrey Andreev38d0e932012-04-03 19:27:45 +030065 protected $_hash_type = 'sha1';
Andrey Andreev56454792012-05-17 14:32:19 +030066
Timothy Warren0688ac92012-04-20 10:25:04 -040067 /**
Calvin Tam55bc5052015-07-24 02:27:24 -070068 * Flag for the existence of mcrypt
Timothy Warren0688ac92012-04-20 10:25:04 -040069 *
70 * @var bool
71 */
Andrey Andreev38d0e932012-04-03 19:27:45 +030072 protected $_mcrypt_exists = FALSE;
Andrey Andreev56454792012-05-17 14:32:19 +030073
Timothy Warren0688ac92012-04-20 10:25:04 -040074 /**
75 * Current cipher to be used with mcrypt
76 *
77 * @var string
78 */
Greg Akerd1af1852011-12-25 21:59:30 -060079 protected $_mcrypt_cipher;
Andrey Andreev56454792012-05-17 14:32:19 +030080
Timothy Warren0688ac92012-04-20 10:25:04 -040081 /**
82 * Method for encrypting/decrypting data
83 *
84 * @var int
85 */
Greg Akerd1af1852011-12-25 21:59:30 -060086 protected $_mcrypt_mode;
Derek Allard2067d1a2008-11-13 22:59:24 +000087
Timothy Warren0688ac92012-04-20 10:25:04 -040088 /**
89 * Initialize Encryption class
Andrey Andreev56454792012-05-17 14:32:19 +030090 *
91 * @return void
Timothy Warren0688ac92012-04-20 10:25:04 -040092 */
Greg Akera9263282010-11-10 15:26:43 -060093 public function __construct()
Derek Allard2067d1a2008-11-13 22:59:24 +000094 {
Andrey Andreev6eb77da2014-05-31 21:18:17 +030095 if (($this->_mcrypt_exists = function_exists('mcrypt_encrypt')) === FALSE)
96 {
97 show_error('The Encrypt library requires the Mcrypt extension.');
98 }
99
Andrey Andreev90726b82015-01-20 12:39:22 +0200100 log_message('info', 'Encrypt Class Initialized');
Derek Allard2067d1a2008-11-13 22:59:24 +0000101 }
102
103 // --------------------------------------------------------------------
104
105 /**
106 * Fetch the encryption key
107 *
108 * Returns it as MD5 in order to have an exact-length 128 bit key.
109 * Mcrypt is sensitive to keys that are not the correct length
110 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000111 * @param string
112 * @return string
113 */
Greg Akerd1af1852011-12-25 21:59:30 -0600114 public function get_key($key = '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000115 {
Alex Bilbied261b1e2012-06-02 11:12:16 +0100116 if ($key === '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000117 {
Alex Bilbied261b1e2012-06-02 11:12:16 +0100118 if ($this->encryption_key !== '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000119 {
120 return $this->encryption_key;
121 }
122
Joffrey Jaffeuxba7f50b2012-06-06 01:40:01 +0200123 $key = config_item('encryption_key');
Derek Allard2067d1a2008-11-13 22:59:24 +0000124
Andrey Andreevd444d442014-10-06 00:00:08 +0300125 if ( ! strlen($key))
Derek Allard2067d1a2008-11-13 22:59:24 +0000126 {
127 show_error('In order to use the encryption class requires that you set an encryption key in your config file.');
128 }
129 }
130
131 return md5($key);
132 }
133
134 // --------------------------------------------------------------------
135
136 /**
137 * Set the encryption key
138 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000139 * @param string
Andrew Podner4296a652012-12-17 07:51:15 -0500140 * @return CI_Encrypt
Derek Allard2067d1a2008-11-13 22:59:24 +0000141 */
Greg Akerd1af1852011-12-25 21:59:30 -0600142 public function set_key($key = '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000143 {
144 $this->encryption_key = $key;
Greg Akerd1af1852011-12-25 21:59:30 -0600145 return $this;
Derek Allard2067d1a2008-11-13 22:59:24 +0000146 }
147
148 // --------------------------------------------------------------------
149
150 /**
151 * Encode
152 *
153 * Encodes the message string using bitwise XOR encoding.
154 * The key is combined with a random hash, and then it
155 * too gets converted using XOR. The whole thing is then run
Andrey Andreev6eb77da2014-05-31 21:18:17 +0300156 * through mcrypt using the randomized key. The end result
157 * is a double-encrypted message string that is randomized
158 * with each call to this function, even if the supplied
159 * message and key are the same.
Derek Allard2067d1a2008-11-13 22:59:24 +0000160 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000161 * @param string the string to encode
162 * @param string the key
163 * @return string
164 */
Greg Akerd1af1852011-12-25 21:59:30 -0600165 public function encode($string, $key = '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000166 {
Andrey Andreev6eb77da2014-05-31 21:18:17 +0300167 return base64_encode($this->mcrypt_encode($string, $this->get_key($key)));
Derek Allard2067d1a2008-11-13 22:59:24 +0000168 }
169
170 // --------------------------------------------------------------------
171
172 /**
173 * Decode
174 *
175 * Reverses the above process
176 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000177 * @param string
178 * @param string
179 * @return string
180 */
Greg Akerd1af1852011-12-25 21:59:30 -0600181 public function decode($string, $key = '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000182 {
Bogdan Lysenkoc16b4f42012-10-11 11:41:01 +0300183 if (preg_match('/[^a-zA-Z0-9\/\+=]/', $string) OR base64_encode(base64_decode($string)) !== $string)
Derek Allard2067d1a2008-11-13 22:59:24 +0000184 {
185 return FALSE;
186 }
187
Andrey Andreev6eb77da2014-05-31 21:18:17 +0300188 return $this->mcrypt_decode(base64_decode($string), $this->get_key($key));
Derek Allard2067d1a2008-11-13 22:59:24 +0000189 }
190
191 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200192
Derek Jones09c77932010-08-31 13:17:10 -0500193 /**
194 * Encode from Legacy
195 *
196 * Takes an encoded string from the original Encryption class algorithms and
197 * returns a newly encoded string using the improved method added in 2.0.0
198 * This allows for backwards compatibility and a method to transition to the
199 * new encryption algorithms.
Barry Mienydd671972010-10-04 16:33:58 +0200200 *
Derek Jones09c77932010-08-31 13:17:10 -0500201 * For more details, see http://codeigniter.com/user_guide/installation/upgrade_200.html#encryption
202 *
Derek Jones09c77932010-08-31 13:17:10 -0500203 * @param string
204 * @param int (mcrypt mode constant)
205 * @param string
206 * @return string
207 */
Greg Akerd1af1852011-12-25 21:59:30 -0600208 public function encode_from_legacy($string, $legacy_mode = MCRYPT_MODE_ECB, $key = '')
Derek Jones09c77932010-08-31 13:17:10 -0500209 {
Andrey Andreev6eb77da2014-05-31 21:18:17 +0300210 if (preg_match('/[^a-zA-Z0-9\/\+=]/', $string))
Andrey Andreev7c251b32011-12-27 16:37:23 +0200211 {
212 return FALSE;
213 }
Barry Mienydd671972010-10-04 16:33:58 +0200214
Derek Jones09c77932010-08-31 13:17:10 -0500215 // decode it first
216 // set mode temporarily to what it was when string was encoded with the legacy
Barry Mienydd671972010-10-04 16:33:58 +0200217 // algorithm - typically MCRYPT_MODE_ECB
Derek Jones09c77932010-08-31 13:17:10 -0500218 $current_mode = $this->_get_mode();
219 $this->set_mode($legacy_mode);
Barry Mienydd671972010-10-04 16:33:58 +0200220
Derek Jones09c77932010-08-31 13:17:10 -0500221 $key = $this->get_key($key);
Derek Jones09c77932010-08-31 13:17:10 -0500222 $dec = base64_decode($string);
Derek Jones09c77932010-08-31 13:17:10 -0500223 if (($dec = $this->mcrypt_decode($dec, $key)) === FALSE)
224 {
Andrey Andreevf696c1f2012-06-12 12:14:51 +0300225 $this->set_mode($current_mode);
Derek Jones09c77932010-08-31 13:17:10 -0500226 return FALSE;
227 }
228
229 $dec = $this->_xor_decode($dec, $key);
230
231 // set the mcrypt mode back to what it should be, typically MCRYPT_MODE_CBC
Derek Jones092103e2010-09-02 11:11:58 -0500232 $this->set_mode($current_mode);
Derek Jones09c77932010-08-31 13:17:10 -0500233
234 // and re-encode
235 return base64_encode($this->mcrypt_encode($dec, $key));
236 }
237
238 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200239
Derek Allard2067d1a2008-11-13 22:59:24 +0000240 /**
Derek Allard2067d1a2008-11-13 22:59:24 +0000241 * XOR Decode
242 *
243 * Takes an encoded string and key as input and generates the
244 * plain-text original message
245 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000246 * @param string
247 * @param string
248 * @return string
249 */
Greg Akerd1af1852011-12-25 21:59:30 -0600250 protected function _xor_decode($string, $key)
Derek Allard2067d1a2008-11-13 22:59:24 +0000251 {
252 $string = $this->_xor_merge($string, $key);
253
254 $dec = '';
Andrey Andreev7c251b32011-12-27 16:37:23 +0200255 for ($i = 0, $l = strlen($string); $i < $l; $i++)
Derek Allard2067d1a2008-11-13 22:59:24 +0000256 {
Andrey Andreev7c251b32011-12-27 16:37:23 +0200257 $dec .= ($string[$i++] ^ $string[$i]);
Derek Allard2067d1a2008-11-13 22:59:24 +0000258 }
259
260 return $dec;
261 }
262
263 // --------------------------------------------------------------------
264
265 /**
266 * XOR key + string Combiner
267 *
268 * Takes a string and key as input and computes the difference using XOR
269 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000270 * @param string
271 * @param string
272 * @return string
273 */
Greg Akerd1af1852011-12-25 21:59:30 -0600274 protected function _xor_merge($string, $key)
Derek Allard2067d1a2008-11-13 22:59:24 +0000275 {
276 $hash = $this->hash($key);
277 $str = '';
Andrey Andreev7c251b32011-12-27 16:37:23 +0200278 for ($i = 0, $ls = strlen($string), $lh = strlen($hash); $i < $ls; $i++)
Derek Allard2067d1a2008-11-13 22:59:24 +0000279 {
Andrey Andreev7c251b32011-12-27 16:37:23 +0200280 $str .= $string[$i] ^ $hash[($i % $lh)];
Derek Allard2067d1a2008-11-13 22:59:24 +0000281 }
282
283 return $str;
284 }
285
286 // --------------------------------------------------------------------
287
288 /**
289 * Encrypt using Mcrypt
290 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000291 * @param string
292 * @param string
293 * @return string
294 */
Greg Akerd1af1852011-12-25 21:59:30 -0600295 public function mcrypt_encode($data, $key)
Derek Allard2067d1a2008-11-13 22:59:24 +0000296 {
297 $init_size = mcrypt_get_iv_size($this->_get_cipher(), $this->_get_mode());
298 $init_vect = mcrypt_create_iv($init_size, MCRYPT_RAND);
299 return $this->_add_cipher_noise($init_vect.mcrypt_encrypt($this->_get_cipher(), $key, $data, $this->_get_mode(), $init_vect), $key);
300 }
301
302 // --------------------------------------------------------------------
303
304 /**
305 * Decrypt using Mcrypt
306 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000307 * @param string
308 * @param string
309 * @return string
310 */
Greg Akerd1af1852011-12-25 21:59:30 -0600311 public function mcrypt_decode($data, $key)
Derek Allard2067d1a2008-11-13 22:59:24 +0000312 {
313 $data = $this->_remove_cipher_noise($data, $key);
314 $init_size = mcrypt_get_iv_size($this->_get_cipher(), $this->_get_mode());
315
316 if ($init_size > strlen($data))
317 {
318 return FALSE;
319 }
320
321 $init_vect = substr($data, 0, $init_size);
322 $data = substr($data, $init_size);
323 return rtrim(mcrypt_decrypt($this->_get_cipher(), $key, $data, $this->_get_mode(), $init_vect), "\0");
324 }
325
326 // --------------------------------------------------------------------
327
328 /**
329 * Adds permuted noise to the IV + encrypted data to protect
330 * against Man-in-the-middle attacks on CBC mode ciphers
331 * http://www.ciphersbyritter.com/GLOSSARY.HTM#IV
332 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000333 * @param string
334 * @param string
335 * @return string
336 */
Greg Akerd1af1852011-12-25 21:59:30 -0600337 protected function _add_cipher_noise($data, $key)
Derek Allard2067d1a2008-11-13 22:59:24 +0000338 {
Andrey Andreev7c251b32011-12-27 16:37:23 +0200339 $key = $this->hash($key);
Derek Allard2067d1a2008-11-13 22:59:24 +0000340 $str = '';
341
Andrey Andreev7c251b32011-12-27 16:37:23 +0200342 for ($i = 0, $j = 0, $ld = strlen($data), $lk = strlen($key); $i < $ld; ++$i, ++$j)
Derek Allard2067d1a2008-11-13 22:59:24 +0000343 {
Andrey Andreev7c251b32011-12-27 16:37:23 +0200344 if ($j >= $lk)
Derek Allard2067d1a2008-11-13 22:59:24 +0000345 {
346 $j = 0;
347 }
348
Andrey Andreev7c251b32011-12-27 16:37:23 +0200349 $str .= chr((ord($data[$i]) + ord($key[$j])) % 256);
Derek Allard2067d1a2008-11-13 22:59:24 +0000350 }
351
352 return $str;
353 }
354
355 // --------------------------------------------------------------------
356
357 /**
358 * Removes permuted noise from the IV + encrypted data, reversing
359 * _add_cipher_noise()
360 *
361 * Function description
362 *
Timothy Warren0688ac92012-04-20 10:25:04 -0400363 * @param string $data
364 * @param string $key
Andrey Andreev38d0e932012-04-03 19:27:45 +0300365 * @return string
Derek Allard2067d1a2008-11-13 22:59:24 +0000366 */
Greg Akerd1af1852011-12-25 21:59:30 -0600367 protected function _remove_cipher_noise($data, $key)
Derek Allard2067d1a2008-11-13 22:59:24 +0000368 {
Andrey Andreev7c251b32011-12-27 16:37:23 +0200369 $key = $this->hash($key);
Derek Allard2067d1a2008-11-13 22:59:24 +0000370 $str = '';
371
Andrey Andreev7c251b32011-12-27 16:37:23 +0200372 for ($i = 0, $j = 0, $ld = strlen($data), $lk = strlen($key); $i < $ld; ++$i, ++$j)
Derek Allard2067d1a2008-11-13 22:59:24 +0000373 {
Andrey Andreev7c251b32011-12-27 16:37:23 +0200374 if ($j >= $lk)
Derek Allard2067d1a2008-11-13 22:59:24 +0000375 {
376 $j = 0;
377 }
378
Andrey Andreev7c251b32011-12-27 16:37:23 +0200379 $temp = ord($data[$i]) - ord($key[$j]);
Derek Allard2067d1a2008-11-13 22:59:24 +0000380
381 if ($temp < 0)
382 {
Andrey Andreev7c251b32011-12-27 16:37:23 +0200383 $temp += 256;
Derek Allard2067d1a2008-11-13 22:59:24 +0000384 }
Barry Mienydd671972010-10-04 16:33:58 +0200385
Derek Allard2067d1a2008-11-13 22:59:24 +0000386 $str .= chr($temp);
387 }
388
389 return $str;
390 }
391
392 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200393
Derek Allard2067d1a2008-11-13 22:59:24 +0000394 /**
395 * Set the Mcrypt Cipher
396 *
Andrey Andreev38d0e932012-04-03 19:27:45 +0300397 * @param int
Andrew Podner4296a652012-12-17 07:51:15 -0500398 * @return CI_Encrypt
Derek Allard2067d1a2008-11-13 22:59:24 +0000399 */
Greg Akerd1af1852011-12-25 21:59:30 -0600400 public function set_cipher($cipher)
Derek Allard2067d1a2008-11-13 22:59:24 +0000401 {
402 $this->_mcrypt_cipher = $cipher;
Greg Akerd1af1852011-12-25 21:59:30 -0600403 return $this;
Derek Allard2067d1a2008-11-13 22:59:24 +0000404 }
405
406 // --------------------------------------------------------------------
407
408 /**
409 * Set the Mcrypt Mode
410 *
Andrey Andreev38d0e932012-04-03 19:27:45 +0300411 * @param int
Andrew Podner4296a652012-12-17 07:51:15 -0500412 * @return CI_Encrypt
Derek Allard2067d1a2008-11-13 22:59:24 +0000413 */
Andrey Andreev7c251b32011-12-27 16:37:23 +0200414 public function set_mode($mode)
Derek Allard2067d1a2008-11-13 22:59:24 +0000415 {
416 $this->_mcrypt_mode = $mode;
Greg Akerd1af1852011-12-25 21:59:30 -0600417 return $this;
Derek Allard2067d1a2008-11-13 22:59:24 +0000418 }
419
420 // --------------------------------------------------------------------
421
422 /**
423 * Get Mcrypt cipher Value
424 *
Andrey Andreev38d0e932012-04-03 19:27:45 +0300425 * @return int
Derek Allard2067d1a2008-11-13 22:59:24 +0000426 */
Greg Akerd1af1852011-12-25 21:59:30 -0600427 protected function _get_cipher()
Derek Allard2067d1a2008-11-13 22:59:24 +0000428 {
Andrey Andreev79eca3d2012-06-04 18:28:50 +0300429 if ($this->_mcrypt_cipher === NULL)
Derek Allard2067d1a2008-11-13 22:59:24 +0000430 {
Andrey Andreevd655a992012-01-10 22:31:29 +0200431 return $this->_mcrypt_cipher = MCRYPT_RIJNDAEL_256;
Derek Allard2067d1a2008-11-13 22:59:24 +0000432 }
433
434 return $this->_mcrypt_cipher;
435 }
436
437 // --------------------------------------------------------------------
438
439 /**
440 * Get Mcrypt Mode Value
441 *
Andrey Andreev38d0e932012-04-03 19:27:45 +0300442 * @return int
Derek Allard2067d1a2008-11-13 22:59:24 +0000443 */
Greg Akerd1af1852011-12-25 21:59:30 -0600444 protected function _get_mode()
Derek Allard2067d1a2008-11-13 22:59:24 +0000445 {
Andrey Andreev79eca3d2012-06-04 18:28:50 +0300446 if ($this->_mcrypt_mode === NULL)
Derek Allard2067d1a2008-11-13 22:59:24 +0000447 {
Andrey Andreevd655a992012-01-10 22:31:29 +0200448 return $this->_mcrypt_mode = MCRYPT_MODE_CBC;
Derek Allard2067d1a2008-11-13 22:59:24 +0000449 }
Barry Mienydd671972010-10-04 16:33:58 +0200450
Derek Allard2067d1a2008-11-13 22:59:24 +0000451 return $this->_mcrypt_mode;
452 }
453
454 // --------------------------------------------------------------------
455
456 /**
457 * Set the Hash type
458 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000459 * @param string
Andrey Andreevf4cb94e2012-01-19 15:16:55 +0200460 * @return void
Derek Allard2067d1a2008-11-13 22:59:24 +0000461 */
Greg Akerd1af1852011-12-25 21:59:30 -0600462 public function set_hash($type = 'sha1')
Derek Allard2067d1a2008-11-13 22:59:24 +0000463 {
Daniel Morrisada77752012-10-04 10:24:16 +0100464 $this->_hash_type = in_array($type, hash_algos()) ? $type : 'sha1';
Derek Allard2067d1a2008-11-13 22:59:24 +0000465 }
466
467 // --------------------------------------------------------------------
468
469 /**
470 * Hash encode a string
471 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000472 * @param string
473 * @return string
Barry Mienydd671972010-10-04 16:33:58 +0200474 */
Greg Akerd1af1852011-12-25 21:59:30 -0600475 public function hash($str)
Derek Allard2067d1a2008-11-13 22:59:24 +0000476 {
Daniel Morrisa9923f52012-10-03 19:37:09 +0100477 return hash($this->_hash_type, $str);
Derek Allard2067d1a2008-11-13 22:59:24 +0000478 }
Andrey Andreev38d0e932012-04-03 19:27:45 +0300479
Derek Allard2067d1a2008-11-13 22:59:24 +0000480}