Passed
Push — 1.0.0-dev ( 7e13dc...c7a39c )
by nguereza
06:11
created
tests/include/common.php 1 patch
Spacing   +36 added lines, -36 removed lines patch added patch discarded remove patch
@@ -29,14 +29,14 @@  discard block
 block discarded – undo
29 29
 		//put the first letter of class to upper case 
30 30
 		$class = ucfirst($class);
31 31
 		static $classes = array();
32
-		if(isset($classes[$class]) /*hack for duplicate log Logger name*/ && $class != 'Log'){
32
+		if (isset($classes[$class]) /*hack for duplicate log Logger name*/ && $class != 'Log') {
33 33
 			return $classes[$class];
34 34
 		}
35 35
 		$found = false;
36 36
 		foreach (array(ROOT_PATH, CORE_PATH) as $path) {
37 37
 			$file = $path . $dir . '/' . $class . '.php';
38
-			if(file_exists($file)){
39
-				if(class_exists($class, false) === false){
38
+			if (file_exists($file)) {
39
+				if (class_exists($class, false) === false) {
40 40
 					require_once $file;
41 41
 				}
42 42
 				//already found
@@ -44,7 +44,7 @@  discard block
 block discarded – undo
44 44
 				break;
45 45
 			}
46 46
 		}
47
-		if(! $found){
47
+		if (!$found) {
48 48
 			//can't use show_error() at this time because some dependencies not yet loaded
49 49
 			set_http_status_header(503);
50 50
 			echo 'Cannot find the class [' . $class . ']';
@@ -54,7 +54,7 @@  discard block
 block discarded – undo
54 54
 		/*
55 55
 		   TODO use the best method to get the Log instance
56 56
 		 */
57
-		if($class == 'Log'){
57
+		if ($class == 'Log') {
58 58
 			//can't use the instruction like "return new Log()" 
59 59
 			//because we need return the reference instance of the loaded class.
60 60
 			$log = new Log();
@@ -72,7 +72,7 @@  discard block
 block discarded – undo
72 72
 
73 73
 	function & class_loaded($class = null){
74 74
 		static $list = array();
75
-		if($class != null){
75
+		if ($class != null) {
76 76
 			$list[strtolower($class)] = $class;
77 77
 		}
78 78
 		return $list;
@@ -80,7 +80,7 @@  discard block
 block discarded – undo
80 80
 
81 81
 	function & load_configurations(array $overwrite_values = array()){
82 82
 		static $config;
83
-		if(empty($config)){
83
+		if (empty($config)) {
84 84
 			$file = CONFIG_PATH . 'config.php';
85 85
 			require_once $file;
86 86
 		
@@ -94,50 +94,50 @@  discard block
 block discarded – undo
94 94
 	/**
95 95
 	*  @test
96 96
 	*/
97
-	function get_config($key, $default = null){
97
+	function get_config($key, $default = null) {
98 98
 		static $cfg;
99
-		if(empty($cfg)){
99
+		if (empty($cfg)) {
100 100
 			$cfg[0] = & load_configurations();
101 101
 		}
102 102
 		return array_key_exists($key, $cfg[0]) ? $cfg[0][$key] : $default;
103 103
 	}
104 104
 
105
-	function save_to_log($level, $message, $logger = null){
105
+	function save_to_log($level, $message, $logger = null) {
106 106
 		return true;
107 107
 	}
108 108
 
109 109
 	
110
-	function set_http_status_header($code = 200, $text = null){
110
+	function set_http_status_header($code = 200, $text = null) {
111 111
 		return true;
112 112
 	}
113 113
 
114 114
 	
115
-	function show_error($msg, $title = 'error', $logging = true){
115
+	function show_error($msg, $title = 'error', $logging = true) {
116 116
 		//show only and continue to help track of some error occured
117
-		echo 'TNHFW Error: '.$msg . "\n";
117
+		echo 'TNHFW Error: ' . $msg . "\n";
118 118
 	}
119 119
 
120
-	function is_https(){
120
+	function is_https() {
121 121
 		return false;
122 122
 	}
123 123
 	
124 124
 	/**
125 125
 	*  @test
126 126
 	*/
127
-	function is_url($url){
127
+	function is_url($url) {
128 128
 		return preg_match('/^(http|https|ftp):\/\/(.*)/', $url);
129 129
 	}
130 130
 		
131
-	function php_exception_handler($ex){
132
-		throw new RuntimeException('PHP Exception : '.$ex->getMessage().' | '.$ex->getFile().' | '.$ex->getLine());
131
+	function php_exception_handler($ex) {
132
+		throw new RuntimeException('PHP Exception : ' . $ex->getMessage() . ' | ' . $ex->getFile() . ' | ' . $ex->getLine());
133 133
 	}
134 134
 	
135 135
 	
136
-	function php_error_handler($errno , $errstr, $errfile , $errline, array $errcontext = array()){
137
-		throw new RuntimeException('TNHFW Exception Error : '.$errstr.' | '.$errfile.' | '.$errline);
136
+	function php_error_handler($errno, $errstr, $errfile, $errline, array $errcontext = array()) {
137
+		throw new RuntimeException('TNHFW Exception Error : ' . $errstr . ' | ' . $errfile . ' | ' . $errline);
138 138
 	}
139 139
 
140
-	function php_shudown_handler(){
140
+	function php_shudown_handler() {
141 141
 		return true;
142 142
 	}
143 143
 
@@ -145,11 +145,11 @@  discard block
 block discarded – undo
145 145
 	/**
146 146
 	*  @test
147 147
 	*/
148
-	function attributes_to_string(array $attributes){
148
+	function attributes_to_string(array $attributes) {
149 149
 		$str = ' ';
150 150
 		//we check that the array passed as an argument is not empty.
151
-		if(! empty($attributes)){
152
-			foreach($attributes as $key => $value){
151
+		if (!empty($attributes)) {
152
+			foreach ($attributes as $key => $value) {
153 153
 				$key = trim(htmlspecialchars($key));
154 154
 				$value = trim(htmlspecialchars($value));
155 155
 				/*
@@ -159,35 +159,35 @@  discard block
 block discarded – undo
159 159
 				* 	$attr = array('placeholder' => 'I am a "puple"')
160 160
 				* 	$str = attributes_to_string($attr); => placeholder = "I am a \"puple\""
161 161
 				 */
162
-				if($value && strpos('"', $value) !== false){
162
+				if ($value && strpos('"', $value) !== false) {
163 163
 					$value = addslashes($value);
164 164
 				}
165
-				$str .= $key.' = "'.$value.'" ';
165
+				$str .= $key . ' = "' . $value . '" ';
166 166
 			}
167 167
 		}
168 168
 		//remove the space after using rtrim()
169 169
 		return rtrim($str);
170 170
 	}
171 171
 
172
-	function stringfy_vars($var){
172
+	function stringfy_vars($var) {
173 173
 		return print_r($var, true);
174 174
 	}
175 175
 
176 176
 	/**
177 177
 	*  @test
178 178
 	*/
179
-	function clean_input($str){
180
-		if(is_array($str)){
179
+	function clean_input($str) {
180
+		if (is_array($str)) {
181 181
 			$str = array_map('clean_input', $str);
182 182
 		}
183
-		else if(is_object($str)){
183
+		else if (is_object($str)) {
184 184
 			$obj = $str;
185 185
 			foreach ($str as $var => $value) {
186 186
 				$obj->$var = clean_input($value);
187 187
 			}
188 188
 			$str = $obj;
189 189
 		}
190
-		else{
190
+		else {
191 191
 			$str = htmlspecialchars(strip_tags($str), ENT_QUOTES, 'UTF-8');
192 192
 		}
193 193
 		return $str;
@@ -196,11 +196,11 @@  discard block
 block discarded – undo
196 196
 	/**
197 197
 	*  @test
198 198
 	*/
199
-	function string_hidden($str, $startCount = 0, $endCount = 0, $hiddenChar = '*'){
199
+	function string_hidden($str, $startCount = 0, $endCount = 0, $hiddenChar = '*') {
200 200
 		//get the string length
201 201
 		$len = strlen($str);
202 202
 		//if str is empty
203
-		if($len <= 0){
203
+		if ($len <= 0) {
204 204
 			return str_repeat($hiddenChar, 6);
205 205
 		}
206 206
 		//if the length is less than startCount and endCount
@@ -208,14 +208,14 @@  discard block
 block discarded – undo
208 208
 		//or startCount is negative or endCount is negative
209 209
 		//return the full string hidden
210 210
 		
211
-		if((($startCount + $endCount) > $len) || ($startCount == 0 && $endCount == 0) || ($startCount < 0 || $endCount < 0)){
211
+		if ((($startCount + $endCount) > $len) || ($startCount == 0 && $endCount == 0) || ($startCount < 0 || $endCount < 0)) {
212 212
 			return str_repeat($hiddenChar, $len);
213 213
 		}
214 214
 		//the start non hidden string
215 215
 		$startNonHiddenStr = substr($str, 0, $startCount);
216 216
 		//the end non hidden string
217 217
 		$endNonHiddenStr = null;
218
-		if($endCount > 0){
218
+		if ($endCount > 0) {
219 219
 			$endNonHiddenStr = substr($str, - $endCount);
220 220
 		}
221 221
 		//the hidden string
@@ -224,12 +224,12 @@  discard block
 block discarded – undo
224 224
 		return $startNonHiddenStr . $hiddenStr . $endNonHiddenStr;
225 225
 	}
226 226
 	
227
-	function set_session_config(){
227
+	function set_session_config() {
228 228
 		return true;
229 229
 	}
230 230
 	
231 231
 	function & get_instance(){
232
-		if(! Controller::get_instance()){
232
+		if (!Controller::get_instance()) {
233 233
 			$c = new Controller();
234 234
 		}
235 235
 		return Controller::get_instance();
Please login to merge, or discard this patch.
tests/tnhfw/classes/DBSessionHandlerTest.php 1 patch
Spacing   +9 added lines, -9 removed lines patch added patch discarded remove patch
@@ -13,7 +13,7 @@  discard block
 block discarded – undo
13 13
 		
14 14
 		private static $config = null;
15 15
 		
16
-		public function __construct(){
16
+		public function __construct() {
17 17
 			$this->db = new Database(array(
18 18
 								'driver'    =>  'sqlite',
19 19
 								'database'  =>  TESTS_PATH . 'assets/db_tests.db',
@@ -49,7 +49,7 @@  discard block
 block discarded – undo
49 49
 
50 50
 		
51 51
 		
52
-		public function testUsingSessionConfiguration(){
52
+		public function testUsingSessionConfiguration() {
53 53
 			//using value in the configuration
54 54
 			static::$config->set('session_save_path', 'DBSessionModel');
55 55
 			static::$config->set('session_secret', $this->secret);
@@ -75,7 +75,7 @@  discard block
 block discarded – undo
75 75
 			$this->assertEquals($dbsh->decode($encoded), 'foo');
76 76
 		}
77 77
 		
78
-		public function testWhenDataIsExpired(){
78
+		public function testWhenDataIsExpired() {
79 79
 			$dbsh = new DBSessionHandler($this->model);
80 80
 			$dbsh->setSessionSecret($this->secret);
81 81
 			
@@ -88,7 +88,7 @@  discard block
 block discarded – undo
88 88
 			$this->assertNull($dbsh->read('foo'));
89 89
 		}
90 90
 		
91
-		public function testWhenDataAlreadyExistDoUpdate(){
91
+		public function testWhenDataAlreadyExistDoUpdate() {
92 92
 			$dbsh = new DBSessionHandler($this->model);
93 93
 			$dbsh->setSessionSecret($this->secret);
94 94
 			
@@ -101,7 +101,7 @@  discard block
 block discarded – undo
101 101
 			$this->assertEquals($dbsh->read('foo'), '445');	
102 102
 		}
103 103
 		
104
-		public function testUsingCustomModelInstance(){
104
+		public function testUsingCustomModelInstance() {
105 105
 			$dbsh = new DBSessionHandler($this->model);
106 106
 			$dbsh->setSessionSecret($this->secret);
107 107
 			
@@ -129,7 +129,7 @@  discard block
 block discarded – undo
129 129
 		}
130 130
 			
131 131
 			
132
-		public function testUsingCustomLogInstance(){
132
+		public function testUsingCustomLogInstance() {
133 133
 			$dbsh = new DBSessionHandler($this->model, new Log());
134 134
 			$dbsh->setSessionSecret($this->secret);
135 135
 			
@@ -156,7 +156,7 @@  discard block
 block discarded – undo
156 156
 			$this->assertEquals($dbsh->decode($encoded), 'foo');
157 157
 		}
158 158
 		
159
-		public function testUsingCustomLoaderInstance(){
159
+		public function testUsingCustomLoaderInstance() {
160 160
 			$dbsh = new DBSessionHandler($this->model, null, new Loader());
161 161
 			$dbsh->setSessionSecret($this->secret);
162 162
 			
@@ -184,7 +184,7 @@  discard block
 block discarded – undo
184 184
 		}
185 185
 		
186 186
 		
187
-		public function testWhenModelInsanceIsNotSet(){
187
+		public function testWhenModelInsanceIsNotSet() {
188 188
 			$dbsh = new DBSessionHandler(null, null, new Loader());
189 189
 			$dbsh->setSessionSecret($this->secret);
190 190
 			
@@ -212,7 +212,7 @@  discard block
 block discarded – undo
212 212
 			$this->assertEquals($dbsh->decode($encoded), 'foo');
213 213
 		}
214 214
 		
215
-		public function testWhenModelTableColumnsIsNotSet(){
215
+		public function testWhenModelTableColumnsIsNotSet() {
216 216
 			//session table is empty
217 217
 			$this->model->setSessionTableColumns(array());
218 218
 			$dbsh = new DBSessionHandler($this->model);
Please login to merge, or discard this patch.
core/libraries/Cookie.php 1 patch
Spacing   +15 added lines, -15 removed lines patch added patch discarded remove patch
@@ -24,7 +24,7 @@  discard block
 block discarded – undo
24 24
 	 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
25 25
 	*/
26 26
 
27
-	class Cookie{
27
+	class Cookie {
28 28
 		
29 29
 		/**
30 30
 		 * The logger instance
@@ -36,9 +36,9 @@  discard block
 block discarded – undo
36 36
 		 * The signleton of the logger
37 37
 		 * @return Object the Log instance
38 38
 		 */
39
-		private static function getLogger(){
40
-			if(self::$logger == null){
41
-				self::$logger[0] =& class_loader('Log', 'classes');
39
+		private static function getLogger() {
40
+			if (self::$logger == null) {
41
+				self::$logger[0] = & class_loader('Log', 'classes');
42 42
 				self::$logger[0]->setLogger('Library::Cookie');
43 43
 			}
44 44
 			return self::$logger[0];
@@ -50,9 +50,9 @@  discard block
 block discarded – undo
50 50
 		 * @param  mixed $default the default value to use if can not find the cokkie item in the list
51 51
 		 * @return mixed          the cookie value if exist or the default value
52 52
 		 */
53
-		public static function get($item, $default = null){
53
+		public static function get($item, $default = null) {
54 54
 			$logger = self::getLogger();
55
-			if(array_key_exists($item, $_COOKIE)){
55
+			if (array_key_exists($item, $_COOKIE)) {
56 56
 				return $_COOKIE[$item];
57 57
 			}
58 58
 			$logger->warning('Cannot find cookie item [' . $item . '], using the default value [' . $default . ']');
@@ -69,14 +69,14 @@  discard block
 block discarded – undo
69 69
 		 * @param boolean $secure   if this cookie will be available on secure connection or not
70 70
 		 * @param boolean $httponly if this cookie will be available under HTTP protocol.
71 71
 		 */
72
-		public static function set($name, $value = '', $expire = 0, $path = '/', $domain = '', $secure = false, $httponly = false){
73
-			if(headers_sent()){
72
+		public static function set($name, $value = '', $expire = 0, $path = '/', $domain = '', $secure = false, $httponly = false) {
73
+			if (headers_sent()) {
74 74
 				show_error('There exists a cookie that we wanted to create that we couldn\'t 
75 75
 						    because headers was already sent. Make sure to do this first 
76 76
 							before outputing anything.');
77 77
 			}
78 78
 			$timestamp = $expire;
79
-			if($expire){
79
+			if ($expire) {
80 80
 				$timestamp = time() + $expire;
81 81
 			}
82 82
 			setcookie($name, $value, $timestamp, $path, $domain, $secure, $httponly);
@@ -87,15 +87,15 @@  discard block
 block discarded – undo
87 87
 		 * @param  string $item the cookie item name to be cleared
88 88
 		 * @return boolean true if the item exists and is deleted successfully otherwise will return false.
89 89
 		 */
90
-		public static function delete($item){
90
+		public static function delete($item) {
91 91
 			$logger = self::getLogger();
92
-			if(array_key_exists($item, $_COOKIE)){
93
-				$logger->info('Delete cookie item ['.$item.']');
92
+			if (array_key_exists($item, $_COOKIE)) {
93
+				$logger->info('Delete cookie item [' . $item . ']');
94 94
 				unset($_COOKIE[$item]);
95 95
 				return true;
96 96
 			}
97
-			else{
98
-				$logger->warning('Cookie item ['.$item.'] to be deleted does not exists');
97
+			else {
98
+				$logger->warning('Cookie item [' . $item . '] to be deleted does not exists');
99 99
 				return false;
100 100
 			}
101 101
 		}
@@ -105,7 +105,7 @@  discard block
 block discarded – undo
105 105
 		 * @param  string $item the cookie item name
106 106
 		 * @return boolean       true if the cookie item is set, false or not
107 107
 		 */
108
-		public static function exists($item){
108
+		public static function exists($item) {
109 109
 			return array_key_exists($item, $_COOKIE);
110 110
 		}
111 111
 
Please login to merge, or discard this patch.
core/libraries/Browser.php 1 patch
Indentation   +1731 added lines, -1731 removed lines patch added patch discarded remove patch
@@ -1,1732 +1,1732 @@
 block discarded – undo
1 1
 <?php
2
-    defined('ROOT_PATH') || exit('Access denied');
3
-    /**
4
-     * File: Browser.php
5
-     * Author: Chris Schuld (http://chrisschuld.com/)
6
-     * Last Modified: July 22nd, 2016
7
-     * @version 2.0
8
-     * @package PegasusPHP
9
-     *
10
-     * Copyright (C) 2008-2010 Chris Schuld  ([email protected])
11
-     *
12
-     * This program is free software; you can redistribute it and/or
13
-     * modify it under the terms of the GNU General Public License as
14
-     * published by the Free Software Foundation; either version 2 of
15
-     * the License, or (at your option) any later version.
16
-     *
17
-     * This program is distributed in the hope that it will be useful,
18
-     * but WITHOUT ANY WARRANTY; without even the implied warranty of
19
-     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
20
-     * GNU General Public License for more details at:
21
-     * http://www.gnu.org/copyleft/gpl.html
22
-     *
23
-     *
24
-     * Typical Usage:
25
-     *
26
-     *   $browser = new Browser();
27
-     *   if( $browser->getBrowser() == Browser::BROWSER_FIREFOX && $browser->getVersion() >= 2 ) {
28
-     *    echo 'You have FireFox version 2 or greater';
29
-     *   }
30
-     *
31
-     * User Agents Sampled from: http://www.useragentstring.com/
32
-     *
33
-     * This implementation is based on the original work from Gary White
34
-     * http://apptools.com/phptools/browser/
35
-     *
36
-     */
37
-    class Browser
38
-    {
39
-        private $_agent = '';
40
-        private $_browser_name = '';
41
-        private $_version = '';
42
-        private $_platform = '';
43
-        private $_os = '';
44
-        private $_is_aol = false;
45
-        private $_is_mobile = false;
46
-        private $_is_tablet = false;
47
-        private $_is_robot = false;
48
-        private $_is_facebook = false;
49
-        private $_aol_version = '';
50
-
51
-        const BROWSER_UNKNOWN = 'unknown';
52
-        const VERSION_UNKNOWN = 'unknown';
53
-
54
-        const BROWSER_OPERA = 'Opera'; // http://www.opera.com/
55
-        const BROWSER_OPERA_MINI = 'Opera Mini'; // http://www.opera.com/mini/
56
-        const BROWSER_WEBTV = 'WebTV'; // http://www.webtv.net/pc/
57
-        const BROWSER_EDGE = 'Edge'; // https://www.microsoft.com/edge
58
-        const BROWSER_IE = 'Internet Explorer'; // http://www.microsoft.com/ie/
59
-        const BROWSER_POCKET_IE = 'Pocket Internet Explorer'; // http://en.wikipedia.org/wiki/Internet_Explorer_Mobile
60
-        const BROWSER_KONQUEROR = 'Konqueror'; // http://www.konqueror.org/
61
-        const BROWSER_ICAB = 'iCab'; // http://www.icab.de/
62
-        const BROWSER_OMNIWEB = 'OmniWeb'; // http://www.omnigroup.com/applications/omniweb/
63
-        const BROWSER_FIREBIRD = 'Firebird'; // http://www.ibphoenix.com/
64
-        const BROWSER_FIREFOX = 'Firefox'; // http://www.mozilla.com/en-US/firefox/firefox.html
65
-        const BROWSER_ICEWEASEL = 'Iceweasel'; // http://www.geticeweasel.org/
66
-        const BROWSER_SHIRETOKO = 'Shiretoko'; // http://wiki.mozilla.org/Projects/shiretoko
67
-        const BROWSER_MOZILLA = 'Mozilla'; // http://www.mozilla.com/en-US/
68
-        const BROWSER_AMAYA = 'Amaya'; // http://www.w3.org/Amaya/
69
-        const BROWSER_LYNX = 'Lynx'; // http://en.wikipedia.org/wiki/Lynx
70
-        const BROWSER_SAFARI = 'Safari'; // http://apple.com
71
-        const BROWSER_IPHONE = 'iPhone'; // http://apple.com
72
-        const BROWSER_IPOD = 'iPod'; // http://apple.com
73
-        const BROWSER_IPAD = 'iPad'; // http://apple.com
74
-        const BROWSER_CHROME = 'Chrome'; // http://www.google.com/chrome
75
-        const BROWSER_ANDROID = 'Android'; // http://www.android.com/
76
-        const BROWSER_GOOGLEBOT = 'GoogleBot'; // http://en.wikipedia.org/wiki/Googlebot
77
-
78
-        const BROWSER_YANDEXBOT = 'YandexBot'; // http://yandex.com/bots
79
-        const BROWSER_YANDEXIMAGERESIZER_BOT = 'YandexImageResizer'; // http://yandex.com/bots
80
-        const BROWSER_YANDEXIMAGES_BOT = 'YandexImages'; // http://yandex.com/bots
81
-        const BROWSER_YANDEXVIDEO_BOT = 'YandexVideo'; // http://yandex.com/bots
82
-        const BROWSER_YANDEXMEDIA_BOT = 'YandexMedia'; // http://yandex.com/bots
83
-        const BROWSER_YANDEXBLOGS_BOT = 'YandexBlogs'; // http://yandex.com/bots
84
-        const BROWSER_YANDEXFAVICONS_BOT = 'YandexFavicons'; // http://yandex.com/bots
85
-        const BROWSER_YANDEXWEBMASTER_BOT = 'YandexWebmaster'; // http://yandex.com/bots
86
-        const BROWSER_YANDEXDIRECT_BOT = 'YandexDirect'; // http://yandex.com/bots
87
-        const BROWSER_YANDEXMETRIKA_BOT = 'YandexMetrika'; // http://yandex.com/bots
88
-        const BROWSER_YANDEXNEWS_BOT = 'YandexNews'; // http://yandex.com/bots
89
-        const BROWSER_YANDEXCATALOG_BOT = 'YandexCatalog'; // http://yandex.com/bots
90
-
91
-        const BROWSER_SLURP = 'Yahoo! Slurp'; // http://en.wikipedia.org/wiki/Yahoo!_Slurp
92
-        const BROWSER_W3CVALIDATOR = 'W3C Validator'; // http://validator.w3.org/
93
-        const BROWSER_BLACKBERRY = 'BlackBerry'; // http://www.blackberry.com/
94
-        const BROWSER_ICECAT = 'IceCat'; // http://en.wikipedia.org/wiki/GNU_IceCat
95
-        const BROWSER_NOKIA_S60 = 'Nokia S60 OSS Browser'; // http://en.wikipedia.org/wiki/Web_Browser_for_S60
96
-        const BROWSER_NOKIA = 'Nokia Browser'; // * all other WAP-based browsers on the Nokia Platform
97
-        const BROWSER_MSN = 'MSN Browser'; // http://explorer.msn.com/
98
-        const BROWSER_MSNBOT = 'MSN Bot'; // http://search.msn.com/msnbot.htm
99
-        const BROWSER_BINGBOT = 'Bing Bot'; // http://en.wikipedia.org/wiki/Bingbot
100
-        const BROWSER_VIVALDI = 'Vivalidi'; // https://vivaldi.com/
101
-        const BROWSER_YANDEX = 'Yandex'; // https://browser.yandex.ua/
102
-
103
-        const BROWSER_NETSCAPE_NAVIGATOR = 'Netscape Navigator'; // http://browser.netscape.com/ (DEPRECATED)
104
-        const BROWSER_GALEON = 'Galeon'; // http://galeon.sourceforge.net/ (DEPRECATED)
105
-        const BROWSER_NETPOSITIVE = 'NetPositive'; // http://en.wikipedia.org/wiki/NetPositive (DEPRECATED)
106
-        const BROWSER_PHOENIX = 'Phoenix'; // http://en.wikipedia.org/wiki/History_of_Mozilla_Firefox (DEPRECATED)
107
-        const BROWSER_PLAYSTATION = "PlayStation";
108
-        const BROWSER_SAMSUNG = "SamsungBrowser";
109
-        const BROWSER_SILK = "Silk";
110
-        const BROWSER_I_FRAME = "Iframely";
111
-        const BROWSER_COCOA = "CocoaRestClient";
112
-
113
-        const PLATFORM_UNKNOWN = 'unknown';
114
-        const PLATFORM_WINDOWS = 'Windows';
115
-        const PLATFORM_WINDOWS_CE = 'Windows CE';
116
-        const PLATFORM_APPLE = 'Apple';
117
-        const PLATFORM_LINUX = 'Linux';
118
-        const PLATFORM_OS2 = 'OS/2';
119
-        const PLATFORM_BEOS = 'BeOS';
120
-        const PLATFORM_IPHONE = 'iPhone';
121
-        const PLATFORM_IPOD = 'iPod';
122
-        const PLATFORM_IPAD = 'iPad';
123
-        const PLATFORM_BLACKBERRY = 'BlackBerry';
124
-        const PLATFORM_NOKIA = 'Nokia';
125
-        const PLATFORM_FREEBSD = 'FreeBSD';
126
-        const PLATFORM_OPENBSD = 'OpenBSD';
127
-        const PLATFORM_NETBSD = 'NetBSD';
128
-        const PLATFORM_SUNOS = 'SunOS';
129
-        const PLATFORM_OPENSOLARIS = 'OpenSolaris';
130
-        const PLATFORM_ANDROID = 'Android';
131
-        const PLATFORM_PLAYSTATION = "Sony PlayStation";
132
-        const PLATFORM_ROKU = "Roku";
133
-        const PLATFORM_APPLE_TV = "Apple TV";
134
-        const PLATFORM_TERMINAL = "Terminal";
135
-        const PLATFORM_FIRE_OS = "Fire OS";
136
-        const PLATFORM_SMART_TV = "SMART-TV";
137
-        const PLATFORM_CHROME_OS = "Chrome OS";
138
-        const PLATFORM_JAVA_ANDROID = "Java/Android";
139
-        const PLATFORM_POSTMAN = "Postman";
140
-        const PLATFORM_I_FRAME = "Iframely";
141
-
142
-        const OPERATING_SYSTEM_UNKNOWN = 'unknown';
143
-
144
-        /**
145
-         * Class constructor
146
-         */
147
-        public function __construct($userAgent = "")
148
-        {
149
-            $this->reset();
150
-            if ($userAgent != "") {
151
-                $this->setUserAgent($userAgent);
152
-            } else {
153
-                $this->determine();
154
-            }
155
-        }
156
-
157
-        /**
158
-         * Reset all properties
159
-         */
160
-        public function reset()
161
-        {
162
-            $this->_agent = isset($_SERVER['HTTP_USER_AGENT']) ? $_SERVER['HTTP_USER_AGENT'] : "";
163
-            $this->_browser_name = self::BROWSER_UNKNOWN;
164
-            $this->_version = self::VERSION_UNKNOWN;
165
-            $this->_platform = self::PLATFORM_UNKNOWN;
166
-            $this->_os = self::OPERATING_SYSTEM_UNKNOWN;
167
-            $this->_is_aol = false;
168
-            $this->_is_mobile = false;
169
-            $this->_is_tablet = false;
170
-            $this->_is_robot = false;
171
-            $this->_is_facebook = false;
172
-            $this->_aol_version = self::VERSION_UNKNOWN;
173
-        }
174
-
175
-        /**
176
-         * Check to see if the specific browser is valid
177
-         * @param string $browserName
178
-         * @return bool True if the browser is the specified browser
179
-         */
180
-        public function isBrowser($browserName)
181
-        {
182
-            return (0 == strcasecmp($this->_browser_name, trim($browserName)));
183
-        }
184
-
185
-        /**
186
-         * The name of the browser.  All return types are from the class contants
187
-         * @return string Name of the browser
188
-         */
189
-        public function getBrowser()
190
-        {
191
-            return $this->_browser_name;
192
-        }
193
-
194
-        /**
195
-         * Set the name of the browser
196
-         * @param $browser string The name of the Browser
197
-         */
198
-        public function setBrowser($browser)
199
-        {
200
-            $this->_browser_name = $browser;
201
-        }
202
-
203
-        /**
204
-         * The name of the platform.  All return types are from the class contants
205
-         * @return string Name of the browser
206
-         */
207
-        public function getPlatform()
208
-        {
209
-            return $this->_platform;
210
-        }
211
-
212
-        /**
213
-         * Set the name of the platform
214
-         * @param string $platform The name of the Platform
215
-         */
216
-        public function setPlatform($platform)
217
-        {
218
-            $this->_platform = $platform;
219
-        }
220
-
221
-        /**
222
-         * The version of the browser.
223
-         * @return string Version of the browser (will only contain alpha-numeric characters and a period)
224
-         */
225
-        public function getVersion()
226
-        {
227
-            return $this->_version;
228
-        }
229
-
230
-        /**
231
-         * Set the version of the browser
232
-         * @param string $version The version of the Browser
233
-         */
234
-        public function setVersion($version)
235
-        {
236
-            $this->_version = preg_replace('/[^0-9,.,a-z,A-Z-]/', '', $version);
237
-        }
238
-
239
-        /**
240
-         * The version of AOL.
241
-         * @return string Version of AOL (will only contain alpha-numeric characters and a period)
242
-         */
243
-        public function getAolVersion()
244
-        {
245
-            return $this->_aol_version;
246
-        }
247
-
248
-        /**
249
-         * Set the version of AOL
250
-         * @param string $version The version of AOL
251
-         */
252
-        public function setAolVersion($version)
253
-        {
254
-            $this->_aol_version = preg_replace('/[^0-9,.,a-z,A-Z]/', '', $version);
255
-        }
256
-
257
-        /**
258
-         * Is the browser from AOL?
259
-         * @return boolean True if the browser is from AOL otherwise false
260
-         */
261
-        public function isAol()
262
-        {
263
-            return $this->_is_aol;
264
-        }
265
-
266
-        /**
267
-         * Is the browser from a mobile device?
268
-         * @return boolean True if the browser is from a mobile device otherwise false
269
-         */
270
-        public function isMobile()
271
-        {
272
-            return $this->_is_mobile;
273
-        }
274
-
275
-        /**
276
-         * Is the browser from a tablet device?
277
-         * @return boolean True if the browser is from a tablet device otherwise false
278
-         */
279
-        public function isTablet()
280
-        {
281
-            return $this->_is_tablet;
282
-        }
283
-
284
-        /**
285
-         * Is the browser from a robot (ex Slurp,GoogleBot)?
286
-         * @return boolean True if the browser is from a robot otherwise false
287
-         */
288
-        public function isRobot()
289
-        {
290
-            return $this->_is_robot;
291
-        }
292
-
293
-        /**
294
-         * Is the browser from facebook?
295
-         * @return boolean True if the browser is from facebook otherwise false
296
-         */
297
-        public function isFacebook()
298
-        {
299
-            return $this->_is_facebook;
300
-        }
301
-
302
-        /**
303
-         * Set the browser to be from AOL
304
-         * @param $isAol
305
-         */
306
-        public function setAol($isAol)
307
-        {
308
-            $this->_is_aol = $isAol;
309
-        }
310
-
311
-        /**
312
-         * Set the Browser to be mobile
313
-         * @param boolean $value is the browser a mobile browser or not
314
-         */
315
-        protected function setMobile($value = true)
316
-        {
317
-            $this->_is_mobile = $value;
318
-        }
319
-
320
-        /**
321
-         * Set the Browser to be tablet
322
-         * @param boolean $value is the browser a tablet browser or not
323
-         */
324
-        protected function setTablet($value = true)
325
-        {
326
-            $this->_is_tablet = $value;
327
-        }
328
-
329
-        /**
330
-         * Set the Browser to be a robot
331
-         * @param boolean $value is the browser a robot or not
332
-         */
333
-        protected function setRobot($value = true)
334
-        {
335
-            $this->_is_robot = $value;
336
-        }
337
-
338
-        /**
339
-         * Set the Browser to be a Facebook request
340
-         * @param boolean $value is the browser a robot or not
341
-         */
342
-        protected function setFacebook($value = true)
343
-        {
344
-            $this->_is_facebook = $value;
345
-        }
346
-
347
-        /**
348
-         * Get the user agent value in use to determine the browser
349
-         * @return string The user agent from the HTTP header
350
-         */
351
-        public function getUserAgent()
352
-        {
353
-            return $this->_agent;
354
-        }
355
-
356
-        /**
357
-         * Set the user agent value (the construction will use the HTTP header value - this will overwrite it)
358
-         * @param string $agent_string The value for the User Agent
359
-         */
360
-        public function setUserAgent($agent_string)
361
-        {
362
-            $this->reset();
363
-            $this->_agent = $agent_string;
364
-            $this->determine();
365
-        }
366
-
367
-        /**
368
-         * Used to determine if the browser is actually "chromeframe"
369
-         * @since 1.7
370
-         * @return boolean True if the browser is using chromeframe
371
-         */
372
-        public function isChromeFrame()
373
-        {
374
-            return (strpos($this->_agent, "chromeframe") !== false);
375
-        }
376
-
377
-        /**
378
-         * Returns a formatted string with a summary of the details of the browser.
379
-         * @return string formatted string with a summary of the browser
380
-         */
381
-        public function __toString()
382
-        {
383
-            return "<strong>Browser Name:</strong> {$this->getBrowser()}<br/>\n" .
384
-                "<strong>Browser Version:</strong> {$this->getVersion()}<br/>\n" .
385
-                "<strong>Browser User Agent String:</strong> {$this->getUserAgent()}<br/>\n" .
386
-                "<strong>Platform:</strong> {$this->getPlatform()}<br/>";
387
-        }
388
-
389
-        /**
390
-         * Protected routine to calculate and determine what the browser is in use (including platform)
391
-         */
392
-        protected function determine()
393
-        {
394
-            $this->checkPlatform();
395
-            $this->checkBrowsers();
396
-            $this->checkForAol();
397
-        }
398
-
399
-        /**
400
-         * Protected routine to determine the browser type
401
-         * @return boolean True if the browser was detected otherwise false
402
-         */
403
-        protected function checkBrowsers()
404
-        {
405
-            return (
406
-                // well-known, well-used
407
-                // Special Notes:
408
-                // (1) Opera must be checked before FireFox due to the odd
409
-                //     user agents used in some older versions of Opera
410
-                // (2) WebTV is strapped onto Internet Explorer so we must
411
-                //     check for WebTV before IE
412
-                // (3) (deprecated) Galeon is based on Firefox and needs to be
413
-                //     tested before Firefox is tested
414
-                // (4) OmniWeb is based on Safari so OmniWeb check must occur
415
-                //     before Safari
416
-                // (5) Netscape 9+ is based on Firefox so Netscape checks
417
-                //     before FireFox are necessary
418
-                // (6) Vivalid is UA contains both Firefox and Chrome so Vivalid checks
419
-                //     before Firefox and Chrome
420
-                $this->checkBrowserWebTv() ||
421
-                $this->checkBrowserEdge() ||
422
-                $this->checkBrowserInternetExplorer() ||
423
-                $this->checkBrowserOpera() ||
424
-                $this->checkBrowserGaleon() ||
425
-                $this->checkBrowserNetscapeNavigator9Plus() ||
426
-                $this->checkBrowserVivaldi() ||
427
-                $this->checkBrowserYandex() ||
428
-                $this->checkBrowserFirefox() ||
429
-                $this->checkBrowserChrome() ||
430
-                $this->checkBrowserOmniWeb() ||
431
-
432
-                // common mobile
433
-                $this->checkBrowserAndroid() ||
434
-                $this->checkBrowseriPad() ||
435
-                $this->checkBrowseriPod() ||
436
-                $this->checkBrowseriPhone() ||
437
-                $this->checkBrowserBlackBerry() ||
438
-                $this->checkBrowserNokia() ||
439
-
440
-                // common bots
441
-                $this->checkBrowserGoogleBot() ||
442
-                $this->checkBrowserMSNBot() ||
443
-                $this->checkBrowserBingBot() ||
444
-                $this->checkBrowserSlurp() ||
445
-
446
-                // Yandex bots
447
-                $this->checkBrowserYandexBot() ||
448
-                $this->checkBrowserYandexImageResizerBot() ||
449
-                $this->checkBrowserYandexBlogsBot() ||
450
-                $this->checkBrowserYandexCatalogBot() ||
451
-                $this->checkBrowserYandexDirectBot() ||
452
-                $this->checkBrowserYandexFaviconsBot() ||
453
-                $this->checkBrowserYandexImagesBot() ||
454
-                $this->checkBrowserYandexMediaBot() ||
455
-                $this->checkBrowserYandexMetrikaBot() ||
456
-                $this->checkBrowserYandexNewsBot() ||
457
-                $this->checkBrowserYandexVideoBot() ||
458
-                $this->checkBrowserYandexWebmasterBot() ||
459
-
460
-                // check for facebook external hit when loading URL
461
-                $this->checkFacebookExternalHit() ||
462
-
463
-                // WebKit base check (post mobile and others)
464
-                $this->checkBrowserSamsung() ||
465
-                $this->checkBrowserSilk() ||
466
-                $this->checkBrowserSafari() ||
467
-
468
-                // everyone else
469
-                $this->checkBrowserNetPositive() ||
470
-                $this->checkBrowserFirebird() ||
471
-                $this->checkBrowserKonqueror() ||
472
-                $this->checkBrowserIcab() ||
473
-                $this->checkBrowserPhoenix() ||
474
-                $this->checkBrowserAmaya() ||
475
-                $this->checkBrowserLynx() ||
476
-                $this->checkBrowserShiretoko() ||
477
-                $this->checkBrowserIceCat() ||
478
-                $this->checkBrowserIceweasel() ||
479
-                $this->checkBrowserW3CValidator() ||
480
-                $this->checkBrowserPlayStation() ||
481
-                $this->checkBrowserIframely() ||
482
-                $this->checkBrowserCocoa() ||
483
-                $this->checkBrowserMozilla() /* Mozilla is such an open standard that you must check it last */
484
-
485
-
486
-            );
487
-        }
488
-
489
-        /**
490
-         * Determine if the user is using a BlackBerry (last updated 1.7)
491
-         * @return boolean True if the browser is the BlackBerry browser otherwise false
492
-         */
493
-        protected function checkBrowserBlackBerry()
494
-        {
495
-            if (stripos($this->_agent, 'blackberry') !== false) {
496
-                $aresult = explode("/", stristr($this->_agent, "BlackBerry"));
497
-                if (isset($aresult[1])) {
498
-                    $aversion = explode(' ', $aresult[1]);
499
-                    $this->setVersion($aversion[0]);
500
-                    $this->_browser_name = self::BROWSER_BLACKBERRY;
501
-                    $this->setMobile(true);
502
-                    return true;
503
-                }
504
-            }
505
-            return false;
506
-        }
507
-
508
-        /**
509
-         * Determine if the user is using an AOL User Agent (last updated 1.7)
510
-         * @return boolean True if the browser is from AOL otherwise false
511
-         */
512
-        protected function checkForAol()
513
-        {
514
-            $this->setAol(false);
515
-            $this->setAolVersion(self::VERSION_UNKNOWN);
516
-
517
-            if (stripos($this->_agent, 'aol') !== false) {
518
-                $aversion = explode(' ', stristr($this->_agent, 'AOL'));
519
-                if (isset($aversion[1])) {
520
-                    $this->setAol(true);
521
-                    $this->setAolVersion(preg_replace('/[^0-9\.a-z]/i', '', $aversion[1]));
522
-                    return true;
523
-                }
524
-            }
525
-            return false;
526
-        }
527
-
528
-        /**
529
-         * Determine if the browser is the GoogleBot or not (last updated 1.7)
530
-         * @return boolean True if the browser is the GoogletBot otherwise false
531
-         */
532
-        protected function checkBrowserGoogleBot()
533
-        {
534
-            if (stripos($this->_agent, 'googlebot') !== false) {
535
-                $aresult = explode('/', stristr($this->_agent, 'googlebot'));
536
-                if (isset($aresult[1])) {
537
-                    $aversion = explode(' ', $aresult[1]);
538
-                    $this->setVersion(str_replace(';', '', $aversion[0]));
539
-                    $this->_browser_name = self::BROWSER_GOOGLEBOT;
540
-                    $this->setRobot(true);
541
-                    return true;
542
-                }
543
-            }
544
-            return false;
545
-        }
546
-
547
-        /**
548
-         * Determine if the browser is the YandexBot or not
549
-         * @return boolean True if the browser is the YandexBot otherwise false
550
-         */
551
-        protected function checkBrowserYandexBot()
552
-        {
553
-            if (stripos($this->_agent, 'YandexBot') !== false) {
554
-                $aresult = explode('/', stristr($this->_agent, 'YandexBot'));
555
-                if (isset($aresult[1])) {
556
-                    $aversion = explode(' ', $aresult[1]);
557
-                    $this->setVersion(str_replace(';', '', $aversion[0]));
558
-                    $this->_browser_name = self::BROWSER_YANDEXBOT;
559
-                    $this->setRobot(true);
560
-                    return true;
561
-                }
562
-            }
563
-            return false;
564
-        }
565
-
566
-        /**
567
-         * Determine if the browser is the YandexImageResizer or not
568
-         * @return boolean True if the browser is the YandexImageResizer otherwise false
569
-         */
570
-        protected function checkBrowserYandexImageResizerBot()
571
-        {
572
-            if (stripos($this->_agent, 'YandexImageResizer') !== false) {
573
-                $aresult = explode('/', stristr($this->_agent, 'YandexImageResizer'));
574
-                if (isset($aresult[1])) {
575
-                    $aversion = explode(' ', $aresult[1]);
576
-                    $this->setVersion(str_replace(';', '', $aversion[0]));
577
-                    $this->_browser_name = self::BROWSER_YANDEXIMAGERESIZER_BOT;
578
-                    $this->setRobot(true);
579
-                    return true;
580
-                }
581
-            }
582
-            return false;
583
-        }
584
-
585
-        /**
586
-         * Determine if the browser is the YandexCatalog or not
587
-         * @return boolean True if the browser is the YandexCatalog otherwise false
588
-         */
589
-        protected function checkBrowserYandexCatalogBot()
590
-        {
591
-            if (stripos($this->_agent, 'YandexCatalog') !== false) {
592
-                $aresult = explode('/', stristr($this->_agent, 'YandexCatalog'));
593
-                if (isset($aresult[1])) {
594
-                    $aversion = explode(' ', $aresult[1]);
595
-                    $this->setVersion(str_replace(';', '', $aversion[0]));
596
-                    $this->_browser_name = self::BROWSER_YANDEXCATALOG_BOT;
597
-                    $this->setRobot(true);
598
-                    return true;
599
-                }
600
-            }
601
-            return false;
602
-        }
603
-
604
-        /**
605
-         * Determine if the browser is the YandexNews or not
606
-         * @return boolean True if the browser is the YandexNews otherwise false
607
-         */
608
-        protected function checkBrowserYandexNewsBot()
609
-        {
610
-            if (stripos($this->_agent, 'YandexNews') !== false) {
611
-                $aresult = explode('/', stristr($this->_agent, 'YandexNews'));
612
-                if (isset($aresult[1])) {
613
-                    $aversion = explode(' ', $aresult[1]);
614
-                    $this->setVersion(str_replace(';', '', $aversion[0]));
615
-                    $this->_browser_name = self::BROWSER_YANDEXNEWS_BOT;
616
-                    $this->setRobot(true);
617
-                    return true;
618
-                }
619
-            }
620
-            return false;
621
-        }
622
-
623
-        /**
624
-         * Determine if the browser is the YandexMetrika or not
625
-         * @return boolean True if the browser is the YandexMetrika otherwise false
626
-         */
627
-        protected function checkBrowserYandexMetrikaBot()
628
-        {
629
-            if (stripos($this->_agent, 'YandexMetrika') !== false) {
630
-                $aresult = explode('/', stristr($this->_agent, 'YandexMetrika'));
631
-                if (isset($aresult[1])) {
632
-                    $aversion = explode(' ', $aresult[1]);
633
-                    $this->setVersion(str_replace(';', '', $aversion[0]));
634
-                    $this->_browser_name = self::BROWSER_YANDEXMETRIKA_BOT;
635
-                    $this->setRobot(true);
636
-                    return true;
637
-                }
638
-            }
639
-            return false;
640
-        }
641
-
642
-        /**
643
-         * Determine if the browser is the YandexDirect or not
644
-         * @return boolean True if the browser is the YandexDirect otherwise false
645
-         */
646
-        protected function checkBrowserYandexDirectBot()
647
-        {
648
-            if (stripos($this->_agent, 'YandexDirect') !== false) {
649
-                $aresult = explode('/', stristr($this->_agent, 'YandexDirect'));
650
-                if (isset($aresult[1])) {
651
-                    $aversion = explode(' ', $aresult[1]);
652
-                    $this->setVersion(str_replace(';', '', $aversion[0]));
653
-                    $this->_browser_name = self::BROWSER_YANDEXDIRECT_BOT;
654
-                    $this->setRobot(true);
655
-                    return true;
656
-                }
657
-            }
658
-            return false;
659
-        }
660
-
661
-        /**
662
-         * Determine if the browser is the YandexWebmaster or not
663
-         * @return boolean True if the browser is the YandexWebmaster otherwise false
664
-         */
665
-        protected function checkBrowserYandexWebmasterBot()
666
-        {
667
-            if (stripos($this->_agent, 'YandexWebmaster') !== false) {
668
-                $aresult = explode('/', stristr($this->_agent, 'YandexWebmaster'));
669
-                if (isset($aresult[1])) {
670
-                    $aversion = explode(' ', $aresult[1]);
671
-                    $this->setVersion(str_replace(';', '', $aversion[0]));
672
-                    $this->_browser_name = self::BROWSER_YANDEXWEBMASTER_BOT;
673
-                    $this->setRobot(true);
674
-                    return true;
675
-                }
676
-            }
677
-            return false;
678
-        }
679
-
680
-        /**
681
-         * Determine if the browser is the YandexFavicons or not
682
-         * @return boolean True if the browser is the YandexFavicons otherwise false
683
-         */
684
-        protected function checkBrowserYandexFaviconsBot()
685
-        {
686
-            if (stripos($this->_agent, 'YandexFavicons') !== false) {
687
-                $aresult = explode('/', stristr($this->_agent, 'YandexFavicons'));
688
-                if (isset($aresult[1])) {
689
-                    $aversion = explode(' ', $aresult[1]);
690
-                    $this->setVersion(str_replace(';', '', $aversion[0]));
691
-                    $this->_browser_name = self::BROWSER_YANDEXFAVICONS_BOT;
692
-                    $this->setRobot(true);
693
-                    return true;
694
-                }
695
-            }
696
-            return false;
697
-        }
698
-
699
-        /**
700
-         * Determine if the browser is the YandexBlogs or not
701
-         * @return boolean True if the browser is the YandexBlogs otherwise false
702
-         */
703
-        protected function checkBrowserYandexBlogsBot()
704
-        {
705
-            if (stripos($this->_agent, 'YandexBlogs') !== false) {
706
-                $aresult = explode('/', stristr($this->_agent, 'YandexBlogs'));
707
-                if (isset($aresult[1])) {
708
-                    $aversion = explode(' ', $aresult[1]);
709
-                    $this->setVersion(str_replace(';', '', $aversion[0]));
710
-                    $this->_browser_name = self::BROWSER_YANDEXBLOGS_BOT;
711
-                    $this->setRobot(true);
712
-                    return true;
713
-                }
714
-            }
715
-            return false;
716
-        }
717
-
718
-        /**
719
-         * Determine if the browser is the YandexMedia or not
720
-         * @return boolean True if the browser is the YandexMedia otherwise false
721
-         */
722
-        protected function checkBrowserYandexMediaBot()
723
-        {
724
-            if (stripos($this->_agent, 'YandexMedia') !== false) {
725
-                $aresult = explode('/', stristr($this->_agent, 'YandexMedia'));
726
-                if (isset($aresult[1])) {
727
-                    $aversion = explode(' ', $aresult[1]);
728
-                    $this->setVersion(str_replace(';', '', $aversion[0]));
729
-                    $this->_browser_name = self::BROWSER_YANDEXMEDIA_BOT;
730
-                    $this->setRobot(true);
731
-                    return true;
732
-                }
733
-            }
734
-            return false;
735
-        }
736
-
737
-        /**
738
-         * Determine if the browser is the YandexVideo or not
739
-         * @return boolean True if the browser is the YandexVideo otherwise false
740
-         */
741
-        protected function checkBrowserYandexVideoBot()
742
-        {
743
-            if (stripos($this->_agent, 'YandexVideo') !== false) {
744
-                $aresult = explode('/', stristr($this->_agent, 'YandexVideo'));
745
-                if (isset($aresult[1])) {
746
-                    $aversion = explode(' ', $aresult[1]);
747
-                    $this->setVersion(str_replace(';', '', $aversion[0]));
748
-                    $this->_browser_name = self::BROWSER_YANDEXVIDEO_BOT;
749
-                    $this->setRobot(true);
750
-                    return true;
751
-                }
752
-            }
753
-            return false;
754
-        }
755
-
756
-        /**
757
-         * Determine if the browser is the YandexImages or not
758
-         * @return boolean True if the browser is the YandexImages otherwise false
759
-         */
760
-        protected function checkBrowserYandexImagesBot()
761
-        {
762
-            if (stripos($this->_agent, 'YandexImages') !== false) {
763
-                $aresult = explode('/', stristr($this->_agent, 'YandexImages'));
764
-                if (isset($aresult[1])) {
765
-                    $aversion = explode(' ', $aresult[1]);
766
-                    $this->setVersion(str_replace(';', '', $aversion[0]));
767
-                    $this->_browser_name = self::BROWSER_YANDEXIMAGES_BOT;
768
-                    $this->setRobot(true);
769
-                    return true;
770
-                }
771
-            }
772
-            return false;
773
-        }
774
-
775
-        /**
776
-         * Determine if the browser is the MSNBot or not (last updated 1.9)
777
-         * @return boolean True if the browser is the MSNBot otherwise false
778
-         */
779
-        protected function checkBrowserMSNBot()
780
-        {
781
-            if (stripos($this->_agent, "msnbot") !== false) {
782
-                $aresult = explode("/", stristr($this->_agent, "msnbot"));
783
-                if (isset($aresult[1])) {
784
-                    $aversion = explode(" ", $aresult[1]);
785
-                    $this->setVersion(str_replace(";", "", $aversion[0]));
786
-                    $this->_browser_name = self::BROWSER_MSNBOT;
787
-                    $this->setRobot(true);
788
-                    return true;
789
-                }
790
-            }
791
-            return false;
792
-        }
793
-
794
-        /**
795
-         * Determine if the browser is the BingBot or not (last updated 1.9)
796
-         * @return boolean True if the browser is the BingBot otherwise false
797
-         */
798
-        protected function checkBrowserBingBot()
799
-        {
800
-            if (stripos($this->_agent, "bingbot") !== false) {
801
-                $aresult = explode("/", stristr($this->_agent, "bingbot"));
802
-                if (isset($aresult[1])) {
803
-                    $aversion = explode(" ", $aresult[1]);
804
-                    $this->setVersion(str_replace(";", "", $aversion[0]));
805
-                    $this->_browser_name = self::BROWSER_BINGBOT;
806
-                    $this->setRobot(true);
807
-                    return true;
808
-                }
809
-            }
810
-            return false;
811
-        }
812
-
813
-        /**
814
-         * Determine if the browser is the W3C Validator or not (last updated 1.7)
815
-         * @return boolean True if the browser is the W3C Validator otherwise false
816
-         */
817
-        protected function checkBrowserW3CValidator()
818
-        {
819
-            if (stripos($this->_agent, 'W3C-checklink') !== false) {
820
-                $aresult = explode('/', stristr($this->_agent, 'W3C-checklink'));
821
-                if (isset($aresult[1])) {
822
-                    $aversion = explode(' ', $aresult[1]);
823
-                    $this->setVersion($aversion[0]);
824
-                    $this->_browser_name = self::BROWSER_W3CVALIDATOR;
825
-                    return true;
826
-                }
827
-            } else if (stripos($this->_agent, 'W3C_Validator') !== false) {
828
-                // Some of the Validator versions do not delineate w/ a slash - add it back in
829
-                $ua = str_replace("W3C_Validator ", "W3C_Validator/", $this->_agent);
830
-                $aresult = explode('/', stristr($ua, 'W3C_Validator'));
831
-                if (isset($aresult[1])) {
832
-                    $aversion = explode(' ', $aresult[1]);
833
-                    $this->setVersion($aversion[0]);
834
-                    $this->_browser_name = self::BROWSER_W3CVALIDATOR;
835
-                    return true;
836
-                }
837
-            } else if (stripos($this->_agent, 'W3C-mobileOK') !== false) {
838
-                $this->_browser_name = self::BROWSER_W3CVALIDATOR;
839
-                $this->setMobile(true);
840
-                return true;
841
-            }
842
-            return false;
843
-        }
844
-
845
-        /**
846
-         * Determine if the browser is the Yahoo! Slurp Robot or not (last updated 1.7)
847
-         * @return boolean True if the browser is the Yahoo! Slurp Robot otherwise false
848
-         */
849
-        protected function checkBrowserSlurp()
850
-        {
851
-            if (stripos($this->_agent, 'slurp') !== false) {
852
-                $aresult = explode('/', stristr($this->_agent, 'Slurp'));
853
-                if (isset($aresult[1])) {
854
-                    $aversion = explode(' ', $aresult[1]);
855
-                    $this->setVersion($aversion[0]);
856
-                    $this->_browser_name = self::BROWSER_SLURP;
857
-                    $this->setRobot(true);
858
-                    $this->setMobile(false);
859
-                    return true;
860
-                }
861
-            }
862
-            return false;
863
-        }
864
-
865
-        /**
866
-         * Determine if the browser is Edge or not
867
-         * @return boolean True if the browser is Edge otherwise false
868
-         */
869
-        protected function checkBrowserEdge()
870
-        {
871
-            if (stripos($this->_agent, 'Edge/') !== false) {
872
-                $aresult = explode('/', stristr($this->_agent, 'Edge'));
873
-                if (isset($aresult[1])) {
874
-                    $aversion = explode(' ', $aresult[1]);
875
-                    $this->setVersion($aversion[0]);
876
-                    $this->setBrowser(self::BROWSER_EDGE);
877
-                    if (stripos($this->_agent, 'Windows Phone') !== false || stripos($this->_agent, 'Android') !== false) {
878
-                        $this->setMobile(true);
879
-                    }
880
-                    return true;
881
-                }
882
-            }
883
-            return false;
884
-        }
885
-
886
-        /**
887
-         * Determine if the browser is Internet Explorer or not (last updated 1.7)
888
-         * @return boolean True if the browser is Internet Explorer otherwise false
889
-         */
890
-        protected function checkBrowserInternetExplorer()
891
-        {
892
-            //  Test for IE11
893
-            if (stripos($this->_agent, 'Trident/7.0; rv:11.0') !== false) {
894
-                $this->setBrowser(self::BROWSER_IE);
895
-                $this->setVersion('11.0');
896
-                return true;
897
-            } // Test for v1 - v1.5 IE
898
-            else if (stripos($this->_agent, 'microsoft internet explorer') !== false) {
899
-                $this->setBrowser(self::BROWSER_IE);
900
-                $this->setVersion('1.0');
901
-                $aresult = stristr($this->_agent, '/');
902
-                if (preg_match('/308|425|426|474|0b1/i', $aresult)) {
903
-                    $this->setVersion('1.5');
904
-                }
905
-                return true;
906
-            } // Test for versions > 1.5
907
-            else if (stripos($this->_agent, 'msie') !== false && stripos($this->_agent, 'opera') === false) {
908
-                // See if the browser is the odd MSN Explorer
909
-                if (stripos($this->_agent, 'msnb') !== false) {
910
-                    $aresult = explode(' ', stristr(str_replace(';', '; ', $this->_agent), 'MSN'));
911
-                    if (isset($aresult[1])) {
912
-                        $this->setBrowser(self::BROWSER_MSN);
913
-                        $this->setVersion(str_replace(array('(', ')', ';'), '', $aresult[1]));
914
-                        return true;
915
-                    }
916
-                }
917
-                $aresult = explode(' ', stristr(str_replace(';', '; ', $this->_agent), 'msie'));
918
-                if (isset($aresult[1])) {
919
-                    $this->setBrowser(self::BROWSER_IE);
920
-                    $this->setVersion(str_replace(array('(', ')', ';'), '', $aresult[1]));
921
-                    if(preg_match('#trident/([0-9\.]+);#i', $this->_agent, $aresult)){
922
-                        if($aresult[1] == '3.1'){
923
-                            $this->setVersion('7.0');
924
-                        }
925
-                        else if($aresult[1] == '4.0'){
926
-                            $this->setVersion('8.0');
927
-                        }
928
-                        else if($aresult[1] == '5.0'){
929
-                            $this->setVersion('9.0');
930
-                        }
931
-                        else if($aresult[1] == '6.0'){
932
-                            $this->setVersion('10.0');
933
-                        }
934
-                        else if($aresult[1] == '7.0'){
935
-                            $this->setVersion('11.0');
936
-                        }
937
-                        else if($aresult[1] == '8.0'){
938
-                            $this->setVersion('11.0');
939
-                        }
940
-                    }
941
-                    if(stripos($this->_agent, 'IEMobile') !== false) {
942
-                        $this->setBrowser(self::BROWSER_POCKET_IE);
943
-                        $this->setMobile(true);
944
-                    }
945
-                    return true;
946
-                }
947
-            } // Test for versions > IE 10
948
-            else if (stripos($this->_agent, 'trident') !== false) {
949
-                $this->setBrowser(self::BROWSER_IE);
950
-                $result = explode('rv:', $this->_agent);
951
-                if (isset($result[1])) {
952
-                    $this->setVersion(preg_replace('/[^0-9.]+/', '', $result[1]));
953
-                    $this->_agent = str_replace(array("Mozilla", "Gecko"), "MSIE", $this->_agent);
954
-                }
955
-            } // Test for Pocket IE
956
-            else if (stripos($this->_agent, 'mspie') !== false || stripos($this->_agent, 'pocket') !== false) {
957
-                $aresult = explode(' ', stristr($this->_agent, 'mspie'));
958
-                if (isset($aresult[1])) {
959
-                    $this->setPlatform(self::PLATFORM_WINDOWS_CE);
960
-                    $this->setBrowser(self::BROWSER_POCKET_IE);
961
-                    $this->setMobile(true);
962
-
963
-                    if (stripos($this->_agent, 'mspie') !== false) {
964
-                        $this->setVersion($aresult[1]);
965
-                    } else {
966
-                        $aversion = explode('/', $this->_agent);
967
-                        if (isset($aversion[1])) {
968
-                            $this->setVersion($aversion[1]);
969
-                        }
970
-                    }
971
-                    return true;
972
-                }
973
-            }
974
-            return false;
975
-        }
976
-
977
-        /**
978
-         * Determine if the browser is Opera or not (last updated 1.7)
979
-         * @return boolean True if the browser is Opera otherwise false
980
-         */
981
-        protected function checkBrowserOpera()
982
-        {
983
-            if (stripos($this->_agent, 'opera mini') !== false) {
984
-                $resultant = stristr($this->_agent, 'opera mini');
985
-                if (preg_match('/\//', $resultant)) {
986
-                    $aresult = explode('/', $resultant);
987
-                    if (isset($aresult[1])) {
988
-                        $aversion = explode(' ', $aresult[1]);
989
-                        $this->setVersion($aversion[0]);
990
-                    }
991
-                } else {
992
-                    $aversion = explode(' ', stristr($resultant, 'opera mini'));
993
-                    if (isset($aversion[1])) {
994
-                        $this->setVersion($aversion[1]);
995
-                    }
996
-                }
997
-                $this->_browser_name = self::BROWSER_OPERA_MINI;
998
-                $this->setMobile(true);
999
-                return true;
1000
-            } else if (stripos($this->_agent, 'opera') !== false) {
1001
-                $resultant = stristr($this->_agent, 'opera');
1002
-                if (preg_match('/Version\/(1*.*)$/', $resultant, $matches)) {
1003
-                    $this->setVersion($matches[1]);
1004
-                } else if (preg_match('/\//', $resultant)) {
1005
-                    $aresult = explode('/', str_replace("(", " ", $resultant));
1006
-                    if (isset($aresult[1])) {
1007
-                        $aversion = explode(' ', $aresult[1]);
1008
-                        $this->setVersion($aversion[0]);
1009
-                    }
1010
-                } else {
1011
-                    $aversion = explode(' ', stristr($resultant, 'opera'));
1012
-                    $this->setVersion(isset($aversion[1]) ? $aversion[1] : "");
1013
-                }
1014
-                if (stripos($this->_agent, 'Opera Mobi') !== false) {
1015
-                    $this->setMobile(true);
1016
-                }
1017
-                $this->_browser_name = self::BROWSER_OPERA;
1018
-                return true;
1019
-            } else if (stripos($this->_agent, 'OPR') !== false) {
1020
-                $resultant = stristr($this->_agent, 'OPR');
1021
-                if (preg_match('/\//', $resultant)) {
1022
-                    $aresult = explode('/', str_replace("(", " ", $resultant));
1023
-                    if (isset($aresult[1])) {
1024
-                        $aversion = explode(' ', $aresult[1]);
1025
-                        $this->setVersion($aversion[0]);
1026
-                    }
1027
-                }
1028
-                if (stripos($this->_agent, 'Mobile') !== false) {
1029
-                    $this->setMobile(true);
1030
-                }
1031
-                $this->_browser_name = self::BROWSER_OPERA;
1032
-                return true;
1033
-            }
1034
-            return false;
1035
-        }
1036
-
1037
-        /**
1038
-         * Determine if the browser is Chrome or not (last updated 1.7)
1039
-         * @return boolean True if the browser is Chrome otherwise false
1040
-         */
1041
-        protected function checkBrowserChrome()
1042
-        {
1043
-            if (stripos($this->_agent, 'Chrome') !== false) {
1044
-                $aresult = explode('/', stristr($this->_agent, 'Chrome'));
1045
-                if (isset($aresult[1])) {
1046
-                    $aversion = explode(' ', $aresult[1]);
1047
-                    $this->setVersion($aversion[0]);
1048
-                    $this->setBrowser(self::BROWSER_CHROME);
1049
-                    //Chrome on Android
1050
-                    if (stripos($this->_agent, 'Android') !== false) {
1051
-                        if (stripos($this->_agent, 'Mobile') !== false) {
1052
-                            $this->setMobile(true);
1053
-                        } else {
1054
-                            $this->setTablet(true);
1055
-                        }
1056
-                    }
1057
-                    return true;
1058
-                }
1059
-            }
1060
-            return false;
1061
-        }
1062
-
1063
-
1064
-        /**
1065
-         * Determine if the browser is WebTv or not (last updated 1.7)
1066
-         * @return boolean True if the browser is WebTv otherwise false
1067
-         */
1068
-        protected function checkBrowserWebTv()
1069
-        {
1070
-            if (stripos($this->_agent, 'webtv') !== false) {
1071
-                $aresult = explode('/', stristr($this->_agent, 'webtv'));
1072
-                if (isset($aresult[1])) {
1073
-                    $aversion = explode(' ', $aresult[1]);
1074
-                    $this->setVersion($aversion[0]);
1075
-                    $this->setBrowser(self::BROWSER_WEBTV);
1076
-                    return true;
1077
-                }
1078
-            }
1079
-            return false;
1080
-        }
1081
-
1082
-        /**
1083
-         * Determine if the browser is NetPositive or not (last updated 1.7)
1084
-         * @return boolean True if the browser is NetPositive otherwise false
1085
-         */
1086
-        protected function checkBrowserNetPositive()
1087
-        {
1088
-            if (stripos($this->_agent, 'NetPositive') !== false) {
1089
-                $aresult = explode('/', stristr($this->_agent, 'NetPositive'));
1090
-                if (isset($aresult[1])) {
1091
-                    $aversion = explode(' ', $aresult[1]);
1092
-                    $this->setVersion(str_replace(array('(', ')', ';'), '', $aversion[0]));
1093
-                    $this->setBrowser(self::BROWSER_NETPOSITIVE);
1094
-                    return true;
1095
-                }
1096
-            }
1097
-            return false;
1098
-        }
1099
-
1100
-        /**
1101
-         * Determine if the browser is Galeon or not (last updated 1.7)
1102
-         * @return boolean True if the browser is Galeon otherwise false
1103
-         */
1104
-        protected function checkBrowserGaleon()
1105
-        {
1106
-            if (stripos($this->_agent, 'galeon') !== false) {
1107
-                $aresult = explode(' ', stristr($this->_agent, 'galeon'));
1108
-                $aversion = explode('/', $aresult[0]);
1109
-                if (isset($aversion[1])) {
1110
-                    $this->setVersion($aversion[1]);
1111
-                    $this->setBrowser(self::BROWSER_GALEON);
1112
-                    return true;
1113
-                }
1114
-            }
1115
-            return false;
1116
-        }
1117
-
1118
-        /**
1119
-         * Determine if the browser is Konqueror or not (last updated 1.7)
1120
-         * @return boolean True if the browser is Konqueror otherwise false
1121
-         */
1122
-        protected function checkBrowserKonqueror()
1123
-        {
1124
-            if (stripos($this->_agent, 'Konqueror') !== false) {
1125
-                $aresult = explode(' ', stristr($this->_agent, 'Konqueror'));
1126
-                $aversion = explode('/', $aresult[0]);
1127
-                if (isset($aversion[1])) {
1128
-                    $this->setVersion($aversion[1]);
1129
-                    $this->setBrowser(self::BROWSER_KONQUEROR);
1130
-                    return true;
1131
-                }
1132
-            }
1133
-            return false;
1134
-        }
1135
-
1136
-        /**
1137
-         * Determine if the browser is iCab or not (last updated 1.7)
1138
-         * @return boolean True if the browser is iCab otherwise false
1139
-         */
1140
-        protected function checkBrowserIcab()
1141
-        {
1142
-            if (stripos($this->_agent, 'icab') !== false) {
1143
-                $aversion = explode(' ', stristr(str_replace('/', ' ', $this->_agent), 'icab'));
1144
-                if (isset($aversion[1])) {
1145
-                    $this->setVersion($aversion[1]);
1146
-                    $this->setBrowser(self::BROWSER_ICAB);
1147
-                    return true;
1148
-                }
1149
-            }
1150
-            return false;
1151
-        }
1152
-
1153
-        /**
1154
-         * Determine if the browser is OmniWeb or not (last updated 1.7)
1155
-         * @return boolean True if the browser is OmniWeb otherwise false
1156
-         */
1157
-        protected function checkBrowserOmniWeb()
1158
-        {
1159
-            if (stripos($this->_agent, 'omniweb') !== false) {
1160
-                $aresult = explode('/', stristr($this->_agent, 'omniweb'));
1161
-                $aversion = explode(' ', isset($aresult[1]) ? $aresult[1] : "");
1162
-                $this->setVersion($aversion[0]);
1163
-                $this->setBrowser(self::BROWSER_OMNIWEB);
1164
-                return true;
1165
-            }
1166
-            return false;
1167
-        }
1168
-
1169
-        /**
1170
-         * Determine if the browser is Phoenix or not (last updated 1.7)
1171
-         * @return boolean True if the browser is Phoenix otherwise false
1172
-         */
1173
-        protected function checkBrowserPhoenix()
1174
-        {
1175
-            if (stripos($this->_agent, 'Phoenix') !== false) {
1176
-                $aversion = explode('/', stristr($this->_agent, 'Phoenix'));
1177
-                if (isset($aversion[1])) {
1178
-                    $this->setVersion($aversion[1]);
1179
-                    $this->setBrowser(self::BROWSER_PHOENIX);
1180
-                    return true;
1181
-                }
1182
-            }
1183
-            return false;
1184
-        }
1185
-
1186
-        /**
1187
-         * Determine if the browser is Firebird or not (last updated 1.7)
1188
-         * @return boolean True if the browser is Firebird otherwise false
1189
-         */
1190
-        protected function checkBrowserFirebird()
1191
-        {
1192
-            if (stripos($this->_agent, 'Firebird') !== false) {
1193
-                $aversion = explode('/', stristr($this->_agent, 'Firebird'));
1194
-                if (isset($aversion[1])) {
1195
-                    $this->setVersion($aversion[1]);
1196
-                    $this->setBrowser(self::BROWSER_FIREBIRD);
1197
-                    return true;
1198
-                }
1199
-            }
1200
-            return false;
1201
-        }
1202
-
1203
-        /**
1204
-         * Determine if the browser is Netscape Navigator 9+ or not (last updated 1.7)
1205
-         * NOTE: (http://browser.netscape.com/ - Official support ended on March 1st, 2008)
1206
-         * @return boolean True if the browser is Netscape Navigator 9+ otherwise false
1207
-         */
1208
-        protected function checkBrowserNetscapeNavigator9Plus()
1209
-        {
1210
-            if (stripos($this->_agent, 'Firefox') !== false && preg_match('/Navigator\/([^ ]*)/i', $this->_agent, $matches)) {
1211
-                $this->setVersion($matches[1]);
1212
-                $this->setBrowser(self::BROWSER_NETSCAPE_NAVIGATOR);
1213
-                return true;
1214
-            } else if (stripos($this->_agent, 'Firefox') === false && preg_match('/Netscape6?\/([^ ]*)/i', $this->_agent, $matches)) {
1215
-                $this->setVersion($matches[1]);
1216
-                $this->setBrowser(self::BROWSER_NETSCAPE_NAVIGATOR);
1217
-                return true;
1218
-            }
1219
-            return false;
1220
-        }
1221
-
1222
-        /**
1223
-         * Determine if the browser is Shiretoko or not (https://wiki.mozilla.org/Projects/shiretoko) (last updated 1.7)
1224
-         * @return boolean True if the browser is Shiretoko otherwise false
1225
-         */
1226
-        protected function checkBrowserShiretoko()
1227
-        {
1228
-            if (stripos($this->_agent, 'Mozilla') !== false && preg_match('/Shiretoko\/([^ ]*)/i', $this->_agent, $matches)) {
1229
-                $this->setVersion($matches[1]);
1230
-                $this->setBrowser(self::BROWSER_SHIRETOKO);
1231
-                return true;
1232
-            }
1233
-            return false;
1234
-        }
1235
-
1236
-        /**
1237
-         * Determine if the browser is Ice Cat or not (http://en.wikipedia.org/wiki/GNU_IceCat) (last updated 1.7)
1238
-         * @return boolean True if the browser is Ice Cat otherwise false
1239
-         */
1240
-        protected function checkBrowserIceCat()
1241
-        {
1242
-            if (stripos($this->_agent, 'Mozilla') !== false && preg_match('/IceCat\/([^ ]*)/i', $this->_agent, $matches)) {
1243
-                $this->setVersion($matches[1]);
1244
-                $this->setBrowser(self::BROWSER_ICECAT);
1245
-                return true;
1246
-            }
1247
-            return false;
1248
-        }
1249
-
1250
-        /**
1251
-         * Determine if the browser is Nokia or not (last updated 1.7)
1252
-         * @return boolean True if the browser is Nokia otherwise false
1253
-         */
1254
-        protected function checkBrowserNokia()
1255
-        {
1256
-            if (preg_match("/Nokia([^\/]+)\/([^ SP]+)/i", $this->_agent, $matches)) {
1257
-                $this->setVersion($matches[2]);
1258
-                if (stripos($this->_agent, 'Series60') !== false || strpos($this->_agent, 'S60') !== false) {
1259
-                    $this->setBrowser(self::BROWSER_NOKIA_S60);
1260
-                } else {
1261
-                    $this->setBrowser(self::BROWSER_NOKIA);
1262
-                }
1263
-                $this->setMobile(true);
1264
-                return true;
1265
-            }
1266
-            return false;
1267
-        }
1268
-
1269
-        /**
1270
-         * Determine if the browser is Firefox or not (last updated 1.7)
1271
-         * @return boolean True if the browser is Firefox otherwise false
1272
-         */
1273
-        protected function checkBrowserFirefox()
1274
-        {
1275
-            if (stripos($this->_agent, 'safari') === false) {
1276
-                if (preg_match("/Firefox[\/ \(]([^ ;\)]+)/i", $this->_agent, $matches)) {
1277
-                    $this->setVersion($matches[1]);
1278
-                    $this->setBrowser(self::BROWSER_FIREFOX);
1279
-                    //Firefox on Android
1280
-                    if (stripos($this->_agent, 'Android') !== false) {
1281
-                        if (stripos($this->_agent, 'Mobile') !== false) {
1282
-                            $this->setMobile(true);
1283
-                        } else {
1284
-                            $this->setTablet(true);
1285
-                        }
1286
-                    }
1287
-                    return true;
1288
-                } else if (preg_match("/Firefox$/i", $this->_agent, $matches)) {
1289
-                    $this->setVersion("");
1290
-                    $this->setBrowser(self::BROWSER_FIREFOX);
1291
-                    return true;
1292
-                }
1293
-            }
1294
-            return false;
1295
-        }
1296
-
1297
-        /**
1298
-         * Determine if the browser is Firefox or not (last updated 1.7)
1299
-         * @return boolean True if the browser is Firefox otherwise false
1300
-         */
1301
-        protected function checkBrowserIceweasel()
1302
-        {
1303
-            if (stripos($this->_agent, 'Iceweasel') !== false) {
1304
-                $aresult = explode('/', stristr($this->_agent, 'Iceweasel'));
1305
-                if (isset($aresult[1])) {
1306
-                    $aversion = explode(' ', $aresult[1]);
1307
-                    $this->setVersion($aversion[0]);
1308
-                    $this->setBrowser(self::BROWSER_ICEWEASEL);
1309
-                    return true;
1310
-                }
1311
-            }
1312
-            return false;
1313
-        }
1314
-
1315
-        /**
1316
-         * Determine if the browser is Mozilla or not (last updated 1.7)
1317
-         * @return boolean True if the browser is Mozilla otherwise false
1318
-         */
1319
-        protected function checkBrowserMozilla()
1320
-        {
1321
-            if (stripos($this->_agent, 'mozilla') !== false && preg_match('/rv:[0-9].[0-9][a-b]?/i', $this->_agent) && stripos($this->_agent, 'netscape') === false) {
1322
-                $aversion = explode(' ', stristr($this->_agent, 'rv:'));
1323
-                preg_match('/rv:[0-9].[0-9][a-b]?/i', $this->_agent, $aversion);
1324
-                $this->setVersion(str_replace('rv:', '', $aversion[0]));
1325
-                $this->setBrowser(self::BROWSER_MOZILLA);
1326
-                return true;
1327
-            } else if (stripos($this->_agent, 'mozilla') !== false && preg_match('/rv:[0-9]\.[0-9]/i', $this->_agent) && stripos($this->_agent, 'netscape') === false) {
1328
-                $aversion = explode('', stristr($this->_agent, 'rv:'));
1329
-                $this->setVersion(str_replace('rv:', '', $aversion[0]));
1330
-                $this->setBrowser(self::BROWSER_MOZILLA);
1331
-                return true;
1332
-            } else if (stripos($this->_agent, 'mozilla') !== false && preg_match('/mozilla\/([^ ]*)/i', $this->_agent, $matches) && stripos($this->_agent, 'netscape') === false) {
1333
-                $this->setVersion($matches[1]);
1334
-                $this->setBrowser(self::BROWSER_MOZILLA);
1335
-                return true;
1336
-            }
1337
-            return false;
1338
-        }
1339
-
1340
-        /**
1341
-         * Determine if the browser is Lynx or not (last updated 1.7)
1342
-         * @return boolean True if the browser is Lynx otherwise false
1343
-         */
1344
-        protected function checkBrowserLynx()
1345
-        {
1346
-            if (stripos($this->_agent, 'lynx') !== false) {
1347
-                $aresult = explode('/', stristr($this->_agent, 'Lynx'));
1348
-                $aversion = explode(' ', (isset($aresult[1]) ? $aresult[1] : ""));
1349
-                $this->setVersion($aversion[0]);
1350
-                $this->setBrowser(self::BROWSER_LYNX);
1351
-                return true;
1352
-            }
1353
-            return false;
1354
-        }
1355
-
1356
-        /**
1357
-         * Determine if the browser is Amaya or not (last updated 1.7)
1358
-         * @return boolean True if the browser is Amaya otherwise false
1359
-         */
1360
-        protected function checkBrowserAmaya()
1361
-        {
1362
-            if (stripos($this->_agent, 'amaya') !== false) {
1363
-                $aresult = explode('/', stristr($this->_agent, 'Amaya'));
1364
-                if (isset($aresult[1])) {
1365
-                    $aversion = explode(' ', $aresult[1]);
1366
-                    $this->setVersion($aversion[0]);
1367
-                    $this->setBrowser(self::BROWSER_AMAYA);
1368
-                    return true;
1369
-                }
1370
-            }
1371
-            return false;
1372
-        }
1373
-
1374
-        /**
1375
-         * Determine if the browser is Safari or not (last updated 1.7)
1376
-         * @return boolean True if the browser is Safari otherwise false
1377
-         */
1378
-        protected function checkBrowserSafari()
1379
-        {
1380
-            if (stripos($this->_agent, 'Safari') !== false
1381
-                && stripos($this->_agent, 'iPhone') === false
1382
-                && stripos($this->_agent, 'iPod') === false
1383
-            ) {
1384
-
1385
-                $aresult = explode('/', stristr($this->_agent, 'Version'));
1386
-                if (isset($aresult[1])) {
1387
-                    $aversion = explode(' ', $aresult[1]);
1388
-                    $this->setVersion($aversion[0]);
1389
-                } else {
1390
-                    $this->setVersion(self::VERSION_UNKNOWN);
1391
-                }
1392
-                $this->setBrowser(self::BROWSER_SAFARI);
1393
-                return true;
1394
-            }
1395
-            return false;
1396
-        }
1397
-
1398
-        protected function checkBrowserSamsung()
1399
-        {
1400
-            if (stripos($this->_agent, 'SamsungBrowser') !== false) {
1401
-
1402
-                $aresult = explode('/', stristr($this->_agent, 'SamsungBrowser'));
1403
-                if (isset($aresult[1])) {
1404
-                    $aversion = explode(' ', $aresult[1]);
1405
-                    $this->setVersion($aversion[0]);
1406
-                } else {
1407
-                    $this->setVersion(self::VERSION_UNKNOWN);
1408
-                }
1409
-                $this->setBrowser(self::BROWSER_SAMSUNG);
1410
-                return true;
1411
-            }
1412
-            return false;
1413
-        }
1414
-
1415
-        protected function checkBrowserSilk()
1416
-        {
1417
-            if (stripos($this->_agent, 'Silk') !== false) {
1418
-                $aresult = explode('/', stristr($this->_agent, 'Silk'));
1419
-                if (isset($aresult[1])) {
1420
-                    $aversion = explode(' ', $aresult[1]);
1421
-                    $this->setVersion($aversion[0]);
1422
-                } else {
1423
-                    $this->setVersion(self::VERSION_UNKNOWN);
1424
-                }
1425
-                $this->setBrowser(self::BROWSER_SILK);
1426
-                return true;
1427
-            }
1428
-            return false;
1429
-        }
1430
-
1431
-        protected function checkBrowserIframely()
1432
-        {
1433
-            if (stripos($this->_agent, 'Iframely') !== false) {
1434
-                $aresult = explode('/', stristr($this->_agent, 'Iframely'));
1435
-                if (isset($aresult[1])) {
1436
-                    $aversion = explode(' ', $aresult[1]);
1437
-                    $this->setVersion($aversion[0]);
1438
-                } else {
1439
-                    $this->setVersion(self::VERSION_UNKNOWN);
1440
-                }
1441
-                $this->setBrowser(self::BROWSER_I_FRAME);
1442
-                return true;
1443
-            }
1444
-            return false;
1445
-        }
1446
-
1447
-        protected function checkBrowserCocoa()
1448
-        {
1449
-            if (stripos($this->_agent, 'CocoaRestClient') !== false) {
1450
-                $aresult = explode('/', stristr($this->_agent, 'CocoaRestClient'));
1451
-                if (isset($aresult[1])) {
1452
-                    $aversion = explode(' ', $aresult[1]);
1453
-                    $this->setVersion($aversion[0]);
1454
-                } else {
1455
-                    $this->setVersion(self::VERSION_UNKNOWN);
1456
-                }
1457
-                $this->setBrowser(self::BROWSER_COCOA);
1458
-                return true;
1459
-            }
1460
-            return false;
1461
-        }
1462
-
1463
-        /**
1464
-         * Detect if URL is loaded from FacebookExternalHit
1465
-         * @return boolean True if it detects FacebookExternalHit otherwise false
1466
-         */
1467
-        protected function checkFacebookExternalHit()
1468
-        {
1469
-            if (stristr($this->_agent, 'FacebookExternalHit')) {
1470
-                $this->setRobot(true);
1471
-                $this->setFacebook(true);
1472
-                return true;
1473
-            }
1474
-            return false;
1475
-        }
1476
-
1477
-        /**
1478
-         * Detect if URL is being loaded from internal Facebook browser
1479
-         * @return boolean True if it detects internal Facebook browser otherwise false
1480
-         */
1481
-        protected function checkForFacebookIos()
1482
-        {
1483
-            if (stristr($this->_agent, 'FBIOS')) {
1484
-                $this->setFacebook(true);
1485
-                return true;
1486
-            }
1487
-            return false;
1488
-        }
1489
-
1490
-        /**
1491
-         * Detect Version for the Safari browser on iOS devices
1492
-         * @return boolean True if it detects the version correctly otherwise false
1493
-         */
1494
-        protected function getSafariVersionOnIos()
1495
-        {
1496
-            $aresult = explode('/', stristr($this->_agent, 'Version'));
1497
-            if (isset($aresult[1])) {
1498
-                $aversion = explode(' ', $aresult[1]);
1499
-                $this->setVersion($aversion[0]);
1500
-                return true;
1501
-            }
1502
-            return false;
1503
-        }
1504
-
1505
-        /**
1506
-         * Detect Version for the Chrome browser on iOS devices
1507
-         * @return boolean True if it detects the version correctly otherwise false
1508
-         */
1509
-        protected function getChromeVersionOnIos()
1510
-        {
1511
-            $aresult = explode('/', stristr($this->_agent, 'CriOS'));
1512
-            if (isset($aresult[1])) {
1513
-                $aversion = explode(' ', $aresult[1]);
1514
-                $this->setVersion($aversion[0]);
1515
-                $this->setBrowser(self::BROWSER_CHROME);
1516
-                return true;
1517
-            }
1518
-            return false;
1519
-        }
1520
-
1521
-        /**
1522
-         * Determine if the browser is iPhone or not (last updated 1.7)
1523
-         * @return boolean True if the browser is iPhone otherwise false
1524
-         */
1525
-        protected function checkBrowseriPhone()
1526
-        {
1527
-            if (stripos($this->_agent, 'iPhone') !== false) {
1528
-                $this->setVersion(self::VERSION_UNKNOWN);
1529
-                $this->setBrowser(self::BROWSER_IPHONE);
1530
-                $this->getSafariVersionOnIos();
1531
-                $this->getChromeVersionOnIos();
1532
-                $this->checkForFacebookIos();
1533
-                $this->setMobile(true);
1534
-                return true;
1535
-
1536
-            }
1537
-            return false;
1538
-        }
1539
-
1540
-        /**
1541
-         * Determine if the browser is iPad or not (last updated 1.7)
1542
-         * @return boolean True if the browser is iPad otherwise false
1543
-         */
1544
-        protected function checkBrowseriPad()
1545
-        {
1546
-            if (stripos($this->_agent, 'iPad') !== false) {
1547
-                $this->setVersion(self::VERSION_UNKNOWN);
1548
-                $this->setBrowser(self::BROWSER_IPAD);
1549
-                $this->getSafariVersionOnIos();
1550
-                $this->getChromeVersionOnIos();
1551
-                $this->checkForFacebookIos();
1552
-                $this->setTablet(true);
1553
-                return true;
1554
-            }
1555
-            return false;
1556
-        }
1557
-
1558
-        /**
1559
-         * Determine if the browser is iPod or not (last updated 1.7)
1560
-         * @return boolean True if the browser is iPod otherwise false
1561
-         */
1562
-        protected function checkBrowseriPod()
1563
-        {
1564
-            if (stripos($this->_agent, 'iPod') !== false) {
1565
-                $this->setVersion(self::VERSION_UNKNOWN);
1566
-                $this->setBrowser(self::BROWSER_IPOD);
1567
-                $this->getSafariVersionOnIos();
1568
-                $this->getChromeVersionOnIos();
1569
-                $this->checkForFacebookIos();
1570
-                $this->setMobile(true);
1571
-                return true;
1572
-            }
1573
-            return false;
1574
-        }
1575
-
1576
-        /**
1577
-         * Determine if the browser is Android or not (last updated 1.7)
1578
-         * @return boolean True if the browser is Android otherwise false
1579
-         */
1580
-        protected function checkBrowserAndroid()
1581
-        {
1582
-            if (stripos($this->_agent, 'Android') !== false) {
1583
-                $aresult = explode(' ', stristr($this->_agent, 'Android'));
1584
-                if (isset($aresult[1])) {
1585
-                    $aversion = explode(' ', $aresult[1]);
1586
-                    $this->setVersion($aversion[0]);
1587
-                } else {
1588
-                    $this->setVersion(self::VERSION_UNKNOWN);
1589
-                }
1590
-                if (stripos($this->_agent, 'Mobile') !== false) {
1591
-                    $this->setMobile(true);
1592
-                } else {
1593
-                    $this->setTablet(true);
1594
-                }
1595
-                $this->setBrowser(self::BROWSER_ANDROID);
1596
-                return true;
1597
-            }
1598
-            return false;
1599
-        }
1600
-
1601
-        /**
1602
-         * Determine if the browser is Vivaldi
1603
-         * @return boolean True if the browser is Vivaldi otherwise false
1604
-         */
1605
-        protected function checkBrowserVivaldi()
1606
-        {
1607
-            if (stripos($this->_agent, 'Vivaldi') !== false) {
1608
-                $aresult = explode('/', stristr($this->_agent, 'Vivaldi'));
1609
-                if (isset($aresult[1])) {
1610
-                    $aversion = explode(' ', $aresult[1]);
1611
-                    $this->setVersion($aversion[0]);
1612
-                    $this->setBrowser(self::BROWSER_VIVALDI);
1613
-                    return true;
1614
-                }
1615
-            }
1616
-            return false;
1617
-        }
1618
-
1619
-        /**
1620
-         * Determine if the browser is Yandex
1621
-         * @return boolean True if the browser is Yandex otherwise false
1622
-         */
1623
-        protected function checkBrowserYandex()
1624
-        {
1625
-            if (stripos($this->_agent, 'YaBrowser') !== false) {
1626
-                $aresult = explode('/', stristr($this->_agent, 'YaBrowser'));
1627
-                if (isset($aresult[1])) {
1628
-                    $aversion = explode(' ', $aresult[1]);
1629
-                    $this->setVersion($aversion[0]);
1630
-                    $this->setBrowser(self::BROWSER_YANDEX);
1631
-
1632
-                    if (stripos($this->_agent, 'iPad') !== false) {
1633
-                        $this->setTablet(true);
1634
-                    } elseif (stripos($this->_agent, 'Mobile') !== false) {
1635
-                        $this->setMobile(true);
1636
-                    } elseif (stripos($this->_agent, 'Android') !== false) {
1637
-                        $this->setTablet(true);
1638
-                    }
1639
-
1640
-                    return true;
1641
-                }
1642
-            }
1643
-
1644
-            return false;
1645
-        }
1646
-
1647
-        /**
1648
-         * Determine if the browser is a PlayStation
1649
-         * @return boolean True if the browser is PlayStation otherwise false
1650
-         */
1651
-        protected function checkBrowserPlayStation()
1652
-        {
1653
-            if (stripos($this->_agent, 'PlayStation ') !== false) {
1654
-                $aresult = explode(' ', stristr($this->_agent, 'PlayStation '));
1655
-                $this->setBrowser(self::BROWSER_PLAYSTATION);
1656
-                if (isset($aresult[0])) {
1657
-                    $aversion = explode(')', $aresult[2]);
1658
-                    $this->setVersion($aversion[0]);
1659
-                    if (stripos($this->_agent, 'Portable)') !== false || stripos($this->_agent, 'Vita') !== false) {
1660
-                        $this->setMobile(true);
1661
-                    }
1662
-                    return true;
1663
-                }
1664
-            }
1665
-            return false;
1666
-        }
1667
-
1668
-        /**
1669
-         * Determine the user's platform (last updated 2.0)
1670
-         */
1671
-        protected function checkPlatform()
1672
-        {
1673
-            if (stripos($this->_agent, 'windows') !== false) {
1674
-                $this->_platform = self::PLATFORM_WINDOWS;
1675
-            } else if (stripos($this->_agent, 'iPad') !== false) {
1676
-                $this->_platform = self::PLATFORM_IPAD;
1677
-            } else if (stripos($this->_agent, 'iPod') !== false) {
1678
-                $this->_platform = self::PLATFORM_IPOD;
1679
-            } else if (stripos($this->_agent, 'iPhone') !== false) {
1680
-                $this->_platform = self::PLATFORM_IPHONE;
1681
-            } elseif (stripos($this->_agent, 'mac') !== false) {
1682
-                $this->_platform = self::PLATFORM_APPLE;
1683
-            } elseif (stripos($this->_agent, 'android') !== false) {
1684
-                $this->_platform = self::PLATFORM_ANDROID;
1685
-            } elseif (stripos($this->_agent, 'Silk') !== false) {
1686
-                $this->_platform = self::PLATFORM_FIRE_OS;
1687
-            } elseif (stripos($this->_agent, 'linux') !== false && stripos($this->_agent, 'SMART-TV') !== false ) {
1688
-                $this->_platform = self::PLATFORM_LINUX .'/'.self::PLATFORM_SMART_TV;
1689
-            } elseif (stripos($this->_agent, 'linux') !== false) {
1690
-                $this->_platform = self::PLATFORM_LINUX;
1691
-            } else if (stripos($this->_agent, 'Nokia') !== false) {
1692
-                $this->_platform = self::PLATFORM_NOKIA;
1693
-            } else if (stripos($this->_agent, 'BlackBerry') !== false) {
1694
-                $this->_platform = self::PLATFORM_BLACKBERRY;
1695
-            } elseif (stripos($this->_agent, 'FreeBSD') !== false) {
1696
-                $this->_platform = self::PLATFORM_FREEBSD;
1697
-            } elseif (stripos($this->_agent, 'OpenBSD') !== false) {
1698
-                $this->_platform = self::PLATFORM_OPENBSD;
1699
-            } elseif (stripos($this->_agent, 'NetBSD') !== false) {
1700
-                $this->_platform = self::PLATFORM_NETBSD;
1701
-            } elseif (stripos($this->_agent, 'OpenSolaris') !== false) {
1702
-                $this->_platform = self::PLATFORM_OPENSOLARIS;
1703
-            } elseif (stripos($this->_agent, 'SunOS') !== false) {
1704
-                $this->_platform = self::PLATFORM_SUNOS;
1705
-            } elseif (stripos($this->_agent, 'OS\/2') !== false) {
1706
-                $this->_platform = self::PLATFORM_OS2;
1707
-            } elseif (stripos($this->_agent, 'BeOS') !== false) {
1708
-                $this->_platform = self::PLATFORM_BEOS;
1709
-            } elseif (stripos($this->_agent, 'win') !== false) {
1710
-                $this->_platform = self::PLATFORM_WINDOWS;
1711
-            } elseif (stripos($this->_agent, 'Playstation') !== false) {
1712
-                $this->_platform = self::PLATFORM_PLAYSTATION;
1713
-            } elseif (stripos($this->_agent, 'Roku') !== false) {
1714
-                $this->_platform = self::PLATFORM_ROKU;
1715
-            } elseif (stripos($this->_agent, 'iOS') !== false) {
1716
-                $this->_platform = self::PLATFORM_IPHONE . '/' . self::PLATFORM_IPAD;
1717
-            } elseif (stripos($this->_agent, 'tvOS') !== false) {
1718
-                $this->_platform = self::PLATFORM_APPLE_TV;
1719
-            } elseif (stripos($this->_agent, 'curl') !== false) {
1720
-                $this->_platform = self::PLATFORM_TERMINAL;
1721
-            } elseif (stripos($this->_agent, 'CrOS') !== false) {
1722
-                $this->_platform = self::PLATFORM_CHROME_OS;
1723
-            } elseif (stripos($this->_agent, 'okhttp') !== false) {
1724
-                $this->_platform = self::PLATFORM_JAVA_ANDROID;
1725
-            } elseif (stripos($this->_agent, 'PostmanRuntime') !== false) {
1726
-                $this->_platform = self::PLATFORM_POSTMAN;
1727
-            } elseif (stripos($this->_agent, 'Iframely') !== false) {
1728
-                $this->_platform = self::PLATFORM_I_FRAME;
1729
-            }
1730
-
1731
-        }
1732
-    }
2
+	defined('ROOT_PATH') || exit('Access denied');
3
+	/**
4
+	 * File: Browser.php
5
+	 * Author: Chris Schuld (http://chrisschuld.com/)
6
+	 * Last Modified: July 22nd, 2016
7
+	 * @version 2.0
8
+	 * @package PegasusPHP
9
+	 *
10
+	 * Copyright (C) 2008-2010 Chris Schuld  ([email protected])
11
+	 *
12
+	 * This program is free software; you can redistribute it and/or
13
+	 * modify it under the terms of the GNU General Public License as
14
+	 * published by the Free Software Foundation; either version 2 of
15
+	 * the License, or (at your option) any later version.
16
+	 *
17
+	 * This program is distributed in the hope that it will be useful,
18
+	 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19
+	 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
20
+	 * GNU General Public License for more details at:
21
+	 * http://www.gnu.org/copyleft/gpl.html
22
+	 *
23
+	 *
24
+	 * Typical Usage:
25
+	 *
26
+	 *   $browser = new Browser();
27
+	 *   if( $browser->getBrowser() == Browser::BROWSER_FIREFOX && $browser->getVersion() >= 2 ) {
28
+	 *    echo 'You have FireFox version 2 or greater';
29
+	 *   }
30
+	 *
31
+	 * User Agents Sampled from: http://www.useragentstring.com/
32
+	 *
33
+	 * This implementation is based on the original work from Gary White
34
+	 * http://apptools.com/phptools/browser/
35
+	 *
36
+	 */
37
+	class Browser
38
+	{
39
+		private $_agent = '';
40
+		private $_browser_name = '';
41
+		private $_version = '';
42
+		private $_platform = '';
43
+		private $_os = '';
44
+		private $_is_aol = false;
45
+		private $_is_mobile = false;
46
+		private $_is_tablet = false;
47
+		private $_is_robot = false;
48
+		private $_is_facebook = false;
49
+		private $_aol_version = '';
50
+
51
+		const BROWSER_UNKNOWN = 'unknown';
52
+		const VERSION_UNKNOWN = 'unknown';
53
+
54
+		const BROWSER_OPERA = 'Opera'; // http://www.opera.com/
55
+		const BROWSER_OPERA_MINI = 'Opera Mini'; // http://www.opera.com/mini/
56
+		const BROWSER_WEBTV = 'WebTV'; // http://www.webtv.net/pc/
57
+		const BROWSER_EDGE = 'Edge'; // https://www.microsoft.com/edge
58
+		const BROWSER_IE = 'Internet Explorer'; // http://www.microsoft.com/ie/
59
+		const BROWSER_POCKET_IE = 'Pocket Internet Explorer'; // http://en.wikipedia.org/wiki/Internet_Explorer_Mobile
60
+		const BROWSER_KONQUEROR = 'Konqueror'; // http://www.konqueror.org/
61
+		const BROWSER_ICAB = 'iCab'; // http://www.icab.de/
62
+		const BROWSER_OMNIWEB = 'OmniWeb'; // http://www.omnigroup.com/applications/omniweb/
63
+		const BROWSER_FIREBIRD = 'Firebird'; // http://www.ibphoenix.com/
64
+		const BROWSER_FIREFOX = 'Firefox'; // http://www.mozilla.com/en-US/firefox/firefox.html
65
+		const BROWSER_ICEWEASEL = 'Iceweasel'; // http://www.geticeweasel.org/
66
+		const BROWSER_SHIRETOKO = 'Shiretoko'; // http://wiki.mozilla.org/Projects/shiretoko
67
+		const BROWSER_MOZILLA = 'Mozilla'; // http://www.mozilla.com/en-US/
68
+		const BROWSER_AMAYA = 'Amaya'; // http://www.w3.org/Amaya/
69
+		const BROWSER_LYNX = 'Lynx'; // http://en.wikipedia.org/wiki/Lynx
70
+		const BROWSER_SAFARI = 'Safari'; // http://apple.com
71
+		const BROWSER_IPHONE = 'iPhone'; // http://apple.com
72
+		const BROWSER_IPOD = 'iPod'; // http://apple.com
73
+		const BROWSER_IPAD = 'iPad'; // http://apple.com
74
+		const BROWSER_CHROME = 'Chrome'; // http://www.google.com/chrome
75
+		const BROWSER_ANDROID = 'Android'; // http://www.android.com/
76
+		const BROWSER_GOOGLEBOT = 'GoogleBot'; // http://en.wikipedia.org/wiki/Googlebot
77
+
78
+		const BROWSER_YANDEXBOT = 'YandexBot'; // http://yandex.com/bots
79
+		const BROWSER_YANDEXIMAGERESIZER_BOT = 'YandexImageResizer'; // http://yandex.com/bots
80
+		const BROWSER_YANDEXIMAGES_BOT = 'YandexImages'; // http://yandex.com/bots
81
+		const BROWSER_YANDEXVIDEO_BOT = 'YandexVideo'; // http://yandex.com/bots
82
+		const BROWSER_YANDEXMEDIA_BOT = 'YandexMedia'; // http://yandex.com/bots
83
+		const BROWSER_YANDEXBLOGS_BOT = 'YandexBlogs'; // http://yandex.com/bots
84
+		const BROWSER_YANDEXFAVICONS_BOT = 'YandexFavicons'; // http://yandex.com/bots
85
+		const BROWSER_YANDEXWEBMASTER_BOT = 'YandexWebmaster'; // http://yandex.com/bots
86
+		const BROWSER_YANDEXDIRECT_BOT = 'YandexDirect'; // http://yandex.com/bots
87
+		const BROWSER_YANDEXMETRIKA_BOT = 'YandexMetrika'; // http://yandex.com/bots
88
+		const BROWSER_YANDEXNEWS_BOT = 'YandexNews'; // http://yandex.com/bots
89
+		const BROWSER_YANDEXCATALOG_BOT = 'YandexCatalog'; // http://yandex.com/bots
90
+
91
+		const BROWSER_SLURP = 'Yahoo! Slurp'; // http://en.wikipedia.org/wiki/Yahoo!_Slurp
92
+		const BROWSER_W3CVALIDATOR = 'W3C Validator'; // http://validator.w3.org/
93
+		const BROWSER_BLACKBERRY = 'BlackBerry'; // http://www.blackberry.com/
94
+		const BROWSER_ICECAT = 'IceCat'; // http://en.wikipedia.org/wiki/GNU_IceCat
95
+		const BROWSER_NOKIA_S60 = 'Nokia S60 OSS Browser'; // http://en.wikipedia.org/wiki/Web_Browser_for_S60
96
+		const BROWSER_NOKIA = 'Nokia Browser'; // * all other WAP-based browsers on the Nokia Platform
97
+		const BROWSER_MSN = 'MSN Browser'; // http://explorer.msn.com/
98
+		const BROWSER_MSNBOT = 'MSN Bot'; // http://search.msn.com/msnbot.htm
99
+		const BROWSER_BINGBOT = 'Bing Bot'; // http://en.wikipedia.org/wiki/Bingbot
100
+		const BROWSER_VIVALDI = 'Vivalidi'; // https://vivaldi.com/
101
+		const BROWSER_YANDEX = 'Yandex'; // https://browser.yandex.ua/
102
+
103
+		const BROWSER_NETSCAPE_NAVIGATOR = 'Netscape Navigator'; // http://browser.netscape.com/ (DEPRECATED)
104
+		const BROWSER_GALEON = 'Galeon'; // http://galeon.sourceforge.net/ (DEPRECATED)
105
+		const BROWSER_NETPOSITIVE = 'NetPositive'; // http://en.wikipedia.org/wiki/NetPositive (DEPRECATED)
106
+		const BROWSER_PHOENIX = 'Phoenix'; // http://en.wikipedia.org/wiki/History_of_Mozilla_Firefox (DEPRECATED)
107
+		const BROWSER_PLAYSTATION = "PlayStation";
108
+		const BROWSER_SAMSUNG = "SamsungBrowser";
109
+		const BROWSER_SILK = "Silk";
110
+		const BROWSER_I_FRAME = "Iframely";
111
+		const BROWSER_COCOA = "CocoaRestClient";
112
+
113
+		const PLATFORM_UNKNOWN = 'unknown';
114
+		const PLATFORM_WINDOWS = 'Windows';
115
+		const PLATFORM_WINDOWS_CE = 'Windows CE';
116
+		const PLATFORM_APPLE = 'Apple';
117
+		const PLATFORM_LINUX = 'Linux';
118
+		const PLATFORM_OS2 = 'OS/2';
119
+		const PLATFORM_BEOS = 'BeOS';
120
+		const PLATFORM_IPHONE = 'iPhone';
121
+		const PLATFORM_IPOD = 'iPod';
122
+		const PLATFORM_IPAD = 'iPad';
123
+		const PLATFORM_BLACKBERRY = 'BlackBerry';
124
+		const PLATFORM_NOKIA = 'Nokia';
125
+		const PLATFORM_FREEBSD = 'FreeBSD';
126
+		const PLATFORM_OPENBSD = 'OpenBSD';
127
+		const PLATFORM_NETBSD = 'NetBSD';
128
+		const PLATFORM_SUNOS = 'SunOS';
129
+		const PLATFORM_OPENSOLARIS = 'OpenSolaris';
130
+		const PLATFORM_ANDROID = 'Android';
131
+		const PLATFORM_PLAYSTATION = "Sony PlayStation";
132
+		const PLATFORM_ROKU = "Roku";
133
+		const PLATFORM_APPLE_TV = "Apple TV";
134
+		const PLATFORM_TERMINAL = "Terminal";
135
+		const PLATFORM_FIRE_OS = "Fire OS";
136
+		const PLATFORM_SMART_TV = "SMART-TV";
137
+		const PLATFORM_CHROME_OS = "Chrome OS";
138
+		const PLATFORM_JAVA_ANDROID = "Java/Android";
139
+		const PLATFORM_POSTMAN = "Postman";
140
+		const PLATFORM_I_FRAME = "Iframely";
141
+
142
+		const OPERATING_SYSTEM_UNKNOWN = 'unknown';
143
+
144
+		/**
145
+		 * Class constructor
146
+		 */
147
+		public function __construct($userAgent = "")
148
+		{
149
+			$this->reset();
150
+			if ($userAgent != "") {
151
+				$this->setUserAgent($userAgent);
152
+			} else {
153
+				$this->determine();
154
+			}
155
+		}
156
+
157
+		/**
158
+		 * Reset all properties
159
+		 */
160
+		public function reset()
161
+		{
162
+			$this->_agent = isset($_SERVER['HTTP_USER_AGENT']) ? $_SERVER['HTTP_USER_AGENT'] : "";
163
+			$this->_browser_name = self::BROWSER_UNKNOWN;
164
+			$this->_version = self::VERSION_UNKNOWN;
165
+			$this->_platform = self::PLATFORM_UNKNOWN;
166
+			$this->_os = self::OPERATING_SYSTEM_UNKNOWN;
167
+			$this->_is_aol = false;
168
+			$this->_is_mobile = false;
169
+			$this->_is_tablet = false;
170
+			$this->_is_robot = false;
171
+			$this->_is_facebook = false;
172
+			$this->_aol_version = self::VERSION_UNKNOWN;
173
+		}
174
+
175
+		/**
176
+		 * Check to see if the specific browser is valid
177
+		 * @param string $browserName
178
+		 * @return bool True if the browser is the specified browser
179
+		 */
180
+		public function isBrowser($browserName)
181
+		{
182
+			return (0 == strcasecmp($this->_browser_name, trim($browserName)));
183
+		}
184
+
185
+		/**
186
+		 * The name of the browser.  All return types are from the class contants
187
+		 * @return string Name of the browser
188
+		 */
189
+		public function getBrowser()
190
+		{
191
+			return $this->_browser_name;
192
+		}
193
+
194
+		/**
195
+		 * Set the name of the browser
196
+		 * @param $browser string The name of the Browser
197
+		 */
198
+		public function setBrowser($browser)
199
+		{
200
+			$this->_browser_name = $browser;
201
+		}
202
+
203
+		/**
204
+		 * The name of the platform.  All return types are from the class contants
205
+		 * @return string Name of the browser
206
+		 */
207
+		public function getPlatform()
208
+		{
209
+			return $this->_platform;
210
+		}
211
+
212
+		/**
213
+		 * Set the name of the platform
214
+		 * @param string $platform The name of the Platform
215
+		 */
216
+		public function setPlatform($platform)
217
+		{
218
+			$this->_platform = $platform;
219
+		}
220
+
221
+		/**
222
+		 * The version of the browser.
223
+		 * @return string Version of the browser (will only contain alpha-numeric characters and a period)
224
+		 */
225
+		public function getVersion()
226
+		{
227
+			return $this->_version;
228
+		}
229
+
230
+		/**
231
+		 * Set the version of the browser
232
+		 * @param string $version The version of the Browser
233
+		 */
234
+		public function setVersion($version)
235
+		{
236
+			$this->_version = preg_replace('/[^0-9,.,a-z,A-Z-]/', '', $version);
237
+		}
238
+
239
+		/**
240
+		 * The version of AOL.
241
+		 * @return string Version of AOL (will only contain alpha-numeric characters and a period)
242
+		 */
243
+		public function getAolVersion()
244
+		{
245
+			return $this->_aol_version;
246
+		}
247
+
248
+		/**
249
+		 * Set the version of AOL
250
+		 * @param string $version The version of AOL
251
+		 */
252
+		public function setAolVersion($version)
253
+		{
254
+			$this->_aol_version = preg_replace('/[^0-9,.,a-z,A-Z]/', '', $version);
255
+		}
256
+
257
+		/**
258
+		 * Is the browser from AOL?
259
+		 * @return boolean True if the browser is from AOL otherwise false
260
+		 */
261
+		public function isAol()
262
+		{
263
+			return $this->_is_aol;
264
+		}
265
+
266
+		/**
267
+		 * Is the browser from a mobile device?
268
+		 * @return boolean True if the browser is from a mobile device otherwise false
269
+		 */
270
+		public function isMobile()
271
+		{
272
+			return $this->_is_mobile;
273
+		}
274
+
275
+		/**
276
+		 * Is the browser from a tablet device?
277
+		 * @return boolean True if the browser is from a tablet device otherwise false
278
+		 */
279
+		public function isTablet()
280
+		{
281
+			return $this->_is_tablet;
282
+		}
283
+
284
+		/**
285
+		 * Is the browser from a robot (ex Slurp,GoogleBot)?
286
+		 * @return boolean True if the browser is from a robot otherwise false
287
+		 */
288
+		public function isRobot()
289
+		{
290
+			return $this->_is_robot;
291
+		}
292
+
293
+		/**
294
+		 * Is the browser from facebook?
295
+		 * @return boolean True if the browser is from facebook otherwise false
296
+		 */
297
+		public function isFacebook()
298
+		{
299
+			return $this->_is_facebook;
300
+		}
301
+
302
+		/**
303
+		 * Set the browser to be from AOL
304
+		 * @param $isAol
305
+		 */
306
+		public function setAol($isAol)
307
+		{
308
+			$this->_is_aol = $isAol;
309
+		}
310
+
311
+		/**
312
+		 * Set the Browser to be mobile
313
+		 * @param boolean $value is the browser a mobile browser or not
314
+		 */
315
+		protected function setMobile($value = true)
316
+		{
317
+			$this->_is_mobile = $value;
318
+		}
319
+
320
+		/**
321
+		 * Set the Browser to be tablet
322
+		 * @param boolean $value is the browser a tablet browser or not
323
+		 */
324
+		protected function setTablet($value = true)
325
+		{
326
+			$this->_is_tablet = $value;
327
+		}
328
+
329
+		/**
330
+		 * Set the Browser to be a robot
331
+		 * @param boolean $value is the browser a robot or not
332
+		 */
333
+		protected function setRobot($value = true)
334
+		{
335
+			$this->_is_robot = $value;
336
+		}
337
+
338
+		/**
339
+		 * Set the Browser to be a Facebook request
340
+		 * @param boolean $value is the browser a robot or not
341
+		 */
342
+		protected function setFacebook($value = true)
343
+		{
344
+			$this->_is_facebook = $value;
345
+		}
346
+
347
+		/**
348
+		 * Get the user agent value in use to determine the browser
349
+		 * @return string The user agent from the HTTP header
350
+		 */
351
+		public function getUserAgent()
352
+		{
353
+			return $this->_agent;
354
+		}
355
+
356
+		/**
357
+		 * Set the user agent value (the construction will use the HTTP header value - this will overwrite it)
358
+		 * @param string $agent_string The value for the User Agent
359
+		 */
360
+		public function setUserAgent($agent_string)
361
+		{
362
+			$this->reset();
363
+			$this->_agent = $agent_string;
364
+			$this->determine();
365
+		}
366
+
367
+		/**
368
+		 * Used to determine if the browser is actually "chromeframe"
369
+		 * @since 1.7
370
+		 * @return boolean True if the browser is using chromeframe
371
+		 */
372
+		public function isChromeFrame()
373
+		{
374
+			return (strpos($this->_agent, "chromeframe") !== false);
375
+		}
376
+
377
+		/**
378
+		 * Returns a formatted string with a summary of the details of the browser.
379
+		 * @return string formatted string with a summary of the browser
380
+		 */
381
+		public function __toString()
382
+		{
383
+			return "<strong>Browser Name:</strong> {$this->getBrowser()}<br/>\n" .
384
+				"<strong>Browser Version:</strong> {$this->getVersion()}<br/>\n" .
385
+				"<strong>Browser User Agent String:</strong> {$this->getUserAgent()}<br/>\n" .
386
+				"<strong>Platform:</strong> {$this->getPlatform()}<br/>";
387
+		}
388
+
389
+		/**
390
+		 * Protected routine to calculate and determine what the browser is in use (including platform)
391
+		 */
392
+		protected function determine()
393
+		{
394
+			$this->checkPlatform();
395
+			$this->checkBrowsers();
396
+			$this->checkForAol();
397
+		}
398
+
399
+		/**
400
+		 * Protected routine to determine the browser type
401
+		 * @return boolean True if the browser was detected otherwise false
402
+		 */
403
+		protected function checkBrowsers()
404
+		{
405
+			return (
406
+				// well-known, well-used
407
+				// Special Notes:
408
+				// (1) Opera must be checked before FireFox due to the odd
409
+				//     user agents used in some older versions of Opera
410
+				// (2) WebTV is strapped onto Internet Explorer so we must
411
+				//     check for WebTV before IE
412
+				// (3) (deprecated) Galeon is based on Firefox and needs to be
413
+				//     tested before Firefox is tested
414
+				// (4) OmniWeb is based on Safari so OmniWeb check must occur
415
+				//     before Safari
416
+				// (5) Netscape 9+ is based on Firefox so Netscape checks
417
+				//     before FireFox are necessary
418
+				// (6) Vivalid is UA contains both Firefox and Chrome so Vivalid checks
419
+				//     before Firefox and Chrome
420
+				$this->checkBrowserWebTv() ||
421
+				$this->checkBrowserEdge() ||
422
+				$this->checkBrowserInternetExplorer() ||
423
+				$this->checkBrowserOpera() ||
424
+				$this->checkBrowserGaleon() ||
425
+				$this->checkBrowserNetscapeNavigator9Plus() ||
426
+				$this->checkBrowserVivaldi() ||
427
+				$this->checkBrowserYandex() ||
428
+				$this->checkBrowserFirefox() ||
429
+				$this->checkBrowserChrome() ||
430
+				$this->checkBrowserOmniWeb() ||
431
+
432
+				// common mobile
433
+				$this->checkBrowserAndroid() ||
434
+				$this->checkBrowseriPad() ||
435
+				$this->checkBrowseriPod() ||
436
+				$this->checkBrowseriPhone() ||
437
+				$this->checkBrowserBlackBerry() ||
438
+				$this->checkBrowserNokia() ||
439
+
440
+				// common bots
441
+				$this->checkBrowserGoogleBot() ||
442
+				$this->checkBrowserMSNBot() ||
443
+				$this->checkBrowserBingBot() ||
444
+				$this->checkBrowserSlurp() ||
445
+
446
+				// Yandex bots
447
+				$this->checkBrowserYandexBot() ||
448
+				$this->checkBrowserYandexImageResizerBot() ||
449
+				$this->checkBrowserYandexBlogsBot() ||
450
+				$this->checkBrowserYandexCatalogBot() ||
451
+				$this->checkBrowserYandexDirectBot() ||
452
+				$this->checkBrowserYandexFaviconsBot() ||
453
+				$this->checkBrowserYandexImagesBot() ||
454
+				$this->checkBrowserYandexMediaBot() ||
455
+				$this->checkBrowserYandexMetrikaBot() ||
456
+				$this->checkBrowserYandexNewsBot() ||
457
+				$this->checkBrowserYandexVideoBot() ||
458
+				$this->checkBrowserYandexWebmasterBot() ||
459
+
460
+				// check for facebook external hit when loading URL
461
+				$this->checkFacebookExternalHit() ||
462
+
463
+				// WebKit base check (post mobile and others)
464
+				$this->checkBrowserSamsung() ||
465
+				$this->checkBrowserSilk() ||
466
+				$this->checkBrowserSafari() ||
467
+
468
+				// everyone else
469
+				$this->checkBrowserNetPositive() ||
470
+				$this->checkBrowserFirebird() ||
471
+				$this->checkBrowserKonqueror() ||
472
+				$this->checkBrowserIcab() ||
473
+				$this->checkBrowserPhoenix() ||
474
+				$this->checkBrowserAmaya() ||
475
+				$this->checkBrowserLynx() ||
476
+				$this->checkBrowserShiretoko() ||
477
+				$this->checkBrowserIceCat() ||
478
+				$this->checkBrowserIceweasel() ||
479
+				$this->checkBrowserW3CValidator() ||
480
+				$this->checkBrowserPlayStation() ||
481
+				$this->checkBrowserIframely() ||
482
+				$this->checkBrowserCocoa() ||
483
+				$this->checkBrowserMozilla() /* Mozilla is such an open standard that you must check it last */
484
+
485
+
486
+			);
487
+		}
488
+
489
+		/**
490
+		 * Determine if the user is using a BlackBerry (last updated 1.7)
491
+		 * @return boolean True if the browser is the BlackBerry browser otherwise false
492
+		 */
493
+		protected function checkBrowserBlackBerry()
494
+		{
495
+			if (stripos($this->_agent, 'blackberry') !== false) {
496
+				$aresult = explode("/", stristr($this->_agent, "BlackBerry"));
497
+				if (isset($aresult[1])) {
498
+					$aversion = explode(' ', $aresult[1]);
499
+					$this->setVersion($aversion[0]);
500
+					$this->_browser_name = self::BROWSER_BLACKBERRY;
501
+					$this->setMobile(true);
502
+					return true;
503
+				}
504
+			}
505
+			return false;
506
+		}
507
+
508
+		/**
509
+		 * Determine if the user is using an AOL User Agent (last updated 1.7)
510
+		 * @return boolean True if the browser is from AOL otherwise false
511
+		 */
512
+		protected function checkForAol()
513
+		{
514
+			$this->setAol(false);
515
+			$this->setAolVersion(self::VERSION_UNKNOWN);
516
+
517
+			if (stripos($this->_agent, 'aol') !== false) {
518
+				$aversion = explode(' ', stristr($this->_agent, 'AOL'));
519
+				if (isset($aversion[1])) {
520
+					$this->setAol(true);
521
+					$this->setAolVersion(preg_replace('/[^0-9\.a-z]/i', '', $aversion[1]));
522
+					return true;
523
+				}
524
+			}
525
+			return false;
526
+		}
527
+
528
+		/**
529
+		 * Determine if the browser is the GoogleBot or not (last updated 1.7)
530
+		 * @return boolean True if the browser is the GoogletBot otherwise false
531
+		 */
532
+		protected function checkBrowserGoogleBot()
533
+		{
534
+			if (stripos($this->_agent, 'googlebot') !== false) {
535
+				$aresult = explode('/', stristr($this->_agent, 'googlebot'));
536
+				if (isset($aresult[1])) {
537
+					$aversion = explode(' ', $aresult[1]);
538
+					$this->setVersion(str_replace(';', '', $aversion[0]));
539
+					$this->_browser_name = self::BROWSER_GOOGLEBOT;
540
+					$this->setRobot(true);
541
+					return true;
542
+				}
543
+			}
544
+			return false;
545
+		}
546
+
547
+		/**
548
+		 * Determine if the browser is the YandexBot or not
549
+		 * @return boolean True if the browser is the YandexBot otherwise false
550
+		 */
551
+		protected function checkBrowserYandexBot()
552
+		{
553
+			if (stripos($this->_agent, 'YandexBot') !== false) {
554
+				$aresult = explode('/', stristr($this->_agent, 'YandexBot'));
555
+				if (isset($aresult[1])) {
556
+					$aversion = explode(' ', $aresult[1]);
557
+					$this->setVersion(str_replace(';', '', $aversion[0]));
558
+					$this->_browser_name = self::BROWSER_YANDEXBOT;
559
+					$this->setRobot(true);
560
+					return true;
561
+				}
562
+			}
563
+			return false;
564
+		}
565
+
566
+		/**
567
+		 * Determine if the browser is the YandexImageResizer or not
568
+		 * @return boolean True if the browser is the YandexImageResizer otherwise false
569
+		 */
570
+		protected function checkBrowserYandexImageResizerBot()
571
+		{
572
+			if (stripos($this->_agent, 'YandexImageResizer') !== false) {
573
+				$aresult = explode('/', stristr($this->_agent, 'YandexImageResizer'));
574
+				if (isset($aresult[1])) {
575
+					$aversion = explode(' ', $aresult[1]);
576
+					$this->setVersion(str_replace(';', '', $aversion[0]));
577
+					$this->_browser_name = self::BROWSER_YANDEXIMAGERESIZER_BOT;
578
+					$this->setRobot(true);
579
+					return true;
580
+				}
581
+			}
582
+			return false;
583
+		}
584
+
585
+		/**
586
+		 * Determine if the browser is the YandexCatalog or not
587
+		 * @return boolean True if the browser is the YandexCatalog otherwise false
588
+		 */
589
+		protected function checkBrowserYandexCatalogBot()
590
+		{
591
+			if (stripos($this->_agent, 'YandexCatalog') !== false) {
592
+				$aresult = explode('/', stristr($this->_agent, 'YandexCatalog'));
593
+				if (isset($aresult[1])) {
594
+					$aversion = explode(' ', $aresult[1]);
595
+					$this->setVersion(str_replace(';', '', $aversion[0]));
596
+					$this->_browser_name = self::BROWSER_YANDEXCATALOG_BOT;
597
+					$this->setRobot(true);
598
+					return true;
599
+				}
600
+			}
601
+			return false;
602
+		}
603
+
604
+		/**
605
+		 * Determine if the browser is the YandexNews or not
606
+		 * @return boolean True if the browser is the YandexNews otherwise false
607
+		 */
608
+		protected function checkBrowserYandexNewsBot()
609
+		{
610
+			if (stripos($this->_agent, 'YandexNews') !== false) {
611
+				$aresult = explode('/', stristr($this->_agent, 'YandexNews'));
612
+				if (isset($aresult[1])) {
613
+					$aversion = explode(' ', $aresult[1]);
614
+					$this->setVersion(str_replace(';', '', $aversion[0]));
615
+					$this->_browser_name = self::BROWSER_YANDEXNEWS_BOT;
616
+					$this->setRobot(true);
617
+					return true;
618
+				}
619
+			}
620
+			return false;
621
+		}
622
+
623
+		/**
624
+		 * Determine if the browser is the YandexMetrika or not
625
+		 * @return boolean True if the browser is the YandexMetrika otherwise false
626
+		 */
627
+		protected function checkBrowserYandexMetrikaBot()
628
+		{
629
+			if (stripos($this->_agent, 'YandexMetrika') !== false) {
630
+				$aresult = explode('/', stristr($this->_agent, 'YandexMetrika'));
631
+				if (isset($aresult[1])) {
632
+					$aversion = explode(' ', $aresult[1]);
633
+					$this->setVersion(str_replace(';', '', $aversion[0]));
634
+					$this->_browser_name = self::BROWSER_YANDEXMETRIKA_BOT;
635
+					$this->setRobot(true);
636
+					return true;
637
+				}
638
+			}
639
+			return false;
640
+		}
641
+
642
+		/**
643
+		 * Determine if the browser is the YandexDirect or not
644
+		 * @return boolean True if the browser is the YandexDirect otherwise false
645
+		 */
646
+		protected function checkBrowserYandexDirectBot()
647
+		{
648
+			if (stripos($this->_agent, 'YandexDirect') !== false) {
649
+				$aresult = explode('/', stristr($this->_agent, 'YandexDirect'));
650
+				if (isset($aresult[1])) {
651
+					$aversion = explode(' ', $aresult[1]);
652
+					$this->setVersion(str_replace(';', '', $aversion[0]));
653
+					$this->_browser_name = self::BROWSER_YANDEXDIRECT_BOT;
654
+					$this->setRobot(true);
655
+					return true;
656
+				}
657
+			}
658
+			return false;
659
+		}
660
+
661
+		/**
662
+		 * Determine if the browser is the YandexWebmaster or not
663
+		 * @return boolean True if the browser is the YandexWebmaster otherwise false
664
+		 */
665
+		protected function checkBrowserYandexWebmasterBot()
666
+		{
667
+			if (stripos($this->_agent, 'YandexWebmaster') !== false) {
668
+				$aresult = explode('/', stristr($this->_agent, 'YandexWebmaster'));
669
+				if (isset($aresult[1])) {
670
+					$aversion = explode(' ', $aresult[1]);
671
+					$this->setVersion(str_replace(';', '', $aversion[0]));
672
+					$this->_browser_name = self::BROWSER_YANDEXWEBMASTER_BOT;
673
+					$this->setRobot(true);
674
+					return true;
675
+				}
676
+			}
677
+			return false;
678
+		}
679
+
680
+		/**
681
+		 * Determine if the browser is the YandexFavicons or not
682
+		 * @return boolean True if the browser is the YandexFavicons otherwise false
683
+		 */
684
+		protected function checkBrowserYandexFaviconsBot()
685
+		{
686
+			if (stripos($this->_agent, 'YandexFavicons') !== false) {
687
+				$aresult = explode('/', stristr($this->_agent, 'YandexFavicons'));
688
+				if (isset($aresult[1])) {
689
+					$aversion = explode(' ', $aresult[1]);
690
+					$this->setVersion(str_replace(';', '', $aversion[0]));
691
+					$this->_browser_name = self::BROWSER_YANDEXFAVICONS_BOT;
692
+					$this->setRobot(true);
693
+					return true;
694
+				}
695
+			}
696
+			return false;
697
+		}
698
+
699
+		/**
700
+		 * Determine if the browser is the YandexBlogs or not
701
+		 * @return boolean True if the browser is the YandexBlogs otherwise false
702
+		 */
703
+		protected function checkBrowserYandexBlogsBot()
704
+		{
705
+			if (stripos($this->_agent, 'YandexBlogs') !== false) {
706
+				$aresult = explode('/', stristr($this->_agent, 'YandexBlogs'));
707
+				if (isset($aresult[1])) {
708
+					$aversion = explode(' ', $aresult[1]);
709
+					$this->setVersion(str_replace(';', '', $aversion[0]));
710
+					$this->_browser_name = self::BROWSER_YANDEXBLOGS_BOT;
711
+					$this->setRobot(true);
712
+					return true;
713
+				}
714
+			}
715
+			return false;
716
+		}
717
+
718
+		/**
719
+		 * Determine if the browser is the YandexMedia or not
720
+		 * @return boolean True if the browser is the YandexMedia otherwise false
721
+		 */
722
+		protected function checkBrowserYandexMediaBot()
723
+		{
724
+			if (stripos($this->_agent, 'YandexMedia') !== false) {
725
+				$aresult = explode('/', stristr($this->_agent, 'YandexMedia'));
726
+				if (isset($aresult[1])) {
727
+					$aversion = explode(' ', $aresult[1]);
728
+					$this->setVersion(str_replace(';', '', $aversion[0]));
729
+					$this->_browser_name = self::BROWSER_YANDEXMEDIA_BOT;
730
+					$this->setRobot(true);
731
+					return true;
732
+				}
733
+			}
734
+			return false;
735
+		}
736
+
737
+		/**
738
+		 * Determine if the browser is the YandexVideo or not
739
+		 * @return boolean True if the browser is the YandexVideo otherwise false
740
+		 */
741
+		protected function checkBrowserYandexVideoBot()
742
+		{
743
+			if (stripos($this->_agent, 'YandexVideo') !== false) {
744
+				$aresult = explode('/', stristr($this->_agent, 'YandexVideo'));
745
+				if (isset($aresult[1])) {
746
+					$aversion = explode(' ', $aresult[1]);
747
+					$this->setVersion(str_replace(';', '', $aversion[0]));
748
+					$this->_browser_name = self::BROWSER_YANDEXVIDEO_BOT;
749
+					$this->setRobot(true);
750
+					return true;
751
+				}
752
+			}
753
+			return false;
754
+		}
755
+
756
+		/**
757
+		 * Determine if the browser is the YandexImages or not
758
+		 * @return boolean True if the browser is the YandexImages otherwise false
759
+		 */
760
+		protected function checkBrowserYandexImagesBot()
761
+		{
762
+			if (stripos($this->_agent, 'YandexImages') !== false) {
763
+				$aresult = explode('/', stristr($this->_agent, 'YandexImages'));
764
+				if (isset($aresult[1])) {
765
+					$aversion = explode(' ', $aresult[1]);
766
+					$this->setVersion(str_replace(';', '', $aversion[0]));
767
+					$this->_browser_name = self::BROWSER_YANDEXIMAGES_BOT;
768
+					$this->setRobot(true);
769
+					return true;
770
+				}
771
+			}
772
+			return false;
773
+		}
774
+
775
+		/**
776
+		 * Determine if the browser is the MSNBot or not (last updated 1.9)
777
+		 * @return boolean True if the browser is the MSNBot otherwise false
778
+		 */
779
+		protected function checkBrowserMSNBot()
780
+		{
781
+			if (stripos($this->_agent, "msnbot") !== false) {
782
+				$aresult = explode("/", stristr($this->_agent, "msnbot"));
783
+				if (isset($aresult[1])) {
784
+					$aversion = explode(" ", $aresult[1]);
785
+					$this->setVersion(str_replace(";", "", $aversion[0]));
786
+					$this->_browser_name = self::BROWSER_MSNBOT;
787
+					$this->setRobot(true);
788
+					return true;
789
+				}
790
+			}
791
+			return false;
792
+		}
793
+
794
+		/**
795
+		 * Determine if the browser is the BingBot or not (last updated 1.9)
796
+		 * @return boolean True if the browser is the BingBot otherwise false
797
+		 */
798
+		protected function checkBrowserBingBot()
799
+		{
800
+			if (stripos($this->_agent, "bingbot") !== false) {
801
+				$aresult = explode("/", stristr($this->_agent, "bingbot"));
802
+				if (isset($aresult[1])) {
803
+					$aversion = explode(" ", $aresult[1]);
804
+					$this->setVersion(str_replace(";", "", $aversion[0]));
805
+					$this->_browser_name = self::BROWSER_BINGBOT;
806
+					$this->setRobot(true);
807
+					return true;
808
+				}
809
+			}
810
+			return false;
811
+		}
812
+
813
+		/**
814
+		 * Determine if the browser is the W3C Validator or not (last updated 1.7)
815
+		 * @return boolean True if the browser is the W3C Validator otherwise false
816
+		 */
817
+		protected function checkBrowserW3CValidator()
818
+		{
819
+			if (stripos($this->_agent, 'W3C-checklink') !== false) {
820
+				$aresult = explode('/', stristr($this->_agent, 'W3C-checklink'));
821
+				if (isset($aresult[1])) {
822
+					$aversion = explode(' ', $aresult[1]);
823
+					$this->setVersion($aversion[0]);
824
+					$this->_browser_name = self::BROWSER_W3CVALIDATOR;
825
+					return true;
826
+				}
827
+			} else if (stripos($this->_agent, 'W3C_Validator') !== false) {
828
+				// Some of the Validator versions do not delineate w/ a slash - add it back in
829
+				$ua = str_replace("W3C_Validator ", "W3C_Validator/", $this->_agent);
830
+				$aresult = explode('/', stristr($ua, 'W3C_Validator'));
831
+				if (isset($aresult[1])) {
832
+					$aversion = explode(' ', $aresult[1]);
833
+					$this->setVersion($aversion[0]);
834
+					$this->_browser_name = self::BROWSER_W3CVALIDATOR;
835
+					return true;
836
+				}
837
+			} else if (stripos($this->_agent, 'W3C-mobileOK') !== false) {
838
+				$this->_browser_name = self::BROWSER_W3CVALIDATOR;
839
+				$this->setMobile(true);
840
+				return true;
841
+			}
842
+			return false;
843
+		}
844
+
845
+		/**
846
+		 * Determine if the browser is the Yahoo! Slurp Robot or not (last updated 1.7)
847
+		 * @return boolean True if the browser is the Yahoo! Slurp Robot otherwise false
848
+		 */
849
+		protected function checkBrowserSlurp()
850
+		{
851
+			if (stripos($this->_agent, 'slurp') !== false) {
852
+				$aresult = explode('/', stristr($this->_agent, 'Slurp'));
853
+				if (isset($aresult[1])) {
854
+					$aversion = explode(' ', $aresult[1]);
855
+					$this->setVersion($aversion[0]);
856
+					$this->_browser_name = self::BROWSER_SLURP;
857
+					$this->setRobot(true);
858
+					$this->setMobile(false);
859
+					return true;
860
+				}
861
+			}
862
+			return false;
863
+		}
864
+
865
+		/**
866
+		 * Determine if the browser is Edge or not
867
+		 * @return boolean True if the browser is Edge otherwise false
868
+		 */
869
+		protected function checkBrowserEdge()
870
+		{
871
+			if (stripos($this->_agent, 'Edge/') !== false) {
872
+				$aresult = explode('/', stristr($this->_agent, 'Edge'));
873
+				if (isset($aresult[1])) {
874
+					$aversion = explode(' ', $aresult[1]);
875
+					$this->setVersion($aversion[0]);
876
+					$this->setBrowser(self::BROWSER_EDGE);
877
+					if (stripos($this->_agent, 'Windows Phone') !== false || stripos($this->_agent, 'Android') !== false) {
878
+						$this->setMobile(true);
879
+					}
880
+					return true;
881
+				}
882
+			}
883
+			return false;
884
+		}
885
+
886
+		/**
887
+		 * Determine if the browser is Internet Explorer or not (last updated 1.7)
888
+		 * @return boolean True if the browser is Internet Explorer otherwise false
889
+		 */
890
+		protected function checkBrowserInternetExplorer()
891
+		{
892
+			//  Test for IE11
893
+			if (stripos($this->_agent, 'Trident/7.0; rv:11.0') !== false) {
894
+				$this->setBrowser(self::BROWSER_IE);
895
+				$this->setVersion('11.0');
896
+				return true;
897
+			} // Test for v1 - v1.5 IE
898
+			else if (stripos($this->_agent, 'microsoft internet explorer') !== false) {
899
+				$this->setBrowser(self::BROWSER_IE);
900
+				$this->setVersion('1.0');
901
+				$aresult = stristr($this->_agent, '/');
902
+				if (preg_match('/308|425|426|474|0b1/i', $aresult)) {
903
+					$this->setVersion('1.5');
904
+				}
905
+				return true;
906
+			} // Test for versions > 1.5
907
+			else if (stripos($this->_agent, 'msie') !== false && stripos($this->_agent, 'opera') === false) {
908
+				// See if the browser is the odd MSN Explorer
909
+				if (stripos($this->_agent, 'msnb') !== false) {
910
+					$aresult = explode(' ', stristr(str_replace(';', '; ', $this->_agent), 'MSN'));
911
+					if (isset($aresult[1])) {
912
+						$this->setBrowser(self::BROWSER_MSN);
913
+						$this->setVersion(str_replace(array('(', ')', ';'), '', $aresult[1]));
914
+						return true;
915
+					}
916
+				}
917
+				$aresult = explode(' ', stristr(str_replace(';', '; ', $this->_agent), 'msie'));
918
+				if (isset($aresult[1])) {
919
+					$this->setBrowser(self::BROWSER_IE);
920
+					$this->setVersion(str_replace(array('(', ')', ';'), '', $aresult[1]));
921
+					if(preg_match('#trident/([0-9\.]+);#i', $this->_agent, $aresult)){
922
+						if($aresult[1] == '3.1'){
923
+							$this->setVersion('7.0');
924
+						}
925
+						else if($aresult[1] == '4.0'){
926
+							$this->setVersion('8.0');
927
+						}
928
+						else if($aresult[1] == '5.0'){
929
+							$this->setVersion('9.0');
930
+						}
931
+						else if($aresult[1] == '6.0'){
932
+							$this->setVersion('10.0');
933
+						}
934
+						else if($aresult[1] == '7.0'){
935
+							$this->setVersion('11.0');
936
+						}
937
+						else if($aresult[1] == '8.0'){
938
+							$this->setVersion('11.0');
939
+						}
940
+					}
941
+					if(stripos($this->_agent, 'IEMobile') !== false) {
942
+						$this->setBrowser(self::BROWSER_POCKET_IE);
943
+						$this->setMobile(true);
944
+					}
945
+					return true;
946
+				}
947
+			} // Test for versions > IE 10
948
+			else if (stripos($this->_agent, 'trident') !== false) {
949
+				$this->setBrowser(self::BROWSER_IE);
950
+				$result = explode('rv:', $this->_agent);
951
+				if (isset($result[1])) {
952
+					$this->setVersion(preg_replace('/[^0-9.]+/', '', $result[1]));
953
+					$this->_agent = str_replace(array("Mozilla", "Gecko"), "MSIE", $this->_agent);
954
+				}
955
+			} // Test for Pocket IE
956
+			else if (stripos($this->_agent, 'mspie') !== false || stripos($this->_agent, 'pocket') !== false) {
957
+				$aresult = explode(' ', stristr($this->_agent, 'mspie'));
958
+				if (isset($aresult[1])) {
959
+					$this->setPlatform(self::PLATFORM_WINDOWS_CE);
960
+					$this->setBrowser(self::BROWSER_POCKET_IE);
961
+					$this->setMobile(true);
962
+
963
+					if (stripos($this->_agent, 'mspie') !== false) {
964
+						$this->setVersion($aresult[1]);
965
+					} else {
966
+						$aversion = explode('/', $this->_agent);
967
+						if (isset($aversion[1])) {
968
+							$this->setVersion($aversion[1]);
969
+						}
970
+					}
971
+					return true;
972
+				}
973
+			}
974
+			return false;
975
+		}
976
+
977
+		/**
978
+		 * Determine if the browser is Opera or not (last updated 1.7)
979
+		 * @return boolean True if the browser is Opera otherwise false
980
+		 */
981
+		protected function checkBrowserOpera()
982
+		{
983
+			if (stripos($this->_agent, 'opera mini') !== false) {
984
+				$resultant = stristr($this->_agent, 'opera mini');
985
+				if (preg_match('/\//', $resultant)) {
986
+					$aresult = explode('/', $resultant);
987
+					if (isset($aresult[1])) {
988
+						$aversion = explode(' ', $aresult[1]);
989
+						$this->setVersion($aversion[0]);
990
+					}
991
+				} else {
992
+					$aversion = explode(' ', stristr($resultant, 'opera mini'));
993
+					if (isset($aversion[1])) {
994
+						$this->setVersion($aversion[1]);
995
+					}
996
+				}
997
+				$this->_browser_name = self::BROWSER_OPERA_MINI;
998
+				$this->setMobile(true);
999
+				return true;
1000
+			} else if (stripos($this->_agent, 'opera') !== false) {
1001
+				$resultant = stristr($this->_agent, 'opera');
1002
+				if (preg_match('/Version\/(1*.*)$/', $resultant, $matches)) {
1003
+					$this->setVersion($matches[1]);
1004
+				} else if (preg_match('/\//', $resultant)) {
1005
+					$aresult = explode('/', str_replace("(", " ", $resultant));
1006
+					if (isset($aresult[1])) {
1007
+						$aversion = explode(' ', $aresult[1]);
1008
+						$this->setVersion($aversion[0]);
1009
+					}
1010
+				} else {
1011
+					$aversion = explode(' ', stristr($resultant, 'opera'));
1012
+					$this->setVersion(isset($aversion[1]) ? $aversion[1] : "");
1013
+				}
1014
+				if (stripos($this->_agent, 'Opera Mobi') !== false) {
1015
+					$this->setMobile(true);
1016
+				}
1017
+				$this->_browser_name = self::BROWSER_OPERA;
1018
+				return true;
1019
+			} else if (stripos($this->_agent, 'OPR') !== false) {
1020
+				$resultant = stristr($this->_agent, 'OPR');
1021
+				if (preg_match('/\//', $resultant)) {
1022
+					$aresult = explode('/', str_replace("(", " ", $resultant));
1023
+					if (isset($aresult[1])) {
1024
+						$aversion = explode(' ', $aresult[1]);
1025
+						$this->setVersion($aversion[0]);
1026
+					}
1027
+				}
1028
+				if (stripos($this->_agent, 'Mobile') !== false) {
1029
+					$this->setMobile(true);
1030
+				}
1031
+				$this->_browser_name = self::BROWSER_OPERA;
1032
+				return true;
1033
+			}
1034
+			return false;
1035
+		}
1036
+
1037
+		/**
1038
+		 * Determine if the browser is Chrome or not (last updated 1.7)
1039
+		 * @return boolean True if the browser is Chrome otherwise false
1040
+		 */
1041
+		protected function checkBrowserChrome()
1042
+		{
1043
+			if (stripos($this->_agent, 'Chrome') !== false) {
1044
+				$aresult = explode('/', stristr($this->_agent, 'Chrome'));
1045
+				if (isset($aresult[1])) {
1046
+					$aversion = explode(' ', $aresult[1]);
1047
+					$this->setVersion($aversion[0]);
1048
+					$this->setBrowser(self::BROWSER_CHROME);
1049
+					//Chrome on Android
1050
+					if (stripos($this->_agent, 'Android') !== false) {
1051
+						if (stripos($this->_agent, 'Mobile') !== false) {
1052
+							$this->setMobile(true);
1053
+						} else {
1054
+							$this->setTablet(true);
1055
+						}
1056
+					}
1057
+					return true;
1058
+				}
1059
+			}
1060
+			return false;
1061
+		}
1062
+
1063
+
1064
+		/**
1065
+		 * Determine if the browser is WebTv or not (last updated 1.7)
1066
+		 * @return boolean True if the browser is WebTv otherwise false
1067
+		 */
1068
+		protected function checkBrowserWebTv()
1069
+		{
1070
+			if (stripos($this->_agent, 'webtv') !== false) {
1071
+				$aresult = explode('/', stristr($this->_agent, 'webtv'));
1072
+				if (isset($aresult[1])) {
1073
+					$aversion = explode(' ', $aresult[1]);
1074
+					$this->setVersion($aversion[0]);
1075
+					$this->setBrowser(self::BROWSER_WEBTV);
1076
+					return true;
1077
+				}
1078
+			}
1079
+			return false;
1080
+		}
1081
+
1082
+		/**
1083
+		 * Determine if the browser is NetPositive or not (last updated 1.7)
1084
+		 * @return boolean True if the browser is NetPositive otherwise false
1085
+		 */
1086
+		protected function checkBrowserNetPositive()
1087
+		{
1088
+			if (stripos($this->_agent, 'NetPositive') !== false) {
1089
+				$aresult = explode('/', stristr($this->_agent, 'NetPositive'));
1090
+				if (isset($aresult[1])) {
1091
+					$aversion = explode(' ', $aresult[1]);
1092
+					$this->setVersion(str_replace(array('(', ')', ';'), '', $aversion[0]));
1093
+					$this->setBrowser(self::BROWSER_NETPOSITIVE);
1094
+					return true;
1095
+				}
1096
+			}
1097
+			return false;
1098
+		}
1099
+
1100
+		/**
1101
+		 * Determine if the browser is Galeon or not (last updated 1.7)
1102
+		 * @return boolean True if the browser is Galeon otherwise false
1103
+		 */
1104
+		protected function checkBrowserGaleon()
1105
+		{
1106
+			if (stripos($this->_agent, 'galeon') !== false) {
1107
+				$aresult = explode(' ', stristr($this->_agent, 'galeon'));
1108
+				$aversion = explode('/', $aresult[0]);
1109
+				if (isset($aversion[1])) {
1110
+					$this->setVersion($aversion[1]);
1111
+					$this->setBrowser(self::BROWSER_GALEON);
1112
+					return true;
1113
+				}
1114
+			}
1115
+			return false;
1116
+		}
1117
+
1118
+		/**
1119
+		 * Determine if the browser is Konqueror or not (last updated 1.7)
1120
+		 * @return boolean True if the browser is Konqueror otherwise false
1121
+		 */
1122
+		protected function checkBrowserKonqueror()
1123
+		{
1124
+			if (stripos($this->_agent, 'Konqueror') !== false) {
1125
+				$aresult = explode(' ', stristr($this->_agent, 'Konqueror'));
1126
+				$aversion = explode('/', $aresult[0]);
1127
+				if (isset($aversion[1])) {
1128
+					$this->setVersion($aversion[1]);
1129
+					$this->setBrowser(self::BROWSER_KONQUEROR);
1130
+					return true;
1131
+				}
1132
+			}
1133
+			return false;
1134
+		}
1135
+
1136
+		/**
1137
+		 * Determine if the browser is iCab or not (last updated 1.7)
1138
+		 * @return boolean True if the browser is iCab otherwise false
1139
+		 */
1140
+		protected function checkBrowserIcab()
1141
+		{
1142
+			if (stripos($this->_agent, 'icab') !== false) {
1143
+				$aversion = explode(' ', stristr(str_replace('/', ' ', $this->_agent), 'icab'));
1144
+				if (isset($aversion[1])) {
1145
+					$this->setVersion($aversion[1]);
1146
+					$this->setBrowser(self::BROWSER_ICAB);
1147
+					return true;
1148
+				}
1149
+			}
1150
+			return false;
1151
+		}
1152
+
1153
+		/**
1154
+		 * Determine if the browser is OmniWeb or not (last updated 1.7)
1155
+		 * @return boolean True if the browser is OmniWeb otherwise false
1156
+		 */
1157
+		protected function checkBrowserOmniWeb()
1158
+		{
1159
+			if (stripos($this->_agent, 'omniweb') !== false) {
1160
+				$aresult = explode('/', stristr($this->_agent, 'omniweb'));
1161
+				$aversion = explode(' ', isset($aresult[1]) ? $aresult[1] : "");
1162
+				$this->setVersion($aversion[0]);
1163
+				$this->setBrowser(self::BROWSER_OMNIWEB);
1164
+				return true;
1165
+			}
1166
+			return false;
1167
+		}
1168
+
1169
+		/**
1170
+		 * Determine if the browser is Phoenix or not (last updated 1.7)
1171
+		 * @return boolean True if the browser is Phoenix otherwise false
1172
+		 */
1173
+		protected function checkBrowserPhoenix()
1174
+		{
1175
+			if (stripos($this->_agent, 'Phoenix') !== false) {
1176
+				$aversion = explode('/', stristr($this->_agent, 'Phoenix'));
1177
+				if (isset($aversion[1])) {
1178
+					$this->setVersion($aversion[1]);
1179
+					$this->setBrowser(self::BROWSER_PHOENIX);
1180
+					return true;
1181
+				}
1182
+			}
1183
+			return false;
1184
+		}
1185
+
1186
+		/**
1187
+		 * Determine if the browser is Firebird or not (last updated 1.7)
1188
+		 * @return boolean True if the browser is Firebird otherwise false
1189
+		 */
1190
+		protected function checkBrowserFirebird()
1191
+		{
1192
+			if (stripos($this->_agent, 'Firebird') !== false) {
1193
+				$aversion = explode('/', stristr($this->_agent, 'Firebird'));
1194
+				if (isset($aversion[1])) {
1195
+					$this->setVersion($aversion[1]);
1196
+					$this->setBrowser(self::BROWSER_FIREBIRD);
1197
+					return true;
1198
+				}
1199
+			}
1200
+			return false;
1201
+		}
1202
+
1203
+		/**
1204
+		 * Determine if the browser is Netscape Navigator 9+ or not (last updated 1.7)
1205
+		 * NOTE: (http://browser.netscape.com/ - Official support ended on March 1st, 2008)
1206
+		 * @return boolean True if the browser is Netscape Navigator 9+ otherwise false
1207
+		 */
1208
+		protected function checkBrowserNetscapeNavigator9Plus()
1209
+		{
1210
+			if (stripos($this->_agent, 'Firefox') !== false && preg_match('/Navigator\/([^ ]*)/i', $this->_agent, $matches)) {
1211
+				$this->setVersion($matches[1]);
1212
+				$this->setBrowser(self::BROWSER_NETSCAPE_NAVIGATOR);
1213
+				return true;
1214
+			} else if (stripos($this->_agent, 'Firefox') === false && preg_match('/Netscape6?\/([^ ]*)/i', $this->_agent, $matches)) {
1215
+				$this->setVersion($matches[1]);
1216
+				$this->setBrowser(self::BROWSER_NETSCAPE_NAVIGATOR);
1217
+				return true;
1218
+			}
1219
+			return false;
1220
+		}
1221
+
1222
+		/**
1223
+		 * Determine if the browser is Shiretoko or not (https://wiki.mozilla.org/Projects/shiretoko) (last updated 1.7)
1224
+		 * @return boolean True if the browser is Shiretoko otherwise false
1225
+		 */
1226
+		protected function checkBrowserShiretoko()
1227
+		{
1228
+			if (stripos($this->_agent, 'Mozilla') !== false && preg_match('/Shiretoko\/([^ ]*)/i', $this->_agent, $matches)) {
1229
+				$this->setVersion($matches[1]);
1230
+				$this->setBrowser(self::BROWSER_SHIRETOKO);
1231
+				return true;
1232
+			}
1233
+			return false;
1234
+		}
1235
+
1236
+		/**
1237
+		 * Determine if the browser is Ice Cat or not (http://en.wikipedia.org/wiki/GNU_IceCat) (last updated 1.7)
1238
+		 * @return boolean True if the browser is Ice Cat otherwise false
1239
+		 */
1240
+		protected function checkBrowserIceCat()
1241
+		{
1242
+			if (stripos($this->_agent, 'Mozilla') !== false && preg_match('/IceCat\/([^ ]*)/i', $this->_agent, $matches)) {
1243
+				$this->setVersion($matches[1]);
1244
+				$this->setBrowser(self::BROWSER_ICECAT);
1245
+				return true;
1246
+			}
1247
+			return false;
1248
+		}
1249
+
1250
+		/**
1251
+		 * Determine if the browser is Nokia or not (last updated 1.7)
1252
+		 * @return boolean True if the browser is Nokia otherwise false
1253
+		 */
1254
+		protected function checkBrowserNokia()
1255
+		{
1256
+			if (preg_match("/Nokia([^\/]+)\/([^ SP]+)/i", $this->_agent, $matches)) {
1257
+				$this->setVersion($matches[2]);
1258
+				if (stripos($this->_agent, 'Series60') !== false || strpos($this->_agent, 'S60') !== false) {
1259
+					$this->setBrowser(self::BROWSER_NOKIA_S60);
1260
+				} else {
1261
+					$this->setBrowser(self::BROWSER_NOKIA);
1262
+				}
1263
+				$this->setMobile(true);
1264
+				return true;
1265
+			}
1266
+			return false;
1267
+		}
1268
+
1269
+		/**
1270
+		 * Determine if the browser is Firefox or not (last updated 1.7)
1271
+		 * @return boolean True if the browser is Firefox otherwise false
1272
+		 */
1273
+		protected function checkBrowserFirefox()
1274
+		{
1275
+			if (stripos($this->_agent, 'safari') === false) {
1276
+				if (preg_match("/Firefox[\/ \(]([^ ;\)]+)/i", $this->_agent, $matches)) {
1277
+					$this->setVersion($matches[1]);
1278
+					$this->setBrowser(self::BROWSER_FIREFOX);
1279
+					//Firefox on Android
1280
+					if (stripos($this->_agent, 'Android') !== false) {
1281
+						if (stripos($this->_agent, 'Mobile') !== false) {
1282
+							$this->setMobile(true);
1283
+						} else {
1284
+							$this->setTablet(true);
1285
+						}
1286
+					}
1287
+					return true;
1288
+				} else if (preg_match("/Firefox$/i", $this->_agent, $matches)) {
1289
+					$this->setVersion("");
1290
+					$this->setBrowser(self::BROWSER_FIREFOX);
1291
+					return true;
1292
+				}
1293
+			}
1294
+			return false;
1295
+		}
1296
+
1297
+		/**
1298
+		 * Determine if the browser is Firefox or not (last updated 1.7)
1299
+		 * @return boolean True if the browser is Firefox otherwise false
1300
+		 */
1301
+		protected function checkBrowserIceweasel()
1302
+		{
1303
+			if (stripos($this->_agent, 'Iceweasel') !== false) {
1304
+				$aresult = explode('/', stristr($this->_agent, 'Iceweasel'));
1305
+				if (isset($aresult[1])) {
1306
+					$aversion = explode(' ', $aresult[1]);
1307
+					$this->setVersion($aversion[0]);
1308
+					$this->setBrowser(self::BROWSER_ICEWEASEL);
1309
+					return true;
1310
+				}
1311
+			}
1312
+			return false;
1313
+		}
1314
+
1315
+		/**
1316
+		 * Determine if the browser is Mozilla or not (last updated 1.7)
1317
+		 * @return boolean True if the browser is Mozilla otherwise false
1318
+		 */
1319
+		protected function checkBrowserMozilla()
1320
+		{
1321
+			if (stripos($this->_agent, 'mozilla') !== false && preg_match('/rv:[0-9].[0-9][a-b]?/i', $this->_agent) && stripos($this->_agent, 'netscape') === false) {
1322
+				$aversion = explode(' ', stristr($this->_agent, 'rv:'));
1323
+				preg_match('/rv:[0-9].[0-9][a-b]?/i', $this->_agent, $aversion);
1324
+				$this->setVersion(str_replace('rv:', '', $aversion[0]));
1325
+				$this->setBrowser(self::BROWSER_MOZILLA);
1326
+				return true;
1327
+			} else if (stripos($this->_agent, 'mozilla') !== false && preg_match('/rv:[0-9]\.[0-9]/i', $this->_agent) && stripos($this->_agent, 'netscape') === false) {
1328
+				$aversion = explode('', stristr($this->_agent, 'rv:'));
1329
+				$this->setVersion(str_replace('rv:', '', $aversion[0]));
1330
+				$this->setBrowser(self::BROWSER_MOZILLA);
1331
+				return true;
1332
+			} else if (stripos($this->_agent, 'mozilla') !== false && preg_match('/mozilla\/([^ ]*)/i', $this->_agent, $matches) && stripos($this->_agent, 'netscape') === false) {
1333
+				$this->setVersion($matches[1]);
1334
+				$this->setBrowser(self::BROWSER_MOZILLA);
1335
+				return true;
1336
+			}
1337
+			return false;
1338
+		}
1339
+
1340
+		/**
1341
+		 * Determine if the browser is Lynx or not (last updated 1.7)
1342
+		 * @return boolean True if the browser is Lynx otherwise false
1343
+		 */
1344
+		protected function checkBrowserLynx()
1345
+		{
1346
+			if (stripos($this->_agent, 'lynx') !== false) {
1347
+				$aresult = explode('/', stristr($this->_agent, 'Lynx'));
1348
+				$aversion = explode(' ', (isset($aresult[1]) ? $aresult[1] : ""));
1349
+				$this->setVersion($aversion[0]);
1350
+				$this->setBrowser(self::BROWSER_LYNX);
1351
+				return true;
1352
+			}
1353
+			return false;
1354
+		}
1355
+
1356
+		/**
1357
+		 * Determine if the browser is Amaya or not (last updated 1.7)
1358
+		 * @return boolean True if the browser is Amaya otherwise false
1359
+		 */
1360
+		protected function checkBrowserAmaya()
1361
+		{
1362
+			if (stripos($this->_agent, 'amaya') !== false) {
1363
+				$aresult = explode('/', stristr($this->_agent, 'Amaya'));
1364
+				if (isset($aresult[1])) {
1365
+					$aversion = explode(' ', $aresult[1]);
1366
+					$this->setVersion($aversion[0]);
1367
+					$this->setBrowser(self::BROWSER_AMAYA);
1368
+					return true;
1369
+				}
1370
+			}
1371
+			return false;
1372
+		}
1373
+
1374
+		/**
1375
+		 * Determine if the browser is Safari or not (last updated 1.7)
1376
+		 * @return boolean True if the browser is Safari otherwise false
1377
+		 */
1378
+		protected function checkBrowserSafari()
1379
+		{
1380
+			if (stripos($this->_agent, 'Safari') !== false
1381
+				&& stripos($this->_agent, 'iPhone') === false
1382
+				&& stripos($this->_agent, 'iPod') === false
1383
+			) {
1384
+
1385
+				$aresult = explode('/', stristr($this->_agent, 'Version'));
1386
+				if (isset($aresult[1])) {
1387
+					$aversion = explode(' ', $aresult[1]);
1388
+					$this->setVersion($aversion[0]);
1389
+				} else {
1390
+					$this->setVersion(self::VERSION_UNKNOWN);
1391
+				}
1392
+				$this->setBrowser(self::BROWSER_SAFARI);
1393
+				return true;
1394
+			}
1395
+			return false;
1396
+		}
1397
+
1398
+		protected function checkBrowserSamsung()
1399
+		{
1400
+			if (stripos($this->_agent, 'SamsungBrowser') !== false) {
1401
+
1402
+				$aresult = explode('/', stristr($this->_agent, 'SamsungBrowser'));
1403
+				if (isset($aresult[1])) {
1404
+					$aversion = explode(' ', $aresult[1]);
1405
+					$this->setVersion($aversion[0]);
1406
+				} else {
1407
+					$this->setVersion(self::VERSION_UNKNOWN);
1408
+				}
1409
+				$this->setBrowser(self::BROWSER_SAMSUNG);
1410
+				return true;
1411
+			}
1412
+			return false;
1413
+		}
1414
+
1415
+		protected function checkBrowserSilk()
1416
+		{
1417
+			if (stripos($this->_agent, 'Silk') !== false) {
1418
+				$aresult = explode('/', stristr($this->_agent, 'Silk'));
1419
+				if (isset($aresult[1])) {
1420
+					$aversion = explode(' ', $aresult[1]);
1421
+					$this->setVersion($aversion[0]);
1422
+				} else {
1423
+					$this->setVersion(self::VERSION_UNKNOWN);
1424
+				}
1425
+				$this->setBrowser(self::BROWSER_SILK);
1426
+				return true;
1427
+			}
1428
+			return false;
1429
+		}
1430
+
1431
+		protected function checkBrowserIframely()
1432
+		{
1433
+			if (stripos($this->_agent, 'Iframely') !== false) {
1434
+				$aresult = explode('/', stristr($this->_agent, 'Iframely'));
1435
+				if (isset($aresult[1])) {
1436
+					$aversion = explode(' ', $aresult[1]);
1437
+					$this->setVersion($aversion[0]);
1438
+				} else {
1439
+					$this->setVersion(self::VERSION_UNKNOWN);
1440
+				}
1441
+				$this->setBrowser(self::BROWSER_I_FRAME);
1442
+				return true;
1443
+			}
1444
+			return false;
1445
+		}
1446
+
1447
+		protected function checkBrowserCocoa()
1448
+		{
1449
+			if (stripos($this->_agent, 'CocoaRestClient') !== false) {
1450
+				$aresult = explode('/', stristr($this->_agent, 'CocoaRestClient'));
1451
+				if (isset($aresult[1])) {
1452
+					$aversion = explode(' ', $aresult[1]);
1453
+					$this->setVersion($aversion[0]);
1454
+				} else {
1455
+					$this->setVersion(self::VERSION_UNKNOWN);
1456
+				}
1457
+				$this->setBrowser(self::BROWSER_COCOA);
1458
+				return true;
1459
+			}
1460
+			return false;
1461
+		}
1462
+
1463
+		/**
1464
+		 * Detect if URL is loaded from FacebookExternalHit
1465
+		 * @return boolean True if it detects FacebookExternalHit otherwise false
1466
+		 */
1467
+		protected function checkFacebookExternalHit()
1468
+		{
1469
+			if (stristr($this->_agent, 'FacebookExternalHit')) {
1470
+				$this->setRobot(true);
1471
+				$this->setFacebook(true);
1472
+				return true;
1473
+			}
1474
+			return false;
1475
+		}
1476
+
1477
+		/**
1478
+		 * Detect if URL is being loaded from internal Facebook browser
1479
+		 * @return boolean True if it detects internal Facebook browser otherwise false
1480
+		 */
1481
+		protected function checkForFacebookIos()
1482
+		{
1483
+			if (stristr($this->_agent, 'FBIOS')) {
1484
+				$this->setFacebook(true);
1485
+				return true;
1486
+			}
1487
+			return false;
1488
+		}
1489
+
1490
+		/**
1491
+		 * Detect Version for the Safari browser on iOS devices
1492
+		 * @return boolean True if it detects the version correctly otherwise false
1493
+		 */
1494
+		protected function getSafariVersionOnIos()
1495
+		{
1496
+			$aresult = explode('/', stristr($this->_agent, 'Version'));
1497
+			if (isset($aresult[1])) {
1498
+				$aversion = explode(' ', $aresult[1]);
1499
+				$this->setVersion($aversion[0]);
1500
+				return true;
1501
+			}
1502
+			return false;
1503
+		}
1504
+
1505
+		/**
1506
+		 * Detect Version for the Chrome browser on iOS devices
1507
+		 * @return boolean True if it detects the version correctly otherwise false
1508
+		 */
1509
+		protected function getChromeVersionOnIos()
1510
+		{
1511
+			$aresult = explode('/', stristr($this->_agent, 'CriOS'));
1512
+			if (isset($aresult[1])) {
1513
+				$aversion = explode(' ', $aresult[1]);
1514
+				$this->setVersion($aversion[0]);
1515
+				$this->setBrowser(self::BROWSER_CHROME);
1516
+				return true;
1517
+			}
1518
+			return false;
1519
+		}
1520
+
1521
+		/**
1522
+		 * Determine if the browser is iPhone or not (last updated 1.7)
1523
+		 * @return boolean True if the browser is iPhone otherwise false
1524
+		 */
1525
+		protected function checkBrowseriPhone()
1526
+		{
1527
+			if (stripos($this->_agent, 'iPhone') !== false) {
1528
+				$this->setVersion(self::VERSION_UNKNOWN);
1529
+				$this->setBrowser(self::BROWSER_IPHONE);
1530
+				$this->getSafariVersionOnIos();
1531
+				$this->getChromeVersionOnIos();
1532
+				$this->checkForFacebookIos();
1533
+				$this->setMobile(true);
1534
+				return true;
1535
+
1536
+			}
1537
+			return false;
1538
+		}
1539
+
1540
+		/**
1541
+		 * Determine if the browser is iPad or not (last updated 1.7)
1542
+		 * @return boolean True if the browser is iPad otherwise false
1543
+		 */
1544
+		protected function checkBrowseriPad()
1545
+		{
1546
+			if (stripos($this->_agent, 'iPad') !== false) {
1547
+				$this->setVersion(self::VERSION_UNKNOWN);
1548
+				$this->setBrowser(self::BROWSER_IPAD);
1549
+				$this->getSafariVersionOnIos();
1550
+				$this->getChromeVersionOnIos();
1551
+				$this->checkForFacebookIos();
1552
+				$this->setTablet(true);
1553
+				return true;
1554
+			}
1555
+			return false;
1556
+		}
1557
+
1558
+		/**
1559
+		 * Determine if the browser is iPod or not (last updated 1.7)
1560
+		 * @return boolean True if the browser is iPod otherwise false
1561
+		 */
1562
+		protected function checkBrowseriPod()
1563
+		{
1564
+			if (stripos($this->_agent, 'iPod') !== false) {
1565
+				$this->setVersion(self::VERSION_UNKNOWN);
1566
+				$this->setBrowser(self::BROWSER_IPOD);
1567
+				$this->getSafariVersionOnIos();
1568
+				$this->getChromeVersionOnIos();
1569
+				$this->checkForFacebookIos();
1570
+				$this->setMobile(true);
1571
+				return true;
1572
+			}
1573
+			return false;
1574
+		}
1575
+
1576
+		/**
1577
+		 * Determine if the browser is Android or not (last updated 1.7)
1578
+		 * @return boolean True if the browser is Android otherwise false
1579
+		 */
1580
+		protected function checkBrowserAndroid()
1581
+		{
1582
+			if (stripos($this->_agent, 'Android') !== false) {
1583
+				$aresult = explode(' ', stristr($this->_agent, 'Android'));
1584
+				if (isset($aresult[1])) {
1585
+					$aversion = explode(' ', $aresult[1]);
1586
+					$this->setVersion($aversion[0]);
1587
+				} else {
1588
+					$this->setVersion(self::VERSION_UNKNOWN);
1589
+				}
1590
+				if (stripos($this->_agent, 'Mobile') !== false) {
1591
+					$this->setMobile(true);
1592
+				} else {
1593
+					$this->setTablet(true);
1594
+				}
1595
+				$this->setBrowser(self::BROWSER_ANDROID);
1596
+				return true;
1597
+			}
1598
+			return false;
1599
+		}
1600
+
1601
+		/**
1602
+		 * Determine if the browser is Vivaldi
1603
+		 * @return boolean True if the browser is Vivaldi otherwise false
1604
+		 */
1605
+		protected function checkBrowserVivaldi()
1606
+		{
1607
+			if (stripos($this->_agent, 'Vivaldi') !== false) {
1608
+				$aresult = explode('/', stristr($this->_agent, 'Vivaldi'));
1609
+				if (isset($aresult[1])) {
1610
+					$aversion = explode(' ', $aresult[1]);
1611
+					$this->setVersion($aversion[0]);
1612
+					$this->setBrowser(self::BROWSER_VIVALDI);
1613
+					return true;
1614
+				}
1615
+			}
1616
+			return false;
1617
+		}
1618
+
1619
+		/**
1620
+		 * Determine if the browser is Yandex
1621
+		 * @return boolean True if the browser is Yandex otherwise false
1622
+		 */
1623
+		protected function checkBrowserYandex()
1624
+		{
1625
+			if (stripos($this->_agent, 'YaBrowser') !== false) {
1626
+				$aresult = explode('/', stristr($this->_agent, 'YaBrowser'));
1627
+				if (isset($aresult[1])) {
1628
+					$aversion = explode(' ', $aresult[1]);
1629
+					$this->setVersion($aversion[0]);
1630
+					$this->setBrowser(self::BROWSER_YANDEX);
1631
+
1632
+					if (stripos($this->_agent, 'iPad') !== false) {
1633
+						$this->setTablet(true);
1634
+					} elseif (stripos($this->_agent, 'Mobile') !== false) {
1635
+						$this->setMobile(true);
1636
+					} elseif (stripos($this->_agent, 'Android') !== false) {
1637
+						$this->setTablet(true);
1638
+					}
1639
+
1640
+					return true;
1641
+				}
1642
+			}
1643
+
1644
+			return false;
1645
+		}
1646
+
1647
+		/**
1648
+		 * Determine if the browser is a PlayStation
1649
+		 * @return boolean True if the browser is PlayStation otherwise false
1650
+		 */
1651
+		protected function checkBrowserPlayStation()
1652
+		{
1653
+			if (stripos($this->_agent, 'PlayStation ') !== false) {
1654
+				$aresult = explode(' ', stristr($this->_agent, 'PlayStation '));
1655
+				$this->setBrowser(self::BROWSER_PLAYSTATION);
1656
+				if (isset($aresult[0])) {
1657
+					$aversion = explode(')', $aresult[2]);
1658
+					$this->setVersion($aversion[0]);
1659
+					if (stripos($this->_agent, 'Portable)') !== false || stripos($this->_agent, 'Vita') !== false) {
1660
+						$this->setMobile(true);
1661
+					}
1662
+					return true;
1663
+				}
1664
+			}
1665
+			return false;
1666
+		}
1667
+
1668
+		/**
1669
+		 * Determine the user's platform (last updated 2.0)
1670
+		 */
1671
+		protected function checkPlatform()
1672
+		{
1673
+			if (stripos($this->_agent, 'windows') !== false) {
1674
+				$this->_platform = self::PLATFORM_WINDOWS;
1675
+			} else if (stripos($this->_agent, 'iPad') !== false) {
1676
+				$this->_platform = self::PLATFORM_IPAD;
1677
+			} else if (stripos($this->_agent, 'iPod') !== false) {
1678
+				$this->_platform = self::PLATFORM_IPOD;
1679
+			} else if (stripos($this->_agent, 'iPhone') !== false) {
1680
+				$this->_platform = self::PLATFORM_IPHONE;
1681
+			} elseif (stripos($this->_agent, 'mac') !== false) {
1682
+				$this->_platform = self::PLATFORM_APPLE;
1683
+			} elseif (stripos($this->_agent, 'android') !== false) {
1684
+				$this->_platform = self::PLATFORM_ANDROID;
1685
+			} elseif (stripos($this->_agent, 'Silk') !== false) {
1686
+				$this->_platform = self::PLATFORM_FIRE_OS;
1687
+			} elseif (stripos($this->_agent, 'linux') !== false && stripos($this->_agent, 'SMART-TV') !== false ) {
1688
+				$this->_platform = self::PLATFORM_LINUX .'/'.self::PLATFORM_SMART_TV;
1689
+			} elseif (stripos($this->_agent, 'linux') !== false) {
1690
+				$this->_platform = self::PLATFORM_LINUX;
1691
+			} else if (stripos($this->_agent, 'Nokia') !== false) {
1692
+				$this->_platform = self::PLATFORM_NOKIA;
1693
+			} else if (stripos($this->_agent, 'BlackBerry') !== false) {
1694
+				$this->_platform = self::PLATFORM_BLACKBERRY;
1695
+			} elseif (stripos($this->_agent, 'FreeBSD') !== false) {
1696
+				$this->_platform = self::PLATFORM_FREEBSD;
1697
+			} elseif (stripos($this->_agent, 'OpenBSD') !== false) {
1698
+				$this->_platform = self::PLATFORM_OPENBSD;
1699
+			} elseif (stripos($this->_agent, 'NetBSD') !== false) {
1700
+				$this->_platform = self::PLATFORM_NETBSD;
1701
+			} elseif (stripos($this->_agent, 'OpenSolaris') !== false) {
1702
+				$this->_platform = self::PLATFORM_OPENSOLARIS;
1703
+			} elseif (stripos($this->_agent, 'SunOS') !== false) {
1704
+				$this->_platform = self::PLATFORM_SUNOS;
1705
+			} elseif (stripos($this->_agent, 'OS\/2') !== false) {
1706
+				$this->_platform = self::PLATFORM_OS2;
1707
+			} elseif (stripos($this->_agent, 'BeOS') !== false) {
1708
+				$this->_platform = self::PLATFORM_BEOS;
1709
+			} elseif (stripos($this->_agent, 'win') !== false) {
1710
+				$this->_platform = self::PLATFORM_WINDOWS;
1711
+			} elseif (stripos($this->_agent, 'Playstation') !== false) {
1712
+				$this->_platform = self::PLATFORM_PLAYSTATION;
1713
+			} elseif (stripos($this->_agent, 'Roku') !== false) {
1714
+				$this->_platform = self::PLATFORM_ROKU;
1715
+			} elseif (stripos($this->_agent, 'iOS') !== false) {
1716
+				$this->_platform = self::PLATFORM_IPHONE . '/' . self::PLATFORM_IPAD;
1717
+			} elseif (stripos($this->_agent, 'tvOS') !== false) {
1718
+				$this->_platform = self::PLATFORM_APPLE_TV;
1719
+			} elseif (stripos($this->_agent, 'curl') !== false) {
1720
+				$this->_platform = self::PLATFORM_TERMINAL;
1721
+			} elseif (stripos($this->_agent, 'CrOS') !== false) {
1722
+				$this->_platform = self::PLATFORM_CHROME_OS;
1723
+			} elseif (stripos($this->_agent, 'okhttp') !== false) {
1724
+				$this->_platform = self::PLATFORM_JAVA_ANDROID;
1725
+			} elseif (stripos($this->_agent, 'PostmanRuntime') !== false) {
1726
+				$this->_platform = self::PLATFORM_POSTMAN;
1727
+			} elseif (stripos($this->_agent, 'Iframely') !== false) {
1728
+				$this->_platform = self::PLATFORM_I_FRAME;
1729
+			}
1730
+
1731
+		}
1732
+	}
Please login to merge, or discard this patch.
core/libraries/FormValidation.php 2 patches
Indentation   +874 added lines, -874 removed lines patch added patch discarded remove patch
@@ -1,916 +1,916 @@
 block discarded – undo
1 1
 <?php
2
-    defined('ROOT_PATH') || exit('Access denied');
3
-    /**
4
-     * TNH Framework
5
-     *
6
-     * A simple PHP framework using HMVC architecture
7
-     *
8
-     * This content is released under the GNU GPL License (GPL)
9
-     *
10
-     * Copyright (C) 2017 Tony NGUEREZA
11
-     *
12
-     * This program is free software; you can redistribute it and/or
13
-     * modify it under the terms of the GNU General Public License
14
-     * as published by the Free Software Foundation; either version 3
15
-     * of the License, or (at your option) any later version.
16
-     *
17
-     * This program is distributed in the hope that it will be useful,
18
-     * but WITHOUT ANY WARRANTY; without even the implied warranty of
19
-     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
20
-     * GNU General Public License for more details.
21
-     *
22
-     * You should have received a copy of the GNU General Public License
23
-     * along with this program; if not, write to the Free Software
24
-     * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
25
-    */
26
-
27
-
28
-     class FormValidation{
2
+	defined('ROOT_PATH') || exit('Access denied');
3
+	/**
4
+	 * TNH Framework
5
+	 *
6
+	 * A simple PHP framework using HMVC architecture
7
+	 *
8
+	 * This content is released under the GNU GPL License (GPL)
9
+	 *
10
+	 * Copyright (C) 2017 Tony NGUEREZA
11
+	 *
12
+	 * This program is free software; you can redistribute it and/or
13
+	 * modify it under the terms of the GNU General Public License
14
+	 * as published by the Free Software Foundation; either version 3
15
+	 * of the License, or (at your option) any later version.
16
+	 *
17
+	 * This program is distributed in the hope that it will be useful,
18
+	 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19
+	 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
20
+	 * GNU General Public License for more details.
21
+	 *
22
+	 * You should have received a copy of the GNU General Public License
23
+	 * along with this program; if not, write to the Free Software
24
+	 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
25
+	 */
26
+
27
+
28
+	 class FormValidation{
29 29
 		 
30
-        /**
31
-         * The form validation status
32
-         * @var boolean
33
-         */
34
-        protected $_success  = false;
35
-
36
-        /**
37
-         * The list of errors messages
38
-         * @var array
39
-         */
40
-        protected $_errorsMessages = array();
30
+		/**
31
+		 * The form validation status
32
+		 * @var boolean
33
+		 */
34
+		protected $_success  = false;
35
+
36
+		/**
37
+		 * The list of errors messages
38
+		 * @var array
39
+		 */
40
+		protected $_errorsMessages = array();
41 41
         
42
-        // Array of rule sets, fieldName => PIPE seperated ruleString
43
-        protected $_rules             = array();
42
+		// Array of rule sets, fieldName => PIPE seperated ruleString
43
+		protected $_rules             = array();
44 44
         
45
-        // Array of errors, niceName => Error Message
46
-        protected $_errors             = array();
45
+		// Array of errors, niceName => Error Message
46
+		protected $_errors             = array();
47 47
         
48
-        // Array of post Key => Nice name labels
49
-        protected $_labels          = array();
48
+		// Array of post Key => Nice name labels
49
+		protected $_labels          = array();
50 50
         
51
-        /**
52
-         * The errors delimiters
53
-         * @var array
54
-         */
55
-        protected $_allErrorsDelimiter   = array('<div class="error">', '</div>');
56
-
57
-        /**
58
-         * The each error delimiter
59
-         * @var array
60
-         */
61
-        protected $_eachErrorDelimiter   = array('<p class="error">', '</p>');
51
+		/**
52
+		 * The errors delimiters
53
+		 * @var array
54
+		 */
55
+		protected $_allErrorsDelimiter   = array('<div class="error">', '</div>');
56
+
57
+		/**
58
+		 * The each error delimiter
59
+		 * @var array
60
+		 */
61
+		protected $_eachErrorDelimiter   = array('<p class="error">', '</p>');
62 62
         
63 63
 		/**
64
-         * Indicated if need force the validation to be failed
65
-         * @var boolean
66
-         */
67
-        protected $_forceFail            = false;
68
-
69
-        /**
70
-         * The list of the error messages overrides by the original
71
-         * @var array
72
-         */
73
-        protected $_errorPhraseOverrides = array();
74
-
75
-        /**
76
-         * The logger instance
77
-         * @var Log
78
-         */
79
-        private $logger;
80
-
81
-        /**
82
-         * The data to be validated, the default is to use $_POST
83
-         * @var array
84
-         */
85
-        private $data = array();
86
-
87
-        /**
88
-         * Whether to check the CSRF. This attribute is just a way to allow custom change of the 
64
+		 * Indicated if need force the validation to be failed
65
+		 * @var boolean
66
+		 */
67
+		protected $_forceFail            = false;
68
+
69
+		/**
70
+		 * The list of the error messages overrides by the original
71
+		 * @var array
72
+		 */
73
+		protected $_errorPhraseOverrides = array();
74
+
75
+		/**
76
+		 * The logger instance
77
+		 * @var Log
78
+		 */
79
+		private $logger;
80
+
81
+		/**
82
+		 * The data to be validated, the default is to use $_POST
83
+		 * @var array
84
+		 */
85
+		private $data = array();
86
+
87
+		/**
88
+		 * Whether to check the CSRF. This attribute is just a way to allow custom change of the 
89 89
 		 * CSRF global configuration
90 90
 		 *
91
-         * @var boolean
92
-         */
93
-        public $enableCsrfCheck = false;
94
-
95
-        /**
96
-         * Set all errors and rule sets empty, and sets success to false.
97
-         *
98
-         * @return void
99
-         */
100
-        public function __construct() {
101
-            $this->logger =& class_loader('Log', 'classes');
102
-            $this->logger->setLogger('Library::FormValidation');
91
+		 * @var boolean
92
+		 */
93
+		public $enableCsrfCheck = false;
94
+
95
+		/**
96
+		 * Set all errors and rule sets empty, and sets success to false.
97
+		 *
98
+		 * @return void
99
+		 */
100
+		public function __construct() {
101
+			$this->logger =& class_loader('Log', 'classes');
102
+			$this->logger->setLogger('Library::FormValidation');
103 103
            
104 104
 		   //Load form validation language message
105
-            Loader::lang('form_validation');
106
-            $obj = & get_instance();
107
-            $this->_errorsMessages  = array(
108
-                        'required'         => $obj->lang->get('fv_required'),
109
-                        'min_length'       => $obj->lang->get('fv_min_length'),
110
-                        'max_length'       => $obj->lang->get('fv_max_length'),
111
-                        'exact_length'     => $obj->lang->get('fv_exact_length'),
112
-                        'less_than'        => $obj->lang->get('fv_less_than'),
113
-                        'greater_than'     => $obj->lang->get('fv_greater_than'),
114
-                        'matches'          => $obj->lang->get('fv_matches'),
115
-                        'valid_email'      => $obj->lang->get('fv_valid_email'),
116
-                        'not_equal'        => array(
117
-                                                'post:key' => $obj->lang->get('fv_not_equal_post_key'),
118
-                                                'string'   => $obj->lang->get('fv_not_equal_string')
119
-                                            ),
120
-                        'depends'          => $obj->lang->get('fv_depends'),
121
-                        'is_unique'        => $obj->lang->get('fv_is_unique'),
122
-                        'is_unique_update' => $obj->lang->get('fv_is_unique_update'),
123
-                        'exists'           => $obj->lang->get('fv_exists'),
124
-                        'regex'            => $obj->lang->get('fv_regex'),
125
-                        'in_list'          => $obj->lang->get('fv_in_list'),
126
-                        'numeric'          => $obj->lang->get('fv_numeric'),
127
-                        'callback'         => $obj->lang->get('fv_callback'),
128
-                    );
129
-            $this->_resetValidation();
130
-            $this->setData($obj->request->post(null));
131
-        }
132
-
133
-        /**
134
-         * Reset the form validation instance
135
-         */
136
-        protected function _resetValidation() {
137
-            $this->_rules                = array();
138
-            $this->_labels               = array();
139
-            $this->_errorPhraseOverrides = array();
140
-            $this->_errors               = array();
141
-            $this->_success              = false;
142
-            $this->_forceFail            = false;
143
-            $this->data                  = array();
105
+			Loader::lang('form_validation');
106
+			$obj = & get_instance();
107
+			$this->_errorsMessages  = array(
108
+						'required'         => $obj->lang->get('fv_required'),
109
+						'min_length'       => $obj->lang->get('fv_min_length'),
110
+						'max_length'       => $obj->lang->get('fv_max_length'),
111
+						'exact_length'     => $obj->lang->get('fv_exact_length'),
112
+						'less_than'        => $obj->lang->get('fv_less_than'),
113
+						'greater_than'     => $obj->lang->get('fv_greater_than'),
114
+						'matches'          => $obj->lang->get('fv_matches'),
115
+						'valid_email'      => $obj->lang->get('fv_valid_email'),
116
+						'not_equal'        => array(
117
+												'post:key' => $obj->lang->get('fv_not_equal_post_key'),
118
+												'string'   => $obj->lang->get('fv_not_equal_string')
119
+											),
120
+						'depends'          => $obj->lang->get('fv_depends'),
121
+						'is_unique'        => $obj->lang->get('fv_is_unique'),
122
+						'is_unique_update' => $obj->lang->get('fv_is_unique_update'),
123
+						'exists'           => $obj->lang->get('fv_exists'),
124
+						'regex'            => $obj->lang->get('fv_regex'),
125
+						'in_list'          => $obj->lang->get('fv_in_list'),
126
+						'numeric'          => $obj->lang->get('fv_numeric'),
127
+						'callback'         => $obj->lang->get('fv_callback'),
128
+					);
129
+			$this->_resetValidation();
130
+			$this->setData($obj->request->post(null));
131
+		}
132
+
133
+		/**
134
+		 * Reset the form validation instance
135
+		 */
136
+		protected function _resetValidation() {
137
+			$this->_rules                = array();
138
+			$this->_labels               = array();
139
+			$this->_errorPhraseOverrides = array();
140
+			$this->_errors               = array();
141
+			$this->_success              = false;
142
+			$this->_forceFail            = false;
143
+			$this->data                  = array();
144 144
 			$this->enableCsrfCheck       = false;
145
-        }
145
+		}
146
+
147
+		/**
148
+		 * Set the form validation data
149
+		 * @param array $data the values to be validated
150
+		 *
151
+		 * @return FormValidation Current instance of object.
152
+		 */
153
+		public function setData(array $data){
154
+			$this->logger->debug('Setting the form validation data, the values are: ' . stringfy_vars($data));
155
+			$this->data = $data;
156
+			return $this;
157
+		}
158
+
159
+		/**
160
+		 * Get the form validation data
161
+		 * @return array the form validation data to be validated
162
+		 */
163
+		public function getData(){
164
+			return $this->data;
165
+		}
166
+
167
+		/**
168
+		 * Get the validation function name to validate a rule
169
+		 *
170
+		 * @return string the function name
171
+		 */
172
+		protected function _toCallCase($funcName, $prefix='_validate') {
173
+			$funcName = strtolower($funcName);
174
+			$finalFuncName = $prefix;
175
+			foreach (explode('_', $funcName) as $funcNamePart) {
176
+				$finalFuncName .= strtoupper($funcNamePart[0]) . substr($funcNamePart, 1);
177
+			}
178
+			return $finalFuncName;
179
+		}
180
+
181
+		/**
182
+		 * Returns the boolean of the data status success. It goes by the simple
183
+		 *
184
+		 * @return boolean Whether or not the data validation has succeeded
185
+		 */
186
+		public function isSuccess() {
187
+			return $this->_success;
188
+		}
189
+
190
+		/**
191
+		 * Checks if the request method is POST or the Data to be validated is set
192
+		 *
193
+		 * @return boolean Whether or not the form has been submitted or the data is available for validation.
194
+		 */
195
+		public function canDoValidation() {
196
+			return get_instance()->request->method() === 'POST' || ! empty($this->data);
197
+		}
198
+
199
+		/**
200
+		 * Runs _run once POST data has been submitted or data is set manually.
201
+		 *
202
+		 * @return boolean
203
+		 */
204
+		public function run() {
205
+			if ($this->canDoValidation()) {
206
+				$this->logger->info('The data to validate are listed below: ' . stringfy_vars($this->getData()));
207
+				$this->_run();
208
+			}
209
+			return $this->isSuccess();
210
+		}
211
+
212
+		/**
213
+		 * Takes and trims each data, if it has any rules, we parse the rule string and run
214
+		 * each rule against the data value. Sets _success to true if there are no errors
215
+		 * afterwards.
216
+		 */
217
+		protected function _run() {
218
+			if(get_instance()->request->method() == 'POST' || $this->enableCsrfCheck){
219
+				$this->logger->debug('Check if CSRF is enabled in configuration');
220
+				//first check for CSRF
221
+				if( get_config('csrf_enable', false) || $this->enableCsrfCheck){
222
+					 $this->logger->info('Check the CSRF value if is valid');
223
+					if(! Security::validateCSRF()){
224
+						show_error('Invalide data, Cross Site Request Forgery do his job, the data to validate is corrupted.');
225
+					}
226
+				}
227
+				else{
228
+					$this->logger->info('CSRF is not enabled in configuration or not set manully, no need to check it');
229
+				}
230
+			}
231
+			/////////////////////////////////////////////
232
+			$this->_forceFail = false;
233
+
234
+			foreach ($this->getData() as $inputName => $inputVal) {
235
+				if(is_array($this->data[$inputName])){
236
+					$this->data[$inputName] = array_map('trim', $this->data[$inputName]);
237
+				}
238
+				else{
239
+					$this->data[$inputName] = trim($this->data[$inputName]);
240
+				}
146 241
 
147
-        /**
148
-         * Set the form validation data
149
-         * @param array $data the values to be validated
242
+				if (array_key_exists($inputName, $this->_rules)) {
243
+					foreach ($this->_parseRuleString($this->_rules[$inputName]) as $eachRule) {
244
+						$this->_validateRule($inputName, $this->data[$inputName], $eachRule);
245
+					}
246
+				}
247
+			}
248
+
249
+			if (empty($this->_errors) && $this->_forceFail === false) {
250
+				$this->_success = true;
251
+			}
252
+		}
253
+
254
+		/**
255
+		 * Adds a rule to a form data validation field.
150 256
 		 *
151
-         * @return FormValidation Current instance of object.
152
-         */
153
-        public function setData(array $data){
154
-            $this->logger->debug('Setting the form validation data, the values are: ' . stringfy_vars($data));
155
-            $this->data = $data;
257
+		 * @param string $inputField Name of the field or the data key to add a rule to
258
+		 * @param string $ruleSets PIPE seperated string of rules
259
+		 *
260
+		 * @return FormValidation Current instance of object.
261
+		 */
262
+		public function setRule($inputField, $inputLabel, $ruleSets) {
263
+			$this->_rules[$inputField] = $ruleSets;
264
+			$this->_labels[$inputField] = $inputLabel;
265
+			$this->logger->info('Set the field rule: name [' .$inputField. '], label [' .$inputLabel. '], rules [' .$ruleSets. ']');
156 266
 			return $this;
157
-        }
158
-
159
-        /**
160
-         * Get the form validation data
161
-         * @return array the form validation data to be validated
162
-         */
163
-        public function getData(){
164
-            return $this->data;
165
-        }
166
-
167
-		/**
168
-		* Get the validation function name to validate a rule
169
-		*
170
-		* @return string the function name
171
-		*/
172
-        protected function _toCallCase($funcName, $prefix='_validate') {
173
-            $funcName = strtolower($funcName);
174
-            $finalFuncName = $prefix;
175
-            foreach (explode('_', $funcName) as $funcNamePart) {
176
-                $finalFuncName .= strtoupper($funcNamePart[0]) . substr($funcNamePart, 1);
177
-            }
178
-            return $finalFuncName;
179
-        }
180
-
181
-        /**
182
-         * Returns the boolean of the data status success. It goes by the simple
183
-         *
184
-         * @return boolean Whether or not the data validation has succeeded
185
-         */
186
-        public function isSuccess() {
187
-            return $this->_success;
188
-        }
189
-
190
-        /**
191
-         * Checks if the request method is POST or the Data to be validated is set
192
-         *
193
-         * @return boolean Whether or not the form has been submitted or the data is available for validation.
194
-         */
195
-        public function canDoValidation() {
196
-            return get_instance()->request->method() === 'POST' || ! empty($this->data);
197
-        }
198
-
199
-        /**
200
-         * Runs _run once POST data has been submitted or data is set manually.
201
-         *
202
-         * @return boolean
203
-         */
204
-        public function run() {
205
-            if ($this->canDoValidation()) {
206
-                $this->logger->info('The data to validate are listed below: ' . stringfy_vars($this->getData()));
207
-                $this->_run();
208
-            }
209
-            return $this->isSuccess();
210
-        }
211
-
212
-        /**
213
-         * Takes and trims each data, if it has any rules, we parse the rule string and run
214
-         * each rule against the data value. Sets _success to true if there are no errors
215
-         * afterwards.
216
-         */
217
-        protected function _run() {
218
-            if(get_instance()->request->method() == 'POST' || $this->enableCsrfCheck){
219
-                $this->logger->debug('Check if CSRF is enabled in configuration');
220
-                //first check for CSRF
221
-                if( get_config('csrf_enable', false) || $this->enableCsrfCheck){
222
-                     $this->logger->info('Check the CSRF value if is valid');
223
-                    if(! Security::validateCSRF()){
224
-                        show_error('Invalide data, Cross Site Request Forgery do his job, the data to validate is corrupted.');
225
-                    }
226
-                }
227
-                else{
228
-                    $this->logger->info('CSRF is not enabled in configuration or not set manully, no need to check it');
229
-                }
230
-            }
231
-            /////////////////////////////////////////////
232
-            $this->_forceFail = false;
233
-
234
-            foreach ($this->getData() as $inputName => $inputVal) {
235
-    			if(is_array($this->data[$inputName])){
236
-    				$this->data[$inputName] = array_map('trim', $this->data[$inputName]);
237
-    			}
238
-    			else{
239
-    				$this->data[$inputName] = trim($this->data[$inputName]);
240
-    			}
241
-
242
-                if (array_key_exists($inputName, $this->_rules)) {
243
-                    foreach ($this->_parseRuleString($this->_rules[$inputName]) as $eachRule) {
244
-                        $this->_validateRule($inputName, $this->data[$inputName], $eachRule);
245
-                    }
246
-                }
247
-            }
248
-
249
-            if (empty($this->_errors) && $this->_forceFail === false) {
250
-                $this->_success = true;
251
-            }
252
-        }
253
-
254
-        /**
255
-         * Adds a rule to a form data validation field.
256
-         *
257
-         * @param string $inputField Name of the field or the data key to add a rule to
258
-         * @param string $ruleSets PIPE seperated string of rules
259
-		 *
260
-         * @return FormValidation Current instance of object.
261
-         */
262
-        public function setRule($inputField, $inputLabel, $ruleSets) {
263
-            $this->_rules[$inputField] = $ruleSets;
264
-            $this->_labels[$inputField] = $inputLabel;
265
-            $this->logger->info('Set the field rule: name [' .$inputField. '], label [' .$inputLabel. '], rules [' .$ruleSets. ']');
266
-            return $this;
267
-        }
268
-
269
-        /**
270
-         * Takes an array of rules and uses setRule() to set them, accepts an array
271
-         * of rule names rather than a pipe-delimited string as well.
272
-         * @param array $ruleSets
267
+		}
268
+
269
+		/**
270
+		 * Takes an array of rules and uses setRule() to set them, accepts an array
271
+		 * of rule names rather than a pipe-delimited string as well.
272
+		 * @param array $ruleSets
273 273
 		 *
274 274
 		 * @return FormValidation Current instance of object.
275
-         */
276
-        public function setRules(array $ruleSets) {
277
-            foreach ($ruleSets as $ruleSet) {
278
-                $pipeDelimitedRules = null;
279
-                if (is_array($ruleSet['rules'])) {
280
-                    $pipeDelimitedRules = implode('|', $ruleSet['rules']);
281
-                } else {
282
-                    $pipeDelimitedRules = $ruleSet['rules'];
283
-                }
284
-                $this->setRule($ruleSet['name'], $ruleSet['label'], $pipeDelimitedRules);
285
-            }
286
-            return $this;
287
-        }
288
-
289
-        /**
290
-         * This method creates the global errors delimiter, each argument occurs once, at the beginning, and
291
-         * end of the errors block respectively.
292
-         *
293
-         * @param string $start Before block of errors gets displayed, HTML allowed.
294
-         * @param string $end After the block of errors gets displayed, HTML allowed.
295
-         *
275
+		 */
276
+		public function setRules(array $ruleSets) {
277
+			foreach ($ruleSets as $ruleSet) {
278
+				$pipeDelimitedRules = null;
279
+				if (is_array($ruleSet['rules'])) {
280
+					$pipeDelimitedRules = implode('|', $ruleSet['rules']);
281
+				} else {
282
+					$pipeDelimitedRules = $ruleSet['rules'];
283
+				}
284
+				$this->setRule($ruleSet['name'], $ruleSet['label'], $pipeDelimitedRules);
285
+			}
286
+			return $this;
287
+		}
288
+
289
+		/**
290
+		 * This method creates the global errors delimiter, each argument occurs once, at the beginning, and
291
+		 * end of the errors block respectively.
292
+		 *
293
+		 * @param string $start Before block of errors gets displayed, HTML allowed.
294
+		 * @param string $end After the block of errors gets displayed, HTML allowed.
295
+		 *
296 296
 		 * @return FormValidation Current instance of object.
297
-         */
298
-        public function setErrorsDelimiter($start, $end) {
299
-            $this->_allErrorsDelimiter[0] = $start;
300
-            $this->_allErrorsDelimiter[1] = $end;
301
-            return $this;
302
-        }
303
-
304
-        /**
305
-         * This is the individual error delimiter, each argument occurs once before and after
306
-         * each individual error listed.
307
-         *
308
-         * @param string $start Displayed before each error.
309
-         * @param string $end Displayed after each error.
310
-         * 
297
+		 */
298
+		public function setErrorsDelimiter($start, $end) {
299
+			$this->_allErrorsDelimiter[0] = $start;
300
+			$this->_allErrorsDelimiter[1] = $end;
301
+			return $this;
302
+		}
303
+
304
+		/**
305
+		 * This is the individual error delimiter, each argument occurs once before and after
306
+		 * each individual error listed.
307
+		 *
308
+		 * @param string $start Displayed before each error.
309
+		 * @param string $end Displayed after each error.
310
+		 * 
311 311
 		 * @return FormValidation Current instance of object.
312
-         */
313
-        public function setErrorDelimiter($start, $end) {
314
-            $this->_eachErrorDelimiter[0] = $start;
315
-            $this->_eachErrorDelimiter[1] = $end;
316
-            return $this;
317
-        }
318
-
319
-		/**
320
-		* Get the each errors delimiters
321
-		*
322
-		* @return array
323
-		*/
324
-    	public function getErrorDelimiter() {
325
-            return $this->_eachErrorDelimiter;
326
-        }
327
-
328
-		/**
329
-		* Get the all errors delimiters
330
-		*
331
-		* @return array
332
-		*/
333
-    	public function getErrorsDelimiter() {
334
-            return $this->_allErrorsDelimiter;
335
-        }
336
-
337
-        /**
338
-         * This sets a custom error message that can override the default error phrase provided
339
-         * by FormValidation, it can be used in the format of setMessage('rule', 'error phrase')
340
-         * which will globally change the error phrase of that rule, or in the format of:
341
-         * setMessage('rule', 'fieldname', 'error phrase') - which will only change the error phrase for
342
-         * that rule, applied on that field.
343
-         *
344
-         * @return boolean True on success, false on failure.
345
-         */
346
-        public function setMessage() {
347
-            $numArgs = func_num_args();
348
-            switch ($numArgs) {
349
-                default:
350
-                    return false;
351
-                // A global rule error message
352
-                case 2:
353
-                    foreach ($this->post(null) as $key => $val) {
354
-                        $this->_errorPhraseOverrides[$key][func_get_arg(0)] = func_get_arg(1);
355
-                    }
356
-                    break;
357
-                // Field specific rule error message
358
-                case 3:
359
-                    $this->_errorPhraseOverrides[func_get_arg(1)][func_get_arg(0)] = func_get_arg(2);
360
-                    break;
361
-            }
362
-            return true;
363
-        }
364
-
365
-        /**
366
-         * Adds a custom error message in the errorSet array, that will
367
-         * forcibly display it.
368
-         *
369
-         * @param string $inputName The form input name or data key
370
-         * @param string $errorMessage Error to display
371
-		 *
372
-         * @return formValidation Current instance of the object
373
-         */
374
-        public function setCustomError($inputName, $errorMessage) {
375
-            $errorMessage = str_replace('%1', $this->_labels[$inputName], $errorMessage);
376
-            $this->_errors[$inputName] = $errorMessage;
377
-            return $this;
378
-        }
379
-
380
-        /**
381
-         * Allows for an accesor to any/all post values, if a value of null is passed as the key, it
382
-         * will recursively find all keys/values of the $_POST array or data array. It also automatically trims
383
-         * all values.
384
-         *
385
-         * @param string $key Key of $this->data to be found, pass null for all Key => Val pairs.
386
-         * @param boolean $trim Defaults to true, trims all $this->data values.
387
-         * @return string|array Array of post or data values if null is passed as key, string if only one key is desired.
388
-         */
389
-        public function post($key = null, $trim = true) {
390
-            $returnValue = null;
391
-            if (is_null($key)) {
392
-                $returnValue = array();
393
-                foreach ($this->getData()  as $key => $val) {
394
-                    $returnValue[$key] = $this->post($key, $trim);
395
-                }
396
-            } else {
397
-                $returnValue = (array_key_exists($key, $this->getData())) ? (($trim) ? trim($this->data[$key]) : $this->data[$key]) : null;
398
-            }
399
-            return $returnValue;
400
-        }
401
-
402
-        /**
403
-         * Gets all errors from errorSet and displays them, can be echo out from the
404
-         * function or just returned.
405
-         *
406
-         * @param boolean $limit number of error to display or return
407
-         * @param boolean $echo Whether or not the values are to be returned or displayed
408
-		 *
409
-         * @return string Errors formatted for output
410
-         */
411
-        public function displayErrors($limit = null, $echo = true) {
412
-            list($errorsStart, $errorsEnd) = $this->_allErrorsDelimiter;
413
-            list($errorStart, $errorEnd) = $this->_eachErrorDelimiter;
414
-            $errorOutput = $errorsStart;
415
-    		$i = 0;
416
-            if (!empty($this->_errors)) {
417
-                foreach ($this->_errors as $fieldName => $error) {
418
-        	    	if ($i === $limit) { 
419
-                        break; 
420
-                    }
421
-                    $errorOutput .= $errorStart;
422
-                    $errorOutput .= $error;
423
-                    $errorOutput .= $errorEnd;
424
-                    $i++;
425
-                }
426
-            }
427
-            $errorOutput .= $errorsEnd;
428
-            echo ($echo) ? $errorOutput : '';
429
-            return (! $echo) ? $errorOutput : null;
430
-        }
431
-
432
-        /**
433
-         * Returns raw array of errors in no format instead of displaying them
434
-         * formatted.
435
-         *
436
-         * @return array
437
-         */
438
-        public function returnErrors() {
439
-            return $this->_errors;
440
-        }
441
-
442
-        /**
443
-         * Breaks up a PIPE seperated string of rules, and puts them into an array.
444
-         *
445
-         * @param string $ruleString String to be parsed.
446
-		 *
447
-         * @return array Array of each value in original string.
448
-         */
449
-        protected function _parseRuleString($ruleString) {
450
-            $ruleSets = array();
451
-            /*
312
+		 */
313
+		public function setErrorDelimiter($start, $end) {
314
+			$this->_eachErrorDelimiter[0] = $start;
315
+			$this->_eachErrorDelimiter[1] = $end;
316
+			return $this;
317
+		}
318
+
319
+		/**
320
+		 * Get the each errors delimiters
321
+		 *
322
+		 * @return array
323
+		 */
324
+		public function getErrorDelimiter() {
325
+			return $this->_eachErrorDelimiter;
326
+		}
327
+
328
+		/**
329
+		 * Get the all errors delimiters
330
+		 *
331
+		 * @return array
332
+		 */
333
+		public function getErrorsDelimiter() {
334
+			return $this->_allErrorsDelimiter;
335
+		}
336
+
337
+		/**
338
+		 * This sets a custom error message that can override the default error phrase provided
339
+		 * by FormValidation, it can be used in the format of setMessage('rule', 'error phrase')
340
+		 * which will globally change the error phrase of that rule, or in the format of:
341
+		 * setMessage('rule', 'fieldname', 'error phrase') - which will only change the error phrase for
342
+		 * that rule, applied on that field.
343
+		 *
344
+		 * @return boolean True on success, false on failure.
345
+		 */
346
+		public function setMessage() {
347
+			$numArgs = func_num_args();
348
+			switch ($numArgs) {
349
+				default:
350
+					return false;
351
+				// A global rule error message
352
+				case 2:
353
+					foreach ($this->post(null) as $key => $val) {
354
+						$this->_errorPhraseOverrides[$key][func_get_arg(0)] = func_get_arg(1);
355
+					}
356
+					break;
357
+				// Field specific rule error message
358
+				case 3:
359
+					$this->_errorPhraseOverrides[func_get_arg(1)][func_get_arg(0)] = func_get_arg(2);
360
+					break;
361
+			}
362
+			return true;
363
+		}
364
+
365
+		/**
366
+		 * Adds a custom error message in the errorSet array, that will
367
+		 * forcibly display it.
368
+		 *
369
+		 * @param string $inputName The form input name or data key
370
+		 * @param string $errorMessage Error to display
371
+		 *
372
+		 * @return formValidation Current instance of the object
373
+		 */
374
+		public function setCustomError($inputName, $errorMessage) {
375
+			$errorMessage = str_replace('%1', $this->_labels[$inputName], $errorMessage);
376
+			$this->_errors[$inputName] = $errorMessage;
377
+			return $this;
378
+		}
379
+
380
+		/**
381
+		 * Allows for an accesor to any/all post values, if a value of null is passed as the key, it
382
+		 * will recursively find all keys/values of the $_POST array or data array. It also automatically trims
383
+		 * all values.
384
+		 *
385
+		 * @param string $key Key of $this->data to be found, pass null for all Key => Val pairs.
386
+		 * @param boolean $trim Defaults to true, trims all $this->data values.
387
+		 * @return string|array Array of post or data values if null is passed as key, string if only one key is desired.
388
+		 */
389
+		public function post($key = null, $trim = true) {
390
+			$returnValue = null;
391
+			if (is_null($key)) {
392
+				$returnValue = array();
393
+				foreach ($this->getData()  as $key => $val) {
394
+					$returnValue[$key] = $this->post($key, $trim);
395
+				}
396
+			} else {
397
+				$returnValue = (array_key_exists($key, $this->getData())) ? (($trim) ? trim($this->data[$key]) : $this->data[$key]) : null;
398
+			}
399
+			return $returnValue;
400
+		}
401
+
402
+		/**
403
+		 * Gets all errors from errorSet and displays them, can be echo out from the
404
+		 * function or just returned.
405
+		 *
406
+		 * @param boolean $limit number of error to display or return
407
+		 * @param boolean $echo Whether or not the values are to be returned or displayed
408
+		 *
409
+		 * @return string Errors formatted for output
410
+		 */
411
+		public function displayErrors($limit = null, $echo = true) {
412
+			list($errorsStart, $errorsEnd) = $this->_allErrorsDelimiter;
413
+			list($errorStart, $errorEnd) = $this->_eachErrorDelimiter;
414
+			$errorOutput = $errorsStart;
415
+			$i = 0;
416
+			if (!empty($this->_errors)) {
417
+				foreach ($this->_errors as $fieldName => $error) {
418
+					if ($i === $limit) { 
419
+						break; 
420
+					}
421
+					$errorOutput .= $errorStart;
422
+					$errorOutput .= $error;
423
+					$errorOutput .= $errorEnd;
424
+					$i++;
425
+				}
426
+			}
427
+			$errorOutput .= $errorsEnd;
428
+			echo ($echo) ? $errorOutput : '';
429
+			return (! $echo) ? $errorOutput : null;
430
+		}
431
+
432
+		/**
433
+		 * Returns raw array of errors in no format instead of displaying them
434
+		 * formatted.
435
+		 *
436
+		 * @return array
437
+		 */
438
+		public function returnErrors() {
439
+			return $this->_errors;
440
+		}
441
+
442
+		/**
443
+		 * Breaks up a PIPE seperated string of rules, and puts them into an array.
444
+		 *
445
+		 * @param string $ruleString String to be parsed.
446
+		 *
447
+		 * @return array Array of each value in original string.
448
+		 */
449
+		protected function _parseRuleString($ruleString) {
450
+			$ruleSets = array();
451
+			/*
452 452
             //////////////// hack for regex rule that can contain "|"
453 453
             */
454
-            if(strpos($ruleString, 'regex') !== false){
455
-                $regexRule = array();
456
-                $rule = '#regex\[\/(.*)\/([a-zA-Z0-9]?)\]#';
457
-                preg_match($rule, $ruleString, $regexRule);
458
-                $ruleStringTemp = preg_replace($rule, '', $ruleString);
459
-                 if(isset($regexRule[0]) && !empty($regexRule[0])){
460
-                     $ruleSets[] = $regexRule[0];
461
-                 }
462
-                 $ruleStringRegex = explode('|', $ruleStringTemp);
463
-                foreach ($ruleStringRegex as $rule) {
464
-                    $rule = trim($rule);
465
-                    if($rule){
466
-                        $ruleSets[] = $rule;
467
-                    }
468
-                }
454
+			if(strpos($ruleString, 'regex') !== false){
455
+				$regexRule = array();
456
+				$rule = '#regex\[\/(.*)\/([a-zA-Z0-9]?)\]#';
457
+				preg_match($rule, $ruleString, $regexRule);
458
+				$ruleStringTemp = preg_replace($rule, '', $ruleString);
459
+				 if(isset($regexRule[0]) && !empty($regexRule[0])){
460
+					 $ruleSets[] = $regexRule[0];
461
+				 }
462
+				 $ruleStringRegex = explode('|', $ruleStringTemp);
463
+				foreach ($ruleStringRegex as $rule) {
464
+					$rule = trim($rule);
465
+					if($rule){
466
+						$ruleSets[] = $rule;
467
+					}
468
+				}
469 469
                  
470
-            }
471
-            /***********************************/
472
-            else{
473
-                if (strpos($ruleString, '|') !== FALSE) {
474
-                    $ruleSets = explode('|', $ruleString);
475
-                } else {
476
-                    $ruleSets[] = $ruleString;
477
-                }
478
-             }
479
-            return $ruleSets;
480
-        }
481
-
482
-        /**
483
-         * Returns whether or not a field obtains the rule "required".
484
-         *
485
-         * @param string $fieldName Field to check if required.
486
-		 *
487
-         * @return boolean Whether or not the field is required.
488
-         */
489
-        protected function _fieldIsRequired($fieldName) {
490
-            $rules = $this->_parseRuleString($this->_rules[$fieldName]);
491
-            return (in_array('required', $rules));
492
-        }
493
-
494
-        /**
495
-         * Takes a data input name, it's value, and the rule it's being validated against (ex: max_length[16])
496
-         * and adds an error to the errorSet if it fails validation of the rule.
497
-         *
498
-         * @param string $inputName Name or key of the validation data
499
-         * @param string $inputVal Value of the validation data
500
-         * @param string $ruleName Rule to be validated against, including args (exact_length[5])
501
-         * @return void
502
-         */
503
-        protected function _validateRule($inputName, $inputVal, $ruleName) {
504
-            $this->logger->debug('Rule validation of field [' .$inputName. '], value [' .$inputVal. '], rule [' .$ruleName. ']');
505
-            // Array to store args
506
-            $ruleArgs = array();
507
-
508
-            // Get the rule arguments, realRule is just the base rule name
509
-            // Like min_length instead of min_length[3]
510
-            $ruleName = preg_replace('/\[(.*)\]/', '', $ruleName);
470
+			}
471
+			/***********************************/
472
+			else{
473
+				if (strpos($ruleString, '|') !== FALSE) {
474
+					$ruleSets = explode('|', $ruleString);
475
+				} else {
476
+					$ruleSets[] = $ruleString;
477
+				}
478
+			 }
479
+			return $ruleSets;
480
+		}
481
+
482
+		/**
483
+		 * Returns whether or not a field obtains the rule "required".
484
+		 *
485
+		 * @param string $fieldName Field to check if required.
486
+		 *
487
+		 * @return boolean Whether or not the field is required.
488
+		 */
489
+		protected function _fieldIsRequired($fieldName) {
490
+			$rules = $this->_parseRuleString($this->_rules[$fieldName]);
491
+			return (in_array('required', $rules));
492
+		}
493
+
494
+		/**
495
+		 * Takes a data input name, it's value, and the rule it's being validated against (ex: max_length[16])
496
+		 * and adds an error to the errorSet if it fails validation of the rule.
497
+		 *
498
+		 * @param string $inputName Name or key of the validation data
499
+		 * @param string $inputVal Value of the validation data
500
+		 * @param string $ruleName Rule to be validated against, including args (exact_length[5])
501
+		 * @return void
502
+		 */
503
+		protected function _validateRule($inputName, $inputVal, $ruleName) {
504
+			$this->logger->debug('Rule validation of field [' .$inputName. '], value [' .$inputVal. '], rule [' .$ruleName. ']');
505
+			// Array to store args
506
+			$ruleArgs = array();
507
+
508
+			// Get the rule arguments, realRule is just the base rule name
509
+			// Like min_length instead of min_length[3]
510
+			$ruleName = preg_replace('/\[(.*)\]/', '', $ruleName);
511 511
             
512
-            if (method_exists($this, $this->_toCallCase($ruleName))) {
513
-                $methodToCall = $this->_toCallCase($ruleName);
514
-                call_user_func(array($this, $methodToCall), $inputName, $ruleName, $ruleArgs);
515
-            }
516
-
517
-            return;
518
-        }
519
-
520
-		/**
521
-		* Set error for the given field or key
522
-		*
523
-		* @param string $inputName the input or key name
524
-		* @param string $ruleName the rule name
525
-		* @param array|string $replacements
526
-		*/
527
-        protected function _setError($inputName, $ruleName, $replacements = array()) {
528
-            $rulePhraseKeyParts = explode(',', $ruleName);
529
-            $rulePhrase = null;
530
-            foreach ($rulePhraseKeyParts as $rulePhraseKeyPart) {
531
-                if (array_key_exists($rulePhraseKeyPart, $this->_errorsMessages)) {
532
-                    $rulePhrase = $this->_errorsMessages[$rulePhraseKeyPart];
533
-                } else {
534
-                    $rulePhrase = $rulePhrase[$rulePhraseKeyPart];
535
-                }
536
-            }
537
-            // Any overrides?
538
-            if (array_key_exists($inputName, $this->_errorPhraseOverrides) && array_key_exists($ruleName, $this->_errorPhraseOverrides[$inputName])) {
539
-                $rulePhrase = $this->_errorPhraseOverrides[$inputName][$ruleName];
540
-            }
541
-            // Type cast to array in case it's a string
542
-            $replacements = (array) $replacements;
512
+			if (method_exists($this, $this->_toCallCase($ruleName))) {
513
+				$methodToCall = $this->_toCallCase($ruleName);
514
+				call_user_func(array($this, $methodToCall), $inputName, $ruleName, $ruleArgs);
515
+			}
516
+
517
+			return;
518
+		}
519
+
520
+		/**
521
+		 * Set error for the given field or key
522
+		 *
523
+		 * @param string $inputName the input or key name
524
+		 * @param string $ruleName the rule name
525
+		 * @param array|string $replacements
526
+		 */
527
+		protected function _setError($inputName, $ruleName, $replacements = array()) {
528
+			$rulePhraseKeyParts = explode(',', $ruleName);
529
+			$rulePhrase = null;
530
+			foreach ($rulePhraseKeyParts as $rulePhraseKeyPart) {
531
+				if (array_key_exists($rulePhraseKeyPart, $this->_errorsMessages)) {
532
+					$rulePhrase = $this->_errorsMessages[$rulePhraseKeyPart];
533
+				} else {
534
+					$rulePhrase = $rulePhrase[$rulePhraseKeyPart];
535
+				}
536
+			}
537
+			// Any overrides?
538
+			if (array_key_exists($inputName, $this->_errorPhraseOverrides) && array_key_exists($ruleName, $this->_errorPhraseOverrides[$inputName])) {
539
+				$rulePhrase = $this->_errorPhraseOverrides[$inputName][$ruleName];
540
+			}
541
+			// Type cast to array in case it's a string
542
+			$replacements = (array) $replacements;
543 543
 			$replacementCount = count($replacements);
544
-            for ($i = 1; $i <= $replacementCount; $i++) {
545
-                $key = $i - 1;
546
-                $rulePhrase = str_replace('%' . $i, $replacements[$key], $rulePhrase);
547
-            }
548
-            if (! array_key_exists($inputName, $this->_errors)) {
549
-                $this->_errors[$inputName] = $rulePhrase;
550
-            }
551
-        }
552
-
553
-        /**
554
-         * Used to run a callback for the callback rule, as well as pass in a default
555
-         * argument of the post value. For example the username field having a rule:
556
-         * callback[userExists] will eval userExists(data[username]) - Note the use
557
-         * of eval over call_user_func is in case the function is not user defined.
558
-         *
559
-         * @param type $inputArg
560
-         * @param string $callbackFunc
561
-		 *
562
-         * @return mixed
563
-         */
564
-        protected function _runCallback($inputArg, $callbackFunc) {
544
+			for ($i = 1; $i <= $replacementCount; $i++) {
545
+				$key = $i - 1;
546
+				$rulePhrase = str_replace('%' . $i, $replacements[$key], $rulePhrase);
547
+			}
548
+			if (! array_key_exists($inputName, $this->_errors)) {
549
+				$this->_errors[$inputName] = $rulePhrase;
550
+			}
551
+		}
552
+
553
+		/**
554
+		 * Used to run a callback for the callback rule, as well as pass in a default
555
+		 * argument of the post value. For example the username field having a rule:
556
+		 * callback[userExists] will eval userExists(data[username]) - Note the use
557
+		 * of eval over call_user_func is in case the function is not user defined.
558
+		 *
559
+		 * @param type $inputArg
560
+		 * @param string $callbackFunc
561
+		 *
562
+		 * @return mixed
563
+		 */
564
+		protected function _runCallback($inputArg, $callbackFunc) {
565 565
 			return eval('return ' . $callbackFunc . '("' . $inputArg . '");');
566
-        }
567
-
568
-        /**
569
-         * Used for applying a rule only if the empty callback evaluates to true,
570
-         * for example required[funcName] - This runs funcName without passing any
571
-         * arguments.
572
-         *
573
-         * @param string $callbackFunc
574
-		 *
575
-         * @return anything
576
-         */
577
-        protected function _runEmptyCallback($callbackFunc) {
578
-            return eval('return ' . $callbackFunc . '();');
579
-        }
580
-
581
-        /**
582
-         * Gets a specific label of a specific field input name.
583
-         *
584
-         * @param string $inputName
585
-		 *
586
-         * @return string
587
-         */
588
-        protected function _getLabel($inputName) {
589
-            return (array_key_exists($inputName, $this->_labels)) ? $this->_labels[$inputName] : $inputName;
590
-        }
566
+		}
567
+
568
+		/**
569
+		 * Used for applying a rule only if the empty callback evaluates to true,
570
+		 * for example required[funcName] - This runs funcName without passing any
571
+		 * arguments.
572
+		 *
573
+		 * @param string $callbackFunc
574
+		 *
575
+		 * @return anything
576
+		 */
577
+		protected function _runEmptyCallback($callbackFunc) {
578
+			return eval('return ' . $callbackFunc . '();');
579
+		}
580
+
581
+		/**
582
+		 * Gets a specific label of a specific field input name.
583
+		 *
584
+		 * @param string $inputName
585
+		 *
586
+		 * @return string
587
+		 */
588
+		protected function _getLabel($inputName) {
589
+			return (array_key_exists($inputName, $this->_labels)) ? $this->_labels[$inputName] : $inputName;
590
+		}
591 591
 		
592
-        /**
593
-         * Peform validation for the rule "required"
594
-         * @param  string $inputName the form field or data key name used
595
-         * @param  string $ruleName  the rule name for this validation ("required")
596
-         * @param  array  $ruleArgs  the rules argument
597
-         */
592
+		/**
593
+		 * Peform validation for the rule "required"
594
+		 * @param  string $inputName the form field or data key name used
595
+		 * @param  string $ruleName  the rule name for this validation ("required")
596
+		 * @param  array  $ruleArgs  the rules argument
597
+		 */
598 598
 		protected function _validateRequired($inputName, $ruleName, array $ruleArgs) {
599
-            $inputVal = $this->post($inputName);
600
-            if(array_key_exists(1, $ruleArgs) && function_exists($ruleArgs[1])) {
601
-                $callbackReturn = $this->_runEmptyCallback($ruleArgs[1]);
602
-                if ($inputVal == '' && $callbackReturn == true) {
603
-                    $this->_setError($inputName, $ruleName, $this->_getLabel($inputName));
604
-                }
605
-            } 
599
+			$inputVal = $this->post($inputName);
600
+			if(array_key_exists(1, $ruleArgs) && function_exists($ruleArgs[1])) {
601
+				$callbackReturn = $this->_runEmptyCallback($ruleArgs[1]);
602
+				if ($inputVal == '' && $callbackReturn == true) {
603
+					$this->_setError($inputName, $ruleName, $this->_getLabel($inputName));
604
+				}
605
+			} 
606 606
 			else if($inputVal == '') {
607 607
 				$this->_setError($inputName, $ruleName, $this->_getLabel($inputName));
608
-            }
609
-        }
610
-
611
-        /**
612
-         * Perform validation for the honey pot so means for the validation to be failed
613
-         * @param  string $inputName the form field or data key name used
614
-         * @param  string $ruleName  the rule name for this validation
615
-         * @param  array  $ruleArgs  the rules argument
616
-         */
617
-        protected function _validateHoneypot($inputName, $ruleName, array $ruleArgs) {
618
-            if ($this->data[$inputName] != '') {
619
-                $this->_forceFail = true;
620
-            }
621
-        }
622
-
623
-        /**
624
-         * Peform validation for the rule "callback"
625
-         * @param  string $inputName the form field or data key name used
626
-         * @param  string $ruleName  the rule name for this validation ("callback")
627
-         * @param  array  $ruleArgs  the rules argument
628
-         */
629
-        protected function _validateCallback($inputName, $ruleName, array $ruleArgs) {
630
-            if (function_exists($ruleArgs[1]) && !empty($this->data[$inputName])) {
608
+			}
609
+		}
610
+
611
+		/**
612
+		 * Perform validation for the honey pot so means for the validation to be failed
613
+		 * @param  string $inputName the form field or data key name used
614
+		 * @param  string $ruleName  the rule name for this validation
615
+		 * @param  array  $ruleArgs  the rules argument
616
+		 */
617
+		protected function _validateHoneypot($inputName, $ruleName, array $ruleArgs) {
618
+			if ($this->data[$inputName] != '') {
619
+				$this->_forceFail = true;
620
+			}
621
+		}
622
+
623
+		/**
624
+		 * Peform validation for the rule "callback"
625
+		 * @param  string $inputName the form field or data key name used
626
+		 * @param  string $ruleName  the rule name for this validation ("callback")
627
+		 * @param  array  $ruleArgs  the rules argument
628
+		 */
629
+		protected function _validateCallback($inputName, $ruleName, array $ruleArgs) {
630
+			if (function_exists($ruleArgs[1]) && !empty($this->data[$inputName])) {
631 631
 				$result = $this->_runCallback($this->data[$inputName], $ruleArgs[1]);
632 632
 				if(! $result){
633 633
 					$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
634 634
 				}
635
-            }
636
-        }
637
-
638
-        /**
639
-         * Peform validation for the rule "depends"
640
-         * @param  string $inputName the form field or data key name used
641
-         * @param  string $ruleName  the rule name for this validation ("depends")
642
-         * @param  array  $ruleArgs  the rules argument
643
-         */
644
-        protected function _validateDepends($inputName, $ruleName, array $ruleArgs) {
645
-            if (array_key_exists($ruleArgs[1], $this->_errors)) {
646
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
647
-            }
648
-        }
649
-
650
-        /**
651
-         * Peform validation for the rule "not_equal"
652
-         * @param  string $inputName the form field or data key name used
653
-         * @param  string $ruleName  the rule name for this validation ("not_equal")
654
-         * @param  array  $ruleArgs  the rules argument
655
-         */
656
-        protected function _validateNotEqual($inputName, $ruleName, array $ruleArgs) {
657
-            $canNotEqual = explode(',', $ruleArgs[1]);
658
-            foreach ($canNotEqual as $doNotEqual) {
659
-                $inputVal = $this->post($inputName);
660
-                if (preg_match('/post:(.*)/', $doNotEqual)) {
661
-                    if ($inputVal == $this->data[str_replace('post:', '', $doNotEqual)]) {
662
-                        $this->_setError($inputName, $ruleName . ',post:key', array($this->_getLabel($inputName), $this->_getLabel(str_replace('post:', '', $doNotEqual))));
663
-                        continue;
664
-                    }
665
-                } 
635
+			}
636
+		}
637
+
638
+		/**
639
+		 * Peform validation for the rule "depends"
640
+		 * @param  string $inputName the form field or data key name used
641
+		 * @param  string $ruleName  the rule name for this validation ("depends")
642
+		 * @param  array  $ruleArgs  the rules argument
643
+		 */
644
+		protected function _validateDepends($inputName, $ruleName, array $ruleArgs) {
645
+			if (array_key_exists($ruleArgs[1], $this->_errors)) {
646
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
647
+			}
648
+		}
649
+
650
+		/**
651
+		 * Peform validation for the rule "not_equal"
652
+		 * @param  string $inputName the form field or data key name used
653
+		 * @param  string $ruleName  the rule name for this validation ("not_equal")
654
+		 * @param  array  $ruleArgs  the rules argument
655
+		 */
656
+		protected function _validateNotEqual($inputName, $ruleName, array $ruleArgs) {
657
+			$canNotEqual = explode(',', $ruleArgs[1]);
658
+			foreach ($canNotEqual as $doNotEqual) {
659
+				$inputVal = $this->post($inputName);
660
+				if (preg_match('/post:(.*)/', $doNotEqual)) {
661
+					if ($inputVal == $this->data[str_replace('post:', '', $doNotEqual)]) {
662
+						$this->_setError($inputName, $ruleName . ',post:key', array($this->_getLabel($inputName), $this->_getLabel(str_replace('post:', '', $doNotEqual))));
663
+						continue;
664
+					}
665
+				} 
666 666
 				else{
667
-                    if ($inputVal == $doNotEqual) {
668
-                        $this->_setError($inputName, $ruleName . ',string', array($this->_getLabel($inputName), $doNotEqual));
669
-                        continue;
670
-                    }
671
-                }
672
-            }
673
-        }
674
-
675
-        /**
676
-         * Peform validation for the rule "matches"
677
-         * @param  string $inputName the form field or data key name used
678
-         * @param  string $ruleName  the rule name for this validation ("matches")
679
-         * @param  array  $ruleArgs  the rules argument
680
-         */
681
-        protected function _validateMatches($inputName, $ruleName, array $ruleArgs) {
682
-            $inputVal = $this->post($inputName);
683
-            if ($inputVal != $this->data[$ruleArgs[1]]) {
684
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
685
-            }
686
-        }
687
-
688
-        /**
689
-         * Peform validation for the rule "valid_email"
690
-         * @param  string $inputName the form field or data key name used
691
-         * @param  string $ruleName  the rule name for this validation ("valid_email")
692
-         * @param  array  $ruleArgs  the rules argument
693
-         */
694
-        protected function _validateValidEmail($inputName, $ruleName, array $ruleArgs) {
695
-            $inputVal = $this->post($inputName);
696
-            if (! preg_match("/^([\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+\.)*[\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+@((((([a-z0-9]{1}[a-z0-9\-]{0,62}[a-z0-9]{1})|[a-z])\.)+[a-z]{2,6})|(\d{1,3}\.){3}\d{1,3}(\:\d{1,5})?)$/i", $inputVal)) {
697
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
698
-                    return;
699
-                }
700
-                $this->_setError($inputName, $ruleName, $this->_getLabel($inputName));
701
-            }
702
-        }
703
-
704
-        /**
705
-         * Peform validation for the rule "exact_length"
706
-         * @param  string $inputName the form field or data key name used
707
-         * @param  string $ruleName  the rule name for this validation ("exact_length")
708
-         * @param  array  $ruleArgs  the rules argument
709
-         */
710
-        protected function _validateExactLength($inputName, $ruleName, array $ruleArgs) {
711
-            $inputVal = $this->post($inputName);
712
-            if (strlen($inputVal) != $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
713
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
714
-                    return;
715
-                }
716
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
717
-            }
718
-        }
719
-
720
-        /**
721
-         * Peform validation for the rule "max_length"
722
-         * @param  string $inputName the form field or data key name used
723
-         * @param  string $ruleName  the rule name for this validation ("max_length")
724
-         * @param  array  $ruleArgs  the rules argument
725
-         */
726
-        protected function _validateMaxLength($inputName, $ruleName, array $ruleArgs) {
727
-            $inputVal = $this->post($inputName);
728
-            if (strlen($inputVal) > $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
729
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
730
-                    return;
731
-                }
732
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
733
-            }
734
-        }
735
-
736
-        /**
737
-         * Peform validation for the rule "min_length"
738
-         * @param  string $inputName the form field or data key name used
739
-         * @param  string $ruleName  the rule name for this validation ("min_length")
740
-         * @param  array  $ruleArgs  the rules argument
741
-         */
742
-        protected function _validateMinLength($inputName, $ruleName, array $ruleArgs) {
743
-            $inputVal = $this->post($inputName);
744
-            if (strlen($inputVal) < $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
745
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
746
-                    return;
747
-                }
748
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
749
-            }
750
-        }
667
+					if ($inputVal == $doNotEqual) {
668
+						$this->_setError($inputName, $ruleName . ',string', array($this->_getLabel($inputName), $doNotEqual));
669
+						continue;
670
+					}
671
+				}
672
+			}
673
+		}
674
+
675
+		/**
676
+		 * Peform validation for the rule "matches"
677
+		 * @param  string $inputName the form field or data key name used
678
+		 * @param  string $ruleName  the rule name for this validation ("matches")
679
+		 * @param  array  $ruleArgs  the rules argument
680
+		 */
681
+		protected function _validateMatches($inputName, $ruleName, array $ruleArgs) {
682
+			$inputVal = $this->post($inputName);
683
+			if ($inputVal != $this->data[$ruleArgs[1]]) {
684
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
685
+			}
686
+		}
687
+
688
+		/**
689
+		 * Peform validation for the rule "valid_email"
690
+		 * @param  string $inputName the form field or data key name used
691
+		 * @param  string $ruleName  the rule name for this validation ("valid_email")
692
+		 * @param  array  $ruleArgs  the rules argument
693
+		 */
694
+		protected function _validateValidEmail($inputName, $ruleName, array $ruleArgs) {
695
+			$inputVal = $this->post($inputName);
696
+			if (! preg_match("/^([\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+\.)*[\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+@((((([a-z0-9]{1}[a-z0-9\-]{0,62}[a-z0-9]{1})|[a-z])\.)+[a-z]{2,6})|(\d{1,3}\.){3}\d{1,3}(\:\d{1,5})?)$/i", $inputVal)) {
697
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
698
+					return;
699
+				}
700
+				$this->_setError($inputName, $ruleName, $this->_getLabel($inputName));
701
+			}
702
+		}
703
+
704
+		/**
705
+		 * Peform validation for the rule "exact_length"
706
+		 * @param  string $inputName the form field or data key name used
707
+		 * @param  string $ruleName  the rule name for this validation ("exact_length")
708
+		 * @param  array  $ruleArgs  the rules argument
709
+		 */
710
+		protected function _validateExactLength($inputName, $ruleName, array $ruleArgs) {
711
+			$inputVal = $this->post($inputName);
712
+			if (strlen($inputVal) != $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
713
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
714
+					return;
715
+				}
716
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
717
+			}
718
+		}
719
+
720
+		/**
721
+		 * Peform validation for the rule "max_length"
722
+		 * @param  string $inputName the form field or data key name used
723
+		 * @param  string $ruleName  the rule name for this validation ("max_length")
724
+		 * @param  array  $ruleArgs  the rules argument
725
+		 */
726
+		protected function _validateMaxLength($inputName, $ruleName, array $ruleArgs) {
727
+			$inputVal = $this->post($inputName);
728
+			if (strlen($inputVal) > $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
729
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
730
+					return;
731
+				}
732
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
733
+			}
734
+		}
735
+
736
+		/**
737
+		 * Peform validation for the rule "min_length"
738
+		 * @param  string $inputName the form field or data key name used
739
+		 * @param  string $ruleName  the rule name for this validation ("min_length")
740
+		 * @param  array  $ruleArgs  the rules argument
741
+		 */
742
+		protected function _validateMinLength($inputName, $ruleName, array $ruleArgs) {
743
+			$inputVal = $this->post($inputName);
744
+			if (strlen($inputVal) < $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
745
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
746
+					return;
747
+				}
748
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
749
+			}
750
+		}
751 751
     	
752
-        /**
753
-         * Peform validation for the rule "less_than"
754
-         * @param  string $inputName the form field or data key name used
755
-         * @param  string $ruleName  the rule name for this validation ("less_than")
756
-         * @param  array  $ruleArgs  the rules argument
757
-         */
758
-    	protected function _validateLessThan($inputName, $ruleName, array $ruleArgs) {
759
-            $inputVal = $this->post($inputName);
760
-            if ($inputVal >= $ruleArgs[1]) { 
761
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
762
-                    return;
763
-                }
764
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
765
-            }
766
-        }
752
+		/**
753
+		 * Peform validation for the rule "less_than"
754
+		 * @param  string $inputName the form field or data key name used
755
+		 * @param  string $ruleName  the rule name for this validation ("less_than")
756
+		 * @param  array  $ruleArgs  the rules argument
757
+		 */
758
+		protected function _validateLessThan($inputName, $ruleName, array $ruleArgs) {
759
+			$inputVal = $this->post($inputName);
760
+			if ($inputVal >= $ruleArgs[1]) { 
761
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
762
+					return;
763
+				}
764
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
765
+			}
766
+		}
767 767
     	
768
-        /**
769
-         * Peform validation for the rule "greater_than"
770
-         * @param  string $inputName the form field or data key name used
771
-         * @param  string $ruleName  the rule name for this validation ("greater_than")
772
-         * @param  array  $ruleArgs  the rules argument
773
-         */
774
-    	protected function _validateGreaterThan($inputName, $ruleName, array $ruleArgs) {
775
-            $inputVal = $this->post($inputName);
776
-            if ($inputVal <= $ruleArgs[1]) {
777
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
778
-                    return;
779
-                }
780
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
781
-            }
782
-        }
768
+		/**
769
+		 * Peform validation for the rule "greater_than"
770
+		 * @param  string $inputName the form field or data key name used
771
+		 * @param  string $ruleName  the rule name for this validation ("greater_than")
772
+		 * @param  array  $ruleArgs  the rules argument
773
+		 */
774
+		protected function _validateGreaterThan($inputName, $ruleName, array $ruleArgs) {
775
+			$inputVal = $this->post($inputName);
776
+			if ($inputVal <= $ruleArgs[1]) {
777
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
778
+					return;
779
+				}
780
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
781
+			}
782
+		}
783 783
     	
784
-        /**
785
-         * Peform validation for the rule "numeric"
786
-         * @param  string $inputName the form field or data key name used
787
-         * @param  string $ruleName  the rule name for this validation ("numeric")
788
-         * @param  array  $ruleArgs  the rules argument
789
-         */
790
-    	protected function _validateNumeric($inputName, $ruleName, array $ruleArgs) {
791
-            $inputVal = $this->post($inputName);
792
-            if (! is_numeric($inputVal)) {
793
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
794
-                    return;
795
-                }
796
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
797
-            }
798
-        }
784
+		/**
785
+		 * Peform validation for the rule "numeric"
786
+		 * @param  string $inputName the form field or data key name used
787
+		 * @param  string $ruleName  the rule name for this validation ("numeric")
788
+		 * @param  array  $ruleArgs  the rules argument
789
+		 */
790
+		protected function _validateNumeric($inputName, $ruleName, array $ruleArgs) {
791
+			$inputVal = $this->post($inputName);
792
+			if (! is_numeric($inputVal)) {
793
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
794
+					return;
795
+				}
796
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
797
+			}
798
+		}
799 799
 		
800
-        /**
801
-         * Peform validation for the rule "exists"
802
-         * @param  string $inputName the form field or data key name used
803
-         * @param  string $ruleName  the rule name for this validation ("exists")
804
-         * @param  array  $ruleArgs  the rules argument
805
-         */
800
+		/**
801
+		 * Peform validation for the rule "exists"
802
+		 * @param  string $inputName the form field or data key name used
803
+		 * @param  string $ruleName  the rule name for this validation ("exists")
804
+		 * @param  array  $ruleArgs  the rules argument
805
+		 */
806 806
 		protected function _validateExists($inputName, $ruleName, array $ruleArgs) {
807
-            $inputVal = $this->post($inputName);
808
-    		$obj = & get_instance();
809
-    		if(! isset($obj->database)){
810
-    			return;
811
-    		}
812
-    		list($table, $column) = explode('.', $ruleArgs[1]);
813
-    		$obj->database->from($table)
814
-    			          ->where($column, $inputVal)
815
-    			          ->get();
816
-    		$nb = $obj->database->numRows();
817
-            if ($nb == 0) {
818
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
819
-                    return;
820
-                }
821
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
822
-            }
823
-        }
824
-
825
-        /**
826
-         * Peform validation for the rule "is_unique"
827
-         * @param  string $inputName the form field or data key name used
828
-         * @param  string $ruleName  the rule name for this validation ("is_unique")
829
-         * @param  array  $ruleArgs  the rules argument
830
-         */
831
-    	protected function _validateIsUnique($inputName, $ruleName, array $ruleArgs) {
832
-            $inputVal = $this->post($inputName);
833
-    		$obj = & get_instance();
834
-    		if(! isset($obj->database)){
835
-    			return;
836
-    		}
837
-    		list($table, $column) = explode('.', $ruleArgs[1]);
838
-    		$obj->database->from($table)
839
-    			          ->where($column, $inputVal)
840
-    			          ->get();
841
-    		$nb = $obj->database->numRows();
842
-            if ($nb != 0) {
843
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
844
-                    return;
845
-                }
846
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
847
-            }
848
-        }
807
+			$inputVal = $this->post($inputName);
808
+			$obj = & get_instance();
809
+			if(! isset($obj->database)){
810
+				return;
811
+			}
812
+			list($table, $column) = explode('.', $ruleArgs[1]);
813
+			$obj->database->from($table)
814
+						  ->where($column, $inputVal)
815
+						  ->get();
816
+			$nb = $obj->database->numRows();
817
+			if ($nb == 0) {
818
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
819
+					return;
820
+				}
821
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
822
+			}
823
+		}
824
+
825
+		/**
826
+		 * Peform validation for the rule "is_unique"
827
+		 * @param  string $inputName the form field or data key name used
828
+		 * @param  string $ruleName  the rule name for this validation ("is_unique")
829
+		 * @param  array  $ruleArgs  the rules argument
830
+		 */
831
+		protected function _validateIsUnique($inputName, $ruleName, array $ruleArgs) {
832
+			$inputVal = $this->post($inputName);
833
+			$obj = & get_instance();
834
+			if(! isset($obj->database)){
835
+				return;
836
+			}
837
+			list($table, $column) = explode('.', $ruleArgs[1]);
838
+			$obj->database->from($table)
839
+						  ->where($column, $inputVal)
840
+						  ->get();
841
+			$nb = $obj->database->numRows();
842
+			if ($nb != 0) {
843
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
844
+					return;
845
+				}
846
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
847
+			}
848
+		}
849 849
     	
850
-        /**
851
-         * Peform validation for the rule "is_unique_update"
852
-         * @param  string $inputName the form field or data key name used
853
-         * @param  string $ruleName  the rule name for this validation ("is_unique_update")
854
-         * @param  array  $ruleArgs  the rules argument
855
-         */
856
-    	protected function _validateIsUniqueUpdate($inputName, $ruleName, array $ruleArgs) {
857
-            $inputVal = $this->post($inputName);
858
-    		$obj = & get_instance();
859
-    		if(! isset($obj->database)){
860
-    			return;
861
-    		}
862
-    		$data = explode(',', $ruleArgs[1]);
863
-    		if(count($data) < 2){
864
-    			return;
865
-    		}
866
-    		list($table, $column) = explode('.', $data[0]);
867
-    		list($field, $val) = explode('=', $data[1]);
868
-    		$obj->database->from($table)
869
-    			          ->where($column, $inputVal)
870
-                		  ->where($field, '!=', trim($val))
871
-                		  ->get();
872
-    		$nb = $obj->database->numRows();
873
-            if ($nb != 0) {
874
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
875
-                    return;
876
-                }
877
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
878
-            }
879
-        }
880
-
881
-        /**
882
-         * Peform validation for the rule "in_list"
883
-         * @param  string $inputName the form field or data key name used
884
-         * @param  string $ruleName  the rule name for this validation ("in_list")
885
-         * @param  array  $ruleArgs  the rules argument
886
-         */
887
-        protected function _validateInList($inputName, $ruleName, array $ruleArgs) {
888
-            $inputVal = $this->post($inputName);
889
-    		$list = explode(',', $ruleArgs[1]);
890
-            $list = array_map('trim', $list);
891
-            if (! in_array($inputVal, $list)) {
892
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
893
-                    return;
894
-                }
895
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
896
-            }
897
-        }
898
-
899
-        /**
900
-         * Peform validation for the rule "regex"
901
-         * @param  string $inputName the form field or data key name used
902
-         * @param  string $ruleName  the rule name for this validation ("regex")
903
-         * @param  array  $ruleArgs  the rules argument
904
-         */
905
-        protected function _validateRegex($inputName, $ruleName, array $ruleArgs) {
906
-            $inputVal = $this->post($inputName);
907
-    		$regex = $ruleArgs[1];
908
-            if (! preg_match($regex, $inputVal)) {
909
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
910
-                    return;
911
-                }
912
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
913
-            }
914
-        }
850
+		/**
851
+		 * Peform validation for the rule "is_unique_update"
852
+		 * @param  string $inputName the form field or data key name used
853
+		 * @param  string $ruleName  the rule name for this validation ("is_unique_update")
854
+		 * @param  array  $ruleArgs  the rules argument
855
+		 */
856
+		protected function _validateIsUniqueUpdate($inputName, $ruleName, array $ruleArgs) {
857
+			$inputVal = $this->post($inputName);
858
+			$obj = & get_instance();
859
+			if(! isset($obj->database)){
860
+				return;
861
+			}
862
+			$data = explode(',', $ruleArgs[1]);
863
+			if(count($data) < 2){
864
+				return;
865
+			}
866
+			list($table, $column) = explode('.', $data[0]);
867
+			list($field, $val) = explode('=', $data[1]);
868
+			$obj->database->from($table)
869
+						  ->where($column, $inputVal)
870
+						  ->where($field, '!=', trim($val))
871
+						  ->get();
872
+			$nb = $obj->database->numRows();
873
+			if ($nb != 0) {
874
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
875
+					return;
876
+				}
877
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
878
+			}
879
+		}
880
+
881
+		/**
882
+		 * Peform validation for the rule "in_list"
883
+		 * @param  string $inputName the form field or data key name used
884
+		 * @param  string $ruleName  the rule name for this validation ("in_list")
885
+		 * @param  array  $ruleArgs  the rules argument
886
+		 */
887
+		protected function _validateInList($inputName, $ruleName, array $ruleArgs) {
888
+			$inputVal = $this->post($inputName);
889
+			$list = explode(',', $ruleArgs[1]);
890
+			$list = array_map('trim', $list);
891
+			if (! in_array($inputVal, $list)) {
892
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
893
+					return;
894
+				}
895
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
896
+			}
897
+		}
898
+
899
+		/**
900
+		 * Peform validation for the rule "regex"
901
+		 * @param  string $inputName the form field or data key name used
902
+		 * @param  string $ruleName  the rule name for this validation ("regex")
903
+		 * @param  array  $ruleArgs  the rules argument
904
+		 */
905
+		protected function _validateRegex($inputName, $ruleName, array $ruleArgs) {
906
+			$inputVal = $this->post($inputName);
907
+			$regex = $ruleArgs[1];
908
+			if (! preg_match($regex, $inputVal)) {
909
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
910
+					return;
911
+				}
912
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
913
+			}
914
+		}
915 915
         
916
-    }
916
+	}
Please login to merge, or discard this patch.
Spacing   +53 added lines, -53 removed lines patch added patch discarded remove patch
@@ -25,13 +25,13 @@  discard block
 block discarded – undo
25 25
     */
26 26
 
27 27
 
28
-     class FormValidation{
28
+     class FormValidation {
29 29
 		 
30 30
         /**
31 31
          * The form validation status
32 32
          * @var boolean
33 33
          */
34
-        protected $_success  = false;
34
+        protected $_success = false;
35 35
 
36 36
         /**
37 37
          * The list of errors messages
@@ -40,31 +40,31 @@  discard block
 block discarded – undo
40 40
         protected $_errorsMessages = array();
41 41
         
42 42
         // Array of rule sets, fieldName => PIPE seperated ruleString
43
-        protected $_rules             = array();
43
+        protected $_rules = array();
44 44
         
45 45
         // Array of errors, niceName => Error Message
46
-        protected $_errors             = array();
46
+        protected $_errors = array();
47 47
         
48 48
         // Array of post Key => Nice name labels
49
-        protected $_labels          = array();
49
+        protected $_labels = array();
50 50
         
51 51
         /**
52 52
          * The errors delimiters
53 53
          * @var array
54 54
          */
55
-        protected $_allErrorsDelimiter   = array('<div class="error">', '</div>');
55
+        protected $_allErrorsDelimiter = array('<div class="error">', '</div>');
56 56
 
57 57
         /**
58 58
          * The each error delimiter
59 59
          * @var array
60 60
          */
61
-        protected $_eachErrorDelimiter   = array('<p class="error">', '</p>');
61
+        protected $_eachErrorDelimiter = array('<p class="error">', '</p>');
62 62
         
63 63
 		/**
64 64
          * Indicated if need force the validation to be failed
65 65
          * @var boolean
66 66
          */
67
-        protected $_forceFail            = false;
67
+        protected $_forceFail = false;
68 68
 
69 69
         /**
70 70
          * The list of the error messages overrides by the original
@@ -98,13 +98,13 @@  discard block
 block discarded – undo
98 98
          * @return void
99 99
          */
100 100
         public function __construct() {
101
-            $this->logger =& class_loader('Log', 'classes');
101
+            $this->logger = & class_loader('Log', 'classes');
102 102
             $this->logger->setLogger('Library::FormValidation');
103 103
            
104 104
 		   //Load form validation language message
105 105
             Loader::lang('form_validation');
106 106
             $obj = & get_instance();
107
-            $this->_errorsMessages  = array(
107
+            $this->_errorsMessages = array(
108 108
                         'required'         => $obj->lang->get('fv_required'),
109 109
                         'min_length'       => $obj->lang->get('fv_min_length'),
110 110
                         'max_length'       => $obj->lang->get('fv_max_length'),
@@ -141,7 +141,7 @@  discard block
 block discarded – undo
141 141
             $this->_success              = false;
142 142
             $this->_forceFail            = false;
143 143
             $this->data                  = array();
144
-			$this->enableCsrfCheck       = false;
144
+			$this->enableCsrfCheck = false;
145 145
         }
146 146
 
147 147
         /**
@@ -150,7 +150,7 @@  discard block
 block discarded – undo
150 150
 		 *
151 151
          * @return FormValidation Current instance of object.
152 152
          */
153
-        public function setData(array $data){
153
+        public function setData(array $data) {
154 154
             $this->logger->debug('Setting the form validation data, the values are: ' . stringfy_vars($data));
155 155
             $this->data = $data;
156 156
 			return $this;
@@ -160,7 +160,7 @@  discard block
 block discarded – undo
160 160
          * Get the form validation data
161 161
          * @return array the form validation data to be validated
162 162
          */
163
-        public function getData(){
163
+        public function getData() {
164 164
             return $this->data;
165 165
         }
166 166
 
@@ -169,7 +169,7 @@  discard block
 block discarded – undo
169 169
 		*
170 170
 		* @return string the function name
171 171
 		*/
172
-        protected function _toCallCase($funcName, $prefix='_validate') {
172
+        protected function _toCallCase($funcName, $prefix = '_validate') {
173 173
             $funcName = strtolower($funcName);
174 174
             $finalFuncName = $prefix;
175 175
             foreach (explode('_', $funcName) as $funcNamePart) {
@@ -193,7 +193,7 @@  discard block
 block discarded – undo
193 193
          * @return boolean Whether or not the form has been submitted or the data is available for validation.
194 194
          */
195 195
         public function canDoValidation() {
196
-            return get_instance()->request->method() === 'POST' || ! empty($this->data);
196
+            return get_instance()->request->method() === 'POST' || !empty($this->data);
197 197
         }
198 198
 
199 199
         /**
@@ -215,16 +215,16 @@  discard block
 block discarded – undo
215 215
          * afterwards.
216 216
          */
217 217
         protected function _run() {
218
-            if(get_instance()->request->method() == 'POST' || $this->enableCsrfCheck){
218
+            if (get_instance()->request->method() == 'POST' || $this->enableCsrfCheck) {
219 219
                 $this->logger->debug('Check if CSRF is enabled in configuration');
220 220
                 //first check for CSRF
221
-                if( get_config('csrf_enable', false) || $this->enableCsrfCheck){
221
+                if (get_config('csrf_enable', false) || $this->enableCsrfCheck) {
222 222
                      $this->logger->info('Check the CSRF value if is valid');
223
-                    if(! Security::validateCSRF()){
223
+                    if (!Security::validateCSRF()) {
224 224
                         show_error('Invalide data, Cross Site Request Forgery do his job, the data to validate is corrupted.');
225 225
                     }
226 226
                 }
227
-                else{
227
+                else {
228 228
                     $this->logger->info('CSRF is not enabled in configuration or not set manully, no need to check it');
229 229
                 }
230 230
             }
@@ -232,10 +232,10 @@  discard block
 block discarded – undo
232 232
             $this->_forceFail = false;
233 233
 
234 234
             foreach ($this->getData() as $inputName => $inputVal) {
235
-    			if(is_array($this->data[$inputName])){
235
+    			if (is_array($this->data[$inputName])) {
236 236
     				$this->data[$inputName] = array_map('trim', $this->data[$inputName]);
237 237
     			}
238
-    			else{
238
+    			else {
239 239
     				$this->data[$inputName] = trim($this->data[$inputName]);
240 240
     			}
241 241
 
@@ -262,7 +262,7 @@  discard block
 block discarded – undo
262 262
         public function setRule($inputField, $inputLabel, $ruleSets) {
263 263
             $this->_rules[$inputField] = $ruleSets;
264 264
             $this->_labels[$inputField] = $inputLabel;
265
-            $this->logger->info('Set the field rule: name [' .$inputField. '], label [' .$inputLabel. '], rules [' .$ruleSets. ']');
265
+            $this->logger->info('Set the field rule: name [' . $inputField . '], label [' . $inputLabel . '], rules [' . $ruleSets . ']');
266 266
             return $this;
267 267
         }
268 268
 
@@ -426,7 +426,7 @@  discard block
 block discarded – undo
426 426
             }
427 427
             $errorOutput .= $errorsEnd;
428 428
             echo ($echo) ? $errorOutput : '';
429
-            return (! $echo) ? $errorOutput : null;
429
+            return (!$echo) ? $errorOutput : null;
430 430
         }
431 431
 
432 432
         /**
@@ -451,25 +451,25 @@  discard block
 block discarded – undo
451 451
             /*
452 452
             //////////////// hack for regex rule that can contain "|"
453 453
             */
454
-            if(strpos($ruleString, 'regex') !== false){
454
+            if (strpos($ruleString, 'regex') !== false) {
455 455
                 $regexRule = array();
456 456
                 $rule = '#regex\[\/(.*)\/([a-zA-Z0-9]?)\]#';
457 457
                 preg_match($rule, $ruleString, $regexRule);
458 458
                 $ruleStringTemp = preg_replace($rule, '', $ruleString);
459
-                 if(isset($regexRule[0]) && !empty($regexRule[0])){
459
+                 if (isset($regexRule[0]) && !empty($regexRule[0])) {
460 460
                      $ruleSets[] = $regexRule[0];
461 461
                  }
462 462
                  $ruleStringRegex = explode('|', $ruleStringTemp);
463 463
                 foreach ($ruleStringRegex as $rule) {
464 464
                     $rule = trim($rule);
465
-                    if($rule){
465
+                    if ($rule) {
466 466
                         $ruleSets[] = $rule;
467 467
                     }
468 468
                 }
469 469
                  
470 470
             }
471 471
             /***********************************/
472
-            else{
472
+            else {
473 473
                 if (strpos($ruleString, '|') !== FALSE) {
474 474
                     $ruleSets = explode('|', $ruleString);
475 475
                 } else {
@@ -501,7 +501,7 @@  discard block
 block discarded – undo
501 501
          * @return void
502 502
          */
503 503
         protected function _validateRule($inputName, $inputVal, $ruleName) {
504
-            $this->logger->debug('Rule validation of field [' .$inputName. '], value [' .$inputVal. '], rule [' .$ruleName. ']');
504
+            $this->logger->debug('Rule validation of field [' . $inputName . '], value [' . $inputVal . '], rule [' . $ruleName . ']');
505 505
             // Array to store args
506 506
             $ruleArgs = array();
507 507
 
@@ -545,7 +545,7 @@  discard block
 block discarded – undo
545 545
                 $key = $i - 1;
546 546
                 $rulePhrase = str_replace('%' . $i, $replacements[$key], $rulePhrase);
547 547
             }
548
-            if (! array_key_exists($inputName, $this->_errors)) {
548
+            if (!array_key_exists($inputName, $this->_errors)) {
549 549
                 $this->_errors[$inputName] = $rulePhrase;
550 550
             }
551 551
         }
@@ -597,13 +597,13 @@  discard block
 block discarded – undo
597 597
          */
598 598
 		protected function _validateRequired($inputName, $ruleName, array $ruleArgs) {
599 599
             $inputVal = $this->post($inputName);
600
-            if(array_key_exists(1, $ruleArgs) && function_exists($ruleArgs[1])) {
600
+            if (array_key_exists(1, $ruleArgs) && function_exists($ruleArgs[1])) {
601 601
                 $callbackReturn = $this->_runEmptyCallback($ruleArgs[1]);
602 602
                 if ($inputVal == '' && $callbackReturn == true) {
603 603
                     $this->_setError($inputName, $ruleName, $this->_getLabel($inputName));
604 604
                 }
605 605
             } 
606
-			else if($inputVal == '') {
606
+			else if ($inputVal == '') {
607 607
 				$this->_setError($inputName, $ruleName, $this->_getLabel($inputName));
608 608
             }
609 609
         }
@@ -629,7 +629,7 @@  discard block
 block discarded – undo
629 629
         protected function _validateCallback($inputName, $ruleName, array $ruleArgs) {
630 630
             if (function_exists($ruleArgs[1]) && !empty($this->data[$inputName])) {
631 631
 				$result = $this->_runCallback($this->data[$inputName], $ruleArgs[1]);
632
-				if(! $result){
632
+				if (!$result) {
633 633
 					$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
634 634
 				}
635 635
             }
@@ -663,7 +663,7 @@  discard block
 block discarded – undo
663 663
                         continue;
664 664
                     }
665 665
                 } 
666
-				else{
666
+				else {
667 667
                     if ($inputVal == $doNotEqual) {
668 668
                         $this->_setError($inputName, $ruleName . ',string', array($this->_getLabel($inputName), $doNotEqual));
669 669
                         continue;
@@ -693,8 +693,8 @@  discard block
 block discarded – undo
693 693
          */
694 694
         protected function _validateValidEmail($inputName, $ruleName, array $ruleArgs) {
695 695
             $inputVal = $this->post($inputName);
696
-            if (! preg_match("/^([\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+\.)*[\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+@((((([a-z0-9]{1}[a-z0-9\-]{0,62}[a-z0-9]{1})|[a-z])\.)+[a-z]{2,6})|(\d{1,3}\.){3}\d{1,3}(\:\d{1,5})?)$/i", $inputVal)) {
697
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
696
+            if (!preg_match("/^([\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+\.)*[\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+@((((([a-z0-9]{1}[a-z0-9\-]{0,62}[a-z0-9]{1})|[a-z])\.)+[a-z]{2,6})|(\d{1,3}\.){3}\d{1,3}(\:\d{1,5})?)$/i", $inputVal)) {
697
+                if (!$this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
698 698
                     return;
699 699
                 }
700 700
                 $this->_setError($inputName, $ruleName, $this->_getLabel($inputName));
@@ -710,7 +710,7 @@  discard block
 block discarded – undo
710 710
         protected function _validateExactLength($inputName, $ruleName, array $ruleArgs) {
711 711
             $inputVal = $this->post($inputName);
712 712
             if (strlen($inputVal) != $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
713
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
713
+                if (!$this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
714 714
                     return;
715 715
                 }
716 716
                 $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
@@ -726,7 +726,7 @@  discard block
 block discarded – undo
726 726
         protected function _validateMaxLength($inputName, $ruleName, array $ruleArgs) {
727 727
             $inputVal = $this->post($inputName);
728 728
             if (strlen($inputVal) > $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
729
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
729
+                if (!$this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
730 730
                     return;
731 731
                 }
732 732
                 $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
@@ -742,7 +742,7 @@  discard block
 block discarded – undo
742 742
         protected function _validateMinLength($inputName, $ruleName, array $ruleArgs) {
743 743
             $inputVal = $this->post($inputName);
744 744
             if (strlen($inputVal) < $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
745
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
745
+                if (!$this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
746 746
                     return;
747 747
                 }
748 748
                 $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
@@ -758,7 +758,7 @@  discard block
 block discarded – undo
758 758
     	protected function _validateLessThan($inputName, $ruleName, array $ruleArgs) {
759 759
             $inputVal = $this->post($inputName);
760 760
             if ($inputVal >= $ruleArgs[1]) { 
761
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
761
+                if (!$this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
762 762
                     return;
763 763
                 }
764 764
                 $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
@@ -774,7 +774,7 @@  discard block
 block discarded – undo
774 774
     	protected function _validateGreaterThan($inputName, $ruleName, array $ruleArgs) {
775 775
             $inputVal = $this->post($inputName);
776 776
             if ($inputVal <= $ruleArgs[1]) {
777
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
777
+                if (!$this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
778 778
                     return;
779 779
                 }
780 780
                 $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
@@ -789,8 +789,8 @@  discard block
 block discarded – undo
789 789
          */
790 790
     	protected function _validateNumeric($inputName, $ruleName, array $ruleArgs) {
791 791
             $inputVal = $this->post($inputName);
792
-            if (! is_numeric($inputVal)) {
793
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
792
+            if (!is_numeric($inputVal)) {
793
+                if (!$this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
794 794
                     return;
795 795
                 }
796 796
                 $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
@@ -806,7 +806,7 @@  discard block
 block discarded – undo
806 806
 		protected function _validateExists($inputName, $ruleName, array $ruleArgs) {
807 807
             $inputVal = $this->post($inputName);
808 808
     		$obj = & get_instance();
809
-    		if(! isset($obj->database)){
809
+    		if (!isset($obj->database)) {
810 810
     			return;
811 811
     		}
812 812
     		list($table, $column) = explode('.', $ruleArgs[1]);
@@ -815,7 +815,7 @@  discard block
 block discarded – undo
815 815
     			          ->get();
816 816
     		$nb = $obj->database->numRows();
817 817
             if ($nb == 0) {
818
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
818
+                if (!$this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
819 819
                     return;
820 820
                 }
821 821
                 $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
@@ -831,7 +831,7 @@  discard block
 block discarded – undo
831 831
     	protected function _validateIsUnique($inputName, $ruleName, array $ruleArgs) {
832 832
             $inputVal = $this->post($inputName);
833 833
     		$obj = & get_instance();
834
-    		if(! isset($obj->database)){
834
+    		if (!isset($obj->database)) {
835 835
     			return;
836 836
     		}
837 837
     		list($table, $column) = explode('.', $ruleArgs[1]);
@@ -840,7 +840,7 @@  discard block
 block discarded – undo
840 840
     			          ->get();
841 841
     		$nb = $obj->database->numRows();
842 842
             if ($nb != 0) {
843
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
843
+                if (!$this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
844 844
                     return;
845 845
                 }
846 846
                 $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
@@ -856,11 +856,11 @@  discard block
 block discarded – undo
856 856
     	protected function _validateIsUniqueUpdate($inputName, $ruleName, array $ruleArgs) {
857 857
             $inputVal = $this->post($inputName);
858 858
     		$obj = & get_instance();
859
-    		if(! isset($obj->database)){
859
+    		if (!isset($obj->database)) {
860 860
     			return;
861 861
     		}
862 862
     		$data = explode(',', $ruleArgs[1]);
863
-    		if(count($data) < 2){
863
+    		if (count($data) < 2) {
864 864
     			return;
865 865
     		}
866 866
     		list($table, $column) = explode('.', $data[0]);
@@ -871,7 +871,7 @@  discard block
 block discarded – undo
871 871
                 		  ->get();
872 872
     		$nb = $obj->database->numRows();
873 873
             if ($nb != 0) {
874
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
874
+                if (!$this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
875 875
                     return;
876 876
                 }
877 877
                 $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
@@ -888,8 +888,8 @@  discard block
 block discarded – undo
888 888
             $inputVal = $this->post($inputName);
889 889
     		$list = explode(',', $ruleArgs[1]);
890 890
             $list = array_map('trim', $list);
891
-            if (! in_array($inputVal, $list)) {
892
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
891
+            if (!in_array($inputVal, $list)) {
892
+                if (!$this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
893 893
                     return;
894 894
                 }
895 895
                 $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
@@ -905,8 +905,8 @@  discard block
 block discarded – undo
905 905
         protected function _validateRegex($inputName, $ruleName, array $ruleArgs) {
906 906
             $inputVal = $this->post($inputName);
907 907
     		$regex = $ruleArgs[1];
908
-            if (! preg_match($regex, $inputVal)) {
909
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
908
+            if (!preg_match($regex, $inputVal)) {
909
+                if (!$this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
910 910
                     return;
911 911
                 }
912 912
                 $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
Please login to merge, or discard this patch.
core/libraries/Pagination.php 1 patch
Indentation   +133 added lines, -133 removed lines patch added patch discarded remove patch
@@ -1,5 +1,5 @@  discard block
 block discarded – undo
1 1
 <?php
2
-    defined('ROOT_PATH') || exit('Access denied');
2
+	defined('ROOT_PATH') || exit('Access denied');
3 3
 	/**
4 4
 	 * TNH Framework
5 5
 	 *
@@ -22,154 +22,154 @@  discard block
 block discarded – undo
22 22
 	 * You should have received a copy of the GNU General Public License
23 23
 	 * along with this program; if not, write to the Free Software
24 24
 	 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
25
-	*/
25
+	 */
26 26
 
27
-    class Pagination{
27
+	class Pagination{
28 28
         
29 29
 		/**
30
-         * The list of loaded config
31
-         * @var array
32
-         */
33
-        private $config = array();
30
+		 * The list of loaded config
31
+		 * @var array
32
+		 */
33
+		private $config = array();
34 34
 
35
-        /**
36
-         * Create an instance of pagination
37
-         * @param array $overwriteConfig the list of configuration to overwrite the defined configuration in config_pagination.php
38
-         */
39
-        public function __construct($overwriteConfig = array()){
40
-            if(file_exists(CONFIG_PATH . 'config_pagination.php')){
41
-                require_once CONFIG_PATH . 'config_pagination.php';
42
-                if(empty($config) || ! is_array($config)){
43
-                    show_error('No configuration found in ' . CONFIG_PATH . 'config_pagination.php');
44
-                }
35
+		/**
36
+		 * Create an instance of pagination
37
+		 * @param array $overwriteConfig the list of configuration to overwrite the defined configuration in config_pagination.php
38
+		 */
39
+		public function __construct($overwriteConfig = array()){
40
+			if(file_exists(CONFIG_PATH . 'config_pagination.php')){
41
+				require_once CONFIG_PATH . 'config_pagination.php';
42
+				if(empty($config) || ! is_array($config)){
43
+					show_error('No configuration found in ' . CONFIG_PATH . 'config_pagination.php');
44
+				}
45 45
 				else{
46 46
 					if(! empty($overwriteConfig)){
47 47
 						$config = array_merge($config, $overwriteConfig);
48 48
 					}
49 49
 					$this->config = $config;
50
-                    //put it gobally
50
+					//put it gobally
51 51
 					Config::setAll($config);
52 52
 					unset($config);
53 53
 				}
54
-            }
55
-            else{
56
-                show_error('Unable to find the pagination configuration file');
57
-            }
58
-        }
54
+			}
55
+			else{
56
+				show_error('Unable to find the pagination configuration file');
57
+			}
58
+		}
59 59
 
60 60
 
61
-        /**
62
-         * Set the pagination custom configuration to overwrite the default configuration in
63
-         * config_pagination.php
64
-         * @param array $config the configuration to set
65
-         */
66
-        public function setConfig(array $config = array()){
67
-            if(! empty($config)){
68
-                $this->config = array_merge($this->config, $config);
69
-                Config::setAll($config);
70
-            }
71
-        }
61
+		/**
62
+		 * Set the pagination custom configuration to overwrite the default configuration in
63
+		 * config_pagination.php
64
+		 * @param array $config the configuration to set
65
+		 */
66
+		public function setConfig(array $config = array()){
67
+			if(! empty($config)){
68
+				$this->config = array_merge($this->config, $config);
69
+				Config::setAll($config);
70
+			}
71
+		}
72 72
 
73
-        /**
74
-         * Generate the pagination link
75
-         * @param  int $totalRows the total number of data
76
-         * @param  int $currentPageNumber the current page number
77
-         * @return string the pagination link
78
-         */
79
-        public function getLink($totalRows, $currentPageNumber){
80
-            $pageQueryName = $this->config['page_query_string_name'];
81
-            $numberOfLink = $this->config['nb_link'];
73
+		/**
74
+		 * Generate the pagination link
75
+		 * @param  int $totalRows the total number of data
76
+		 * @param  int $currentPageNumber the current page number
77
+		 * @return string the pagination link
78
+		 */
79
+		public function getLink($totalRows, $currentPageNumber){
80
+			$pageQueryName = $this->config['page_query_string_name'];
81
+			$numberOfLink = $this->config['nb_link'];
82 82
 			$numberOfRowPerPage = $this->config['pagination_per_page'];
83
-            $queryString = Url::queryString();
84
-            $currentUrl = Url::current();
85
-            if($queryString == ''){
86
-                $query = '?' . $pageQueryName . '=';
87
-            }
88
-            else{
89
-                $tab = explode($pageQueryName . '=', $queryString);
90
-                $nb = count($tab);
91
-                if($nb == 1){
92
-                    $query = '?' . $queryString . '&' . $pageQueryName . '=';
93
-                }
94
-                else{
95
-                    if($tab[0] == ''){
96
-                        $query = '?' . $pageQueryName . '=';
97
-                    }
98
-                    else{
99
-                        $query = '?' . $tab[0] . '' . $pageQueryName . '=';
100
-                    }
101
-                }
102
-            }
103
-            $temp = explode('?', $currentUrl);
104
-            $query = $temp[0] . $query;
105
-            $navbar = '';
106
-            $numberOfPage = ceil($totalRows / $numberOfRowPerPage);
83
+			$queryString = Url::queryString();
84
+			$currentUrl = Url::current();
85
+			if($queryString == ''){
86
+				$query = '?' . $pageQueryName . '=';
87
+			}
88
+			else{
89
+				$tab = explode($pageQueryName . '=', $queryString);
90
+				$nb = count($tab);
91
+				if($nb == 1){
92
+					$query = '?' . $queryString . '&' . $pageQueryName . '=';
93
+				}
94
+				else{
95
+					if($tab[0] == ''){
96
+						$query = '?' . $pageQueryName . '=';
97
+					}
98
+					else{
99
+						$query = '?' . $tab[0] . '' . $pageQueryName . '=';
100
+					}
101
+				}
102
+			}
103
+			$temp = explode('?', $currentUrl);
104
+			$query = $temp[0] . $query;
105
+			$navbar = '';
106
+			$numberOfPage = ceil($totalRows / $numberOfRowPerPage);
107 107
 			if(! is_numeric ($currentPageNumber) || $currentPageNumber <= 0){
108 108
 				$currentPageNumber = 1;
109 109
 			}
110
-            if($numberOfPage <= 1 || $numberOfLink <= 0 || $numberOfRowPerPage <= 0 || !is_numeric($numberOfLink) || !is_numeric($numberOfRowPerPage)
111
-            ){
112
-                return $navbar;
113
-            }
114
-            if($numberOfLink % 2 == 0){
115
-                $start = $currentPageNumber - ($numberOfLink / 2) + 1;
116
-                $end = $currentPageNumber + ($numberOfLink / 2);
117
-            }
118
-            else{
119
-                $start = $currentPageNumber - floor($numberOfLink / 2);
120
-                $end = $currentPageNumber + floor($numberOfLink / 2);
121
-            }
122
-            if($start <= 1){
123
-                $begin = 1;
124
-                $end = $numberOfLink;
125
-            }
126
-            else if($start > 1 && $end < $numberOfPage){
127
-                $begin = $start;
128
-                $end = $end;
129
-            }
130
-            else{
131
-                $begin = ($numberOfPage - $numberOfLink) + 1;
132
-                $end = $numberOfPage;
133
-            }
134
-            if($numberOfPage <= $numberOfLink){
135
-                $begin = 1;
136
-                $end = $numberOfPage;
137
-            }
138
-            if($currentPageNumber == 1){
139
-                for($i = $begin; $i <= $end; $i++){
140
-                    if($i == $currentPageNumber){
141
-                        $navbar .= $this->config['active_link_open'] . $currentPageNumber . $this->config['active_link_close'];
142
-                    }
143
-                    else{
144
-                        $navbar .= $this->config['digit_open'] . '<a href="' . $query . $i . '" ' . attributes_to_string($this->config['attributes']) . '>' . $i . '</a>' . $this->config['digit_close'];
145
-                    }
146
-                }
147
-                $navbar .= $this->config['next_open'] . '<a href="' . $query . ($currentPageNumber + 1) . '">' . $this->config['next_text'] . '</a>' . $this->config['next_close'];
148
-            }
149
-            else if($currentPageNumber > 1 && $currentPageNumber < $numberOfPage){
150
-                $navbar .= $this->config['previous_open'] . '<a href="' . $query . ($currentPageNumber - 1) . '">' . $this->config['previous_text'] . '</a>' . $this->config['previous_close'];
151
-                for($i = $begin; $i <= $end; $i++){
152
-                    if($i == $currentPageNumber){
153
-                        $navbar .= $this->config['active_link_open'] . $currentPageNumber . $this->config['active_link_close'];
154
-                    }
155
-                    else{
156
-                        $navbar .= $this->config['digit_open'] . '<a href="' . $query . $i . '"' . attributes_to_string($this->config['attributes']) . '>' . $i .'</a>' . $this->config['digit_close'];
157
-                    }
158
-                }
159
-                $navbar .= $this->config['next_open']."<a href='$query".($currentPageNumber + 1)."'>".$this->config['next_text']."</a>".$this->config['next_close'];
160
-            }
161
-            else if($currentPageNumber == $numberOfPage){
162
-                $navbar .= $this->config['previous_open'] . '<a href="' . $query . ($currentPageNumber - 1) . '">' . $this->config['previous_text'] . '</a>' . $this->config['previous_close'];
163
-                for($i = $begin; $i <= $end; $i++){
164
-                    if($i == $currentPageNumber){
165
-                        $navbar .= $this->config['active_link_open'] . $currentPageNumber . $this->config['active_link_close'];
166
-                    }
167
-                    else{
168
-                        $navbar .= $this->config['digit_open'] . '<a href="' . $query . $i . '"' . attributes_to_string($this->config['attributes']) . '>' . $i . '</a>' . $this->config['digit_close'];
169
-                    }
170
-                }
171
-            }
172
-            $navbar = $this->config['pagination_open'] . $navbar . $this->config['pagination_close'];
173
-            return $navbar;
174
-        }
175
-    }
110
+			if($numberOfPage <= 1 || $numberOfLink <= 0 || $numberOfRowPerPage <= 0 || !is_numeric($numberOfLink) || !is_numeric($numberOfRowPerPage)
111
+			){
112
+				return $navbar;
113
+			}
114
+			if($numberOfLink % 2 == 0){
115
+				$start = $currentPageNumber - ($numberOfLink / 2) + 1;
116
+				$end = $currentPageNumber + ($numberOfLink / 2);
117
+			}
118
+			else{
119
+				$start = $currentPageNumber - floor($numberOfLink / 2);
120
+				$end = $currentPageNumber + floor($numberOfLink / 2);
121
+			}
122
+			if($start <= 1){
123
+				$begin = 1;
124
+				$end = $numberOfLink;
125
+			}
126
+			else if($start > 1 && $end < $numberOfPage){
127
+				$begin = $start;
128
+				$end = $end;
129
+			}
130
+			else{
131
+				$begin = ($numberOfPage - $numberOfLink) + 1;
132
+				$end = $numberOfPage;
133
+			}
134
+			if($numberOfPage <= $numberOfLink){
135
+				$begin = 1;
136
+				$end = $numberOfPage;
137
+			}
138
+			if($currentPageNumber == 1){
139
+				for($i = $begin; $i <= $end; $i++){
140
+					if($i == $currentPageNumber){
141
+						$navbar .= $this->config['active_link_open'] . $currentPageNumber . $this->config['active_link_close'];
142
+					}
143
+					else{
144
+						$navbar .= $this->config['digit_open'] . '<a href="' . $query . $i . '" ' . attributes_to_string($this->config['attributes']) . '>' . $i . '</a>' . $this->config['digit_close'];
145
+					}
146
+				}
147
+				$navbar .= $this->config['next_open'] . '<a href="' . $query . ($currentPageNumber + 1) . '">' . $this->config['next_text'] . '</a>' . $this->config['next_close'];
148
+			}
149
+			else if($currentPageNumber > 1 && $currentPageNumber < $numberOfPage){
150
+				$navbar .= $this->config['previous_open'] . '<a href="' . $query . ($currentPageNumber - 1) . '">' . $this->config['previous_text'] . '</a>' . $this->config['previous_close'];
151
+				for($i = $begin; $i <= $end; $i++){
152
+					if($i == $currentPageNumber){
153
+						$navbar .= $this->config['active_link_open'] . $currentPageNumber . $this->config['active_link_close'];
154
+					}
155
+					else{
156
+						$navbar .= $this->config['digit_open'] . '<a href="' . $query . $i . '"' . attributes_to_string($this->config['attributes']) . '>' . $i .'</a>' . $this->config['digit_close'];
157
+					}
158
+				}
159
+				$navbar .= $this->config['next_open']."<a href='$query".($currentPageNumber + 1)."'>".$this->config['next_text']."</a>".$this->config['next_close'];
160
+			}
161
+			else if($currentPageNumber == $numberOfPage){
162
+				$navbar .= $this->config['previous_open'] . '<a href="' . $query . ($currentPageNumber - 1) . '">' . $this->config['previous_text'] . '</a>' . $this->config['previous_close'];
163
+				for($i = $begin; $i <= $end; $i++){
164
+					if($i == $currentPageNumber){
165
+						$navbar .= $this->config['active_link_open'] . $currentPageNumber . $this->config['active_link_close'];
166
+					}
167
+					else{
168
+						$navbar .= $this->config['digit_open'] . '<a href="' . $query . $i . '"' . attributes_to_string($this->config['attributes']) . '>' . $i . '</a>' . $this->config['digit_close'];
169
+					}
170
+				}
171
+			}
172
+			$navbar = $this->config['pagination_open'] . $navbar . $this->config['pagination_close'];
173
+			return $navbar;
174
+		}
175
+	}
Please login to merge, or discard this patch.
core/libraries/Assets.php 1 patch
Spacing   +12 added lines, -12 removed lines patch added patch discarded remove patch
@@ -38,7 +38,7 @@  discard block
 block discarded – undo
38 38
 	 *  @since 1.0.0
39 39
 	 *  @filesource
40 40
 	 */
41
-	class Assets{
41
+	class Assets {
42 42
 		
43 43
 		/**
44 44
 		 * The logger instance
@@ -50,10 +50,10 @@  discard block
 block discarded – undo
50 50
 		 * The signleton of the logger
51 51
 		 * @return Object the Log instance
52 52
 		 */
53
-		private static function getLogger(){
54
-			if(self::$logger == null){
53
+		private static function getLogger() {
54
+			if (self::$logger == null) {
55 55
 				//can't assign reference to static variable
56
-				self::$logger[0] =& class_loader('Log', 'classes');
56
+				self::$logger[0] = & class_loader('Log', 'classes');
57 57
 				self::$logger[0]->setLogger('Library::Assets');
58 58
 			}
59 59
 			return self::$logger[0];
@@ -72,13 +72,13 @@  discard block
 block discarded – undo
72 72
 		 *  @param $asset the name of the assets file path with the extension.
73 73
 		 *  @return string|null the absolute path of the assets file, if it exists otherwise returns null if the file does not exist.
74 74
 		 */
75
-		public static function path($asset){
75
+		public static function path($asset) {
76 76
 			$logger = self::getLogger();	
77 77
 			$path = ASSETS_PATH . $asset;
78 78
 			
79 79
 			$logger->debug('Including the Assets file [' . $path . ']');
80 80
 			//Check if the file exists
81
-			if(file_exists($path)){
81
+			if (file_exists($path)) {
82 82
 				$logger->info('Assets file [' . $path . '] included successfully');
83 83
 				return Url::base_url($path);
84 84
 			}
@@ -98,7 +98,7 @@  discard block
 block discarded – undo
98 98
 		 *  @param $path the name of the css file without the extension.
99 99
 		 *  @return string|null the absolute path of the css file, if it exists otherwise returns null if the file does not exist.
100 100
 		 */
101
-		public static function css($path){
101
+		public static function css($path) {
102 102
 			$logger = self::getLogger();
103 103
 			/*
104 104
 			* if the file name contains the ".css" extension, replace it with 
@@ -109,7 +109,7 @@  discard block
 block discarded – undo
109 109
 			
110 110
 			$logger->debug('Including the Assets file [' . $path . '] for CSS');
111 111
 			//Check if the file exists
112
-			if(file_exists($path)){
112
+			if (file_exists($path)) {
113 113
 				$logger->info('Assets file [' . $path . '] for CSS included successfully');
114 114
 				return Url::base_url($path);
115 115
 			}
@@ -129,12 +129,12 @@  discard block
 block discarded – undo
129 129
 		 *  @param $path the name of the javascript file without the extension.
130 130
 		 *  @return string|null the absolute path of the javascript file, if it exists otherwise returns null if the file does not exist.
131 131
 		 */
132
-		public static function js($path){
132
+		public static function js($path) {
133 133
 			$logger = self::getLogger();
134 134
 			$path = str_ireplace('.js', '', $path);
135 135
 			$path = ASSETS_PATH . 'js/' . $path . '.js';
136 136
 			$logger->debug('Including the Assets file [' . $path . '] for javascript');
137
-			if(file_exists($path)){
137
+			if (file_exists($path)) {
138 138
 				$logger->info('Assets file [' . $path . '] for Javascript included successfully');
139 139
 				return Url::base_url($path);
140 140
 			}
@@ -154,11 +154,11 @@  discard block
 block discarded – undo
154 154
 		 *  @param $path the name of the image file with the extension.
155 155
 		 *  @return string|null the absolute path of the image file, if it exists otherwise returns null if the file does not exist.
156 156
 		 */
157
-		public static function img($path){
157
+		public static function img($path) {
158 158
 			$logger = self::getLogger();
159 159
 			$path = ASSETS_PATH . 'images/' . $path;
160 160
 			$logger->debug('Including the Assets file [' . $path . '] for image');
161
-			if(file_exists($path)){
161
+			if (file_exists($path)) {
162 162
 				$logger->info('Assets file [' . $path . '] for image included successfully');
163 163
 				return Url::base_url($path);
164 164
 			}
Please login to merge, or discard this patch.
core/libraries/Benchmark.php 1 patch
Spacing   +8 added lines, -8 removed lines patch added patch discarded remove patch
@@ -27,7 +27,7 @@  discard block
 block discarded – undo
27 27
 	/**
28 28
 	 * Class for Benchmark
29 29
 	 */
30
-	class Benchmark{
30
+	class Benchmark {
31 31
 		/**
32 32
 		 * The markers for excution time
33 33
 		 * @var array
@@ -44,7 +44,7 @@  discard block
 block discarded – undo
44 44
 		 * This method is used to mark one point for benchmark (execution time and memory usage)
45 45
 		 * @param  string $name the marker name
46 46
 		 */
47
-		public function mark($name){
47
+		public function mark($name) {
48 48
 			//Marker for execution time
49 49
 			$this->markersTime[$name] = microtime(true);
50 50
 			//Marker for memory usage
@@ -58,12 +58,12 @@  discard block
 block discarded – undo
58 58
 		 * @param  integer $decimalCount   the number of decimal
59 59
 		 * @return string         the total execution time
60 60
 		 */
61
-		public function elapsedTime($startMarkerName = null, $endMarkerName = null, $decimalCount = 6){
62
-			if(! $startMarkerName || !isset($this->markersTime[$startMarkerName])){
61
+		public function elapsedTime($startMarkerName = null, $endMarkerName = null, $decimalCount = 6) {
62
+			if (!$startMarkerName || !isset($this->markersTime[$startMarkerName])) {
63 63
 				return 0;
64 64
 			}
65 65
 			
66
-			if(! isset($this->markersTime[$endMarkerName])){
66
+			if (!isset($this->markersTime[$endMarkerName])) {
67 67
 				$this->markersTime[$endMarkerName] = microtime(true);
68 68
 			}
69 69
 			return number_format($this->markersTime[$endMarkerName] - $this->markersTime[$startMarkerName], $decimalCount);
@@ -76,12 +76,12 @@  discard block
 block discarded – undo
76 76
 		 * @param  integer $decimalCount   the number of decimal
77 77
 		 * @return string         the total memory usage
78 78
 		 */
79
-		public function memoryUsage($startMarkerName = null, $endMarkerName = null, $decimalCount = 6){
80
-			if(! $startMarkerName || !isset($this->markersMemory[$startMarkerName])){
79
+		public function memoryUsage($startMarkerName = null, $endMarkerName = null, $decimalCount = 6) {
80
+			if (!$startMarkerName || !isset($this->markersMemory[$startMarkerName])) {
81 81
 				return 0;
82 82
 			}
83 83
 			
84
-			if(! isset($this->markersMemory[$endMarkerName])){
84
+			if (!isset($this->markersMemory[$endMarkerName])) {
85 85
 				$this->markersMemory[$endMarkerName] = microtime(true);
86 86
 			}
87 87
 			return number_format($this->markersMemory[$endMarkerName] - $this->markersMemory[$startMarkerName], $decimalCount);
Please login to merge, or discard this patch.
core/libraries/Email.php 1 patch
Spacing   +8 added lines, -8 removed lines patch added patch discarded remove patch
@@ -86,7 +86,7 @@  discard block
 block discarded – undo
86 86
 		 */
87 87
 		public function __construct()
88 88
 		{
89
-			$this->logger =& class_loader('Log', 'classes');
89
+			$this->logger = & class_loader('Log', 'classes');
90 90
             $this->logger->setLogger('Library::Email');
91 91
 			$this->reset();
92 92
 		}
@@ -148,10 +148,10 @@  discard block
 block discarded – undo
148 148
 		public function setTos(array $emails)
149 149
 		{
150 150
 			foreach ($emails as $name => $email) {
151
-				if(is_numeric($name)){
151
+				if (is_numeric($name)) {
152 152
 					$this->setTo($email);
153 153
 				}
154
-				else{
154
+				else {
155 155
 					$this->setTo($email, $name);
156 156
 				}
157 157
 			}
@@ -281,8 +281,8 @@  discard block
 block discarded – undo
281 281
 		 */
282 282
 		public function addAttachment($path, $filename = null, $data = null)
283 283
 		{
284
-			if(! file_exists($path)){
285
-				show_error('The file [' .$path. '] does not exists.');
284
+			if (!file_exists($path)) {
285
+				show_error('The file [' . $path . '] does not exists.');
286 286
 			}
287 287
 			$filename = empty($filename) ? basename($path) : $filename;
288 288
 			$filename = $this->encodeUtf8($this->filterOther((string) $filename));
@@ -304,13 +304,13 @@  discard block
 block discarded – undo
304 304
 		 */
305 305
 		public function getAttachmentData($path)
306 306
 		{
307
-			if(! file_exists($path)){
308
-				show_error('The file [' .$path. '] does not exists.');
307
+			if (!file_exists($path)) {
308
+				show_error('The file [' . $path . '] does not exists.');
309 309
 			}
310 310
 			$filesize = filesize($path);
311 311
 			$handle = fopen($path, "r");
312 312
 			$attachment = null;
313
-			if(is_resource($handle)){
313
+			if (is_resource($handle)) {
314 314
 				$attachment = fread($handle, $filesize);
315 315
 				fclose($handle);
316 316
 			}
Please login to merge, or discard this patch.