00001 <?php
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036 class Sanitize {
00037
00038
00039
00040
00041
00042
00043
00044
00045 function paranoid($string, $allowed = array()) {
00046 $allow = null;
00047 if (!empty($allowed)) {
00048 foreach ($allowed as $value) {
00049 $allow .= "\\$value";
00050 }
00051 }
00052
00053 if (is_array($string)) {
00054 $cleaned = array();
00055 foreach ($string as $key => $clean) {
00056 $cleaned[$key] = preg_replace("/[^{$allow}a-zA-Z0-9]/", '', $clean);
00057 }
00058 } else {
00059 $cleaned = preg_replace("/[^{$allow}a-zA-Z0-9]/", '', $string);
00060 }
00061 return $cleaned;
00062 }
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072 function escape($string, $connection = 'default') {
00073 $db =& ConnectionManager::getDataSource($connection);
00074 if (is_numeric($string) || $string === null || is_bool($string)) {
00075 return $string;
00076 }
00077 $string = substr($db->value($string), 1);
00078 $string = substr($string, 0, -1);
00079 return $string;
00080 }
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090 function html($string, $remove = false) {
00091 if ($remove) {
00092 $string = strip_tags($string);
00093 } else {
00094 $patterns = array("/\&/", "/%/", "/</", "/>/", '/"/', "/'/", "/\(/", "/\)/", "/\+/", "/-/");
00095 $replacements = array("&", "%", "<", ">", """, "'", "(", ")", "+", "-");
00096 $string = preg_replace($patterns, $replacements, $string);
00097 }
00098 return $string;
00099 }
00100
00101
00102
00103
00104
00105
00106
00107
00108 function stripWhitespace($str) {
00109 $r = preg_replace('/[\n\r\t]+/', '', $str);
00110 return preg_replace('/\s{2,}/', ' ', $r);
00111 }
00112
00113
00114
00115
00116
00117
00118
00119
00120 function stripImages($str) {
00121 $str = preg_replace('/(<a[^>]*>)(<img[^>]+alt=")([^"]*)("[^>]*>)(<\/a>)/i', '$1$3$5<br />', $str);
00122 $str = preg_replace('/(<img[^>]+alt=")([^"]*)("[^>]*>)/i', '$2<br />', $str);
00123 $str = preg_replace('/<img[^>]*>/i', '', $str);
00124 return $str;
00125 }
00126
00127
00128
00129
00130
00131
00132
00133
00134 function stripScripts($str) {
00135 return preg_replace('/(<link[^>]+rel="[^"]*stylesheet"[^>]*>|<img[^>]*>|style="[^"]*")|<script[^>]*>.*?<\/script>|<style[^>]*>.*?<\/style>|<!--.*?-->/i', '', $str);
00136 }
00137
00138
00139
00140
00141
00142
00143
00144 function stripAll($str) {
00145 $str = Sanitize::stripWhitespace($str);
00146 $str = Sanitize::stripImages($str);
00147 $str = Sanitize::stripScripts($str);
00148 return $str;
00149 }
00150
00151
00152
00153
00154
00155
00156
00157
00158
00159
00160 function stripTags() {
00161 $params = params(func_get_args());
00162 $str = $params[0];
00163
00164 for ($i = 1; $i < count($params); $i++) {
00165 $str = preg_replace('/<' . $params[$i] . '\b[^>]*>/i', '', $str);
00166 $str = preg_replace('/<\/' . $params[$i] . '[^>]*>/i', '', $str);
00167 }
00168 return $str;
00169 }
00170
00171
00172
00173
00174
00175
00176
00177
00178
00179
00180
00181
00182 function clean($data, $options = array()) {
00183 if (empty($data)) {
00184 return $data;
00185 }
00186
00187 if (is_string($options)) {
00188 $options = array('connection' => $options);
00189 } else if (!is_array($options)) {
00190 $options = array();
00191 }
00192
00193 $options = array_merge(array(
00194 'connection' => 'default',
00195 'odd_spaces' => true,
00196 'encode' => true,
00197 'dollar' => true,
00198 'carriage' => true,
00199 'unicode' => true,
00200 'escape' => true,
00201 'backslash' => true
00202 ), $options);
00203
00204 if (is_array($data)) {
00205 foreach ($data as $key => $val) {
00206 $data[$key] = Sanitize::clean($val, $options);
00207 }
00208 return $data;
00209 } else {
00210 if ($options['odd_spaces']) {
00211 $data = str_replace(chr(0xCA), '', str_replace(' ', ' ', $data));
00212 }
00213 if ($options['encode']) {
00214 $data = Sanitize::html($data);
00215 }
00216 if ($options['dollar']) {
00217 $data = str_replace("\\\$", "$", $data);
00218 }
00219 if ($options['carriage']) {
00220 $data = str_replace("\r", "", $data);
00221 }
00222
00223 $data = str_replace("'", "'", str_replace("!", "!", $data));
00224
00225 if ($options['unicode']) {
00226 $data = preg_replace("/&#([0-9]+);/s", "&#\\1;", $data);
00227 }
00228 if ($options['escape']) {
00229 $data = Sanitize::escape($data, $options['connection']);
00230 }
00231 if ($options['backslash']) {
00232 $data = preg_replace("/\\\(?!&#|\?#)/", "\\", $data);
00233 }
00234 return $data;
00235 }
00236 }
00237
00238
00239
00240
00241
00242
00243
00244 function formatColumns(&$model) {
00245 foreach ($model->data as $name => $values) {
00246 if ($name == $model->alias) {
00247 $curModel =& $model;
00248 } elseif (isset($model->{$name}) && is_object($model->{$name}) && is_subclass_of($model->{$name}, 'Model')) {
00249 $curModel =& $model->{$name};
00250 } else {
00251 $curModel = null;
00252 }
00253
00254 if ($curModel != null) {
00255 foreach ($values as $column => $data) {
00256 $colType = $curModel->getColumnType($column);
00257
00258 if ($colType != null) {
00259 $db =& ConnectionManager::getDataSource($curModel->useDbConfig);
00260 $colData = $db->columns[$colType];
00261
00262 if (isset($colData['limit']) && strlen(strval($data)) > $colData['limit']) {
00263 $data = substr(strval($data), 0, $colData['limit']);
00264 }
00265
00266 if (isset($colData['formatter']) || isset($colData['format'])) {
00267
00268 switch (strtolower($colData['formatter'])) {
00269 case 'date':
00270 $data = date($colData['format'], strtotime($data));
00271 break;
00272 case 'sprintf':
00273 $data = sprintf($colData['format'], $data);
00274 break;
00275 case 'intval':
00276 $data = intval($data);
00277 break;
00278 case 'floatval':
00279 $data = floatval($data);
00280 break;
00281 }
00282 }
00283 $model->data[$name][$column]=$data;
00284 /*
00285 switch ($colType) {
00286 case 'integer':
00287 case 'int':
00288 return $data;
00289 break;
00290 case 'string':
00291 case 'text':
00292 case 'binary':
00293 case 'date':
00294 case 'time':
00295 case 'datetime':
00296 case 'timestamp':
00297 case 'date':
00298 return "'" . $data . "'";
00299 break;
00300 }
00301 */
00302 }
00303 }
00304 }
00305 }
00306 }
00307 }
00308 ?>