blob: c02abbbcbc83bfa81a805cac6297e7551c7ac103 [file] [log] [blame]
Andrey Andreevc5536aa2012-11-01 17:33:58 +02001<?php
Derek Allard2067d1a2008-11-13 22:59:24 +00002/**
3 * CodeIgniter
4 *
Phil Sturgeon07c1ac82012-03-09 17:03:37 +00005 * An open source application development framework for PHP 5.2.4 or newer
Derek Allard2067d1a2008-11-13 22:59:24 +00006 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05007 * NOTICE OF LICENSE
Eric Barnescccde962011-12-04 00:01:17 -05008 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05009 * Licensed under the Open Software License version 3.0
Eric Barnescccde962011-12-04 00:01:17 -050010 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -050011 * This source file is subject to the Open Software License (OSL 3.0) that is
12 * bundled with this package in the files license.txt / license.rst. It is
13 * also available through the world wide web at this URL:
14 * http://opensource.org/licenses/OSL-3.0
15 * If you did not receive a copy of the license and are unable to obtain it
16 * through the world wide web, please send an email to
17 * licensing@ellislab.com so we can send you a copy immediately.
18 *
Derek Allard2067d1a2008-11-13 22:59:24 +000019 * @package CodeIgniter
Derek Jonesf4a4bd82011-10-20 12:18:42 -050020 * @author EllisLab Dev Team
Andrey Andreev80500af2013-01-01 08:16:53 +020021 * @copyright Copyright (c) 2008 - 2013, EllisLab, Inc. (http://ellislab.com/)
Derek Jonesf4a4bd82011-10-20 12:18:42 -050022 * @license http://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
Derek Allard2067d1a2008-11-13 22:59:24 +000023 * @link http://codeigniter.com
24 * @since Version 1.0
25 * @filesource
26 */
Andrey Andreevc5536aa2012-11-01 17:33:58 +020027defined('BASEPATH') OR exit('No direct script access allowed');
Derek Allard2067d1a2008-11-13 22:59:24 +000028
Derek Allard2067d1a2008-11-13 22:59:24 +000029/**
30 * Form Validation Class
31 *
32 * @package CodeIgniter
33 * @subpackage Libraries
34 * @category Validation
Derek Jonesf4a4bd82011-10-20 12:18:42 -050035 * @author EllisLab Dev Team
Derek Allard2067d1a2008-11-13 22:59:24 +000036 * @link http://codeigniter.com/user_guide/libraries/form_validation.html
37 */
38class CI_Form_validation {
Barry Mienydd671972010-10-04 16:33:58 +020039
Timothy Warren0688ac92012-04-20 10:25:04 -040040 /**
41 * Reference to the CodeIgniter instance
42 *
43 * @var object
44 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +010045 protected $CI;
Derek Allard2067d1a2008-11-13 22:59:24 +000046
Timothy Warren0688ac92012-04-20 10:25:04 -040047 /**
48 * Validation data for the current form submission
49 *
50 * @var array
51 */
Andrey Andreev56454792012-05-17 14:32:19 +030052 protected $_field_data = array();
53
Timothy Warren0688ac92012-04-20 10:25:04 -040054 /**
55 * Validation rules for the current form
56 *
57 * @var array
58 */
Andrey Andreev56454792012-05-17 14:32:19 +030059 protected $_config_rules = array();
60
Timothy Warren0688ac92012-04-20 10:25:04 -040061 /**
62 * Array of validation errors
63 *
64 * @var array
65 */
Andrey Andreev78f55772012-04-03 19:59:08 +030066 protected $_error_array = array();
Andrey Andreev56454792012-05-17 14:32:19 +030067
Timothy Warren0688ac92012-04-20 10:25:04 -040068 /**
69 * Array of custom error messages
70 *
71 * @var array
72 */
Andrey Andreev78f55772012-04-03 19:59:08 +030073 protected $_error_messages = array();
Andrey Andreev56454792012-05-17 14:32:19 +030074
Timothy Warren0688ac92012-04-20 10:25:04 -040075 /**
76 * Start tag for error wrapping
77 *
78 * @var string
79 */
Andrey Andreev78f55772012-04-03 19:59:08 +030080 protected $_error_prefix = '<p>';
Andrey Andreev56454792012-05-17 14:32:19 +030081
Timothy Warren0688ac92012-04-20 10:25:04 -040082 /**
83 * End tag for error wrapping
Andrey Andreev56454792012-05-17 14:32:19 +030084 *
Timothy Warren0688ac92012-04-20 10:25:04 -040085 * @var string
86 */
Andrey Andreev78f55772012-04-03 19:59:08 +030087 protected $_error_suffix = '</p>';
Andrey Andreev56454792012-05-17 14:32:19 +030088
Timothy Warren0688ac92012-04-20 10:25:04 -040089 /**
90 * Custom error message
91 *
92 * @var string
93 */
Andrey Andreev78f55772012-04-03 19:59:08 +030094 protected $error_string = '';
Andrey Andreev56454792012-05-17 14:32:19 +030095
Timothy Warren0688ac92012-04-20 10:25:04 -040096 /**
97 * Whether the form data has been validated as safe
98 *
99 * @var bool
100 */
Andrey Andreev78f55772012-04-03 19:59:08 +0300101 protected $_safe_form_data = FALSE;
Andrey Andreev56454792012-05-17 14:32:19 +0300102
Timothy Warren0688ac92012-04-20 10:25:04 -0400103 /**
104 * Custom data to validate
105 *
106 * @var array
107 */
Andrey Andreevcff35802012-11-26 15:49:52 +0200108 public $validation_data = array();
Derek Allard2067d1a2008-11-13 22:59:24 +0000109
Timothy Warren0688ac92012-04-20 10:25:04 -0400110 /**
111 * Initialize Form_Validation class
112 *
Andrey Andreev56454792012-05-17 14:32:19 +0300113 * @param array $rules
114 * @return void
Timothy Warren0688ac92012-04-20 10:25:04 -0400115 */
Greg Akera9263282010-11-10 15:26:43 -0600116 public function __construct($rules = array())
Barry Mienydd671972010-10-04 16:33:58 +0200117 {
Derek Allard2067d1a2008-11-13 22:59:24 +0000118 $this->CI =& get_instance();
Barry Mienydd671972010-10-04 16:33:58 +0200119
Mike Funk326a5e72012-02-24 10:06:28 -0500120 // applies delimiters set in config file.
Mike Funk7f42d062012-03-08 09:00:57 -0500121 if (isset($rules['error_prefix']))
122 {
123 $this->_error_prefix = $rules['error_prefix'];
124 unset($rules['error_prefix']);
125 }
126 if (isset($rules['error_suffix']))
127 {
128 $this->_error_suffix = $rules['error_suffix'];
129 unset($rules['error_suffix']);
130 }
Andrey Andreev31cf46e2012-03-20 15:48:00 +0200131
Derek Allard2067d1a2008-11-13 22:59:24 +0000132 // Validation rules can be stored in a config file.
133 $this->_config_rules = $rules;
Barry Mienydd671972010-10-04 16:33:58 +0200134
Derek Allard2067d1a2008-11-13 22:59:24 +0000135 // Automatically load the form helper
136 $this->CI->load->helper('form');
137
Andrey Andreev901573c2012-01-11 01:40:48 +0200138 log_message('debug', 'Form Validation Class Initialized');
Derek Allard2067d1a2008-11-13 22:59:24 +0000139 }
Barry Mienydd671972010-10-04 16:33:58 +0200140
Derek Allard2067d1a2008-11-13 22:59:24 +0000141 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200142
Derek Allard2067d1a2008-11-13 22:59:24 +0000143 /**
144 * Set Rules
145 *
146 * This function takes an array of field names and validation
147 * rules as input, validates the info, and stores it
148 *
Timothy Warren0688ac92012-04-20 10:25:04 -0400149 * @param mixed $field
150 * @param string $label
151 * @param mixed $rules
Andrew Podner4296a652012-12-17 07:51:15 -0500152 * @return CI_Form_validation
Derek Allard2067d1a2008-11-13 22:59:24 +0000153 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100154 public function set_rules($field, $label = '', $rules = '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000155 {
156 // No reason to set rules if we have no POST data
JonoB099c4782012-03-04 14:37:30 +0000157 // or a validation array has not been specified
Andrey Andreev3b2c5082012-03-07 22:49:24 +0200158 if ($this->CI->input->method() !== 'post' && empty($this->validation_data))
Derek Allard2067d1a2008-11-13 22:59:24 +0000159 {
Greg Aker9f9af602010-11-10 15:41:51 -0600160 return $this;
Derek Allard2067d1a2008-11-13 22:59:24 +0000161 }
Barry Mienydd671972010-10-04 16:33:58 +0200162
tiyowanc2acb232012-03-14 21:24:00 +0400163 // If an array was passed via the first parameter instead of individual string
Derek Allard2067d1a2008-11-13 22:59:24 +0000164 // values we cycle through it and recursively call this function.
165 if (is_array($field))
166 {
167 foreach ($field as $row)
168 {
169 // Houston, we have a problem...
Andrey Andreev78f55772012-04-03 19:59:08 +0300170 if ( ! isset($row['field'], $row['rules']))
Derek Allard2067d1a2008-11-13 22:59:24 +0000171 {
172 continue;
173 }
174
175 // If the field label wasn't passed we use the field name
Andrey Andreev78f55772012-04-03 19:59:08 +0300176 $label = isset($row['label']) ? $row['label'] : $row['field'];
Derek Allard2067d1a2008-11-13 22:59:24 +0000177
178 // Here we go!
179 $this->set_rules($row['field'], $label, $row['rules']);
180 }
Andrey Andreev78f55772012-04-03 19:59:08 +0300181
Greg Aker9f9af602010-11-10 15:41:51 -0600182 return $this;
Derek Allard2067d1a2008-11-13 22:59:24 +0000183 }
Barry Mienydd671972010-10-04 16:33:58 +0200184
Kevin Wood-Friend6a56d502012-06-12 09:54:01 -0400185 // Convert an array of rules to a string
186 if (is_array($rules))
187 {
188 $rules = implode('|', $rules);
189 }
190
Derek Allard2067d1a2008-11-13 22:59:24 +0000191 // No fields? Nothing to do...
Alex Bilbied261b1e2012-06-02 11:12:16 +0100192 if ( ! is_string($field) OR ! is_string($rules) OR $field === '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000193 {
Greg Aker9f9af602010-11-10 15:41:51 -0600194 return $this;
Derek Allard2067d1a2008-11-13 22:59:24 +0000195 }
196
197 // If the field label wasn't passed we use the field name
Alex Bilbied261b1e2012-06-02 11:12:16 +0100198 $label = ($label === '') ? $field : $label;
Derek Allard2067d1a2008-11-13 22:59:24 +0000199
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200200 // Is the field name an array? If it is an array, we break it apart
Barry Mienydd671972010-10-04 16:33:58 +0200201 // into its components so that we can fetch the corresponding POST data later
Andrey Andreev7a7ad782012-11-12 17:21:01 +0200202 $indexes = array();
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200203 if (preg_match_all('/\[(.*?)\]/', $field, $matches))
Barry Mienydd671972010-10-04 16:33:58 +0200204 {
Andrey Andreev7a7ad782012-11-12 17:21:01 +0200205 sscanf($field, '%[^[][', $indexes[0]);
Derek Allard2067d1a2008-11-13 22:59:24 +0000206
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200207 for ($i = 0, $c = count($matches[0]); $i < $c; $i++)
Derek Allard2067d1a2008-11-13 22:59:24 +0000208 {
Alex Bilbied261b1e2012-06-02 11:12:16 +0100209 if ($matches[1][$i] !== '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000210 {
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200211 $indexes[] = $matches[1][$i];
Derek Allard2067d1a2008-11-13 22:59:24 +0000212 }
213 }
Barry Mienydd671972010-10-04 16:33:58 +0200214
Derek Allard2067d1a2008-11-13 22:59:24 +0000215 $is_array = TRUE;
216 }
217 else
218 {
Barry Mienydd671972010-10-04 16:33:58 +0200219 $is_array = FALSE;
Derek Allard2067d1a2008-11-13 22:59:24 +0000220 }
Barry Mienydd671972010-10-04 16:33:58 +0200221
222 // Build our master array
Derek Allard2067d1a2008-11-13 22:59:24 +0000223 $this->_field_data[$field] = array(
Andrey Andreev56454792012-05-17 14:32:19 +0300224 'field' => $field,
225 'label' => $label,
226 'rules' => $rules,
227 'is_array' => $is_array,
228 'keys' => $indexes,
229 'postdata' => NULL,
230 'error' => ''
Phil Sturgeonef112c02011-02-07 13:01:47 +0000231 );
Greg Aker9f9af602010-11-10 15:41:51 -0600232
233 return $this;
Derek Allard2067d1a2008-11-13 22:59:24 +0000234 }
235
236 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200237
Derek Allard2067d1a2008-11-13 22:59:24 +0000238 /**
JonoB099c4782012-03-04 14:37:30 +0000239 * By default, form validation uses the $_POST array to validate
Andrey Andreevc8da4fe2012-03-04 19:20:33 +0200240 *
JonoB099c4782012-03-04 14:37:30 +0000241 * If an array is set through this method, then this array will
242 * be used instead of the $_POST array
Andrey Andreev3b2c5082012-03-07 22:49:24 +0200243 *
244 * Note that if you are validating multiple arrays, then the
245 * reset_validation() function should be called after validating
JonoB883f80f2012-03-05 09:51:27 +0000246 * each array due to the limitations of CI's singleton
Andrey Andreevc8da4fe2012-03-04 19:20:33 +0200247 *
248 * @param array $data
249 * @return void
JonoB099c4782012-03-04 14:37:30 +0000250 */
Andrey Andreeva4712f52014-01-06 11:25:46 +0200251 public function set_data(array $data)
JonoB099c4782012-03-04 14:37:30 +0000252 {
Andrey Andreeva4712f52014-01-06 11:25:46 +0200253 if ( ! empty($data))
JonoB099c4782012-03-04 14:37:30 +0000254 {
Andrey Andreevc8da4fe2012-03-04 19:20:33 +0200255 $this->validation_data = $data;
JonoB099c4782012-03-04 14:37:30 +0000256 }
257 }
Andrey Andreevc8da4fe2012-03-04 19:20:33 +0200258
JonoB099c4782012-03-04 14:37:30 +0000259 // --------------------------------------------------------------------
Derek Allard2067d1a2008-11-13 22:59:24 +0000260
261 /**
262 * Set Error Message
263 *
Andrey Andreev78f55772012-04-03 19:59:08 +0300264 * Lets users set their own error messages on the fly. Note:
265 * The key name has to match the function name that it corresponds to.
Derek Allard2067d1a2008-11-13 22:59:24 +0000266 *
Andrey Andreev78f55772012-04-03 19:59:08 +0300267 * @param array
Derek Allard2067d1a2008-11-13 22:59:24 +0000268 * @param string
Andrew Podner4296a652012-12-17 07:51:15 -0500269 * @return CI_Form_validation
Derek Allard2067d1a2008-11-13 22:59:24 +0000270 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100271 public function set_message($lang, $val = '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000272 {
273 if ( ! is_array($lang))
274 {
275 $lang = array($lang => $val);
276 }
Barry Mienydd671972010-10-04 16:33:58 +0200277
Derek Allard2067d1a2008-11-13 22:59:24 +0000278 $this->_error_messages = array_merge($this->_error_messages, $lang);
Greg Aker9f9af602010-11-10 15:41:51 -0600279 return $this;
Derek Allard2067d1a2008-11-13 22:59:24 +0000280 }
Barry Mienydd671972010-10-04 16:33:58 +0200281
Derek Allard2067d1a2008-11-13 22:59:24 +0000282 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200283
Derek Allard2067d1a2008-11-13 22:59:24 +0000284 /**
285 * Set The Error Delimiter
286 *
287 * Permits a prefix/suffix to be added to each error message
288 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000289 * @param string
290 * @param string
Andrew Podner4296a652012-12-17 07:51:15 -0500291 * @return CI_Form_validation
Barry Mienydd671972010-10-04 16:33:58 +0200292 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100293 public function set_error_delimiters($prefix = '<p>', $suffix = '</p>')
Derek Allard2067d1a2008-11-13 22:59:24 +0000294 {
295 $this->_error_prefix = $prefix;
296 $this->_error_suffix = $suffix;
Greg Aker9f9af602010-11-10 15:41:51 -0600297 return $this;
Derek Allard2067d1a2008-11-13 22:59:24 +0000298 }
299
300 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200301
Derek Allard2067d1a2008-11-13 22:59:24 +0000302 /**
303 * Get Error Message
304 *
305 * Gets the error message associated with a particular field
306 *
Andrey Andreeva4712f52014-01-06 11:25:46 +0200307 * @param string $field Field name
308 * @param string $prefix HTML start tag
309 * @param strign $suffix HTML end tag
Andrey Andreev78f55772012-04-03 19:59:08 +0300310 * @return string
Barry Mienydd671972010-10-04 16:33:58 +0200311 */
Andrey Andreeva4712f52014-01-06 11:25:46 +0200312 public function error($field, $prefix = '', $suffix = '')
Barry Mienydd671972010-10-04 16:33:58 +0200313 {
Andrey Andreev78f55772012-04-03 19:59:08 +0300314 if (empty($this->_field_data[$field]['error']))
Derek Allard2067d1a2008-11-13 22:59:24 +0000315 {
316 return '';
317 }
Barry Mienydd671972010-10-04 16:33:58 +0200318
Alex Bilbied261b1e2012-06-02 11:12:16 +0100319 if ($prefix === '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000320 {
321 $prefix = $this->_error_prefix;
322 }
323
Alex Bilbied261b1e2012-06-02 11:12:16 +0100324 if ($suffix === '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000325 {
326 $suffix = $this->_error_suffix;
327 }
328
329 return $prefix.$this->_field_data[$field]['error'].$suffix;
330 }
331
332 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200333
Derek Allard2067d1a2008-11-13 22:59:24 +0000334 /**
Michiel Vugteveen676a0dd2012-03-02 10:10:34 +0100335 * Get Array of Error Messages
336 *
337 * Returns the error messages as an array
338 *
339 * @return array
340 */
341 public function error_array()
342 {
343 return $this->_error_array;
344 }
345
346 // --------------------------------------------------------------------
347
348 /**
Derek Allard2067d1a2008-11-13 22:59:24 +0000349 * Error String
350 *
351 * Returns the error messages as a string, wrapped in the error delimiters
352 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000353 * @param string
354 * @param string
Andrey Andreev78f55772012-04-03 19:59:08 +0300355 * @return string
Barry Mienydd671972010-10-04 16:33:58 +0200356 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100357 public function error_string($prefix = '', $suffix = '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000358 {
vlakoff35672462013-02-15 01:36:04 +0100359 // No errors, validation passes!
Derek Allard2067d1a2008-11-13 22:59:24 +0000360 if (count($this->_error_array) === 0)
361 {
362 return '';
363 }
Barry Mienydd671972010-10-04 16:33:58 +0200364
Alex Bilbied261b1e2012-06-02 11:12:16 +0100365 if ($prefix === '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000366 {
367 $prefix = $this->_error_prefix;
368 }
369
Alex Bilbied261b1e2012-06-02 11:12:16 +0100370 if ($suffix === '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000371 {
372 $suffix = $this->_error_suffix;
373 }
Barry Mienydd671972010-10-04 16:33:58 +0200374
Derek Allard2067d1a2008-11-13 22:59:24 +0000375 // Generate the error string
376 $str = '';
377 foreach ($this->_error_array as $val)
378 {
Alex Bilbied261b1e2012-06-02 11:12:16 +0100379 if ($val !== '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000380 {
381 $str .= $prefix.$val.$suffix."\n";
382 }
383 }
Barry Mienydd671972010-10-04 16:33:58 +0200384
Derek Allard2067d1a2008-11-13 22:59:24 +0000385 return $str;
386 }
387
388 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200389
Derek Allard2067d1a2008-11-13 22:59:24 +0000390 /**
391 * Run the Validator
392 *
393 * This function does all the work.
394 *
Timothy Warren0688ac92012-04-20 10:25:04 -0400395 * @param string $group
Derek Allard2067d1a2008-11-13 22:59:24 +0000396 * @return bool
Barry Mienydd671972010-10-04 16:33:58 +0200397 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100398 public function run($group = '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000399 {
Derek Jones37f4b9c2011-07-01 17:56:50 -0500400 // Do we even have any data to process? Mm?
Andrey Andreev78f55772012-04-03 19:59:08 +0300401 $validation_array = empty($this->validation_data) ? $_POST : $this->validation_data;
JonoB099c4782012-03-04 14:37:30 +0000402 if (count($validation_array) === 0)
Derek Allard2067d1a2008-11-13 22:59:24 +0000403 {
404 return FALSE;
405 }
Barry Mienydd671972010-10-04 16:33:58 +0200406
Derek Allard2067d1a2008-11-13 22:59:24 +0000407 // Does the _field_data array containing the validation rules exist?
408 // If not, we look to see if they were assigned via a config file
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200409 if (count($this->_field_data) === 0)
Derek Allard2067d1a2008-11-13 22:59:24 +0000410 {
Derek Jones37f4b9c2011-07-01 17:56:50 -0500411 // No validation rules? We're done...
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200412 if (count($this->_config_rules) === 0)
Derek Allard2067d1a2008-11-13 22:59:24 +0000413 {
414 return FALSE;
415 }
Barry Mienydd671972010-10-04 16:33:58 +0200416
Derek Allard2067d1a2008-11-13 22:59:24 +0000417 // Is there a validation rule for the particular URI being accessed?
Alex Bilbied261b1e2012-06-02 11:12:16 +0100418 $uri = ($group === '') ? trim($this->CI->uri->ruri_string(), '/') : $group;
Barry Mienydd671972010-10-04 16:33:58 +0200419
Alex Bilbied261b1e2012-06-02 11:12:16 +0100420 if ($uri !== '' && isset($this->_config_rules[$uri]))
Derek Allard2067d1a2008-11-13 22:59:24 +0000421 {
422 $this->set_rules($this->_config_rules[$uri]);
423 }
424 else
425 {
426 $this->set_rules($this->_config_rules);
427 }
Barry Mienydd671972010-10-04 16:33:58 +0200428
Andrey Andreev901573c2012-01-11 01:40:48 +0200429 // Were we able to set the rules correctly?
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200430 if (count($this->_field_data) === 0)
Derek Allard2067d1a2008-11-13 22:59:24 +0000431 {
Andrey Andreev901573c2012-01-11 01:40:48 +0200432 log_message('debug', 'Unable to find validation rules');
Derek Allard2067d1a2008-11-13 22:59:24 +0000433 return FALSE;
434 }
435 }
Barry Mienydd671972010-10-04 16:33:58 +0200436
Derek Allard2067d1a2008-11-13 22:59:24 +0000437 // Load the language file containing error messages
438 $this->CI->lang->load('form_validation');
Barry Mienydd671972010-10-04 16:33:58 +0200439
Andrey Andreev751f2472012-11-03 18:26:27 +0200440 // Cycle through the rules for each field and match the corresponding $validation_data item
Derek Allard2067d1a2008-11-13 22:59:24 +0000441 foreach ($this->_field_data as $field => $row)
Barry Mienydd671972010-10-04 16:33:58 +0200442 {
Andrey Andreev751f2472012-11-03 18:26:27 +0200443 // Fetch the data from the validation_data array item and cache it in the _field_data array.
Derek Allard2067d1a2008-11-13 22:59:24 +0000444 // Depending on whether the field name is an array or a string will determine where we get it from.
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200445 if ($row['is_array'] === TRUE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000446 {
JonoB099c4782012-03-04 14:37:30 +0000447 $this->_field_data[$field]['postdata'] = $this->_reduce_array($validation_array, $row['keys']);
Derek Allard2067d1a2008-11-13 22:59:24 +0000448 }
Andrey Andreevfff6c2a2012-05-13 22:15:23 +0300449 elseif (isset($validation_array[$field]) && $validation_array[$field] !== '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000450 {
Andrey Andreev78f55772012-04-03 19:59:08 +0300451 $this->_field_data[$field]['postdata'] = $validation_array[$field];
Derek Allard2067d1a2008-11-13 22:59:24 +0000452 }
Andrey Andreev751f2472012-11-03 18:26:27 +0200453 }
Barry Mienydd671972010-10-04 16:33:58 +0200454
Andrey Andreev751f2472012-11-03 18:26:27 +0200455 // Execute validation rules
456 // Note: A second foreach (for now) is required in order to avoid false-positives
457 // for rules like 'matches', which correlate to other validation fields.
458 foreach ($this->_field_data as $field => $row)
459 {
Andrey Andreev3d9cec92012-07-08 21:50:19 +0300460 // Don't try to validate if we have no rules set
461 if (empty($row['rules']))
462 {
463 continue;
464 }
Barry Mienydd671972010-10-04 16:33:58 +0200465
466 $this->_execute($row, explode('|', $row['rules']), $this->_field_data[$field]['postdata']);
Derek Allard2067d1a2008-11-13 22:59:24 +0000467 }
468
469 // Did we end up with any errors?
470 $total_errors = count($this->_error_array);
Derek Allard2067d1a2008-11-13 22:59:24 +0000471 if ($total_errors > 0)
472 {
473 $this->_safe_form_data = TRUE;
474 }
475
476 // Now we need to re-set the POST data with the new, processed data
477 $this->_reset_post_array();
Barry Mienydd671972010-10-04 16:33:58 +0200478
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200479 return ($total_errors === 0);
Derek Allard2067d1a2008-11-13 22:59:24 +0000480 }
481
482 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200483
Derek Allard2067d1a2008-11-13 22:59:24 +0000484 /**
485 * Traverse a multidimensional $_POST array index until the data is found
486 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000487 * @param array
488 * @param array
Andrey Andreev78f55772012-04-03 19:59:08 +0300489 * @param int
Derek Allard2067d1a2008-11-13 22:59:24 +0000490 * @return mixed
Barry Mienydd671972010-10-04 16:33:58 +0200491 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100492 protected function _reduce_array($array, $keys, $i = 0)
Derek Allard2067d1a2008-11-13 22:59:24 +0000493 {
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200494 if (is_array($array) && isset($keys[$i]))
Derek Allard2067d1a2008-11-13 22:59:24 +0000495 {
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200496 return isset($array[$keys[$i]]) ? $this->_reduce_array($array[$keys[$i]], $keys, ($i+1)) : NULL;
Derek Allard2067d1a2008-11-13 22:59:24 +0000497 }
Barry Mienydd671972010-10-04 16:33:58 +0200498
Andrey Andreev2d48b4f2012-11-23 17:33:21 +0200499 // NULL must be returned for empty fields
Andrey Andreev44c34632012-11-23 18:46:34 +0200500 return ($array === '') ? NULL : $array;
Derek Allard2067d1a2008-11-13 22:59:24 +0000501 }
502
503 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200504
Derek Allard2067d1a2008-11-13 22:59:24 +0000505 /**
506 * Re-populate the _POST array with our finalized and processed data
507 *
Andrey Andreev6de924c2012-01-20 13:18:18 +0200508 * @return void
Barry Mienydd671972010-10-04 16:33:58 +0200509 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100510 protected function _reset_post_array()
Derek Allard2067d1a2008-11-13 22:59:24 +0000511 {
512 foreach ($this->_field_data as $field => $row)
513 {
vlakoff1228fe22013-01-14 01:30:09 +0100514 if ($row['postdata'] !== NULL)
Derek Allard2067d1a2008-11-13 22:59:24 +0000515 {
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200516 if ($row['is_array'] === FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000517 {
518 if (isset($_POST[$row['field']]))
519 {
Andrey Andreevc2268712013-02-08 22:10:23 +0200520 $_POST[$row['field']] = $row['postdata'];
Derek Allard2067d1a2008-11-13 22:59:24 +0000521 }
522 }
523 else
524 {
Derek Jones63eeae32009-02-10 19:08:56 +0000525 // start with a reference
526 $post_ref =& $_POST;
Barry Mienydd671972010-10-04 16:33:58 +0200527
Derek Jones63eeae32009-02-10 19:08:56 +0000528 // before we assign values, make a reference to the right POST key
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200529 if (count($row['keys']) === 1)
Derek Allard2067d1a2008-11-13 22:59:24 +0000530 {
Derek Jones63eeae32009-02-10 19:08:56 +0000531 $post_ref =& $post_ref[current($row['keys'])];
Derek Allard2067d1a2008-11-13 22:59:24 +0000532 }
533 else
534 {
Derek Allard2067d1a2008-11-13 22:59:24 +0000535 foreach ($row['keys'] as $val)
536 {
Derek Jones63eeae32009-02-10 19:08:56 +0000537 $post_ref =& $post_ref[$val];
Derek Allard2067d1a2008-11-13 22:59:24 +0000538 }
539 }
Derek Jones63eeae32009-02-10 19:08:56 +0000540
Derek Allard2067d1a2008-11-13 22:59:24 +0000541 if (is_array($row['postdata']))
Derek Jones63eeae32009-02-10 19:08:56 +0000542 {
Derek Allard2067d1a2008-11-13 22:59:24 +0000543 $array = array();
544 foreach ($row['postdata'] as $k => $v)
545 {
Andrey Andreevc2268712013-02-08 22:10:23 +0200546 $array[$k] = $v;
Derek Allard2067d1a2008-11-13 22:59:24 +0000547 }
Derek Jones63eeae32009-02-10 19:08:56 +0000548
549 $post_ref = $array;
Derek Allard2067d1a2008-11-13 22:59:24 +0000550 }
551 else
Derek Jones63eeae32009-02-10 19:08:56 +0000552 {
Andrey Andreevc2268712013-02-08 22:10:23 +0200553 $post_ref = $row['postdata'];
Derek Allard2067d1a2008-11-13 22:59:24 +0000554 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000555 }
556 }
557 }
558 }
559
560 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200561
Derek Allard2067d1a2008-11-13 22:59:24 +0000562 /**
563 * Executes the Validation routines
564 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000565 * @param array
566 * @param array
567 * @param mixed
Andrey Andreev78f55772012-04-03 19:59:08 +0300568 * @param int
Derek Allard2067d1a2008-11-13 22:59:24 +0000569 * @return mixed
Barry Mienydd671972010-10-04 16:33:58 +0200570 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100571 protected function _execute($row, $rules, $postdata = NULL, $cycles = 0)
Derek Allard2067d1a2008-11-13 22:59:24 +0000572 {
573 // If the $_POST data is an array we will run a recursive call
574 if (is_array($postdata))
Barry Mienydd671972010-10-04 16:33:58 +0200575 {
Derek Allard2067d1a2008-11-13 22:59:24 +0000576 foreach ($postdata as $key => $val)
577 {
Andrey Andreev8d3099d2012-06-21 16:00:20 +0300578 $this->_execute($row, $rules, $val, $key);
Derek Allard2067d1a2008-11-13 22:59:24 +0000579 }
Barry Mienydd671972010-10-04 16:33:58 +0200580
Derek Allard2067d1a2008-11-13 22:59:24 +0000581 return;
582 }
Barry Mienydd671972010-10-04 16:33:58 +0200583
Derek Allard2067d1a2008-11-13 22:59:24 +0000584 // If the field is blank, but NOT required, no further tests are necessary
585 $callback = FALSE;
Hashem Qolami05370bf2013-07-22 01:52:04 +0430586 if ( ! in_array('required', $rules) && ($postdata === NULL OR $postdata === ''))
Derek Allard2067d1a2008-11-13 22:59:24 +0000587 {
588 // Before we bail out, does the rule contain a callback?
Andrey Andreev901573c2012-01-11 01:40:48 +0200589 if (preg_match('/(callback_\w+(\[.*?\])?)/', implode(' ', $rules), $match))
Derek Allard2067d1a2008-11-13 22:59:24 +0000590 {
591 $callback = TRUE;
Andrey Andreev78f55772012-04-03 19:59:08 +0300592 $rules = array(1 => $match[1]);
Derek Allard2067d1a2008-11-13 22:59:24 +0000593 }
594 else
595 {
596 return;
597 }
598 }
599
Derek Allard2067d1a2008-11-13 22:59:24 +0000600 // Isset Test. Typically this rule will only apply to checkboxes.
Hashem Qolami05370bf2013-07-22 01:52:04 +0430601 if (($postdata === NULL OR $postdata === '') && $callback === FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000602 {
603 if (in_array('isset', $rules, TRUE) OR in_array('required', $rules))
604 {
605 // Set the message type
Andrey Andreev78f55772012-04-03 19:59:08 +0300606 $type = in_array('required', $rules) ? 'required' : 'isset';
Barry Mienydd671972010-10-04 16:33:58 +0200607
Andrey Andreev56454792012-05-17 14:32:19 +0300608 if (isset($this->_error_messages[$type]))
Derek Allard2067d1a2008-11-13 22:59:24 +0000609 {
610 $line = $this->_error_messages[$type];
611 }
Andrey Andreevd4eec9f2012-12-14 11:07:13 +0200612 elseif (FALSE === ($line = $this->CI->lang->line('form_validation_'.$type))
613 // DEPRECATED support for non-prefixed keys
614 && FALSE === ($line = $this->CI->lang->line($type, FALSE)))
Andrey Andreev56454792012-05-17 14:32:19 +0300615 {
616 $line = 'The field was not set';
617 }
Barry Mienydd671972010-10-04 16:33:58 +0200618
Derek Allard2067d1a2008-11-13 22:59:24 +0000619 // Build the error message
Eric Roberts41cc0902012-01-24 00:59:44 -0600620 $message = $this->_build_error_msg($line, $this->_translate_fieldname($row['label']));
Derek Allard2067d1a2008-11-13 22:59:24 +0000621
622 // Save the error message
623 $this->_field_data[$row['field']]['error'] = $message;
Barry Mienydd671972010-10-04 16:33:58 +0200624
Derek Allard2067d1a2008-11-13 22:59:24 +0000625 if ( ! isset($this->_error_array[$row['field']]))
626 {
627 $this->_error_array[$row['field']] = $message;
628 }
629 }
Barry Mienydd671972010-10-04 16:33:58 +0200630
Derek Allard2067d1a2008-11-13 22:59:24 +0000631 return;
632 }
633
634 // --------------------------------------------------------------------
635
636 // Cycle through each rule and run it
Andrey Andreev78f55772012-04-03 19:59:08 +0300637 foreach ($rules as $rule)
Derek Allard2067d1a2008-11-13 22:59:24 +0000638 {
639 $_in_array = FALSE;
Barry Mienydd671972010-10-04 16:33:58 +0200640
Derek Allard2067d1a2008-11-13 22:59:24 +0000641 // We set the $postdata variable with the current data in our master array so that
642 // each cycle of the loop is dealing with the processed data from the last cycle
Alex Bilbied261b1e2012-06-02 11:12:16 +0100643 if ($row['is_array'] === TRUE && is_array($this->_field_data[$row['field']]['postdata']))
Derek Allard2067d1a2008-11-13 22:59:24 +0000644 {
645 // We shouldn't need this safety, but just in case there isn't an array index
646 // associated with this cycle we'll bail out
647 if ( ! isset($this->_field_data[$row['field']]['postdata'][$cycles]))
648 {
649 continue;
650 }
Barry Mienydd671972010-10-04 16:33:58 +0200651
Derek Allard2067d1a2008-11-13 22:59:24 +0000652 $postdata = $this->_field_data[$row['field']]['postdata'][$cycles];
653 $_in_array = TRUE;
654 }
655 else
656 {
Andrey Andreev6ac51442012-06-18 13:05:17 +0300657 // If we get an array field, but it's not expected - then it is most likely
658 // somebody messing with the form on the client side, so we'll just consider
659 // it an empty field
660 $postdata = is_array($this->_field_data[$row['field']]['postdata'])
661 ? NULL
662 : $this->_field_data[$row['field']]['postdata'];
Derek Allard2067d1a2008-11-13 22:59:24 +0000663 }
664
Barry Mienydd671972010-10-04 16:33:58 +0200665 // Is the rule a callback?
Derek Allard2067d1a2008-11-13 22:59:24 +0000666 $callback = FALSE;
Andrey Andreev901573c2012-01-11 01:40:48 +0200667 if (strpos($rule, 'callback_') === 0)
Derek Allard2067d1a2008-11-13 22:59:24 +0000668 {
669 $rule = substr($rule, 9);
670 $callback = TRUE;
671 }
Barry Mienydd671972010-10-04 16:33:58 +0200672
Derek Allard2067d1a2008-11-13 22:59:24 +0000673 // Strip the parameter (if exists) from the rule
674 // Rules can contain a parameter: max_length[5]
675 $param = FALSE;
Andrey Andreev901573c2012-01-11 01:40:48 +0200676 if (preg_match('/(.*?)\[(.*)\]/', $rule, $match))
Derek Allard2067d1a2008-11-13 22:59:24 +0000677 {
Andrey Andreevef758bd2012-11-15 12:24:52 +0200678 $rule = $match[1];
679 $param = $match[2];
Derek Allard2067d1a2008-11-13 22:59:24 +0000680 }
Barry Mienydd671972010-10-04 16:33:58 +0200681
Derek Allard2067d1a2008-11-13 22:59:24 +0000682 // Call the function that corresponds to the rule
683 if ($callback === TRUE)
684 {
685 if ( ! method_exists($this->CI, $rule))
Barry Mienydd671972010-10-04 16:33:58 +0200686 {
Andrey Andreev901573c2012-01-11 01:40:48 +0200687 log_message('debug', 'Unable to find callback validation rule: '.$rule);
688 $result = FALSE;
Derek Allard2067d1a2008-11-13 22:59:24 +0000689 }
Andrey Andreev901573c2012-01-11 01:40:48 +0200690 else
691 {
692 // Run the function and grab the result
693 $result = $this->CI->$rule($postdata, $param);
694 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000695
696 // Re-assign the result to the master data array
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200697 if ($_in_array === TRUE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000698 {
Andrey Andreev78f55772012-04-03 19:59:08 +0300699 $this->_field_data[$row['field']]['postdata'][$cycles] = is_bool($result) ? $postdata : $result;
Derek Allard2067d1a2008-11-13 22:59:24 +0000700 }
701 else
702 {
Andrey Andreev78f55772012-04-03 19:59:08 +0300703 $this->_field_data[$row['field']]['postdata'] = is_bool($result) ? $postdata : $result;
Derek Allard2067d1a2008-11-13 22:59:24 +0000704 }
Barry Mienydd671972010-10-04 16:33:58 +0200705
Derek Allard2067d1a2008-11-13 22:59:24 +0000706 // If the field isn't required and we just processed a callback we'll move on...
Andrey Andreev6de924c2012-01-20 13:18:18 +0200707 if ( ! in_array('required', $rules, TRUE) && $result !== FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000708 {
Derek Allard4e5cf1c2009-07-06 20:53:41 +0000709 continue;
Derek Allard2067d1a2008-11-13 22:59:24 +0000710 }
711 }
Andrey Andreev78f55772012-04-03 19:59:08 +0300712 elseif ( ! method_exists($this, $rule))
Barry Mienydd671972010-10-04 16:33:58 +0200713 {
Andrey Andreev78f55772012-04-03 19:59:08 +0300714 // If our own wrapper function doesn't exist we see if a native PHP function does.
715 // Users can use any native PHP function call that has one param.
716 if (function_exists($rule))
Derek Allard2067d1a2008-11-13 22:59:24 +0000717 {
Andrey Andreev320d37c2012-04-03 20:21:39 +0300718 $result = ($param !== FALSE) ? $rule($postdata, $param) : $rule($postdata);
Barry Mienydd671972010-10-04 16:33:58 +0200719
Andrey Andreev78f55772012-04-03 19:59:08 +0300720 if ($_in_array === TRUE)
721 {
722 $this->_field_data[$row['field']]['postdata'][$cycles] = is_bool($result) ? $postdata : $result;
Derek Allard2067d1a2008-11-13 22:59:24 +0000723 }
patwork02404a12011-04-08 15:45:46 +0200724 else
725 {
Andrey Andreevcec2ba52012-04-03 20:26:38 +0300726 $this->_field_data[$row['field']]['postdata'] = is_bool($result) ? $postdata : $result;
patwork02404a12011-04-08 15:45:46 +0200727 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000728 }
Andrey Andreev901573c2012-01-11 01:40:48 +0200729 else
730 {
Andrey Andreevcec2ba52012-04-03 20:26:38 +0300731 log_message('debug', 'Unable to find validation rule: '.$rule);
732 $result = FALSE;
Andrey Andreev901573c2012-01-11 01:40:48 +0200733 }
Andrey Andreev78f55772012-04-03 19:59:08 +0300734 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000735 else
736 {
Derek Allard2067d1a2008-11-13 22:59:24 +0000737 $result = $this->$rule($postdata, $param);
738
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200739 if ($_in_array === TRUE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000740 {
Andrey Andreev78f55772012-04-03 19:59:08 +0300741 $this->_field_data[$row['field']]['postdata'][$cycles] = is_bool($result) ? $postdata : $result;
Derek Allard2067d1a2008-11-13 22:59:24 +0000742 }
743 else
744 {
Andrey Andreev78f55772012-04-03 19:59:08 +0300745 $this->_field_data[$row['field']]['postdata'] = is_bool($result) ? $postdata : $result;
Derek Allard2067d1a2008-11-13 22:59:24 +0000746 }
747 }
Barry Mienydd671972010-10-04 16:33:58 +0200748
Andrey Andreev901573c2012-01-11 01:40:48 +0200749 // Did the rule test negatively? If so, grab the error.
Derek Allard2067d1a2008-11-13 22:59:24 +0000750 if ($result === FALSE)
Barry Mienydd671972010-10-04 16:33:58 +0200751 {
Derek Allard2067d1a2008-11-13 22:59:24 +0000752 if ( ! isset($this->_error_messages[$rule]))
753 {
Andrey Andreevd4eec9f2012-12-14 11:07:13 +0200754 if (FALSE === ($line = $this->CI->lang->line('form_validation_'.$rule))
755 // DEPRECATED support for non-prefixed keys
756 && FALSE === ($line = $this->CI->lang->line($rule, FALSE)))
Derek Allard2067d1a2008-11-13 22:59:24 +0000757 {
758 $line = 'Unable to access an error message corresponding to your field name.';
Barry Mienydd671972010-10-04 16:33:58 +0200759 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000760 }
761 else
762 {
763 $line = $this->_error_messages[$rule];
764 }
Barry Mienydd671972010-10-04 16:33:58 +0200765
Derek Allard2067d1a2008-11-13 22:59:24 +0000766 // Is the parameter we are inserting into the error message the name
Andrey Andreev901573c2012-01-11 01:40:48 +0200767 // of another field? If so we need to grab its "field label"
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200768 if (isset($this->_field_data[$param], $this->_field_data[$param]['label']))
Derek Allard2067d1a2008-11-13 22:59:24 +0000769 {
Pascal Krietec1895832009-10-13 12:56:43 +0000770 $param = $this->_translate_fieldname($this->_field_data[$param]['label']);
Derek Allard2067d1a2008-11-13 22:59:24 +0000771 }
Barry Mienydd671972010-10-04 16:33:58 +0200772
Derek Allard2067d1a2008-11-13 22:59:24 +0000773 // Build the error message
Eric Roberts41cc0902012-01-24 00:59:44 -0600774 $message = $this->_build_error_msg($line, $this->_translate_fieldname($row['label']), $param);
Derek Allard2067d1a2008-11-13 22:59:24 +0000775
776 // Save the error message
777 $this->_field_data[$row['field']]['error'] = $message;
Barry Mienydd671972010-10-04 16:33:58 +0200778
Derek Allard2067d1a2008-11-13 22:59:24 +0000779 if ( ! isset($this->_error_array[$row['field']]))
780 {
781 $this->_error_array[$row['field']] = $message;
782 }
Barry Mienydd671972010-10-04 16:33:58 +0200783
Derek Allard2067d1a2008-11-13 22:59:24 +0000784 return;
785 }
786 }
787 }
788
789 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200790
Derek Allard2067d1a2008-11-13 22:59:24 +0000791 /**
792 * Translate a field name
793 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000794 * @param string the field name
795 * @return string
Barry Mienydd671972010-10-04 16:33:58 +0200796 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100797 protected function _translate_fieldname($fieldname)
Derek Allard2067d1a2008-11-13 22:59:24 +0000798 {
799 // Do we need to translate the field name?
800 // We look for the prefix lang: to determine this
Andrey Andreev7a7ad782012-11-12 17:21:01 +0200801 if (sscanf($fieldname, 'lang:%s', $line) === 1)
Derek Allard2067d1a2008-11-13 22:59:24 +0000802 {
Derek Jones37f4b9c2011-07-01 17:56:50 -0500803 // Were we able to translate the field name? If not we use $line
Andrey Andreevd4eec9f2012-12-14 11:07:13 +0200804 if (FALSE === ($fieldname = $this->CI->lang->line('form_validation_'.$line))
805 // DEPRECATED support for non-prefixed keys
806 && FALSE === ($fieldname = $this->CI->lang->line($line, FALSE)))
Derek Allard2067d1a2008-11-13 22:59:24 +0000807 {
808 return $line;
809 }
810 }
811
812 return $fieldname;
813 }
814
815 // --------------------------------------------------------------------
Andrey Andreevd4eec9f2012-12-14 11:07:13 +0200816
Eric Roberts41cc0902012-01-24 00:59:44 -0600817 /**
818 * Build an error message using the field and param.
819 *
820 * @param string The error message line
821 * @param string A field's human name
822 * @param mixed A rule's optional parameter
823 * @return string
824 */
825 protected function _build_error_msg($line, $field = '', $param = '')
826 {
827 // Check for %s in the string for legacy support.
Eric Roberts24a13f52012-12-12 07:09:42 -0600828 if (strpos($line, '%s') !== FALSE)
Eric Roberts41cc0902012-01-24 00:59:44 -0600829 {
830 return sprintf($line, $field, $param);
831 }
Andrew Podner4296a652012-12-17 07:51:15 -0500832
Eric Roberts41cc0902012-01-24 00:59:44 -0600833 return str_replace(array('{field}', '{param}'), array($field, $param), $line);
834 }
835
836 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200837
Derek Allard2067d1a2008-11-13 22:59:24 +0000838 /**
nisheeth-barthwala7447d22013-03-21 15:48:10 +0530839 * Checks if the rule is present within the validator
840 *
841 * Permits you to check if a rule is present within the validator
842 *
843 * @param string the field name
844 * @return bool
845 */
846 public function has_rule($field)
847 {
848 return isset($this->_field_data[$field]);
849 }
850
851 // --------------------------------------------------------------------
852
853 /**
Derek Allard2067d1a2008-11-13 22:59:24 +0000854 * Get the value from a form
855 *
856 * Permits you to repopulate a form field with the value it was submitted
857 * with, or, if that value doesn't exist, with the default
858 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000859 * @param string the field name
860 * @param string
Andrey Andreev46ac8812012-02-28 14:32:54 +0200861 * @return string
Barry Mienydd671972010-10-04 16:33:58 +0200862 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100863 public function set_value($field = '', $default = '')
Derek Allard2067d1a2008-11-13 22:59:24 +0000864 {
Andrey Andreev46ac8812012-02-28 14:32:54 +0200865 if ( ! isset($this->_field_data[$field], $this->_field_data[$field]['postdata']))
Derek Allard2067d1a2008-11-13 22:59:24 +0000866 {
867 return $default;
868 }
Barry Mienydd671972010-10-04 16:33:58 +0200869
Phil Sturgeon5c561802011-01-05 16:31:59 +0000870 // If the data is an array output them one at a time.
Greg Aker03abee32011-12-25 00:31:29 -0600871 // E.g: form_input('name[]', set_value('name[]');
Phil Sturgeon5c561802011-01-05 16:31:59 +0000872 if (is_array($this->_field_data[$field]['postdata']))
873 {
874 return array_shift($this->_field_data[$field]['postdata']);
875 }
Phil Sturgeonc3828712011-01-19 12:31:47 +0000876
Derek Allard2067d1a2008-11-13 22:59:24 +0000877 return $this->_field_data[$field]['postdata'];
878 }
Barry Mienydd671972010-10-04 16:33:58 +0200879
Derek Allard2067d1a2008-11-13 22:59:24 +0000880 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200881
Derek Allard2067d1a2008-11-13 22:59:24 +0000882 /**
883 * Set Select
884 *
885 * Enables pull-down lists to be set to the value the user
886 * selected in the event of an error
887 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000888 * @param string
889 * @param string
Timothy Warren0688ac92012-04-20 10:25:04 -0400890 * @param bool
Derek Allard2067d1a2008-11-13 22:59:24 +0000891 * @return string
Barry Mienydd671972010-10-04 16:33:58 +0200892 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100893 public function set_select($field = '', $value = '', $default = FALSE)
Barry Mienydd671972010-10-04 16:33:58 +0200894 {
Andrey Andreev46ac8812012-02-28 14:32:54 +0200895 if ( ! isset($this->_field_data[$field], $this->_field_data[$field]['postdata']))
Derek Allard2067d1a2008-11-13 22:59:24 +0000896 {
Andrey Andreev6de924c2012-01-20 13:18:18 +0200897 return ($default === TRUE && count($this->_field_data) === 0) ? ' selected="selected"' : '';
Derek Allard2067d1a2008-11-13 22:59:24 +0000898 }
Barry Mienydd671972010-10-04 16:33:58 +0200899
Derek Allard2067d1a2008-11-13 22:59:24 +0000900 $field = $this->_field_data[$field]['postdata'];
Andrey Andreeva587a932013-10-23 19:57:46 +0300901 $value = (string) $value;
Derek Allard2067d1a2008-11-13 22:59:24 +0000902 if (is_array($field))
903 {
Andrey Andreeva587a932013-10-23 19:57:46 +0300904 // Note: in_array('', array(0)) returns TRUE, do not use it
905 foreach ($field as &$v)
Derek Allard2067d1a2008-11-13 22:59:24 +0000906 {
Andrey Andreeva587a932013-10-23 19:57:46 +0300907 if ($value === $v)
908 {
909 return ' selected="selected"';
910 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000911 }
Andrey Andreeva587a932013-10-23 19:57:46 +0300912
913 return '';
Derek Allard2067d1a2008-11-13 22:59:24 +0000914 }
Alex Bilbied261b1e2012-06-02 11:12:16 +0100915 elseif (($field === '' OR $value === '') OR ($field !== $value))
Derek Allard2067d1a2008-11-13 22:59:24 +0000916 {
Andrey Andreev901573c2012-01-11 01:40:48 +0200917 return '';
Derek Allard2067d1a2008-11-13 22:59:24 +0000918 }
Barry Mienydd671972010-10-04 16:33:58 +0200919
Derek Allard2067d1a2008-11-13 22:59:24 +0000920 return ' selected="selected"';
921 }
Barry Mienydd671972010-10-04 16:33:58 +0200922
Derek Allard2067d1a2008-11-13 22:59:24 +0000923 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200924
Derek Allard2067d1a2008-11-13 22:59:24 +0000925 /**
926 * Set Radio
927 *
928 * Enables radio buttons to be set to the value the user
929 * selected in the event of an error
930 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000931 * @param string
932 * @param string
Timothy Warren0688ac92012-04-20 10:25:04 -0400933 * @param bool
Derek Allard2067d1a2008-11-13 22:59:24 +0000934 * @return string
Barry Mienydd671972010-10-04 16:33:58 +0200935 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100936 public function set_radio($field = '', $value = '', $default = FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000937 {
Andrey Andreev46ac8812012-02-28 14:32:54 +0200938 if ( ! isset($this->_field_data[$field], $this->_field_data[$field]['postdata']))
Derek Allard2067d1a2008-11-13 22:59:24 +0000939 {
Andrey Andreev6de924c2012-01-20 13:18:18 +0200940 return ($default === TRUE && count($this->_field_data) === 0) ? ' checked="checked"' : '';
Derek Allard2067d1a2008-11-13 22:59:24 +0000941 }
Barry Mienydd671972010-10-04 16:33:58 +0200942
Derek Allard2067d1a2008-11-13 22:59:24 +0000943 $field = $this->_field_data[$field]['postdata'];
Andrey Andreeva587a932013-10-23 19:57:46 +0300944 $value = (string) $value;
Derek Allard2067d1a2008-11-13 22:59:24 +0000945 if (is_array($field))
946 {
Andrey Andreeva587a932013-10-23 19:57:46 +0300947 // Note: in_array('', array(0)) returns TRUE, do not use it
948 foreach ($field as &$v)
Derek Allard2067d1a2008-11-13 22:59:24 +0000949 {
Andrey Andreeva587a932013-10-23 19:57:46 +0300950 if ($value === $v)
951 {
952 return ' checked="checked"';
953 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000954 }
Andrey Andreeva587a932013-10-23 19:57:46 +0300955
956 return '';
Derek Allard2067d1a2008-11-13 22:59:24 +0000957 }
Alex Bilbied261b1e2012-06-02 11:12:16 +0100958 elseif (($field === '' OR $value === '') OR ($field !== $value))
Derek Allard2067d1a2008-11-13 22:59:24 +0000959 {
Andrey Andreev901573c2012-01-11 01:40:48 +0200960 return '';
Derek Allard2067d1a2008-11-13 22:59:24 +0000961 }
Barry Mienydd671972010-10-04 16:33:58 +0200962
Derek Allard2067d1a2008-11-13 22:59:24 +0000963 return ' checked="checked"';
964 }
Barry Mienydd671972010-10-04 16:33:58 +0200965
Derek Allard2067d1a2008-11-13 22:59:24 +0000966 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200967
Derek Allard2067d1a2008-11-13 22:59:24 +0000968 /**
969 * Set Checkbox
970 *
971 * Enables checkboxes to be set to the value the user
972 * selected in the event of an error
973 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000974 * @param string
975 * @param string
Timothy Warren0688ac92012-04-20 10:25:04 -0400976 * @param bool
Derek Allard2067d1a2008-11-13 22:59:24 +0000977 * @return string
Barry Mienydd671972010-10-04 16:33:58 +0200978 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100979 public function set_checkbox($field = '', $value = '', $default = FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000980 {
Andrey Andreev8dc532d2011-12-24 17:57:54 +0200981 // Logic is exactly the same as for radio fields
982 return $this->set_radio($field, $value, $default);
Derek Allard2067d1a2008-11-13 22:59:24 +0000983 }
Barry Mienydd671972010-10-04 16:33:58 +0200984
Derek Allard2067d1a2008-11-13 22:59:24 +0000985 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200986
Derek Allard2067d1a2008-11-13 22:59:24 +0000987 /**
988 * Required
989 *
Derek Allard2067d1a2008-11-13 22:59:24 +0000990 * @param string
991 * @return bool
992 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +0100993 public function required($str)
Derek Allard2067d1a2008-11-13 22:59:24 +0000994 {
Andrey Andreev78f55772012-04-03 19:59:08 +0300995 return is_array($str) ? (bool) count($str) : (trim($str) !== '');
Derek Allard2067d1a2008-11-13 22:59:24 +0000996 }
Barry Mienydd671972010-10-04 16:33:58 +0200997
Derek Allard2067d1a2008-11-13 22:59:24 +0000998 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +0200999
Derek Allard2067d1a2008-11-13 22:59:24 +00001000 /**
Dan Horrigan2280e8e2010-12-15 10:16:38 -05001001 * Performs a Regular Expression match test.
1002 *
Dan Horrigan2280e8e2010-12-15 10:16:38 -05001003 * @param string
Andrey Andreev78f55772012-04-03 19:59:08 +03001004 * @param string regex
Dan Horrigan2280e8e2010-12-15 10:16:38 -05001005 * @return bool
1006 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001007 public function regex_match($str, $regex)
Dan Horrigan2280e8e2010-12-15 10:16:38 -05001008 {
Andrey Andreev8dc532d2011-12-24 17:57:54 +02001009 return (bool) preg_match($regex, $str);
Dan Horrigan2280e8e2010-12-15 10:16:38 -05001010 }
1011
1012 // --------------------------------------------------------------------
1013
1014 /**
Derek Allard2067d1a2008-11-13 22:59:24 +00001015 * Match one field to another
1016 *
Andrey Andreeva779b2c2012-10-26 16:25:47 +03001017 * @param string $str string to compare against
1018 * @param string $field
Derek Allard2067d1a2008-11-13 22:59:24 +00001019 * @return bool
1020 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001021 public function matches($str, $field)
Derek Allard2067d1a2008-11-13 22:59:24 +00001022 {
Andrey Andreeva779b2c2012-10-26 16:25:47 +03001023 return isset($this->_field_data[$field], $this->_field_data[$field]['postdata'])
1024 ? ($str === $this->_field_data[$field]['postdata'])
1025 : FALSE;
Derek Allard2067d1a2008-11-13 22:59:24 +00001026 }
Derek Allard2067d1a2008-11-13 22:59:24 +00001027
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001028 // --------------------------------------------------------------------
1029
1030 /**
Raul Baldner Juniorf38564d2012-10-11 11:32:23 -03001031 * Differs from another field
1032 *
1033 * @param string
1034 * @param string field
1035 * @return bool
1036 */
1037 public function differs($str, $field)
1038 {
1039 return ! (isset($this->_field_data[$field]) && $this->_field_data[$field]['postdata'] === $str);
Derek Allard2067d1a2008-11-13 22:59:24 +00001040 }
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001041
1042 // --------------------------------------------------------------------
1043
1044 /**
Andrey Andreevd09d6502012-01-03 06:38:33 +02001045 * Is Unique
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001046 *
Andrey Andreevd09d6502012-01-03 06:38:33 +02001047 * Check if the input value doesn't already exist
1048 * in the specified database field.
1049 *
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001050 * @param string
Andrey Andreev78f55772012-04-03 19:59:08 +03001051 * @param string field
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001052 * @return bool
1053 */
1054 public function is_unique($str, $field)
1055 {
Andrey Andreev7a7ad782012-11-12 17:21:01 +02001056 sscanf($field, '%[^.].%[^.]', $table, $field);
Eric Barnescccde962011-12-04 00:01:17 -05001057 if (isset($this->CI->db))
1058 {
1059 $query = $this->CI->db->limit(1)->get_where($table, array($field => $str));
1060 return $query->num_rows() === 0;
1061 }
1062 return FALSE;
Greg Aker03abee32011-12-25 00:31:29 -06001063 }
Barry Mienydd671972010-10-04 16:33:58 +02001064
Derek Allard2067d1a2008-11-13 22:59:24 +00001065 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001066
Derek Allard2067d1a2008-11-13 22:59:24 +00001067 /**
1068 * Minimum Length
1069 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001070 * @param string
Michiel Vugteveena8221ad2012-06-14 23:26:34 +02001071 * @param string
Derek Allard2067d1a2008-11-13 22:59:24 +00001072 * @return bool
Barry Mienydd671972010-10-04 16:33:58 +02001073 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001074 public function min_length($str, $val)
Derek Allard2067d1a2008-11-13 22:59:24 +00001075 {
Michiel Vugteveenceaf8872012-06-15 11:56:24 +02001076 if ( ! is_numeric($val))
Derek Allard2067d1a2008-11-13 22:59:24 +00001077 {
1078 return FALSE;
1079 }
Michiel Vugteveenceaf8872012-06-15 11:56:24 +02001080 else
1081 {
1082 $val = (int) $val;
1083 }
Derek Allard2067d1a2008-11-13 22:59:24 +00001084
Andrey Andreev78f55772012-04-03 19:59:08 +03001085 return (MB_ENABLED === TRUE)
1086 ? ($val <= mb_strlen($str))
Michiel Vugteveenceaf8872012-06-15 11:56:24 +02001087 : ($val <= strlen($str));
Derek Allard2067d1a2008-11-13 22:59:24 +00001088 }
Barry Mienydd671972010-10-04 16:33:58 +02001089
Derek Allard2067d1a2008-11-13 22:59:24 +00001090 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001091
Derek Allard2067d1a2008-11-13 22:59:24 +00001092 /**
1093 * Max Length
1094 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001095 * @param string
Michiel Vugteveena8221ad2012-06-14 23:26:34 +02001096 * @param string
Derek Allard2067d1a2008-11-13 22:59:24 +00001097 * @return bool
Barry Mienydd671972010-10-04 16:33:58 +02001098 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001099 public function max_length($str, $val)
Derek Allard2067d1a2008-11-13 22:59:24 +00001100 {
Michiel Vugteveenceaf8872012-06-15 11:56:24 +02001101 if ( ! is_numeric($val))
Derek Allard2067d1a2008-11-13 22:59:24 +00001102 {
1103 return FALSE;
1104 }
Michiel Vugteveenceaf8872012-06-15 11:56:24 +02001105 else
1106 {
1107 $val = (int) $val;
1108 }
Derek Allard2067d1a2008-11-13 22:59:24 +00001109
Andrey Andreev78f55772012-04-03 19:59:08 +03001110 return (MB_ENABLED === TRUE)
1111 ? ($val >= mb_strlen($str))
1112 : ($val >= strlen($str));
Derek Allard2067d1a2008-11-13 22:59:24 +00001113 }
Barry Mienydd671972010-10-04 16:33:58 +02001114
Derek Allard2067d1a2008-11-13 22:59:24 +00001115 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001116
Derek Allard2067d1a2008-11-13 22:59:24 +00001117 /**
1118 * Exact Length
1119 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001120 * @param string
Michiel Vugteveeneccde132012-06-14 23:22:26 +02001121 * @param string
Derek Allard2067d1a2008-11-13 22:59:24 +00001122 * @return bool
Barry Mienydd671972010-10-04 16:33:58 +02001123 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001124 public function exact_length($str, $val)
Derek Allard2067d1a2008-11-13 22:59:24 +00001125 {
Michiel Vugteveenceaf8872012-06-15 11:56:24 +02001126 if ( ! is_numeric($val))
Derek Allard2067d1a2008-11-13 22:59:24 +00001127 {
1128 return FALSE;
1129 }
Michiel Vugteveenceaf8872012-06-15 11:56:24 +02001130 else
1131 {
1132 $val = (int) $val;
1133 }
Derek Allard2067d1a2008-11-13 22:59:24 +00001134
Andrey Andreev78f55772012-04-03 19:59:08 +03001135 return (MB_ENABLED === TRUE)
Michiel Vugteveenceaf8872012-06-15 11:56:24 +02001136 ? (mb_strlen($str) === $val)
1137 : (strlen($str) === $val);
Derek Allard2067d1a2008-11-13 22:59:24 +00001138 }
Barry Mienydd671972010-10-04 16:33:58 +02001139
Derek Allard2067d1a2008-11-13 22:59:24 +00001140 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001141
Derek Allard2067d1a2008-11-13 22:59:24 +00001142 /**
Andrey Andreevdaaca882012-11-26 22:16:12 +02001143 * Valid URL
1144 *
1145 * @param string $str
1146 * @return bool
1147 */
1148 public function valid_url($str)
1149 {
1150 if (empty($str))
1151 {
1152 return FALSE;
1153 }
1154 elseif (preg_match('/^(?:([^:]*)\:)?\/\/(.+)$/', $str, $matches))
1155 {
1156 if (empty($matches[2]))
1157 {
1158 return FALSE;
1159 }
1160 elseif ( ! in_array($matches[1], array('http', 'https'), TRUE))
1161 {
1162 return FALSE;
1163 }
1164
1165 $str = $matches[2];
1166 }
1167
1168 $str = 'http://'.$str;
1169
1170 // There's a bug affecting PHP 5.2.13, 5.3.2 that considers the
1171 // underscore to be a valid hostname character instead of a dash.
1172 // Reference: https://bugs.php.net/bug.php?id=51192
1173 if (version_compare(PHP_VERSION, '5.2.13', '==') === 0 OR version_compare(PHP_VERSION, '5.3.2', '==') === 0)
1174 {
1175 sscanf($str, 'http://%[^/]', $host);
1176 $str = substr_replace($str, strtr($host, array('_' => '-', '-' => '_')), 7, strlen($host));
1177 }
1178
1179 return (filter_var($str, FILTER_VALIDATE_URL) !== FALSE);
Derek Allard2067d1a2008-11-13 22:59:24 +00001180 }
1181
1182 // --------------------------------------------------------------------
1183
1184 /**
1185 * Valid Email
1186 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001187 * @param string
1188 * @return bool
Barry Mienydd671972010-10-04 16:33:58 +02001189 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001190 public function valid_email($str)
Derek Allard2067d1a2008-11-13 22:59:24 +00001191 {
Andrey Andreev580388b2012-06-27 15:43:46 +03001192 return (bool) filter_var($str, FILTER_VALIDATE_EMAIL);
Derek Allard2067d1a2008-11-13 22:59:24 +00001193 }
1194
1195 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001196
Derek Allard2067d1a2008-11-13 22:59:24 +00001197 /**
1198 * Valid Emails
1199 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001200 * @param string
1201 * @return bool
Barry Mienydd671972010-10-04 16:33:58 +02001202 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001203 public function valid_emails($str)
Derek Allard2067d1a2008-11-13 22:59:24 +00001204 {
1205 if (strpos($str, ',') === FALSE)
1206 {
1207 return $this->valid_email(trim($str));
1208 }
Barry Mienydd671972010-10-04 16:33:58 +02001209
Pascal Kriete14287f32011-02-14 13:39:34 -05001210 foreach (explode(',', $str) as $email)
Derek Allard2067d1a2008-11-13 22:59:24 +00001211 {
Andrey Andreev8dc532d2011-12-24 17:57:54 +02001212 if (trim($email) !== '' && $this->valid_email(trim($email)) === FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +00001213 {
1214 return FALSE;
1215 }
1216 }
Barry Mienydd671972010-10-04 16:33:58 +02001217
Derek Allard2067d1a2008-11-13 22:59:24 +00001218 return TRUE;
1219 }
1220
1221 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001222
Derek Allard2067d1a2008-11-13 22:59:24 +00001223 /**
1224 * Validate IP Address
1225 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001226 * @param string
Andrey Andreev5a257182012-06-10 06:18:14 +03001227 * @param string 'ipv4' or 'ipv6' to validate a specific IP format
Bo-Yi Wu013c8952011-09-12 15:03:44 +08001228 * @return bool
Derek Allard2067d1a2008-11-13 22:59:24 +00001229 */
Andrey Andreev5a257182012-06-10 06:18:14 +03001230 public function valid_ip($ip, $which = '')
Derek Allard2067d1a2008-11-13 22:59:24 +00001231 {
Andrey Andreev5a257182012-06-10 06:18:14 +03001232 return $this->CI->input->valid_ip($ip, $which);
Derek Allard2067d1a2008-11-13 22:59:24 +00001233 }
1234
1235 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001236
Derek Allard2067d1a2008-11-13 22:59:24 +00001237 /**
1238 * Alpha
1239 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001240 * @param string
1241 * @return bool
Barry Mienydd671972010-10-04 16:33:58 +02001242 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001243 public function alpha($str)
Derek Allard2067d1a2008-11-13 22:59:24 +00001244 {
Andrey Andreevacb962e2012-06-27 12:04:24 +03001245 return ctype_alpha($str);
Derek Allard2067d1a2008-11-13 22:59:24 +00001246 }
Barry Mienydd671972010-10-04 16:33:58 +02001247
Derek Allard2067d1a2008-11-13 22:59:24 +00001248 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001249
Derek Allard2067d1a2008-11-13 22:59:24 +00001250 /**
1251 * Alpha-numeric
1252 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001253 * @param string
1254 * @return bool
Barry Mienydd671972010-10-04 16:33:58 +02001255 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001256 public function alpha_numeric($str)
Derek Allard2067d1a2008-11-13 22:59:24 +00001257 {
Andrey Andreevacb962e2012-06-27 12:04:24 +03001258 return ctype_alnum((string) $str);
Derek Allard2067d1a2008-11-13 22:59:24 +00001259 }
Barry Mienydd671972010-10-04 16:33:58 +02001260
Derek Allard2067d1a2008-11-13 22:59:24 +00001261 // --------------------------------------------------------------------
Sajan Parikh2d1608a2013-02-02 08:00:39 -06001262
1263 /**
1264 * Alpha-numeric w/ spaces
1265 *
1266 * @param string
1267 * @return bool
1268 */
1269 public function alpha_numeric_spaces($str)
1270 {
Sajan Parikhdf3bfed2013-02-04 12:25:49 -06001271 return (bool) preg_match('/^[A-Z0-9 ]+$/i', $str);
Sajan Parikh2d1608a2013-02-02 08:00:39 -06001272 }
1273
1274 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001275
Derek Allard2067d1a2008-11-13 22:59:24 +00001276 /**
1277 * Alpha-numeric with underscores and dashes
1278 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001279 * @param string
1280 * @return bool
Barry Mienydd671972010-10-04 16:33:58 +02001281 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001282 public function alpha_dash($str)
Derek Allard2067d1a2008-11-13 22:59:24 +00001283 {
Andrey Andreev8dc532d2011-12-24 17:57:54 +02001284 return (bool) preg_match('/^[a-z0-9_-]+$/i', $str);
Derek Allard2067d1a2008-11-13 22:59:24 +00001285 }
Barry Mienydd671972010-10-04 16:33:58 +02001286
Derek Allard2067d1a2008-11-13 22:59:24 +00001287 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001288
Derek Allard2067d1a2008-11-13 22:59:24 +00001289 /**
1290 * Numeric
1291 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001292 * @param string
1293 * @return bool
Barry Mienydd671972010-10-04 16:33:58 +02001294 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001295 public function numeric($str)
Derek Allard2067d1a2008-11-13 22:59:24 +00001296 {
Andrey Andreev8dc532d2011-12-24 17:57:54 +02001297 return (bool) preg_match('/^[\-+]?[0-9]*\.?[0-9]+$/', $str);
Derek Allard2067d1a2008-11-13 22:59:24 +00001298
1299 }
1300
1301 // --------------------------------------------------------------------
1302
Barry Mienydd671972010-10-04 16:33:58 +02001303 /**
Derek Allard2067d1a2008-11-13 22:59:24 +00001304 * Integer
1305 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001306 * @param string
1307 * @return bool
Barry Mienydd671972010-10-04 16:33:58 +02001308 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001309 public function integer($str)
Derek Allard2067d1a2008-11-13 22:59:24 +00001310 {
Phil Sturgeonef112c02011-02-07 13:01:47 +00001311 return (bool) preg_match('/^[\-+]?[0-9]+$/', $str);
1312 }
1313
1314 // --------------------------------------------------------------------
1315
1316 /**
1317 * Decimal number
1318 *
Phil Sturgeonef112c02011-02-07 13:01:47 +00001319 * @param string
1320 * @return bool
1321 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001322 public function decimal($str)
Phil Sturgeonef112c02011-02-07 13:01:47 +00001323 {
1324 return (bool) preg_match('/^[\-+]?[0-9]+\.[0-9]+$/', $str);
1325 }
1326
1327 // --------------------------------------------------------------------
1328
1329 /**
Andrey Andreevc68905a2012-02-02 21:41:54 +02001330 * Greater than
Phil Sturgeonef112c02011-02-07 13:01:47 +00001331 *
Phil Sturgeonef112c02011-02-07 13:01:47 +00001332 * @param string
Timothy Warren0688ac92012-04-20 10:25:04 -04001333 * @param int
Phil Sturgeonef112c02011-02-07 13:01:47 +00001334 * @return bool
1335 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001336 public function greater_than($str, $min)
Phil Sturgeonef112c02011-02-07 13:01:47 +00001337 {
Andrey Andreev78f55772012-04-03 19:59:08 +03001338 return is_numeric($str) ? ($str > $min) : FALSE;
Phil Sturgeonef112c02011-02-07 13:01:47 +00001339 }
1340
1341 // --------------------------------------------------------------------
1342
1343 /**
Nick Busey98c347d2012-02-02 11:07:03 -07001344 * Equal to or Greater than
1345 *
Nick Busey98c347d2012-02-02 11:07:03 -07001346 * @param string
Timothy Warren0688ac92012-04-20 10:25:04 -04001347 * @param int
Nick Busey98c347d2012-02-02 11:07:03 -07001348 * @return bool
1349 */
Andrey Andreev3b2c5082012-03-07 22:49:24 +02001350 public function greater_than_equal_to($str, $min)
Nick Busey98c347d2012-02-02 11:07:03 -07001351 {
Andrey Andreev78f55772012-04-03 19:59:08 +03001352 return is_numeric($str) ? ($str >= $min) : FALSE;
Phil Sturgeonef112c02011-02-07 13:01:47 +00001353 }
1354
1355 // --------------------------------------------------------------------
1356
1357 /**
1358 * Less than
1359 *
Phil Sturgeonef112c02011-02-07 13:01:47 +00001360 * @param string
Timothy Warren0688ac92012-04-20 10:25:04 -04001361 * @param int
Phil Sturgeonef112c02011-02-07 13:01:47 +00001362 * @return bool
1363 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001364 public function less_than($str, $max)
Phil Sturgeonef112c02011-02-07 13:01:47 +00001365 {
Andrey Andreev78f55772012-04-03 19:59:08 +03001366 return is_numeric($str) ? ($str < $max) : FALSE;
Derek Allard2067d1a2008-11-13 22:59:24 +00001367 }
Derek Allard2067d1a2008-11-13 22:59:24 +00001368
1369 // --------------------------------------------------------------------
1370
Barry Mienydd671972010-10-04 16:33:58 +02001371 /**
Nick Busey98c347d2012-02-02 11:07:03 -07001372 * Equal to or Less than
1373 *
Nick Busey98c347d2012-02-02 11:07:03 -07001374 * @param string
Timothy Warren0688ac92012-04-20 10:25:04 -04001375 * @param int
Nick Busey98c347d2012-02-02 11:07:03 -07001376 * @return bool
1377 */
Andrey Andreev3b2c5082012-03-07 22:49:24 +02001378 public function less_than_equal_to($str, $max)
Nick Busey98c347d2012-02-02 11:07:03 -07001379 {
Andrey Andreev78f55772012-04-03 19:59:08 +03001380 return is_numeric($str) ? ($str <= $max) : FALSE;
Derek Allard2067d1a2008-11-13 22:59:24 +00001381 }
1382
1383 // --------------------------------------------------------------------
1384
Barry Mienydd671972010-10-04 16:33:58 +02001385 /**
Derek Jones37f4b9c2011-07-01 17:56:50 -05001386 * Is a Natural number (0,1,2,3, etc.)
Barry Mienydd671972010-10-04 16:33:58 +02001387 *
Barry Mienydd671972010-10-04 16:33:58 +02001388 * @param string
1389 * @return bool
1390 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001391 public function is_natural($str)
Barry Mienydd671972010-10-04 16:33:58 +02001392 {
Andrey Andreevacb962e2012-06-27 12:04:24 +03001393 return ctype_digit((string) $str);
Barry Mienydd671972010-10-04 16:33:58 +02001394 }
1395
1396 // --------------------------------------------------------------------
1397
1398 /**
Derek Jones37f4b9c2011-07-01 17:56:50 -05001399 * Is a Natural number, but not a zero (1,2,3, etc.)
Barry Mienydd671972010-10-04 16:33:58 +02001400 *
Barry Mienydd671972010-10-04 16:33:58 +02001401 * @param string
1402 * @return bool
1403 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001404 public function is_natural_no_zero($str)
Barry Mienydd671972010-10-04 16:33:58 +02001405 {
Andrey Andreevacb962e2012-06-27 12:04:24 +03001406 return ($str != 0 && ctype_digit((string) $str));
Barry Mienydd671972010-10-04 16:33:58 +02001407 }
1408
Derek Allard2067d1a2008-11-13 22:59:24 +00001409 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001410
Derek Allard2067d1a2008-11-13 22:59:24 +00001411 /**
1412 * Valid Base64
1413 *
1414 * Tests a string for characters outside of the Base64 alphabet
1415 * as defined by RFC 2045 http://www.faqs.org/rfcs/rfc2045
1416 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001417 * @param string
1418 * @return bool
1419 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001420 public function valid_base64($str)
Derek Allard2067d1a2008-11-13 22:59:24 +00001421 {
Andrey Andreevcd9797a2013-06-28 14:03:48 +03001422 return (base64_encode(base64_decode($str)) === $str);
Derek Allard2067d1a2008-11-13 22:59:24 +00001423 }
Barry Mienydd671972010-10-04 16:33:58 +02001424
Derek Allard2067d1a2008-11-13 22:59:24 +00001425 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001426
Derek Allard2067d1a2008-11-13 22:59:24 +00001427 /**
1428 * Prep data for form
1429 *
1430 * This function allows HTML to be safely shown in a form.
1431 * Special characters are converted.
1432 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001433 * @param string
1434 * @return string
1435 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001436 public function prep_for_form($data = '')
Derek Allard2067d1a2008-11-13 22:59:24 +00001437 {
Andrey Andreev7c4d1062012-11-01 15:14:34 +02001438 if ($this->_safe_form_data === FALSE OR empty($data))
1439 {
1440 return $data;
1441 }
1442
Derek Allard2067d1a2008-11-13 22:59:24 +00001443 if (is_array($data))
1444 {
1445 foreach ($data as $key => $val)
1446 {
1447 $data[$key] = $this->prep_for_form($val);
1448 }
Barry Mienydd671972010-10-04 16:33:58 +02001449
Derek Allard2067d1a2008-11-13 22:59:24 +00001450 return $data;
1451 }
Barry Mienydd671972010-10-04 16:33:58 +02001452
Andrey Andreev901573c2012-01-11 01:40:48 +02001453 return str_replace(array("'", '"', '<', '>'), array('&#39;', '&quot;', '&lt;', '&gt;'), stripslashes($data));
Derek Allard2067d1a2008-11-13 22:59:24 +00001454 }
Barry Mienydd671972010-10-04 16:33:58 +02001455
Derek Allard2067d1a2008-11-13 22:59:24 +00001456 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001457
Derek Allard2067d1a2008-11-13 22:59:24 +00001458 /**
1459 * Prep URL
1460 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001461 * @param string
1462 * @return string
Barry Mienydd671972010-10-04 16:33:58 +02001463 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001464 public function prep_url($str = '')
Derek Allard2067d1a2008-11-13 22:59:24 +00001465 {
Alex Bilbied261b1e2012-06-02 11:12:16 +01001466 if ($str === 'http://' OR $str === '')
Derek Allard2067d1a2008-11-13 22:59:24 +00001467 {
1468 return '';
1469 }
Barry Mienydd671972010-10-04 16:33:58 +02001470
Andrey Andreev901573c2012-01-11 01:40:48 +02001471 if (strpos($str, 'http://') !== 0 && strpos($str, 'https://') !== 0)
Derek Allard2067d1a2008-11-13 22:59:24 +00001472 {
Andrey Andreev901573c2012-01-11 01:40:48 +02001473 return 'http://'.$str;
Derek Allard2067d1a2008-11-13 22:59:24 +00001474 }
Barry Mienydd671972010-10-04 16:33:58 +02001475
Derek Allard2067d1a2008-11-13 22:59:24 +00001476 return $str;
1477 }
Barry Mienydd671972010-10-04 16:33:58 +02001478
Derek Allard2067d1a2008-11-13 22:59:24 +00001479 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001480
Derek Allard2067d1a2008-11-13 22:59:24 +00001481 /**
1482 * Strip Image Tags
1483 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001484 * @param string
1485 * @return string
Barry Mienydd671972010-10-04 16:33:58 +02001486 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001487 public function strip_image_tags($str)
Derek Allard2067d1a2008-11-13 22:59:24 +00001488 {
Andrey Andreev1a24a9d2012-06-27 00:52:47 +03001489 return $this->CI->security->strip_image_tags($str);
Derek Allard2067d1a2008-11-13 22:59:24 +00001490 }
Barry Mienydd671972010-10-04 16:33:58 +02001491
Derek Allard2067d1a2008-11-13 22:59:24 +00001492 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001493
Derek Allard2067d1a2008-11-13 22:59:24 +00001494 /**
1495 * XSS Clean
1496 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001497 * @param string
1498 * @return string
Barry Mienydd671972010-10-04 16:33:58 +02001499 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001500 public function xss_clean($str)
Derek Allard2067d1a2008-11-13 22:59:24 +00001501 {
Derek Jones5640a712010-04-23 11:22:40 -05001502 return $this->CI->security->xss_clean($str);
Derek Allard2067d1a2008-11-13 22:59:24 +00001503 }
Barry Mienydd671972010-10-04 16:33:58 +02001504
Derek Allard2067d1a2008-11-13 22:59:24 +00001505 // --------------------------------------------------------------------
Barry Mienydd671972010-10-04 16:33:58 +02001506
Derek Allard2067d1a2008-11-13 22:59:24 +00001507 /**
1508 * Convert PHP tags to entities
1509 *
Derek Allard2067d1a2008-11-13 22:59:24 +00001510 * @param string
1511 * @return string
Barry Mienydd671972010-10-04 16:33:58 +02001512 */
Phil Sturgeon3837ae72011-05-09 21:12:26 +01001513 public function encode_php_tags($str)
Derek Allard2067d1a2008-11-13 22:59:24 +00001514 {
Andrey Andreev838a9d62012-12-03 14:37:47 +02001515 return str_replace(array('<?', '?>'), array('&lt;?', '?&gt;'), $str);
Derek Allard2067d1a2008-11-13 22:59:24 +00001516 }
1517
JonoB099c4782012-03-04 14:37:30 +00001518 // --------------------------------------------------------------------
Andrey Andreevc8da4fe2012-03-04 19:20:33 +02001519
1520 /**
1521 * Reset validation vars
1522 *
1523 * Prevents subsequent validation routines from being affected by the
JonoB099c4782012-03-04 14:37:30 +00001524 * results of any previous validation routine due to the CI singleton.
Andrey Andreevc8da4fe2012-03-04 19:20:33 +02001525 *
Andrey Andreev3b2c5082012-03-07 22:49:24 +02001526 * @return void
Andrey Andreevc8da4fe2012-03-04 19:20:33 +02001527 */
JonoB883f80f2012-03-05 09:51:27 +00001528 public function reset_validation()
Andrey Andreevc8da4fe2012-03-04 19:20:33 +02001529 {
JonoB099c4782012-03-04 14:37:30 +00001530 $this->_field_data = array();
1531 $this->_config_rules = array();
1532 $this->_error_array = array();
1533 $this->_error_messages = array();
1534 $this->error_string = '';
Andrey Andreevc8da4fe2012-03-04 19:20:33 +02001535 }
1536
Derek Allard2067d1a2008-11-13 22:59:24 +00001537}
Derek Allard2067d1a2008-11-13 22:59:24 +00001538
1539/* End of file Form_validation.php */
Eric Roberts24a13f52012-12-12 07:09:42 -06001540/* Location: ./system/libraries/Form_validation.php */