blob: 8fb53e71849731072ccec63863dd667e6ddbbb99 [file] [log] [blame]
Derek Allard2067d1a2008-11-13 22:59:24 +00001<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
2/**
3 * CodeIgniter
4 *
5 * An open source application development framework for PHP 4.3.2 or newer
6 *
7 * @package CodeIgniter
8 * @author ExpressionEngine Dev Team
Derek Jonesfc395a12009-04-22 14:15:09 +00009 * @copyright Copyright (c) 2008 - 2009, EllisLab, Inc.
Derek Allard2067d1a2008-11-13 22:59:24 +000010 * @license http://codeigniter.com/user_guide/license.html
11 * @link http://codeigniter.com
12 * @since Version 1.0
13 * @filesource
14 */
15
16// ------------------------------------------------------------------------
17
18/**
19 * CodeIgniter Security Helpers
20 *
21 * @package CodeIgniter
22 * @subpackage Helpers
23 * @category Helpers
24 * @author ExpressionEngine Dev Team
25 * @link http://codeigniter.com/user_guide/helpers/security_helper.html
26 */
27
28// ------------------------------------------------------------------------
29
30/**
31 * XSS Filtering
32 *
33 * @access public
34 * @param string
Derek Jonesf0bcb3c2009-02-10 18:40:21 +000035 * @param bool whether or not the content is an image file
Derek Allard2067d1a2008-11-13 22:59:24 +000036 * @return string
37 */
38if ( ! function_exists('xss_clean'))
39{
Derek Jonesf0bcb3c2009-02-10 18:40:21 +000040 function xss_clean($str, $is_image = FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +000041 {
42 $CI =& get_instance();
Derek Jonesf0bcb3c2009-02-10 18:40:21 +000043 return $CI->input->xss_clean($str, $is_image);
Derek Allard2067d1a2008-11-13 22:59:24 +000044 }
45}
46
47// --------------------------------------------------------------------
48
49/**
50 * Hash encode a string
51 *
Derek Allard8719a5c2009-10-08 16:42:59 +000052 * This is simply an alias for do_hash()
53 * dohash() is now deprecated
54 */
55if ( ! function_exists('dohash'))
56{
57 function dohash($str, $type = 'sha1')
58 {
59 return $this->do_hash($str, $type);
60 }
61}
62
63// --------------------------------------------------------------------
64
65/**
66 * Hash encode a string
67 *
Derek Allard2067d1a2008-11-13 22:59:24 +000068 * @access public
69 * @param string
70 * @return string
71 */
Derek Allard8719a5c2009-10-08 16:42:59 +000072if ( ! function_exists('do_hash'))
Derek Allard2067d1a2008-11-13 22:59:24 +000073{
Derek Allard8719a5c2009-10-08 16:42:59 +000074 function do_hash($str, $type = 'sha1')
Derek Allard2067d1a2008-11-13 22:59:24 +000075 {
76 if ($type == 'sha1')
77 {
78 if ( ! function_exists('sha1'))
79 {
80 if ( ! function_exists('mhash'))
81 {
82 require_once(BASEPATH.'libraries/Sha1'.EXT);
83 $SH = new CI_SHA;
84 return $SH->generate($str);
85 }
86 else
87 {
88 return bin2hex(mhash(MHASH_SHA1, $str));
89 }
90 }
91 else
92 {
93 return sha1($str);
94 }
95 }
96 else
97 {
98 return md5($str);
99 }
100 }
101}
102
103// ------------------------------------------------------------------------
104
105/**
106 * Strip Image Tags
107 *
108 * @access public
109 * @param string
110 * @return string
111 */
112if ( ! function_exists('strip_image_tags'))
113{
114 function strip_image_tags($str)
115 {
116 $str = preg_replace("#<img\s+.*?src\s*=\s*[\"'](.+?)[\"'].*?\>#", "\\1", $str);
117 $str = preg_replace("#<img\s+.*?src\s*=\s*(.+?).*?\>#", "\\1", $str);
118
119 return $str;
120 }
121}
122
123// ------------------------------------------------------------------------
124
125/**
126 * Convert PHP tags to entities
127 *
128 * @access public
129 * @param string
130 * @return string
131 */
132if ( ! function_exists('encode_php_tags'))
133{
134 function encode_php_tags($str)
135 {
136 return str_replace(array('<?php', '<?PHP', '<?', '?>'), array('&lt;?php', '&lt;?PHP', '&lt;?', '?&gt;'), $str);
137 }
138}
139
140
141/* End of file security_helper.php */
Derek Jonesa3ffbbb2008-05-11 18:18:29 +0000142/* Location: ./system/helpers/security_helper.php */