Test Failed
Push — 1.0.0-dev ( f8836a...d20bd6 )
by nguereza
04:07
created
tests/hmvc/models/DBSessionModel.php 1 patch
Spacing   +3 added lines, -3 removed lines patch added patch discarded remove patch
@@ -1,5 +1,5 @@  discard block
 block discarded – undo
1 1
 <?php
2
-	class DBSessionModel extends DBSessionHandlerModel{
2
+	class DBSessionModel extends DBSessionHandlerModel {
3 3
 		
4 4
 		protected $_table = 'ses';
5 5
 		protected $primary_key = 's_id';
@@ -14,14 +14,14 @@  discard block
 block discarded – undo
14 14
 			'skey' => 'test_id' //VARCHAR(255) 
15 15
 		);
16 16
 		
17
-		public function deleteByTime($time){
17
+		public function deleteByTime($time) {
18 18
 			$this->_database->from($this->_table)
19 19
 						->where('s_time', '<', $time)
20 20
 						->delete();
21 21
 		}
22 22
 
23 23
 		
24
-		public function getKeyValue(){
24
+		public function getKeyValue() {
25 25
 			$user_id = 0;
26 26
 			return $user_id;
27 27
 		}
Please login to merge, or discard this patch.
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/test.php 1 patch
Indentation   +5 added lines, -5 removed lines patch added patch discarded remove patch
@@ -1,10 +1,10 @@
 block discarded – undo
1 1
  <?php
2 2
            
3
-            $pdo = new PDO('sqlite:D:\wamp\www\tnh-fw\tests\assets\db_tests.db', '', '');
4
-            $pdo->exec("SET NAMES 'UTF8' COLLATE 'utf8_general_ci'");
5
-            $pdo->exec("SET CHARACTER SET 'UTF8'");
6
-            $pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_OBJ);
7
-            $pdo->setAttribute(PDO::ATTR_CURSOR, PDO::CURSOR_FWDONLY);
3
+			$pdo = new PDO('sqlite:D:\wamp\www\tnh-fw\tests\assets\db_tests.db', '', '');
4
+			$pdo->exec("SET NAMES 'UTF8' COLLATE 'utf8_general_ci'");
5
+			$pdo->exec("SET CHARACTER SET 'UTF8'");
6
+			$pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_OBJ);
7
+			$pdo->setAttribute(PDO::ATTR_CURSOR, PDO::CURSOR_FWDONLY);
8 8
 			$r = $pdo->query("SELECT * FROM ses WHERE s_id = 'tony' LIMIT 1");
9 9
 			
10 10
 			$nb = $r->rowCount();
Please login to merge, or discard this patch.
tests/bootstrap.php 2 patches
Indentation   +126 added lines, -126 removed lines patch added patch discarded remove patch
@@ -21,21 +21,21 @@  discard block
 block discarded – undo
21 21
 	 * You should have received a copy of the GNU General Public License
22 22
 	 * along with this program; if not, write to the Free Software
23 23
 	 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
24
-	*/
24
+	 */
25 25
 	
26 26
 	error_reporting(E_ALL | E_STRICT);
27 27
 	ini_set('display_errors', 1);
28 28
 
29 29
 	/**
30
-	* the directory separator, under windows it is \ and unix, linux /
31
-	*/
30
+	 * the directory separator, under windows it is \ and unix, linux /
31
+	 */
32 32
 	define('DS', DIRECTORY_SEPARATOR);
33 33
 
34 34
 	/**
35
-	* The root directory of the application.
36
-	*
37
-	* you can place this directory outside of your web directory, for example "/home/your_app", etc.
38
-	*/
35
+	 * The root directory of the application.
36
+	 *
37
+	 * you can place this directory outside of your web directory, for example "/home/your_app", etc.
38
+	 */
39 39
 	define('ROOT_PATH', dirname(realpath(__FILE__)) . DS . '..' . DS);
40 40
 	
41 41
 	//tests dir path
@@ -43,176 +43,176 @@  discard block
 block discarded – undo
43 43
 
44 44
 
45 45
 	/**
46
-	* The path to the directory.
47
-	*
48
-	* That contains your static files (javascript, css, images, etc.)
49
-	* Note: the path must be relative to the file index.php (the front-end controller).
50
-	*/
46
+	 * The path to the directory.
47
+	 *
48
+	 * That contains your static files (javascript, css, images, etc.)
49
+	 * Note: the path must be relative to the file index.php (the front-end controller).
50
+	 */
51 51
 	define('ASSETS_PATH', 'assets/');
52 52
 
53 53
 	/**
54
-	* The path to the directory of your cache files.
55
-	*
56
-	* This feature is available currently for database and views.
57
-	*/
54
+	 * The path to the directory of your cache files.
55
+	 *
56
+	 * This feature is available currently for database and views.
57
+	 */
58 58
 	define('CACHE_PATH', ROOT_PATH . 'cache' . DS);
59 59
 
60 60
 	/**
61
-	* Custom application path for tests 
62
-	*/
61
+	 * Custom application path for tests 
62
+	 */
63 63
 	define('APPS_PATH', TESTS_PATH .'hmvc' . DS);
64 64
 
65 65
 	/**
66
-	* The path to the controller directory of your application.
67
-	*
68
-	* If you already know the MVC architecture you know what a controller means; 
69
-	* it is he who makes the business logic of your application in general.
70
-	*/
66
+	 * The path to the controller directory of your application.
67
+	 *
68
+	 * If you already know the MVC architecture you know what a controller means; 
69
+	 * it is he who makes the business logic of your application in general.
70
+	 */
71 71
 	define('APPS_CONTROLLER_PATH', APPS_PATH . 'controllers' . DS);
72 72
 
73 73
 	/**
74
-	* The path to the directory of your model classes of your application. 
75
-	*
76
-	* If you already know the MVC architecture you know what a model means; 
77
-	* it's the one who interacts with the database, in one word persistent data from your application.
78
-	*/
74
+	 * The path to the directory of your model classes of your application. 
75
+	 *
76
+	 * If you already know the MVC architecture you know what a model means; 
77
+	 * it's the one who interacts with the database, in one word persistent data from your application.
78
+	 */
79 79
 	define('APPS_MODEL_PATH', APPS_PATH . 'models' . DS);
80 80
 
81 81
 	/**
82
-	* The path to the directory of your views.
83
-	*
84
-	* If you already know the MVC architecture you know what a view means, 
85
-	* a view is just a user interface (html page, form, etc.) that is to say 
86
-	* everything displayed in the browser interface, etc.
87
-	*/
82
+	 * The path to the directory of your views.
83
+	 *
84
+	 * If you already know the MVC architecture you know what a view means, 
85
+	 * a view is just a user interface (html page, form, etc.) that is to say 
86
+	 * everything displayed in the browser interface, etc.
87
+	 */
88 88
 	define('APPS_VIEWS_PATH', APPS_PATH . 'views' . DS);
89 89
 
90 90
 	/**
91
-	* The path to the configuration directory.
92
-	*
93
-	* That contains most of the configuration files for your 
94
-	* application (database, class loading file, functions, etc.)
95
-	*/
91
+	 * The path to the configuration directory.
92
+	 *
93
+	 * That contains most of the configuration files for your 
94
+	 * application (database, class loading file, functions, etc.)
95
+	 */
96 96
 	define('CONFIG_PATH', ROOT_PATH . 'config' . DS);
97 97
 
98 98
 	/** 
99
-	* The core directory
100
-	*
101
-	* It is recommended to put this folder out of the web directory of your server and 
102
-	* you should not change its content because in case of update you could lose the modified files.
103
-	*/
99
+	 * The core directory
100
+	 *
101
+	 * It is recommended to put this folder out of the web directory of your server and 
102
+	 * you should not change its content because in case of update you could lose the modified files.
103
+	 */
104 104
 	define('CORE_PATH', ROOT_PATH . 'core' . DS);
105 105
 	
106 106
 	/**
107
-	* The path to the directory of core classes that used by the system.
108
-	*
109
-	* It contains PHP classes that are used by the framework internally.
110
-	*/
107
+	 * The path to the directory of core classes that used by the system.
108
+	 *
109
+	 * It contains PHP classes that are used by the framework internally.
110
+	 */
111 111
 	define('CORE_CLASSES_PATH', CORE_PATH . 'classes' . DS);
112 112
 	
113 113
 	/**
114
-	* The path to the directory of core classes for the cache used by the system.
115
-	*
116
-	* It contains PHP classes for the cache drivers.
117
-	*/
114
+	 * The path to the directory of core classes for the cache used by the system.
115
+	 *
116
+	 * It contains PHP classes for the cache drivers.
117
+	 */
118 118
 	define('CORE_CLASSES_CACHE_PATH', CORE_CLASSES_PATH . 'cache' . DS);
119 119
 	
120 120
 	/**
121
-	* The path to the directory of core classes for the model used by the system.
122
-	*
123
-	* It contains PHP classes for the models.
124
-	*/
121
+	 * The path to the directory of core classes for the model used by the system.
122
+	 *
123
+	 * It contains PHP classes for the models.
124
+	 */
125 125
 	define('CORE_CLASSES_MODEL_PATH', CORE_CLASSES_PATH . 'model' . DS);
126 126
 
127 127
 	/**
128
-	* The path to the directory of functions or helper systems.
129
-	*
130
-	* It contains PHP functions that perform a particular task: character string processing, URL, etc.
131
-	*/
128
+	 * The path to the directory of functions or helper systems.
129
+	 *
130
+	 * It contains PHP functions that perform a particular task: character string processing, URL, etc.
131
+	 */
132 132
 	define('CORE_FUNCTIONS_PATH', CORE_PATH . 'functions' . DS);
133 133
 
134 134
 	/**
135
-	* The path to the core directory of languages files. 
136
-	*
137
-	*/
135
+	 * The path to the core directory of languages files. 
136
+	 *
137
+	 */
138 138
 	define('CORE_LANG_PATH', CORE_PATH . 'lang' . DS);
139 139
 
140 140
 	/**
141
-	* The path to the system library directory.
142
-	*
143
-	* Which contains the libraries most often used in your web application, as for the 
144
-	* core directory it is advisable to put it out of the root directory of your application.
145
-	*/
141
+	 * The path to the system library directory.
142
+	 *
143
+	 * Which contains the libraries most often used in your web application, as for the 
144
+	 * core directory it is advisable to put it out of the root directory of your application.
145
+	 */
146 146
 	define('CORE_LIBRARY_PATH', CORE_PATH . 'libraries' . DS);
147 147
 
148 148
 	/**
149
-	* The path to the system view directory.
150
-	*
151
-	* That contains the views used for the system, such as error messages, and so on.
152
-	*/
149
+	 * The path to the system view directory.
150
+	 *
151
+	 * That contains the views used for the system, such as error messages, and so on.
152
+	 */
153 153
 	define('CORE_VIEWS_PATH', CORE_PATH . 'views' . DS);
154 154
 	
155 155
 	/**
156
-	* The path to the directory of your PHP personal functions or helper.
157
-	*
158
-	* It contains your PHP functions that perform a particular task: utilities, etc.
159
-	* Note: Do not put your personal functions or helpers in the system functions directory, 
160
-	* because if you update the system you may lose them.
161
-	*/
156
+	 * The path to the directory of your PHP personal functions or helper.
157
+	 *
158
+	 * It contains your PHP functions that perform a particular task: utilities, etc.
159
+	 * Note: Do not put your personal functions or helpers in the system functions directory, 
160
+	 * because if you update the system you may lose them.
161
+	 */
162 162
 	define('FUNCTIONS_PATH', ROOT_PATH . 'functions' . DS);
163 163
 
164 164
 	/**
165
-	* The path to the app directory of personal language. 
166
-	*
167
-	* This feature is not yet available. 
168
-	* You can help us do this if you are nice or wish to see the developed framework.
169
-	*/
165
+	 * The path to the app directory of personal language. 
166
+	 *
167
+	 * This feature is not yet available. 
168
+	 * You can help us do this if you are nice or wish to see the developed framework.
169
+	 */
170 170
 	define('APP_LANG_PATH', ROOT_PATH . 'lang' . DS);
171 171
 
172 172
 	/**
173
-	* The path to the directory of your personal libraries
174
-	*
175
-	* It contains your PHP classes, package, etc.
176
-	* Note: you should not put your personal libraries in the system library directory, 
177
-	* because it is recalled in case of updating the system you might have surprises.
178
-	*/
173
+	 * The path to the directory of your personal libraries
174
+	 *
175
+	 * It contains your PHP classes, package, etc.
176
+	 * Note: you should not put your personal libraries in the system library directory, 
177
+	 * because it is recalled in case of updating the system you might have surprises.
178
+	 */
179 179
 	define('LIBRARY_PATH', ROOT_PATH . 'libraries' . DS);
180 180
 
181 181
 	/**
182
-	* The path to the directory that contains the log files.
183
-	*
184
-	* Note: This directory must be available in writing and if possible must have as owner the user who launches your web server, 
185
-	* under unix or linux most often with the apache web server it is "www-data" or "httpd" even "nobody" for more
186
-	* details see the documentation of your web server.
187
-	* Example for Unix or linux with apache web server:
188
-	* # chmod -R 700 /path/to/your/logs/directory/
189
-	* # chown -R www-data:www-data /path/to/your/logs/directory/
190
-	*/
182
+	 * The path to the directory that contains the log files.
183
+	 *
184
+	 * Note: This directory must be available in writing and if possible must have as owner the user who launches your web server, 
185
+	 * under unix or linux most often with the apache web server it is "www-data" or "httpd" even "nobody" for more
186
+	 * details see the documentation of your web server.
187
+	 * Example for Unix or linux with apache web server:
188
+	 * # chmod -R 700 /path/to/your/logs/directory/
189
+	 * # chown -R www-data:www-data /path/to/your/logs/directory/
190
+	 */
191 191
 	define('LOGS_PATH', ROOT_PATH . 'logs' . DS);
192 192
 
193 193
 	/**
194
-	* The path to the modules directory. 
195
-	*
196
-	* It contains your modules used files (config, controllers, libraries, etc.) that is to say which contains your files of the modules, 
197
-	* in HMVC architecture (hierichical, controllers, models, views).
198
-	*/
194
+	 * The path to the modules directory. 
195
+	 *
196
+	 * It contains your modules used files (config, controllers, libraries, etc.) that is to say which contains your files of the modules, 
197
+	 * in HMVC architecture (hierichical, controllers, models, views).
198
+	 */
199 199
 	define('MODULE_PATH', dirname(realpath(__FILE__)) . DS .'hmvc' . DS . 'modules' . DS);
200 200
 
201 201
 	/**
202
-	* The path to the directory of sources external to your application.
203
-	*
204
-	* If you have already used "composer" you know what that means.
205
-	*/
202
+	 * The path to the directory of sources external to your application.
203
+	 *
204
+	 * If you have already used "composer" you know what that means.
205
+	 */
206 206
 	define('VENDOR_PATH', ROOT_PATH . 'vendor' . DS);
207 207
 
208 208
 	/**
209
-	* The front controller of your application.
210
-	*
211
-	* "index.php" it is through this file that all the requests come, there is a possibility to hidden it in the url of 
212
-	* your application by using the rewrite module URL of your web server .
213
-	* For example, under apache web server, there is a configuration example file that is located at the root 
214
-	* of your framework folder : "htaccess.txt" rename it to ".htaccess".
215
-	*/
209
+	 * The front controller of your application.
210
+	 *
211
+	 * "index.php" it is through this file that all the requests come, there is a possibility to hidden it in the url of 
212
+	 * your application by using the rewrite module URL of your web server .
213
+	 * For example, under apache web server, there is a configuration example file that is located at the root 
214
+	 * of your framework folder : "htaccess.txt" rename it to ".htaccess".
215
+	 */
216 216
 	define('SELF', pathinfo(__FILE__, PATHINFO_BASENAME));
217 217
 	
218 218
 	/**
@@ -221,14 +221,14 @@  discard block
 block discarded – undo
221 221
 	define('IS_CLI', stripos('cli', php_sapi_name()) !== false);
222 222
 
223 223
 	/**
224
-	* The environment of your application (production, test, development). 
225
-	*
226
-	* if your application is still in development you use the value "development" 
227
-	* so you will have the display of the error messages, etc. 
228
-	* Once you finish the development of your application that is to put it online 
229
-	* you change this value to "production" or "testing", in this case there will be deactivation of error messages, 
230
-	* the loading of the system, will be fast.
231
-	*/
224
+	 * The environment of your application (production, test, development). 
225
+	 *
226
+	 * if your application is still in development you use the value "development" 
227
+	 * so you will have the display of the error messages, etc. 
228
+	 * Once you finish the development of your application that is to put it online 
229
+	 * you change this value to "production" or "testing", in this case there will be deactivation of error messages, 
230
+	 * the loading of the system, will be fast.
231
+	 */
232 232
 	define('ENVIRONMENT', 'testing');
233 233
 	
234 234
 	
@@ -259,13 +259,13 @@  discard block
 block discarded – undo
259 259
 	require_once  'include/testsUtil.php';
260 260
 	
261 261
 	/**
262
-	* Setting of the PHP error message handling function
263
-	*/
262
+	 * Setting of the PHP error message handling function
263
+	 */
264 264
 	set_error_handler('php_error_handler');
265 265
 
266 266
 	/**
267
-	* Setting of the PHP error exception handling function
268
-	*/
267
+	 * Setting of the PHP error exception handling function
268
+	 */
269 269
 	set_exception_handler('php_exception_handler');
270 270
 
271 271
 	/**
Please login to merge, or discard this patch.
Spacing   +4 added lines, -4 removed lines patch added patch discarded remove patch
@@ -60,7 +60,7 @@  discard block
 block discarded – undo
60 60
 	/**
61 61
 	* Custom application path for tests 
62 62
 	*/
63
-	define('APPS_PATH', TESTS_PATH .'hmvc' . DS);
63
+	define('APPS_PATH', TESTS_PATH . 'hmvc' . DS);
64 64
 
65 65
 	/**
66 66
 	* The path to the controller directory of your application.
@@ -196,7 +196,7 @@  discard block
 block discarded – undo
196 196
 	* It contains your modules used files (config, controllers, libraries, etc.) that is to say which contains your files of the modules, 
197 197
 	* in HMVC architecture (hierichical, controllers, models, views).
198 198
 	*/
199
-	define('MODULE_PATH', dirname(realpath(__FILE__)) . DS .'hmvc' . DS . 'modules' . DS);
199
+	define('MODULE_PATH', dirname(realpath(__FILE__)) . DS . 'hmvc' . DS . 'modules' . DS);
200 200
 
201 201
 	/**
202 202
 	* The path to the directory of sources external to your application.
@@ -235,7 +235,7 @@  discard block
 block discarded – undo
235 235
 	//Fix to allow test as if application is running in CLI mode $_SESSION global variable is not available
236 236
 	$_SESSION = array();
237 237
 	
238
-	if(! isset($_SERVER['REMOTE_ADDR'])){ 
238
+	if (!isset($_SERVER['REMOTE_ADDR'])) { 
239 239
 		$_SERVER['REMOTE_ADDR'] = '127.0.0.1';
240 240
 	}
241 241
 
@@ -243,7 +243,7 @@  discard block
 block discarded – undo
243 243
 	require_once  'include/autoloader.php';
244 244
 	
245 245
 	//check for composer autoload file if exists include it
246
-	if(file_exists(VENDOR_PATH . 'autoload.php')){
246
+	if (file_exists(VENDOR_PATH . 'autoload.php')) {
247 247
 		require_once VENDOR_PATH . 'autoload.php';
248 248
 		
249 249
 		//define the class alias for vstream
Please login to merge, or discard this patch.
tests/tnhfw/classes/DBSessionHandlerTest.php 1 patch
Spacing   +8 added lines, -8 removed lines patch added patch discarded remove patch
@@ -47,7 +47,7 @@  discard block
 block discarded – undo
47 47
 
48 48
 		
49 49
 		
50
-		public function testUsingSessionConfiguration(){
50
+		public function testUsingSessionConfiguration() {
51 51
 			$data = $this->model->get('tony');
52 52
 			//file_put_contents('D:\tnh.txt', stringfy_vars($data));
53 53
 			//using value in the configuration
@@ -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->assertFalse($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.
tests/tnhfw/CommonTest.php 1 patch
Spacing   +3 added lines, -3 removed lines patch added patch discarded remove patch
@@ -24,20 +24,20 @@
 block discarded – undo
24 24
 		}
25 25
 
26 26
 		
27
-		public function testFunctionGetConfigKeyNotExist(){
27
+		public function testFunctionGetConfigKeyNotExist() {
28 28
 			$key = 'foo';
29 29
 			$cfg = get_config($key);
30 30
 			$this->assertNull($cfg);
31 31
 		}
32 32
 		
33
-		public function testFunctionGetConfigKeyNotExistUsingDefaultValue(){
33
+		public function testFunctionGetConfigKeyNotExistUsingDefaultValue() {
34 34
 			$key = 'foo';
35 35
 			$expected = 'bar';
36 36
 			$cfg = get_config($key, $expected);
37 37
 			$this->assertEquals($cfg, $expected);
38 38
 		}
39 39
 		
40
-		public function testFunctionGetConfigAfterSet(){
40
+		public function testFunctionGetConfigAfterSet() {
41 41
 			$key = 'foo';
42 42
 			$expected = 'bar';
43 43
 			$c = new Config();
Please login to merge, or discard this patch.
core/classes/Database.php 3 patches
Indentation   +1238 added lines, -1238 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,188 +22,188 @@  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
   class Database{
27 27
 	
28 28
 	/**
29 29
 	 * The PDO instance
30 30
 	 * @var object
31
-	*/
32
-    private $pdo                 = null;
31
+	 */
32
+	private $pdo                 = null;
33 33
     
34 34
 	/**
35 35
 	 * The database name used for the application
36 36
 	 * @var string
37
-	*/
37
+	 */
38 38
 	private $databaseName        = null;
39 39
     
40 40
 	/**
41 41
 	 * The SQL SELECT statment
42 42
 	 * @var string
43
-	*/
43
+	 */
44 44
 	private $select              = '*';
45 45
 	
46 46
 	/**
47 47
 	 * The SQL FROM statment
48 48
 	 * @var string
49
-	*/
50
-    private $from                = null;
49
+	 */
50
+	private $from                = null;
51 51
 	
52 52
 	/**
53 53
 	 * The SQL WHERE statment
54 54
 	 * @var string
55
-	*/
56
-    private $where               = null;
55
+	 */
56
+	private $where               = null;
57 57
 	
58 58
 	/**
59 59
 	 * The SQL LIMIT statment
60 60
 	 * @var string
61
-	*/
62
-    private $limit               = null;
61
+	 */
62
+	private $limit               = null;
63 63
 	
64 64
 	/**
65 65
 	 * The SQL JOIN statment
66 66
 	 * @var string
67
-	*/
68
-    private $join                = null;
67
+	 */
68
+	private $join                = null;
69 69
 	
70 70
 	/**
71 71
 	 * The SQL ORDER BY statment
72 72
 	 * @var string
73
-	*/
74
-    private $orderBy             = null;
73
+	 */
74
+	private $orderBy             = null;
75 75
 	
76 76
 	/**
77 77
 	 * The SQL GROUP BY statment
78 78
 	 * @var string
79
-	*/
80
-    private $groupBy             = null;
79
+	 */
80
+	private $groupBy             = null;
81 81
 	
82 82
 	/**
83 83
 	 * The SQL HAVING statment
84 84
 	 * @var string
85
-	*/
86
-    private $having              = null;
85
+	 */
86
+	private $having              = null;
87 87
 	
88 88
 	/**
89 89
 	 * The number of rows returned by the last query
90 90
 	 * @var int
91
-	*/
92
-    private $numRows             = 0;
91
+	 */
92
+	private $numRows             = 0;
93 93
 	
94 94
 	/**
95 95
 	 * The last insert id for the primary key column that have auto increment or sequence
96 96
 	 * @var mixed
97
-	*/
98
-    private $insertId            = null;
97
+	 */
98
+	private $insertId            = null;
99 99
 	
100 100
 	/**
101 101
 	 * The full SQL query statment after build for each command
102 102
 	 * @var string
103
-	*/
104
-    private $query               = null;
103
+	 */
104
+	private $query               = null;
105 105
 	
106 106
 	/**
107 107
 	 * The error returned for the last query
108 108
 	 * @var string
109
-	*/
110
-    private $error               = null;
109
+	 */
110
+	private $error               = null;
111 111
 	
112 112
 	/**
113 113
 	 * The result returned for the last query
114 114
 	 * @var mixed
115
-	*/
116
-    private $result              = array();
115
+	 */
116
+	private $result              = array();
117 117
 	
118 118
 	/**
119 119
 	 * The prefix used in each database table
120 120
 	 * @var string
121
-	*/
122
-    private $prefix              = null;
121
+	 */
122
+	private $prefix              = null;
123 123
 	
124 124
 	/**
125 125
 	 * The list of SQL valid operators
126 126
 	 * @var array
127
-	*/
128
-    private $operatorList        = array('=','!=','<','>','<=','>=','<>');
127
+	 */
128
+	private $operatorList        = array('=','!=','<','>','<=','>=','<>');
129 129
     
130 130
 	/**
131 131
 	 * The cache default time to live in second. 0 means no need to use the cache feature
132 132
 	 * @var int
133
-	*/
133
+	 */
134 134
 	private $cacheTtl              = 0;
135 135
 	
136 136
 	/**
137 137
 	 * The cache current time to live. 0 means no need to use the cache feature
138 138
 	 * @var int
139
-	*/
140
-    private $temporaryCacheTtl   = 0;
139
+	 */
140
+	private $temporaryCacheTtl   = 0;
141 141
 	
142 142
 	/**
143 143
 	 * The number of executed query for the current request
144 144
 	 * @var int
145
-	*/
146
-    private $queryCount          = 0;
145
+	 */
146
+	private $queryCount          = 0;
147 147
 	
148 148
 	/**
149 149
 	 * The default data to be used in the statments query INSERT, UPDATE
150 150
 	 * @var array
151
-	*/
152
-    private $data                = array();
151
+	 */
152
+	private $data                = array();
153 153
 	
154 154
 	/**
155 155
 	 * The database configuration
156 156
 	 * @var array
157
-	*/
158
-    private $config              = array();
157
+	 */
158
+	private $config              = array();
159 159
 	
160 160
 	/**
161 161
 	 * The logger instance
162 162
 	 * @var Log
163 163
 	 */
164
-    private $logger              = null;
165
-
166
-
167
-    /**
168
-    * The cache instance
169
-    * @var CacheInterface
170
-    */
171
-    private $cacheInstance       = null;
172
-
173
-     /**
174
-    * The benchmark instance
175
-    * @var Benchmark
176
-    */
177
-    private $benchmarkInstance   = null;
178
-
179
-
180
-    /**
181
-     * Construct new database
182
-     * @param array $overwriteConfig the config to overwrite with the config set in database.php
183
-     * @param object $logger the log instance
184
-     */
185
-    public function __construct($overwriteConfig = array(), Log $logger = null){
186
-        /**
187
-         * instance of the Log class
188
-         */
189
-        if(is_object($logger)){
190
-          $this->logger = $logger;
191
-        }
192
-        else{
193
-            $this->logger =& class_loader('Log', 'classes');
194
-            $this->logger->setLogger('Library::Database');
195
-        }
196
-
197
-        $db = array();
198
-      	if(file_exists(CONFIG_PATH . 'database.php')){
199
-          //here don't use require_once because somewhere user can create database instance directly
200
-      	  require CONFIG_PATH . 'database.php';
201
-        }
164
+	private $logger              = null;
165
+
166
+
167
+	/**
168
+	 * The cache instance
169
+	 * @var CacheInterface
170
+	 */
171
+	private $cacheInstance       = null;
172
+
173
+	 /**
174
+	  * The benchmark instance
175
+	  * @var Benchmark
176
+	  */
177
+	private $benchmarkInstance   = null;
178
+
179
+
180
+	/**
181
+	 * Construct new database
182
+	 * @param array $overwriteConfig the config to overwrite with the config set in database.php
183
+	 * @param object $logger the log instance
184
+	 */
185
+	public function __construct($overwriteConfig = array(), Log $logger = null){
186
+		/**
187
+		 * instance of the Log class
188
+		 */
189
+		if(is_object($logger)){
190
+		  $this->logger = $logger;
191
+		}
192
+		else{
193
+			$this->logger =& class_loader('Log', 'classes');
194
+			$this->logger->setLogger('Library::Database');
195
+		}
196
+
197
+		$db = array();
198
+	  	if(file_exists(CONFIG_PATH . 'database.php')){
199
+		  //here don't use require_once because somewhere user can create database instance directly
200
+	  	  require CONFIG_PATH . 'database.php';
201
+		}
202 202
           
203 203
 				if(! empty($overwriteConfig)){
204 204
 				  $db = array_merge($db, $overwriteConfig);
205 205
 				}
206
-        $config = array();
206
+		$config = array();
207 207
 				$config['driver']    = isset($db['driver']) ? $db['driver'] : 'mysql';
208 208
 				$config['username']  = isset($db['username']) ? $db['username'] : 'root';
209 209
 				$config['password']  = isset($db['password']) ? $db['password'] : '';
@@ -212,1031 +212,1031 @@  discard block
 block discarded – undo
212 212
 				$config['charset']   = isset($db['charset']) ? $db['charset'] : 'utf8';
213 213
 				$config['collation'] = isset($db['collation']) ? $db['collation'] : 'utf8_general_ci';
214 214
 				$config['prefix']    = isset($db['prefix']) ? $db['prefix'] : '';
215
-        $port = '';
216
-        if(strstr($config['hostname'], ':')){
217
-          $p = explode(':', $config['hostname']);
218
-          $port = isset($p[1]) ? $p[1] : '';
219
-          $config['hostname'] = isset($p[0]) ? $p[0] : '';
220
-        }
215
+		$port = '';
216
+		if(strstr($config['hostname'], ':')){
217
+		  $p = explode(':', $config['hostname']);
218
+		  $port = isset($p[1]) ? $p[1] : '';
219
+		  $config['hostname'] = isset($p[0]) ? $p[0] : '';
220
+		}
221 221
 				$config['port']      = $port;
222 222
 				
223 223
 		  	$this->setDatabaseConfiguration($config);
224
-    		$this->temporaryCacheTtl = $this->cacheTtl;
225
-    }
226
-
227
-    /**
228
-     * This is used to connect to database
229
-     * @return bool 
230
-     */
231
-    public function connect(){
232
-      $config = $this->getDatabaseConfiguration();
233
-      if(! empty($config)){
234
-        try{
235
-            $driverDsnMap = array(
236
-              'mysql' => 'mysql:host=' . $config['hostname'] . ';' 
237
-                          . (($config['port']) != '' ? 'port=' . $config['port'] . ';' : '') 
238
-                          . 'dbname=' . $config['database'],
239
-              'pgsql' => 'pgsql:host=' . $config['hostname'] . ';' 
240
-                          . (($config['port']) != '' ? 'port=' . $config['port'] . ';' : '')
241
-                          . 'dbname=' . $config['database'],
242
-              'sqlite' => 'sqlite:' . $config['database'],
243
-              'oracle' => 'oci:dbname=' . $config['hostname'] 
244
-                          . (($config['port']) != '' ? ':' . $config['port'] : '')
245
-                          . '/' . $config['database']
246
-            );
247
-            $dsn = isset($driverDsnMap[$config['driver']]) ? $driverDsnMap[$config['driver']] : '';
224
+			$this->temporaryCacheTtl = $this->cacheTtl;
225
+	}
226
+
227
+	/**
228
+	 * This is used to connect to database
229
+	 * @return bool 
230
+	 */
231
+	public function connect(){
232
+	  $config = $this->getDatabaseConfiguration();
233
+	  if(! empty($config)){
234
+		try{
235
+			$driverDsnMap = array(
236
+			  'mysql' => 'mysql:host=' . $config['hostname'] . ';' 
237
+						  . (($config['port']) != '' ? 'port=' . $config['port'] . ';' : '') 
238
+						  . 'dbname=' . $config['database'],
239
+			  'pgsql' => 'pgsql:host=' . $config['hostname'] . ';' 
240
+						  . (($config['port']) != '' ? 'port=' . $config['port'] . ';' : '')
241
+						  . 'dbname=' . $config['database'],
242
+			  'sqlite' => 'sqlite:' . $config['database'],
243
+			  'oracle' => 'oci:dbname=' . $config['hostname'] 
244
+						  . (($config['port']) != '' ? ':' . $config['port'] : '')
245
+						  . '/' . $config['database']
246
+			);
247
+			$dsn = isset($driverDsnMap[$config['driver']]) ? $driverDsnMap[$config['driver']] : '';
248 248
             
249
-            $this->pdo = new PDO($dsn, $config['username'], $config['password']);
250
-            $this->pdo->exec("SET NAMES '" . $config['charset'] . "' COLLATE '" . $config['collation'] . "'");
251
-            $this->pdo->exec("SET CHARACTER SET '" . $config['charset'] . "'");
252
-            $this->pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_OBJ);
253
-            return true;
254
-          }
255
-          catch (PDOException $e){
256
-            $this->logger->fatal($e->getMessage());
257
-            show_error('Cannot connect to Database.');
258
-            return false;
259
-          }
260
-      }
261
-      else{
262
-        show_error('Database configuration is not set.');
263
-        return false;
264
-      }
265
-    }
266
-
267
-    /**
268
-     * Set the SQL FROM statment
269
-     * @param  string|array $table the table name or array of table list
270
-     * @return object        the current Database instance
271
-     */
272
-    public function from($table){
273
-      if(is_array($table)){
274
-        $froms = '';
275
-        foreach($table as $key){
276
-          $froms .= $this->prefix . $key . ', ';
277
-        }
278
-        $this->from = rtrim($froms, ', ');
279
-      }
280
-      else{
281
-        $this->from = $this->prefix . $table;
282
-      }
283
-      return $this;
284
-    }
285
-
286
-    /**
287
-     * Set the SQL SELECT statment
288
-     * @param  string|array $fields the field name or array of field list
289
-     * @return object        the current Database instance
290
-     */
291
-    public function select($fields){
292
-      $select = (is_array($fields) ? implode(', ', $fields) : $fields);
293
-      $this->select = ($this->select == '*' ? $select : $this->select . ', ' . $select);
294
-      return $this;
295
-    }
296
-
297
-    /**
298
-     * Set the SQL SELECT DISTINCT statment
299
-     * @param  string $field the field name to distinct
300
-     * @return object        the current Database instance
301
-     */
302
-    public function distinct($field){
303
-      $distinct = ' DISTINCT ' . $field;
304
-      $this->select = ($this->select == '*' ? $distinct : $this->select . ', ' . $distinct);
305
-
306
-      return $this;
307
-    }
308
-
309
-    /**
310
-     * Set the SQL function MAX in SELECT statment
311
-     * @param  string $field the field name
312
-     * @param  string $name  if is not null represent the alias used for this field in the result
313
-     * @return object        the current Database instance
314
-     */
315
-    public function max($field, $name = null){
316
-      $func = 'MAX(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
317
-      $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
318
-      return $this;
319
-    }
320
-
321
-    /**
322
-     * Set the SQL function MIN in SELECT statment
323
-     * @param  string $field the field name
324
-     * @param  string $name  if is not null represent the alias used for this field in the result
325
-     * @return object        the current Database instance
326
-     */
327
-    public function min($field, $name = null){
328
-      $func = 'MIN(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
329
-      $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
330
-      return $this;
331
-    }
332
-
333
-    /**
334
-     * Set the SQL function SUM in SELECT statment
335
-     * @param  string $field the field name
336
-     * @param  string $name  if is not null represent the alias used for this field in the result
337
-     * @return object        the current Database instance
338
-     */
339
-    public function sum($field, $name = null){
340
-      $func = 'SUM(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
341
-      $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
342
-      return $this;
343
-    }
344
-
345
-    /**
346
-     * Set the SQL function COUNT in SELECT statment
347
-     * @param  string $field the field name
348
-     * @param  string $name  if is not null represent the alias used for this field in the result
349
-     * @return object        the current Database instance
350
-     */
351
-    public function count($field = '*', $name = null){
352
-      $func = 'COUNT(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
353
-      $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
354
-      return $this;
355
-    }
356
-
357
-    /**
358
-     * Set the SQL function AVG in SELECT statment
359
-     * @param  string $field the field name
360
-     * @param  string $name  if is not null represent the alias used for this field in the result
361
-     * @return object        the current Database instance
362
-     */
363
-    public function avg($field, $name = null){
364
-      $func = 'AVG(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
365
-      $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
366
-      return $this;
367
-    }
368
-
369
-    /**
370
-     * Set the SQL JOIN statment
371
-     * @param  string $table  the join table name
372
-     * @param  string $field1 the first field for join conditions	
373
-     * @param  string $op     the join condition operator. If is null the default will be "="
374
-     * @param  string $field2 the second field for join conditions
375
-     * @param  string $type   the type of join (INNER, LEFT, RIGHT)
376
-     * @return object        the current Database instance
377
-     */
378
-    public function join($table, $field1 = null, $op = null, $field2 = null, $type = ''){
379
-      $on = $field1;
380
-      $table = $this->prefix . $table;
381
-      if(! is_null($op)){
382
-        $on = (! in_array($op, $this->operatorList) ? $this->prefix . $field1 . ' = ' . $this->prefix . $op : $this->prefix . $field1 . ' ' . $op . ' ' . $this->prefix . $field2);
383
-      }
384
-      if (is_null($this->join)){
385
-        $this->join = ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
386
-      }
387
-      else{
388
-        $this->join = $this->join . ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
389
-      }
390
-      return $this;
391
-    }
392
-
393
-    /**
394
-     * Set the SQL INNER JOIN statment
395
-     * @see  Database::join()
396
-     * @return object        the current Database instance
397
-     */
398
-    public function innerJoin($table, $field1, $op = null, $field2 = ''){
399
-      return $this->join($table, $field1, $op, $field2, 'INNER ');
400
-    }
401
-
402
-    /**
403
-     * Set the SQL LEFT JOIN statment
404
-     * @see  Database::join()
405
-     * @return object        the current Database instance
406
-     */
407
-    public function leftJoin($table, $field1, $op = null, $field2 = ''){
408
-      return $this->join($table, $field1, $op, $field2, 'LEFT ');
409
-	}
410
-
411
-	/**
412
-     * Set the SQL RIGHT JOIN statment
413
-     * @see  Database::join()
414
-     * @return object        the current Database instance
415
-     */
416
-    public function rightJoin($table, $field1, $op = null, $field2 = ''){
417
-      return $this->join($table, $field1, $op, $field2, 'RIGHT ');
418
-    }
419
-
420
-    /**
421
-     * Set the SQL FULL OUTER JOIN statment
422
-     * @see  Database::join()
423
-     * @return object        the current Database instance
424
-     */
425
-    public function fullOuterJoin($table, $field1, $op = null, $field2 = ''){
426
-    	return $this->join($table, $field1, $op, $field2, 'FULL OUTER ');
427
-    }
428
-
429
-    /**
430
-     * Set the SQL LEFT OUTER JOIN statment
431
-     * @see  Database::join()
432
-     * @return object        the current Database instance
433
-     */
434
-    public function leftOuterJoin($table, $field1, $op = null, $field2 = ''){
435
-      return $this->join($table, $field1, $op, $field2, 'LEFT OUTER ');
436
-    }
437
-
438
-    /**
439
-     * Set the SQL RIGHT OUTER JOIN statment
440
-     * @see  Database::join()
441
-     * @return object        the current Database instance
442
-     */
443
-    public function rightOuterJoin($table, $field1, $op = null, $field2 = ''){
444
-      return $this->join($table, $field1, $op, $field2, 'RIGHT OUTER ');
445
-    }
446
-
447
-    /**
448
-     * Set the SQL WHERE CLAUSE for IS NULL
449
-     * @param  string|array $field  the field name or array of field list
450
-     * @param  string $andOr the separator type used 'AND', 'OR', etc.
451
-     * @return object        the current Database instance
452
-     */
453
-    public function whereIsNull($field, $andOr = 'AND'){
454
-      if(is_array($field)){
455
-        foreach($field as $f){
456
-        	$this->whereIsNull($f, $andOr);
457
-        }
458
-      }
459
-      else{
460
-        if (! $this->where){
461
-          $this->where = $field.' IS NULL ';
462
-        }
463
-        else{
464
-            $this->where = $this->where . ' '.$andOr.' ' . $field.' IS NULL ';
465
-          }
466
-      }
467
-      return $this;
468
-    }
469
-
470
-    /**
471
-     * Set the SQL WHERE CLAUSE for IS NOT NULL
472
-     * @param  string|array $field  the field name or array of field list
473
-     * @param  string $andOr the separator type used 'AND', 'OR', etc.
474
-     * @return object        the current Database instance
475
-     */
476
-    public function whereIsNotNull($field, $andOr = 'AND'){
477
-      if(is_array($field)){
478
-        foreach($field as $f){
479
-          $this->whereIsNotNull($f, $andOr);
480
-        }
481
-      }
482
-      else{
483
-        if (! $this->where){
484
-          $this->where = $field.' IS NOT NULL ';
485
-        }
486
-        else{
487
-            $this->where = $this->where . ' '.$andOr.' ' . $field.' IS NOT NULL ';
488
-          }
489
-      }
490
-      return $this;
491
-    }
249
+			$this->pdo = new PDO($dsn, $config['username'], $config['password']);
250
+			$this->pdo->exec("SET NAMES '" . $config['charset'] . "' COLLATE '" . $config['collation'] . "'");
251
+			$this->pdo->exec("SET CHARACTER SET '" . $config['charset'] . "'");
252
+			$this->pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_OBJ);
253
+			return true;
254
+		  }
255
+		  catch (PDOException $e){
256
+			$this->logger->fatal($e->getMessage());
257
+			show_error('Cannot connect to Database.');
258
+			return false;
259
+		  }
260
+	  }
261
+	  else{
262
+		show_error('Database configuration is not set.');
263
+		return false;
264
+	  }
265
+	}
266
+
267
+	/**
268
+	 * Set the SQL FROM statment
269
+	 * @param  string|array $table the table name or array of table list
270
+	 * @return object        the current Database instance
271
+	 */
272
+	public function from($table){
273
+	  if(is_array($table)){
274
+		$froms = '';
275
+		foreach($table as $key){
276
+		  $froms .= $this->prefix . $key . ', ';
277
+		}
278
+		$this->from = rtrim($froms, ', ');
279
+	  }
280
+	  else{
281
+		$this->from = $this->prefix . $table;
282
+	  }
283
+	  return $this;
284
+	}
285
+
286
+	/**
287
+	 * Set the SQL SELECT statment
288
+	 * @param  string|array $fields the field name or array of field list
289
+	 * @return object        the current Database instance
290
+	 */
291
+	public function select($fields){
292
+	  $select = (is_array($fields) ? implode(', ', $fields) : $fields);
293
+	  $this->select = ($this->select == '*' ? $select : $this->select . ', ' . $select);
294
+	  return $this;
295
+	}
296
+
297
+	/**
298
+	 * Set the SQL SELECT DISTINCT statment
299
+	 * @param  string $field the field name to distinct
300
+	 * @return object        the current Database instance
301
+	 */
302
+	public function distinct($field){
303
+	  $distinct = ' DISTINCT ' . $field;
304
+	  $this->select = ($this->select == '*' ? $distinct : $this->select . ', ' . $distinct);
305
+
306
+	  return $this;
307
+	}
308
+
309
+	/**
310
+	 * Set the SQL function MAX in SELECT statment
311
+	 * @param  string $field the field name
312
+	 * @param  string $name  if is not null represent the alias used for this field in the result
313
+	 * @return object        the current Database instance
314
+	 */
315
+	public function max($field, $name = null){
316
+	  $func = 'MAX(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
317
+	  $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
318
+	  return $this;
319
+	}
320
+
321
+	/**
322
+	 * Set the SQL function MIN in SELECT statment
323
+	 * @param  string $field the field name
324
+	 * @param  string $name  if is not null represent the alias used for this field in the result
325
+	 * @return object        the current Database instance
326
+	 */
327
+	public function min($field, $name = null){
328
+	  $func = 'MIN(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
329
+	  $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
330
+	  return $this;
331
+	}
332
+
333
+	/**
334
+	 * Set the SQL function SUM in SELECT statment
335
+	 * @param  string $field the field name
336
+	 * @param  string $name  if is not null represent the alias used for this field in the result
337
+	 * @return object        the current Database instance
338
+	 */
339
+	public function sum($field, $name = null){
340
+	  $func = 'SUM(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
341
+	  $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
342
+	  return $this;
343
+	}
344
+
345
+	/**
346
+	 * Set the SQL function COUNT in SELECT statment
347
+	 * @param  string $field the field name
348
+	 * @param  string $name  if is not null represent the alias used for this field in the result
349
+	 * @return object        the current Database instance
350
+	 */
351
+	public function count($field = '*', $name = null){
352
+	  $func = 'COUNT(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
353
+	  $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
354
+	  return $this;
355
+	}
356
+
357
+	/**
358
+	 * Set the SQL function AVG in SELECT statment
359
+	 * @param  string $field the field name
360
+	 * @param  string $name  if is not null represent the alias used for this field in the result
361
+	 * @return object        the current Database instance
362
+	 */
363
+	public function avg($field, $name = null){
364
+	  $func = 'AVG(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
365
+	  $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
366
+	  return $this;
367
+	}
368
+
369
+	/**
370
+	 * Set the SQL JOIN statment
371
+	 * @param  string $table  the join table name
372
+	 * @param  string $field1 the first field for join conditions	
373
+	 * @param  string $op     the join condition operator. If is null the default will be "="
374
+	 * @param  string $field2 the second field for join conditions
375
+	 * @param  string $type   the type of join (INNER, LEFT, RIGHT)
376
+	 * @return object        the current Database instance
377
+	 */
378
+	public function join($table, $field1 = null, $op = null, $field2 = null, $type = ''){
379
+	  $on = $field1;
380
+	  $table = $this->prefix . $table;
381
+	  if(! is_null($op)){
382
+		$on = (! in_array($op, $this->operatorList) ? $this->prefix . $field1 . ' = ' . $this->prefix . $op : $this->prefix . $field1 . ' ' . $op . ' ' . $this->prefix . $field2);
383
+	  }
384
+	  if (is_null($this->join)){
385
+		$this->join = ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
386
+	  }
387
+	  else{
388
+		$this->join = $this->join . ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
389
+	  }
390
+	  return $this;
391
+	}
392
+
393
+	/**
394
+	 * Set the SQL INNER JOIN statment
395
+	 * @see  Database::join()
396
+	 * @return object        the current Database instance
397
+	 */
398
+	public function innerJoin($table, $field1, $op = null, $field2 = ''){
399
+	  return $this->join($table, $field1, $op, $field2, 'INNER ');
400
+	}
401
+
402
+	/**
403
+	 * Set the SQL LEFT JOIN statment
404
+	 * @see  Database::join()
405
+	 * @return object        the current Database instance
406
+	 */
407
+	public function leftJoin($table, $field1, $op = null, $field2 = ''){
408
+	  return $this->join($table, $field1, $op, $field2, 'LEFT ');
409
+	}
410
+
411
+	/**
412
+	 * Set the SQL RIGHT JOIN statment
413
+	 * @see  Database::join()
414
+	 * @return object        the current Database instance
415
+	 */
416
+	public function rightJoin($table, $field1, $op = null, $field2 = ''){
417
+	  return $this->join($table, $field1, $op, $field2, 'RIGHT ');
418
+	}
419
+
420
+	/**
421
+	 * Set the SQL FULL OUTER JOIN statment
422
+	 * @see  Database::join()
423
+	 * @return object        the current Database instance
424
+	 */
425
+	public function fullOuterJoin($table, $field1, $op = null, $field2 = ''){
426
+		return $this->join($table, $field1, $op, $field2, 'FULL OUTER ');
427
+	}
428
+
429
+	/**
430
+	 * Set the SQL LEFT OUTER JOIN statment
431
+	 * @see  Database::join()
432
+	 * @return object        the current Database instance
433
+	 */
434
+	public function leftOuterJoin($table, $field1, $op = null, $field2 = ''){
435
+	  return $this->join($table, $field1, $op, $field2, 'LEFT OUTER ');
436
+	}
437
+
438
+	/**
439
+	 * Set the SQL RIGHT OUTER JOIN statment
440
+	 * @see  Database::join()
441
+	 * @return object        the current Database instance
442
+	 */
443
+	public function rightOuterJoin($table, $field1, $op = null, $field2 = ''){
444
+	  return $this->join($table, $field1, $op, $field2, 'RIGHT OUTER ');
445
+	}
446
+
447
+	/**
448
+	 * Set the SQL WHERE CLAUSE for IS NULL
449
+	 * @param  string|array $field  the field name or array of field list
450
+	 * @param  string $andOr the separator type used 'AND', 'OR', etc.
451
+	 * @return object        the current Database instance
452
+	 */
453
+	public function whereIsNull($field, $andOr = 'AND'){
454
+	  if(is_array($field)){
455
+		foreach($field as $f){
456
+			$this->whereIsNull($f, $andOr);
457
+		}
458
+	  }
459
+	  else{
460
+		if (! $this->where){
461
+		  $this->where = $field.' IS NULL ';
462
+		}
463
+		else{
464
+			$this->where = $this->where . ' '.$andOr.' ' . $field.' IS NULL ';
465
+		  }
466
+	  }
467
+	  return $this;
468
+	}
469
+
470
+	/**
471
+	 * Set the SQL WHERE CLAUSE for IS NOT NULL
472
+	 * @param  string|array $field  the field name or array of field list
473
+	 * @param  string $andOr the separator type used 'AND', 'OR', etc.
474
+	 * @return object        the current Database instance
475
+	 */
476
+	public function whereIsNotNull($field, $andOr = 'AND'){
477
+	  if(is_array($field)){
478
+		foreach($field as $f){
479
+		  $this->whereIsNotNull($f, $andOr);
480
+		}
481
+	  }
482
+	  else{
483
+		if (! $this->where){
484
+		  $this->where = $field.' IS NOT NULL ';
485
+		}
486
+		else{
487
+			$this->where = $this->where . ' '.$andOr.' ' . $field.' IS NOT NULL ';
488
+		  }
489
+	  }
490
+	  return $this;
491
+	}
492 492
     
493
-    /**
494
-     * Set the SQL WHERE CLAUSE statment
495
-     * @param  string|array  $where the where field or array of field list
496
-     * @param  string  $op     the condition operator. If is null the default will be "="
497
-     * @param  mixed  $val    the where value
498
-     * @param  string  $type   the type used for this where clause (NOT, etc.)
499
-     * @param  string  $andOr the separator type used 'AND', 'OR', etc.
500
-     * @param  boolean $escape whether to escape or not the $val
501
-     * @return object        the current Database instance
502
-     */
503
-    public function where($where, $op = null, $val = null, $type = '', $andOr = 'AND', $escape = true){
504
-      if (is_array($where)){
505
-        $_where = array();
506
-        foreach ($where as $column => $data){
507
-          if(is_null($data)){
508
-            $data = '';
509
-          }
510
-          $_where[] = $type . $column . '=' . ($escape ? $this->escape($data) : $data);
511
-        }
512
-        $where = implode(' '.$andOr.' ', $_where);
513
-      }
514
-      else{
515
-        if(is_array($op)){
516
-          $x = explode('?', $where);
517
-          $w = '';
518
-          foreach($x as $k => $v){
519
-            if(! empty($v)){
520
-                if(isset($op[$k]) && is_null($op[$k])){
521
-                  $op[$k] = '';
522
-                }
523
-                $w .= $type . $v . (isset($op[$k]) ? ($escape ? $this->escape($op[$k]) : $op[$k]) : '');
524
-            }
525
-          }
526
-          $where = $w;
527
-        }
528
-        else if (! in_array((string)$op, $this->operatorList)){
529
-          if(is_null($op)){
530
-            $op = '';
531
-          }
532
-        	$where = $type . $where . ' = ' . ($escape ? $this->escape($op) : $op);
533
-        }
534
-        else{
535
-          if(is_null($val)){
536
-            $val = '';
537
-          }
538
-        	$where = $type . $where . $op . ($escape ? $this->escape($val) : $val);
539
-        }
540
-      }
541
-      if (is_null($this->where)){
542
-        $this->where = $where;
543
-      }
544
-      else{
545
-        if(substr($this->where, -1) == '('){
546
-          $this->where = $this->where . ' ' . $where;
547
-        }
548
-        else{
549
-          $this->where = $this->where . ' '.$andOr.' ' . $where;
550
-        }
551
-      }
552
-      return $this;
553
-    }
554
-
555
-    /**
556
-     * Set the SQL WHERE CLAUSE statment using OR
557
-     * @see  Database::where()
558
-     * @return object        the current Database instance
559
-     */
560
-    public function orWhere($where, $op = null, $val = null, $escape = true){
561
-      return $this->where($where, $op, $val, '', 'OR', $escape);
562
-    }
563
-
564
-
565
-    /**
566
-     * Set the SQL WHERE CLAUSE statment using AND and NOT
567
-     * @see  Database::where()
568
-     * @return object        the current Database instance
569
-     */
570
-    public function notWhere($where, $op = null, $val = null, $escape = true){
571
-      return $this->where($where, $op, $val, 'NOT ', 'AND', $escape);
572
-    }
573
-
574
-    /**
575
-     * Set the SQL WHERE CLAUSE statment using OR and NOT
576
-     * @see  Database::where()
577
-     * @return object        the current Database instance
578
-     */
579
-    public function orNotWhere($where, $op = null, $val = null, $escape = true){
580
-    	return $this->where($where, $op, $val, 'NOT ', 'OR', $escape);
581
-    }
582
-
583
-    /**
584
-     * Set the opened parenthesis for the complex SQL query
585
-     * @param  string $type   the type of this grouped (NOT, etc.)
586
-     * @param  string $andOr the multiple conditions separator (AND, OR, etc.)
587
-     * @return object        the current Database instance
588
-     */
589
-    public function groupStart($type = '', $andOr = ' AND'){
590
-      if (is_null($this->where)){
591
-        $this->where = $type . ' (';
592
-      }
593
-      else{
594
-          if(substr($this->where, -1) == '('){
595
-            $this->where .= $type . ' (';
596
-          }
597
-          else{
598
-          	$this->where .= $andOr . ' ' . $type . ' (';
599
-          }
600
-      }
601
-      return $this;
602
-    }
603
-
604
-    /**
605
-     * Set the opened parenthesis for the complex SQL query using NOT type
606
-     * @see  Database::groupStart()
607
-     * @return object        the current Database instance
608
-     */
609
-    public function notGroupStart(){
610
-      return $this->groupStart('NOT');
611
-    }
612
-
613
-    /**
614
-     * Set the opened parenthesis for the complex SQL query using OR for separator
615
-     * @see  Database::groupStart()
616
-     * @return object        the current Database instance
617
-     */
618
-    public function orGroupStart(){
619
-      return $this->groupStart('', ' OR');
620
-    }
621
-
622
-     /**
623
-     * Set the opened parenthesis for the complex SQL query using OR for separator and NOT for type
624
-     * @see  Database::groupStart()
625
-     * @return object        the current Database instance
626
-     */
627
-    public function orNotGroupStart(){
628
-      return $this->groupStart('NOT', ' OR');
629
-    }
630
-
631
-    /**
632
-     * Close the parenthesis for the grouped SQL
633
-     * @return object        the current Database instance
634
-     */
635
-    public function groupEnd(){
636
-      $this->where .= ')';
637
-      return $this;
638
-    }
639
-
640
-    /**
641
-     * Set the SQL WHERE CLAUSE statment for IN
642
-     * @param  string  $field  the field name for IN statment
643
-     * @param  array   $keys   the list of values used
644
-     * @param  string  $type   the condition separator type (NOT)
645
-     * @param  string  $andOr the multiple conditions separator (OR, AND)
646
-     * @param  boolean $escape whether to escape or not the values
647
-     * @return object        the current Database instance
648
-     */
649
-    public function in($field, array $keys, $type = '', $andOr = 'AND', $escape = true){
650
-      if (is_array($keys)){
651
-        $_keys = array();
652
-        foreach ($keys as $k => $v){
653
-          if(is_null($v)){
654
-            $v = '';
655
-          }
656
-          $_keys[] = (is_numeric($v) ? $v : ($escape ? $this->escape($v) : $v));
657
-        }
658
-        $keys = implode(', ', $_keys);
659
-        if (is_null($this->where)){
660
-          $this->where = $field . ' ' . $type . 'IN (' . $keys . ')';
661
-        }
662
-        else{
663
-          if(substr($this->where, -1) == '('){
664
-            $this->where = $this->where . ' ' . $field . ' '.$type.'IN (' . $keys . ')';
665
-          }
666
-          else{
667
-            $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' '.$type.'IN (' . $keys . ')';
668
-          }
669
-        }
670
-      }
671
-      return $this;
672
-    }
673
-
674
-    /**
675
-     * Set the SQL WHERE CLAUSE statment for NOT IN with AND separator
676
-     * @see  Database::in()
677
-     * @return object        the current Database instance
678
-     */
679
-    public function notIn($field, array $keys, $escape = true){
680
-      return $this->in($field, $keys, 'NOT ', 'AND', $escape);
681
-    }
682
-
683
-    /**
684
-     * Set the SQL WHERE CLAUSE statment for IN with OR separator
685
-     * @see  Database::in()
686
-     * @return object        the current Database instance
687
-     */
688
-    public function orIn($field, array $keys, $escape = true){
689
-      return $this->in($field, $keys, '', 'OR', $escape);
690
-    }
691
-
692
-    /**
693
-     * Set the SQL WHERE CLAUSE statment for NOT IN with OR separator
694
-     * @see  Database::in()
695
-     * @return object        the current Database instance
696
-     */
697
-    public function orNotIn($field, array $keys, $escape = true){
698
-      return $this->in($field, $keys, 'NOT ', 'OR', $escape);
699
-    }
700
-
701
-    /**
702
-     * Set the SQL WHERE CLAUSE statment for BETWEEN
703
-     * @param  string  $field  the field used for the BETWEEN statment
704
-     * @param  mixed  $value1 the BETWEEN begin value
705
-     * @param  mixed  $value2 the BETWEEN end value
706
-     * @param  string  $type   the condition separator type (NOT)
707
-     * @param  string  $andOr the multiple conditions separator (OR, AND)
708
-     * @param  boolean $escape whether to escape or not the values
709
-     * @return object        the current Database instance
710
-     */
711
-    public function between($field, $value1, $value2, $type = '', $andOr = 'AND', $escape = true){
712
-      if(is_null($value1)){
713
-        $value1 = '';
714
-      }
715
-      if(is_null($value2)){
716
-        $value2 = '';
717
-      }
718
-      if (is_null($this->where)){
719
-      	$this->where = $field . ' ' . $type . 'BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
720
-      }
721
-      else{
722
-        if(substr($this->where, -1) == '('){
723
-          $this->where = $this->where . ' ' . $field . ' ' . $type . 'BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
724
-        }
725
-        else{
726
-          $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' ' . $type . 'BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
727
-        }
728
-      }
729
-      return $this;
730
-    }
731
-
732
-    /**
733
-     * Set the SQL WHERE CLAUSE statment for BETWEEN with NOT type and AND separator
734
-     * @see  Database::between()
735
-     * @return object        the current Database instance
736
-     */
737
-    public function notBetween($field, $value1, $value2, $escape = true){
738
-      return $this->between($field, $value1, $value2, 'NOT ', 'AND', $escape);
739
-    }
740
-
741
-    /**
742
-     * Set the SQL WHERE CLAUSE statment for BETWEEN with OR separator
743
-     * @see  Database::between()
744
-     * @return object        the current Database instance
745
-     */
746
-    public function orBetween($field, $value1, $value2, $escape = true){
747
-      return $this->between($field, $value1, $value2, '', 'OR', $escape);
748
-    }
749
-
750
-    /**
751
-     * Set the SQL WHERE CLAUSE statment for BETWEEN with NOT type and OR separator
752
-     * @see  Database::between()
753
-     * @return object        the current Database instance
754
-     */
755
-    public function orNotBetween($field, $value1, $value2, $escape = true){
756
-      return $this->between($field, $value1, $value2, 'NOT ', 'OR', $escape);
757
-    }
758
-
759
-    /**
760
-     * Set the SQL WHERE CLAUSE statment for LIKE
761
-     * @param  string  $field  the field name used in LIKE statment
762
-     * @param  string  $data   the LIKE value for this field including the '%', and '_' part
763
-     * @param  string  $type   the condition separator type (NOT)
764
-     * @param  string  $andOr the multiple conditions separator (OR, AND)
765
-     * @param  boolean $escape whether to escape or not the values
766
-     * @return object        the current Database instance
767
-     */
768
-    public function like($field, $data, $type = '', $andOr = 'AND', $escape = true){
769
-      if(is_null($data)){
770
-        $data = '';
771
-      }
772
-      $like = $escape ? $this->escape($data) : $data;
773
-      if (is_null($this->where)){
774
-        $this->where = $field . ' ' . $type . 'LIKE ' . $like;
775
-      }
776
-      else{
777
-        if(substr($this->where, -1) == '('){
778
-          $this->where = $this->where . ' ' . $field . ' ' . $type . 'LIKE ' . $like;
779
-        }
780
-        else{
781
-          $this->where = $this->where . ' '.$andOr.' ' . $field . ' ' . $type . 'LIKE ' . $like;
782
-        }
783
-      }
784
-      return $this;
785
-    }
786
-
787
-    /**
788
-     * Set the SQL WHERE CLAUSE statment for LIKE with OR separator
789
-     * @see  Database::like()
790
-     * @return object        the current Database instance
791
-     */
792
-    public function orLike($field, $data, $escape = true){
793
-      return $this->like($field, $data, '', 'OR', $escape);
794
-    }
795
-
796
-    /**
797
-     * Set the SQL WHERE CLAUSE statment for LIKE with NOT type and AND separator
798
-     * @see  Database::like()
799
-     * @return object        the current Database instance
800
-     */
801
-    public function notLike($field, $data, $escape = true){
802
-      return $this->like($field, $data, 'NOT ', 'AND', $escape);
803
-    }
804
-
805
-    /**
806
-     * Set the SQL WHERE CLAUSE statment for LIKE with NOT type and OR separator
807
-     * @see  Database::like()
808
-     * @return object        the current Database instance
809
-     */
810
-    public function orNotLike($field, $data, $escape = true){
811
-      return $this->like($field, $data, 'NOT ', 'OR', $escape);
812
-    }
813
-
814
-    /**
815
-     * Set the SQL LIMIT statment
816
-     * @param  int $limit    the limit offset. If $limitEnd is null this will be the limit count
817
-     * like LIMIT n;
818
-     * @param  int $limitEnd the limit count
819
-     * @return object        the current Database instance
820
-     */
821
-    public function limit($limit, $limitEnd = null){
822
-      if(is_null($limit)){
823
-        return;
824
-      }
825
-      if (! is_null($limitEnd)){
826
-        $this->limit = $limit . ', ' . $limitEnd;
827
-      }
828
-      else{
829
-        $this->limit = $limit;
830
-      }
831
-      return $this;
832
-    }
833
-
834
-    /**
835
-     * Set the SQL ORDER BY CLAUSE statment
836
-     * @param  string $orderBy   the field name used for order
837
-     * @param  string $orderDir the order direction (ASC or DESC)
838
-     * @return object        the current Database instance
839
-     */
840
-    public function orderBy($orderBy, $orderDir = ' ASC'){
841
-      if (! is_null($orderDir)){
842
-        $this->orderBy = ! $this->orderBy ? ($orderBy . ' ' . strtoupper($orderDir)) : $this->orderBy . ', ' . $orderBy . ' ' . strtoupper($orderDir);
843
-      }
844
-      else{
845
-        if(stristr($orderBy, ' ') || $orderBy == 'rand()'){
846
-          $this->orderBy = ! $this->orderBy ? $orderBy : $this->orderBy . ', ' . $orderBy;
847
-        }
848
-        else{
849
-          $this->orderBy = ! $this->orderBy ? ($orderBy . ' ASC') : $this->orderBy . ', ' . ($orderBy . ' ASC');
850
-        }
851
-      }
852
-      return $this;
853
-    }
854
-
855
-    /**
856
-     * Set the SQL GROUP BY CLAUSE statment
857
-     * @param  string|array $field the field name used or array of field list
858
-     * @return object        the current Database instance
859
-     */
860
-    public function groupBy($field){
861
-      if(is_array($field)){
862
-        $this->groupBy = implode(', ', $field);
863
-      }
864
-      else{
865
-        $this->groupBy = $field;
866
-      }
867
-      return $this;
868
-    }
869
-
870
-    /**
871
-     * Set the SQL HAVING CLAUSE statment
872
-     * @param  string  $field  the field name used for HAVING statment
873
-     * @param  string|array  $op     the operator used or array
874
-     * @param  mixed  $val    the value for HAVING comparaison
875
-     * @param  boolean $escape whether to escape or not the values
876
-     * @return object        the current Database instance
877
-     */
878
-    public function having($field, $op = null, $val = null, $escape = true){
879
-      if(is_array($op)){
880
-        $x = explode('?', $field);
881
-        $w = '';
882
-        foreach($x as $k => $v){
883
-  	      if(!empty($v)){
884
-            if(isset($op[$k]) && is_null($op[$k])){
885
-              $op[$k] = '';
886
-            }
887
-  	      	$w .= $v . (isset($op[$k]) ? ($escape ? $this->escape($op[$k]) : $op[$k]) : '');
888
-  	      }
889
-      	}
890
-        $this->having = $w;
891
-      }
892
-      else if (! in_array($op, $this->operatorList)){
893
-        if(is_null($op)){
894
-          $op = '';
895
-        }
896
-        $this->having = $field . ' > ' . ($escape ? $this->escape($op) : $op);
897
-      }
898
-      else{
899
-        if(is_null($val)){
900
-          $val = '';
901
-        }
902
-        $this->having = $field . ' ' . $op . ' ' . ($escape ? $this->escape($val) : $val);
903
-      }
904
-      return $this;
905
-    }
906
-
907
-    /**
908
-     * Return the number of rows returned by the current query
909
-     * @return int
910
-     */
911
-    public function numRows(){
912
-      return $this->numRows;
913
-    }
914
-
915
-    /**
916
-     * Return the last insert id value
917
-     * @return mixed
918
-     */
919
-    public function insertId(){
920
-      return $this->insertId;
921
-    }
922
-
923
-    /**
924
-     * Show an error got from the current query (SQL command synthax error, database driver returned error, etc.)
925
-     */
926
-    public function error(){
493
+	/**
494
+	 * Set the SQL WHERE CLAUSE statment
495
+	 * @param  string|array  $where the where field or array of field list
496
+	 * @param  string  $op     the condition operator. If is null the default will be "="
497
+	 * @param  mixed  $val    the where value
498
+	 * @param  string  $type   the type used for this where clause (NOT, etc.)
499
+	 * @param  string  $andOr the separator type used 'AND', 'OR', etc.
500
+	 * @param  boolean $escape whether to escape or not the $val
501
+	 * @return object        the current Database instance
502
+	 */
503
+	public function where($where, $op = null, $val = null, $type = '', $andOr = 'AND', $escape = true){
504
+	  if (is_array($where)){
505
+		$_where = array();
506
+		foreach ($where as $column => $data){
507
+		  if(is_null($data)){
508
+			$data = '';
509
+		  }
510
+		  $_where[] = $type . $column . '=' . ($escape ? $this->escape($data) : $data);
511
+		}
512
+		$where = implode(' '.$andOr.' ', $_where);
513
+	  }
514
+	  else{
515
+		if(is_array($op)){
516
+		  $x = explode('?', $where);
517
+		  $w = '';
518
+		  foreach($x as $k => $v){
519
+			if(! empty($v)){
520
+				if(isset($op[$k]) && is_null($op[$k])){
521
+				  $op[$k] = '';
522
+				}
523
+				$w .= $type . $v . (isset($op[$k]) ? ($escape ? $this->escape($op[$k]) : $op[$k]) : '');
524
+			}
525
+		  }
526
+		  $where = $w;
527
+		}
528
+		else if (! in_array((string)$op, $this->operatorList)){
529
+		  if(is_null($op)){
530
+			$op = '';
531
+		  }
532
+			$where = $type . $where . ' = ' . ($escape ? $this->escape($op) : $op);
533
+		}
534
+		else{
535
+		  if(is_null($val)){
536
+			$val = '';
537
+		  }
538
+			$where = $type . $where . $op . ($escape ? $this->escape($val) : $val);
539
+		}
540
+	  }
541
+	  if (is_null($this->where)){
542
+		$this->where = $where;
543
+	  }
544
+	  else{
545
+		if(substr($this->where, -1) == '('){
546
+		  $this->where = $this->where . ' ' . $where;
547
+		}
548
+		else{
549
+		  $this->where = $this->where . ' '.$andOr.' ' . $where;
550
+		}
551
+	  }
552
+	  return $this;
553
+	}
554
+
555
+	/**
556
+	 * Set the SQL WHERE CLAUSE statment using OR
557
+	 * @see  Database::where()
558
+	 * @return object        the current Database instance
559
+	 */
560
+	public function orWhere($where, $op = null, $val = null, $escape = true){
561
+	  return $this->where($where, $op, $val, '', 'OR', $escape);
562
+	}
563
+
564
+
565
+	/**
566
+	 * Set the SQL WHERE CLAUSE statment using AND and NOT
567
+	 * @see  Database::where()
568
+	 * @return object        the current Database instance
569
+	 */
570
+	public function notWhere($where, $op = null, $val = null, $escape = true){
571
+	  return $this->where($where, $op, $val, 'NOT ', 'AND', $escape);
572
+	}
573
+
574
+	/**
575
+	 * Set the SQL WHERE CLAUSE statment using OR and NOT
576
+	 * @see  Database::where()
577
+	 * @return object        the current Database instance
578
+	 */
579
+	public function orNotWhere($where, $op = null, $val = null, $escape = true){
580
+		return $this->where($where, $op, $val, 'NOT ', 'OR', $escape);
581
+	}
582
+
583
+	/**
584
+	 * Set the opened parenthesis for the complex SQL query
585
+	 * @param  string $type   the type of this grouped (NOT, etc.)
586
+	 * @param  string $andOr the multiple conditions separator (AND, OR, etc.)
587
+	 * @return object        the current Database instance
588
+	 */
589
+	public function groupStart($type = '', $andOr = ' AND'){
590
+	  if (is_null($this->where)){
591
+		$this->where = $type . ' (';
592
+	  }
593
+	  else{
594
+		  if(substr($this->where, -1) == '('){
595
+			$this->where .= $type . ' (';
596
+		  }
597
+		  else{
598
+		  	$this->where .= $andOr . ' ' . $type . ' (';
599
+		  }
600
+	  }
601
+	  return $this;
602
+	}
603
+
604
+	/**
605
+	 * Set the opened parenthesis for the complex SQL query using NOT type
606
+	 * @see  Database::groupStart()
607
+	 * @return object        the current Database instance
608
+	 */
609
+	public function notGroupStart(){
610
+	  return $this->groupStart('NOT');
611
+	}
612
+
613
+	/**
614
+	 * Set the opened parenthesis for the complex SQL query using OR for separator
615
+	 * @see  Database::groupStart()
616
+	 * @return object        the current Database instance
617
+	 */
618
+	public function orGroupStart(){
619
+	  return $this->groupStart('', ' OR');
620
+	}
621
+
622
+	 /**
623
+	  * Set the opened parenthesis for the complex SQL query using OR for separator and NOT for type
624
+	  * @see  Database::groupStart()
625
+	  * @return object        the current Database instance
626
+	  */
627
+	public function orNotGroupStart(){
628
+	  return $this->groupStart('NOT', ' OR');
629
+	}
630
+
631
+	/**
632
+	 * Close the parenthesis for the grouped SQL
633
+	 * @return object        the current Database instance
634
+	 */
635
+	public function groupEnd(){
636
+	  $this->where .= ')';
637
+	  return $this;
638
+	}
639
+
640
+	/**
641
+	 * Set the SQL WHERE CLAUSE statment for IN
642
+	 * @param  string  $field  the field name for IN statment
643
+	 * @param  array   $keys   the list of values used
644
+	 * @param  string  $type   the condition separator type (NOT)
645
+	 * @param  string  $andOr the multiple conditions separator (OR, AND)
646
+	 * @param  boolean $escape whether to escape or not the values
647
+	 * @return object        the current Database instance
648
+	 */
649
+	public function in($field, array $keys, $type = '', $andOr = 'AND', $escape = true){
650
+	  if (is_array($keys)){
651
+		$_keys = array();
652
+		foreach ($keys as $k => $v){
653
+		  if(is_null($v)){
654
+			$v = '';
655
+		  }
656
+		  $_keys[] = (is_numeric($v) ? $v : ($escape ? $this->escape($v) : $v));
657
+		}
658
+		$keys = implode(', ', $_keys);
659
+		if (is_null($this->where)){
660
+		  $this->where = $field . ' ' . $type . 'IN (' . $keys . ')';
661
+		}
662
+		else{
663
+		  if(substr($this->where, -1) == '('){
664
+			$this->where = $this->where . ' ' . $field . ' '.$type.'IN (' . $keys . ')';
665
+		  }
666
+		  else{
667
+			$this->where = $this->where . ' ' . $andOr . ' ' . $field . ' '.$type.'IN (' . $keys . ')';
668
+		  }
669
+		}
670
+	  }
671
+	  return $this;
672
+	}
673
+
674
+	/**
675
+	 * Set the SQL WHERE CLAUSE statment for NOT IN with AND separator
676
+	 * @see  Database::in()
677
+	 * @return object        the current Database instance
678
+	 */
679
+	public function notIn($field, array $keys, $escape = true){
680
+	  return $this->in($field, $keys, 'NOT ', 'AND', $escape);
681
+	}
682
+
683
+	/**
684
+	 * Set the SQL WHERE CLAUSE statment for IN with OR separator
685
+	 * @see  Database::in()
686
+	 * @return object        the current Database instance
687
+	 */
688
+	public function orIn($field, array $keys, $escape = true){
689
+	  return $this->in($field, $keys, '', 'OR', $escape);
690
+	}
691
+
692
+	/**
693
+	 * Set the SQL WHERE CLAUSE statment for NOT IN with OR separator
694
+	 * @see  Database::in()
695
+	 * @return object        the current Database instance
696
+	 */
697
+	public function orNotIn($field, array $keys, $escape = true){
698
+	  return $this->in($field, $keys, 'NOT ', 'OR', $escape);
699
+	}
700
+
701
+	/**
702
+	 * Set the SQL WHERE CLAUSE statment for BETWEEN
703
+	 * @param  string  $field  the field used for the BETWEEN statment
704
+	 * @param  mixed  $value1 the BETWEEN begin value
705
+	 * @param  mixed  $value2 the BETWEEN end value
706
+	 * @param  string  $type   the condition separator type (NOT)
707
+	 * @param  string  $andOr the multiple conditions separator (OR, AND)
708
+	 * @param  boolean $escape whether to escape or not the values
709
+	 * @return object        the current Database instance
710
+	 */
711
+	public function between($field, $value1, $value2, $type = '', $andOr = 'AND', $escape = true){
712
+	  if(is_null($value1)){
713
+		$value1 = '';
714
+	  }
715
+	  if(is_null($value2)){
716
+		$value2 = '';
717
+	  }
718
+	  if (is_null($this->where)){
719
+	  	$this->where = $field . ' ' . $type . 'BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
720
+	  }
721
+	  else{
722
+		if(substr($this->where, -1) == '('){
723
+		  $this->where = $this->where . ' ' . $field . ' ' . $type . 'BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
724
+		}
725
+		else{
726
+		  $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' ' . $type . 'BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
727
+		}
728
+	  }
729
+	  return $this;
730
+	}
731
+
732
+	/**
733
+	 * Set the SQL WHERE CLAUSE statment for BETWEEN with NOT type and AND separator
734
+	 * @see  Database::between()
735
+	 * @return object        the current Database instance
736
+	 */
737
+	public function notBetween($field, $value1, $value2, $escape = true){
738
+	  return $this->between($field, $value1, $value2, 'NOT ', 'AND', $escape);
739
+	}
740
+
741
+	/**
742
+	 * Set the SQL WHERE CLAUSE statment for BETWEEN with OR separator
743
+	 * @see  Database::between()
744
+	 * @return object        the current Database instance
745
+	 */
746
+	public function orBetween($field, $value1, $value2, $escape = true){
747
+	  return $this->between($field, $value1, $value2, '', 'OR', $escape);
748
+	}
749
+
750
+	/**
751
+	 * Set the SQL WHERE CLAUSE statment for BETWEEN with NOT type and OR separator
752
+	 * @see  Database::between()
753
+	 * @return object        the current Database instance
754
+	 */
755
+	public function orNotBetween($field, $value1, $value2, $escape = true){
756
+	  return $this->between($field, $value1, $value2, 'NOT ', 'OR', $escape);
757
+	}
758
+
759
+	/**
760
+	 * Set the SQL WHERE CLAUSE statment for LIKE
761
+	 * @param  string  $field  the field name used in LIKE statment
762
+	 * @param  string  $data   the LIKE value for this field including the '%', and '_' part
763
+	 * @param  string  $type   the condition separator type (NOT)
764
+	 * @param  string  $andOr the multiple conditions separator (OR, AND)
765
+	 * @param  boolean $escape whether to escape or not the values
766
+	 * @return object        the current Database instance
767
+	 */
768
+	public function like($field, $data, $type = '', $andOr = 'AND', $escape = true){
769
+	  if(is_null($data)){
770
+		$data = '';
771
+	  }
772
+	  $like = $escape ? $this->escape($data) : $data;
773
+	  if (is_null($this->where)){
774
+		$this->where = $field . ' ' . $type . 'LIKE ' . $like;
775
+	  }
776
+	  else{
777
+		if(substr($this->where, -1) == '('){
778
+		  $this->where = $this->where . ' ' . $field . ' ' . $type . 'LIKE ' . $like;
779
+		}
780
+		else{
781
+		  $this->where = $this->where . ' '.$andOr.' ' . $field . ' ' . $type . 'LIKE ' . $like;
782
+		}
783
+	  }
784
+	  return $this;
785
+	}
786
+
787
+	/**
788
+	 * Set the SQL WHERE CLAUSE statment for LIKE with OR separator
789
+	 * @see  Database::like()
790
+	 * @return object        the current Database instance
791
+	 */
792
+	public function orLike($field, $data, $escape = true){
793
+	  return $this->like($field, $data, '', 'OR', $escape);
794
+	}
795
+
796
+	/**
797
+	 * Set the SQL WHERE CLAUSE statment for LIKE with NOT type and AND separator
798
+	 * @see  Database::like()
799
+	 * @return object        the current Database instance
800
+	 */
801
+	public function notLike($field, $data, $escape = true){
802
+	  return $this->like($field, $data, 'NOT ', 'AND', $escape);
803
+	}
804
+
805
+	/**
806
+	 * Set the SQL WHERE CLAUSE statment for LIKE with NOT type and OR separator
807
+	 * @see  Database::like()
808
+	 * @return object        the current Database instance
809
+	 */
810
+	public function orNotLike($field, $data, $escape = true){
811
+	  return $this->like($field, $data, 'NOT ', 'OR', $escape);
812
+	}
813
+
814
+	/**
815
+	 * Set the SQL LIMIT statment
816
+	 * @param  int $limit    the limit offset. If $limitEnd is null this will be the limit count
817
+	 * like LIMIT n;
818
+	 * @param  int $limitEnd the limit count
819
+	 * @return object        the current Database instance
820
+	 */
821
+	public function limit($limit, $limitEnd = null){
822
+	  if(is_null($limit)){
823
+		return;
824
+	  }
825
+	  if (! is_null($limitEnd)){
826
+		$this->limit = $limit . ', ' . $limitEnd;
827
+	  }
828
+	  else{
829
+		$this->limit = $limit;
830
+	  }
831
+	  return $this;
832
+	}
833
+
834
+	/**
835
+	 * Set the SQL ORDER BY CLAUSE statment
836
+	 * @param  string $orderBy   the field name used for order
837
+	 * @param  string $orderDir the order direction (ASC or DESC)
838
+	 * @return object        the current Database instance
839
+	 */
840
+	public function orderBy($orderBy, $orderDir = ' ASC'){
841
+	  if (! is_null($orderDir)){
842
+		$this->orderBy = ! $this->orderBy ? ($orderBy . ' ' . strtoupper($orderDir)) : $this->orderBy . ', ' . $orderBy . ' ' . strtoupper($orderDir);
843
+	  }
844
+	  else{
845
+		if(stristr($orderBy, ' ') || $orderBy == 'rand()'){
846
+		  $this->orderBy = ! $this->orderBy ? $orderBy : $this->orderBy . ', ' . $orderBy;
847
+		}
848
+		else{
849
+		  $this->orderBy = ! $this->orderBy ? ($orderBy . ' ASC') : $this->orderBy . ', ' . ($orderBy . ' ASC');
850
+		}
851
+	  }
852
+	  return $this;
853
+	}
854
+
855
+	/**
856
+	 * Set the SQL GROUP BY CLAUSE statment
857
+	 * @param  string|array $field the field name used or array of field list
858
+	 * @return object        the current Database instance
859
+	 */
860
+	public function groupBy($field){
861
+	  if(is_array($field)){
862
+		$this->groupBy = implode(', ', $field);
863
+	  }
864
+	  else{
865
+		$this->groupBy = $field;
866
+	  }
867
+	  return $this;
868
+	}
869
+
870
+	/**
871
+	 * Set the SQL HAVING CLAUSE statment
872
+	 * @param  string  $field  the field name used for HAVING statment
873
+	 * @param  string|array  $op     the operator used or array
874
+	 * @param  mixed  $val    the value for HAVING comparaison
875
+	 * @param  boolean $escape whether to escape or not the values
876
+	 * @return object        the current Database instance
877
+	 */
878
+	public function having($field, $op = null, $val = null, $escape = true){
879
+	  if(is_array($op)){
880
+		$x = explode('?', $field);
881
+		$w = '';
882
+		foreach($x as $k => $v){
883
+  		  if(!empty($v)){
884
+			if(isset($op[$k]) && is_null($op[$k])){
885
+			  $op[$k] = '';
886
+			}
887
+  		  	$w .= $v . (isset($op[$k]) ? ($escape ? $this->escape($op[$k]) : $op[$k]) : '');
888
+  		  }
889
+	  	}
890
+		$this->having = $w;
891
+	  }
892
+	  else if (! in_array($op, $this->operatorList)){
893
+		if(is_null($op)){
894
+		  $op = '';
895
+		}
896
+		$this->having = $field . ' > ' . ($escape ? $this->escape($op) : $op);
897
+	  }
898
+	  else{
899
+		if(is_null($val)){
900
+		  $val = '';
901
+		}
902
+		$this->having = $field . ' ' . $op . ' ' . ($escape ? $this->escape($val) : $val);
903
+	  }
904
+	  return $this;
905
+	}
906
+
907
+	/**
908
+	 * Return the number of rows returned by the current query
909
+	 * @return int
910
+	 */
911
+	public function numRows(){
912
+	  return $this->numRows;
913
+	}
914
+
915
+	/**
916
+	 * Return the last insert id value
917
+	 * @return mixed
918
+	 */
919
+	public function insertId(){
920
+	  return $this->insertId;
921
+	}
922
+
923
+	/**
924
+	 * Show an error got from the current query (SQL command synthax error, database driver returned error, etc.)
925
+	 */
926
+	public function error(){
927 927
   		if($this->error){
928 928
   			show_error('Query: "' . $this->query . '" Error: ' . $this->error, 'Database Error');
929 929
   		}
930
-    }
931
-
932
-    /**
933
-     * Get the result of one record rows returned by the current query
934
-     * @param  boolean $returnSQLQueryOrResultType if is boolean and true will return the SQL query string.
935
-     * If is string will determine the result type "array" or "object"
936
-     * @return mixed       the query SQL string or the record result
937
-     */
938
-    public function get($returnSQLQueryOrResultType = false){
939
-      $this->limit = 1;
940
-      $query = $this->getAll(true);
941
-      if($returnSQLQueryOrResultType === true){
942
-        return $query;
943
-      }
944
-      else{
945
-        return $this->query( $query, false, (($returnSQLQueryOrResultType == 'array') ? true : false) );
946
-      }
947
-    }
948
-
949
-    /**
950
-     * Get the result of record rows list returned by the current query
951
-     * @param  boolean $returnSQLQueryOrResultType if is boolean and true will return the SQL query string.
952
-     * If is string will determine the result type "array" or "object"
953
-     * @return mixed       the query SQL string or the record result
954
-     */
955
-    public function getAll($returnSQLQueryOrResultType = false){
956
-      $query = 'SELECT ' . $this->select . ' FROM ' . $this->from;
957
-      if (! is_null($this->join)){
958
-        $query .= $this->join;
959
-      }
930
+	}
931
+
932
+	/**
933
+	 * Get the result of one record rows returned by the current query
934
+	 * @param  boolean $returnSQLQueryOrResultType if is boolean and true will return the SQL query string.
935
+	 * If is string will determine the result type "array" or "object"
936
+	 * @return mixed       the query SQL string or the record result
937
+	 */
938
+	public function get($returnSQLQueryOrResultType = false){
939
+	  $this->limit = 1;
940
+	  $query = $this->getAll(true);
941
+	  if($returnSQLQueryOrResultType === true){
942
+		return $query;
943
+	  }
944
+	  else{
945
+		return $this->query( $query, false, (($returnSQLQueryOrResultType == 'array') ? true : false) );
946
+	  }
947
+	}
948
+
949
+	/**
950
+	 * Get the result of record rows list returned by the current query
951
+	 * @param  boolean $returnSQLQueryOrResultType if is boolean and true will return the SQL query string.
952
+	 * If is string will determine the result type "array" or "object"
953
+	 * @return mixed       the query SQL string or the record result
954
+	 */
955
+	public function getAll($returnSQLQueryOrResultType = false){
956
+	  $query = 'SELECT ' . $this->select . ' FROM ' . $this->from;
957
+	  if (! is_null($this->join)){
958
+		$query .= $this->join;
959
+	  }
960 960
 	  
961
-      if (! is_null($this->where)){
962
-        $query .= ' WHERE ' . $this->where;
963
-      }
961
+	  if (! is_null($this->where)){
962
+		$query .= ' WHERE ' . $this->where;
963
+	  }
964 964
 
965
-      if (! is_null($this->groupBy)){
966
-        $query .= ' GROUP BY ' . $this->groupBy;
967
-      }
965
+	  if (! is_null($this->groupBy)){
966
+		$query .= ' GROUP BY ' . $this->groupBy;
967
+	  }
968 968
 
969
-      if (! is_null($this->having)){
970
-        $query .= ' HAVING ' . $this->having;
971
-      }
969
+	  if (! is_null($this->having)){
970
+		$query .= ' HAVING ' . $this->having;
971
+	  }
972 972
 
973
-      if (! is_null($this->orderBy)){
974
-          $query .= ' ORDER BY ' . $this->orderBy;
975
-      }
973
+	  if (! is_null($this->orderBy)){
974
+		  $query .= ' ORDER BY ' . $this->orderBy;
975
+	  }
976 976
 
977
-      if(! is_null($this->limit)){
978
-      	$query .= ' LIMIT ' . $this->limit;
979
-      }
977
+	  if(! is_null($this->limit)){
978
+	  	$query .= ' LIMIT ' . $this->limit;
979
+	  }
980 980
 	  
981 981
 	  if($returnSQLQueryOrResultType === true){
982
-    	return $query;
983
-      }
984
-      else{
985
-    	return $this->query($query, true, (($returnSQLQueryOrResultType == 'array') ? true : false) );
986
-      }
987
-    }
988
-
989
-    /**
990
-     * Insert new record in the database
991
-     * @param  array   $data   the record data if is empty will use the $this->data array.
992
-     * @param  boolean $escape  whether to escape or not the values
993
-     * @return mixed          the insert id of the new record or null
994
-     */
995
-    public function insert($data = array(), $escape = true){
996
-      $column = array();
997
-      $val = array();
998
-      if(! $data && $this->getData()){
999
-        $columns = array_keys($this->getData());
1000
-        $column = implode(',', $columns);
1001
-        $val = implode(', ', $this->getData());
1002
-      }
1003
-      else{
1004
-        $columns = array_keys($data);
1005
-        $column = implode(',', $columns);
1006
-        $val = implode(', ', ($escape ? array_map(array($this, 'escape'), $data) : $data));
1007
-      }
1008
-
1009
-      $query = 'INSERT INTO ' . $this->from . ' (' . $column . ') VALUES (' . $val . ')';
1010
-      $query = $this->query($query);
1011
-
1012
-      if ($query){
1013
-        if(! $this->pdo){
1014
-          $this->connect();
1015
-        }
1016
-        $this->insertId = $this->pdo->lastInsertId();
1017
-        return $this->insertId();
1018
-      }
1019
-      else{
982
+		return $query;
983
+	  }
984
+	  else{
985
+		return $this->query($query, true, (($returnSQLQueryOrResultType == 'array') ? true : false) );
986
+	  }
987
+	}
988
+
989
+	/**
990
+	 * Insert new record in the database
991
+	 * @param  array   $data   the record data if is empty will use the $this->data array.
992
+	 * @param  boolean $escape  whether to escape or not the values
993
+	 * @return mixed          the insert id of the new record or null
994
+	 */
995
+	public function insert($data = array(), $escape = true){
996
+	  $column = array();
997
+	  $val = array();
998
+	  if(! $data && $this->getData()){
999
+		$columns = array_keys($this->getData());
1000
+		$column = implode(',', $columns);
1001
+		$val = implode(', ', $this->getData());
1002
+	  }
1003
+	  else{
1004
+		$columns = array_keys($data);
1005
+		$column = implode(',', $columns);
1006
+		$val = implode(', ', ($escape ? array_map(array($this, 'escape'), $data) : $data));
1007
+	  }
1008
+
1009
+	  $query = 'INSERT INTO ' . $this->from . ' (' . $column . ') VALUES (' . $val . ')';
1010
+	  $query = $this->query($query);
1011
+
1012
+	  if ($query){
1013
+		if(! $this->pdo){
1014
+		  $this->connect();
1015
+		}
1016
+		$this->insertId = $this->pdo->lastInsertId();
1017
+		return $this->insertId();
1018
+	  }
1019
+	  else{
1020 1020
 		  return false;
1021
-      }
1022
-    }
1023
-
1024
-    /**
1025
-     * Update record in the database
1026
-     * @param  array   $data   the record data if is empty will use the $this->data array.
1027
-     * @param  boolean $escape  whether to escape or not the values
1028
-     * @return mixed          the update status
1029
-     */
1030
-    public function update($data = array(), $escape = true){
1031
-      $query = 'UPDATE ' . $this->from . ' SET ';
1032
-      $values = array();
1033
-      if(! $data && $this->getData()){
1034
-        foreach ($this->getData() as $column => $val){
1035
-          $values[] = $column . ' = ' . $val;
1036
-        }
1037
-      }
1038
-      else{
1039
-        foreach ($data as $column => $val){
1040
-          $values[] = $column . '=' . ($escape ? $this->escape($val) : $val);
1041
-        }
1042
-      }
1043
-      $query .= (is_array($data) ? implode(', ', $values) : $data);
1044
-      if (! is_null($this->where)){
1045
-        $query .= ' WHERE ' . $this->where;
1046
-      }
1047
-
1048
-      if (! is_null($this->orderBy)){
1049
-        $query .= ' ORDER BY ' . $this->orderBy;
1050
-      }
1051
-
1052
-      if (! is_null($this->limit)){
1053
-        $query .= ' LIMIT ' . $this->limit;
1054
-      }
1055
-      return $this->query($query);
1056
-    }
1057
-
1058
-    /**
1059
-     * Delete the record in database
1060
-     * @return mixed the delete status
1061
-     */
1062
-    public function delete(){
1063
-    	$query = 'DELETE FROM ' . $this->from;
1064
-
1065
-    	if (! is_null($this->where)){
1066
-    		$query .= ' WHERE ' . $this->where;
1067
-      	}
1068
-
1069
-    	if (! is_null($this->orderBy)){
1070
-    	  $query .= ' ORDER BY ' . $this->orderBy;
1071
-      	}
1072
-
1073
-    	if (! is_null($this->limit)){
1074
-    		$query .= ' LIMIT ' . $this->limit;
1075
-      	}
1076
-
1077
-    	if($query == 'DELETE FROM ' . $this->from && $this->config['driver'] != 'sqlite'){  
1078
-    		$query = 'TRUNCATE TABLE ' . $this->from;
1079
-      }
1080
-    	return $this->query($query);
1081
-    }
1082
-
1083
-    /**
1084
-     * Execute an SQL query
1085
-     * @param  string  $query the query SQL string
1086
-     * @param  boolean $all   whether to return all record or not
1087
-     * @param  boolean $array return the result as array
1088
-     * @return mixed         the query result
1089
-     */
1090
-    public function query($query, $all = true, $array = false){
1091
-      $this->reset();
1092
-      if(is_array($all)){
1093
-        $x = explode('?', $query);
1094
-        $q = '';
1095
-        foreach($x as $k => $v){
1096
-          if(! empty($v)){
1097
-            $q .= $v . (isset($all[$k]) ? $this->escape($all[$k]) : '');
1098
-          }
1099
-        }
1100
-        $query = $q;
1101
-      }
1102
-
1103
-      $this->query = preg_replace('/\s\s+|\t\t+/', ' ', trim($query));
1104
-      $sqlSELECTQuery = stristr($this->query, 'SELECT');
1105
-      $this->logger->info('Execute SQL query ['.$this->query.'], return type: ' . ($array?'ARRAY':'OBJECT') .', return as list: ' . ($all ? 'YES':'NO'));
1106
-      //cache expire time
1021
+	  }
1022
+	}
1023
+
1024
+	/**
1025
+	 * Update record in the database
1026
+	 * @param  array   $data   the record data if is empty will use the $this->data array.
1027
+	 * @param  boolean $escape  whether to escape or not the values
1028
+	 * @return mixed          the update status
1029
+	 */
1030
+	public function update($data = array(), $escape = true){
1031
+	  $query = 'UPDATE ' . $this->from . ' SET ';
1032
+	  $values = array();
1033
+	  if(! $data && $this->getData()){
1034
+		foreach ($this->getData() as $column => $val){
1035
+		  $values[] = $column . ' = ' . $val;
1036
+		}
1037
+	  }
1038
+	  else{
1039
+		foreach ($data as $column => $val){
1040
+		  $values[] = $column . '=' . ($escape ? $this->escape($val) : $val);
1041
+		}
1042
+	  }
1043
+	  $query .= (is_array($data) ? implode(', ', $values) : $data);
1044
+	  if (! is_null($this->where)){
1045
+		$query .= ' WHERE ' . $this->where;
1046
+	  }
1047
+
1048
+	  if (! is_null($this->orderBy)){
1049
+		$query .= ' ORDER BY ' . $this->orderBy;
1050
+	  }
1051
+
1052
+	  if (! is_null($this->limit)){
1053
+		$query .= ' LIMIT ' . $this->limit;
1054
+	  }
1055
+	  return $this->query($query);
1056
+	}
1057
+
1058
+	/**
1059
+	 * Delete the record in database
1060
+	 * @return mixed the delete status
1061
+	 */
1062
+	public function delete(){
1063
+		$query = 'DELETE FROM ' . $this->from;
1064
+
1065
+		if (! is_null($this->where)){
1066
+			$query .= ' WHERE ' . $this->where;
1067
+	  	}
1068
+
1069
+		if (! is_null($this->orderBy)){
1070
+		  $query .= ' ORDER BY ' . $this->orderBy;
1071
+	  	}
1072
+
1073
+		if (! is_null($this->limit)){
1074
+			$query .= ' LIMIT ' . $this->limit;
1075
+	  	}
1076
+
1077
+		if($query == 'DELETE FROM ' . $this->from && $this->config['driver'] != 'sqlite'){  
1078
+			$query = 'TRUNCATE TABLE ' . $this->from;
1079
+	  }
1080
+		return $this->query($query);
1081
+	}
1082
+
1083
+	/**
1084
+	 * Execute an SQL query
1085
+	 * @param  string  $query the query SQL string
1086
+	 * @param  boolean $all   whether to return all record or not
1087
+	 * @param  boolean $array return the result as array
1088
+	 * @return mixed         the query result
1089
+	 */
1090
+	public function query($query, $all = true, $array = false){
1091
+	  $this->reset();
1092
+	  if(is_array($all)){
1093
+		$x = explode('?', $query);
1094
+		$q = '';
1095
+		foreach($x as $k => $v){
1096
+		  if(! empty($v)){
1097
+			$q .= $v . (isset($all[$k]) ? $this->escape($all[$k]) : '');
1098
+		  }
1099
+		}
1100
+		$query = $q;
1101
+	  }
1102
+
1103
+	  $this->query = preg_replace('/\s\s+|\t\t+/', ' ', trim($query));
1104
+	  $sqlSELECTQuery = stristr($this->query, 'SELECT');
1105
+	  $this->logger->info('Execute SQL query ['.$this->query.'], return type: ' . ($array?'ARRAY':'OBJECT') .', return as list: ' . ($all ? 'YES':'NO'));
1106
+	  //cache expire time
1107 1107
   	  $cacheExpire = $this->temporaryCacheTtl;
1108 1108
   	  
1109 1109
   	  //return to the initial cache time
1110 1110
   	  $this->temporaryCacheTtl = $this->cacheTtl;
1111 1111
   	  
1112 1112
   	  //config for cache
1113
-        $cacheEnable = get_config('cache_enable');
1113
+		$cacheEnable = get_config('cache_enable');
1114 1114
   	  
1115 1115
   	  //the database cache content
1116
-        $cacheContent = null;
1116
+		$cacheContent = null;
1117 1117
   	  
1118 1118
   	  //this database query cache key
1119
-        $cacheKey = null;
1119
+		$cacheKey = null;
1120 1120
   	  
1121 1121
   	  //the cache manager instance
1122
-      $cacheInstance = null;
1122
+	  $cacheInstance = null;
1123 1123
   	  
1124 1124
   	  //if can use cache feature for this query
1125 1125
   	  $dbCacheStatus = $cacheEnable && $cacheExpire > 0;
1126 1126
 	  
1127
-      if ($dbCacheStatus && $sqlSELECTQuery){
1128
-        $this->logger->info('The cache is enabled for this query, try to get result from cache'); 
1129
-        $cacheKey = md5($query . $all . $array);
1130
-        if(is_object($this->cacheInstance)){
1131
-          $cacheInstance = $this->cacheInstance;
1132
-        }
1133
-        else{
1134
-          $obj = & get_instance();
1135
-          $cacheInstance = $obj->cache;  
1136
-        }
1137
-        $cacheContent = $cacheInstance->get($cacheKey);        
1138
-      }
1139
-      else{
1127
+	  if ($dbCacheStatus && $sqlSELECTQuery){
1128
+		$this->logger->info('The cache is enabled for this query, try to get result from cache'); 
1129
+		$cacheKey = md5($query . $all . $array);
1130
+		if(is_object($this->cacheInstance)){
1131
+		  $cacheInstance = $this->cacheInstance;
1132
+		}
1133
+		else{
1134
+		  $obj = & get_instance();
1135
+		  $cacheInstance = $obj->cache;  
1136
+		}
1137
+		$cacheContent = $cacheInstance->get($cacheKey);        
1138
+	  }
1139
+	  else{
1140 1140
 		  $this->logger->info('The cache is not enabled for this query or is not the SELECT query, get the result directly from real database');
1141
-      }
1141
+	  }
1142 1142
 
1143
-      if(! $this->pdo){
1144
-        $this->connect();
1145
-      }
1143
+	  if(! $this->pdo){
1144
+		$this->connect();
1145
+	  }
1146 1146
       
1147
-      if (! $cacheContent && $sqlSELECTQuery){
1148
-		    //for database query execution time
1149
-        $benchmarkMarkerKey = md5($query . $all . $array);
1150
-        $bench = null;
1151
-        if(is_object($this->benchmarkInstance)){
1152
-          $bench = $this->benchmarkInstance;
1153
-        }
1154
-        else{
1155
-          $obj = & get_instance();
1156
-          $bench = $obj->benchmark;  
1157
-        }
1158
-        $bench->mark('DATABASE_QUERY_START(' . $benchmarkMarkerKey . ')');
1159
-        //Now execute the query
1160
-		    $sqlQuery = $this->pdo->query($this->query);
1147
+	  if (! $cacheContent && $sqlSELECTQuery){
1148
+			//for database query execution time
1149
+		$benchmarkMarkerKey = md5($query . $all . $array);
1150
+		$bench = null;
1151
+		if(is_object($this->benchmarkInstance)){
1152
+		  $bench = $this->benchmarkInstance;
1153
+		}
1154
+		else{
1155
+		  $obj = & get_instance();
1156
+		  $bench = $obj->benchmark;  
1157
+		}
1158
+		$bench->mark('DATABASE_QUERY_START(' . $benchmarkMarkerKey . ')');
1159
+		//Now execute the query
1160
+			$sqlQuery = $this->pdo->query($this->query);
1161 1161
         
1162
-    		//get response time for this query
1163
-        $responseTime = $bench->elapsedTime('DATABASE_QUERY_START(' . $benchmarkMarkerKey . ')', 'DATABASE_QUERY_END(' . $benchmarkMarkerKey . ')');
1164
-	     	//TODO use the configuration value for the high response time currently is 1 second
1165
-        if($responseTime >= 1 ){
1166
-            $this->logger->warning('High response time while processing database query [' .$query. ']. The response time is [' .$responseTime. '] sec.');
1167
-        }
1168
-        if ($sqlQuery){
1169
-            //if need return all result like list of record
1170
-            if ($all){
1171
-    				    $this->result = ($array == false) ? $sqlQuery->fetchAll(PDO::FETCH_OBJ) : $sqlQuery->fetchAll(PDO::FETCH_ASSOC);
1172
-    		    }
1173
-            else{
1174
-				        $this->result = ($array == false) ? $sqlQuery->fetch(PDO::FETCH_OBJ) : $sqlQuery->fetch(PDO::FETCH_ASSOC);
1175
-            }
1176
-            //Sqlite and pgsql always return 0 when using rowCount()
1177
-            if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1178
-              $this->numRows = count($this->result);  
1179
-            }
1180
-            else{
1181
-              $this->numRows = $sqlQuery->rowCount(); 
1182
-            }
1183
-
1184
-          if ($dbCacheStatus && $sqlSELECTQuery){
1185
-              $this->logger->info('Save the result for query [' .$this->query. '] into cache for future use');
1186
-              $cacheInstance->set($cacheKey, $this->result, $cacheExpire);
1187
-          }
1188
-        }
1189
-        else{
1190
-          $error = $this->pdo->errorInfo();
1191
-          $this->error = isset($error[2]) ? $error[2] : '';
1192
-          $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1193
-          $this->error();
1194
-        }
1195
-      }
1196
-      else if ((! $cacheContent && !$sqlSELECTQuery) || ($cacheContent && !$sqlSELECTQuery)){
1197
-    		$queryStr = $this->pdo->query($this->query);
1198
-    		if($queryStr){
1199
-          //Sqlite and pgsql always return 0 when using rowCount()
1200
-          if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1201
-            $this->result = 1; //to test the result for the query like UPDATE, INSERT, DELETE
1202
-            $this->numRows = 1;  
1203
-          }
1204
-          else{
1205
-              $this->result = $queryStr->rowCount() >= 0; //to test the result for the query like UPDATE, INSERT, DELETE
1206
-              $this->numRows = $queryStr->rowCount(); 
1207
-          }
1208
-    		}
1209
-        if (! $this->result){
1210
-          $error = $this->pdo->errorInfo();
1211
-          $this->error = isset($error[2]) ? $error[2] : '';
1212
-          $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1213
-          $this->error();
1214
-        }
1215
-      }
1216
-      else{
1217
-        $this->logger->info('The result for query [' .$this->query. '] already cached use it');
1218
-        $this->result = $cacheContent;
1219
-	     	$this->numRows = count($this->result);
1220
-      }
1221
-      $this->queryCount++;
1222
-      if(! $this->result){
1223
-        $this->logger->info('No result where found for the query [' . $query . ']');
1224
-      }
1225
-      return $this->result;
1226
-    }
1227
-
1228
-    /**
1229
-     * Set database cache time to live
1230
-     * @param integer $ttl the cache time to live in second
1231
-     * @return object        the current Database instance
1232
-     */
1233
-    public function setCache($ttl = 0){
1234
-      if($ttl > 0){
1235
-        $this->cacheTtl = $ttl;
1236
-		    $this->temporaryCacheTtl = $ttl;
1237
-      }
1238
-      return $this;
1239
-    }
1162
+			//get response time for this query
1163
+		$responseTime = $bench->elapsedTime('DATABASE_QUERY_START(' . $benchmarkMarkerKey . ')', 'DATABASE_QUERY_END(' . $benchmarkMarkerKey . ')');
1164
+		 	//TODO use the configuration value for the high response time currently is 1 second
1165
+		if($responseTime >= 1 ){
1166
+			$this->logger->warning('High response time while processing database query [' .$query. ']. The response time is [' .$responseTime. '] sec.');
1167
+		}
1168
+		if ($sqlQuery){
1169
+			//if need return all result like list of record
1170
+			if ($all){
1171
+						$this->result = ($array == false) ? $sqlQuery->fetchAll(PDO::FETCH_OBJ) : $sqlQuery->fetchAll(PDO::FETCH_ASSOC);
1172
+				}
1173
+			else{
1174
+						$this->result = ($array == false) ? $sqlQuery->fetch(PDO::FETCH_OBJ) : $sqlQuery->fetch(PDO::FETCH_ASSOC);
1175
+			}
1176
+			//Sqlite and pgsql always return 0 when using rowCount()
1177
+			if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1178
+			  $this->numRows = count($this->result);  
1179
+			}
1180
+			else{
1181
+			  $this->numRows = $sqlQuery->rowCount(); 
1182
+			}
1183
+
1184
+		  if ($dbCacheStatus && $sqlSELECTQuery){
1185
+			  $this->logger->info('Save the result for query [' .$this->query. '] into cache for future use');
1186
+			  $cacheInstance->set($cacheKey, $this->result, $cacheExpire);
1187
+		  }
1188
+		}
1189
+		else{
1190
+		  $error = $this->pdo->errorInfo();
1191
+		  $this->error = isset($error[2]) ? $error[2] : '';
1192
+		  $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1193
+		  $this->error();
1194
+		}
1195
+	  }
1196
+	  else if ((! $cacheContent && !$sqlSELECTQuery) || ($cacheContent && !$sqlSELECTQuery)){
1197
+			$queryStr = $this->pdo->query($this->query);
1198
+			if($queryStr){
1199
+		  //Sqlite and pgsql always return 0 when using rowCount()
1200
+		  if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1201
+			$this->result = 1; //to test the result for the query like UPDATE, INSERT, DELETE
1202
+			$this->numRows = 1;  
1203
+		  }
1204
+		  else{
1205
+			  $this->result = $queryStr->rowCount() >= 0; //to test the result for the query like UPDATE, INSERT, DELETE
1206
+			  $this->numRows = $queryStr->rowCount(); 
1207
+		  }
1208
+			}
1209
+		if (! $this->result){
1210
+		  $error = $this->pdo->errorInfo();
1211
+		  $this->error = isset($error[2]) ? $error[2] : '';
1212
+		  $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1213
+		  $this->error();
1214
+		}
1215
+	  }
1216
+	  else{
1217
+		$this->logger->info('The result for query [' .$this->query. '] already cached use it');
1218
+		$this->result = $cacheContent;
1219
+		 	$this->numRows = count($this->result);
1220
+	  }
1221
+	  $this->queryCount++;
1222
+	  if(! $this->result){
1223
+		$this->logger->info('No result where found for the query [' . $query . ']');
1224
+	  }
1225
+	  return $this->result;
1226
+	}
1227
+
1228
+	/**
1229
+	 * Set database cache time to live
1230
+	 * @param integer $ttl the cache time to live in second
1231
+	 * @return object        the current Database instance
1232
+	 */
1233
+	public function setCache($ttl = 0){
1234
+	  if($ttl > 0){
1235
+		$this->cacheTtl = $ttl;
1236
+			$this->temporaryCacheTtl = $ttl;
1237
+	  }
1238
+	  return $this;
1239
+	}
1240 1240
 	
1241 1241
 	/**
1242 1242
 	 * Enabled cache temporary for the current query not globally	
@@ -1244,186 +1244,186 @@  discard block
 block discarded – undo
1244 1244
 	 * @return object        the current Database instance
1245 1245
 	 */
1246 1246
 	public function cached($ttl = 0){
1247
-      if($ttl > 0){
1248
-        $this->temporaryCacheTtl = $ttl;
1249
-      }
1247
+	  if($ttl > 0){
1248
+		$this->temporaryCacheTtl = $ttl;
1249
+	  }
1250
+	  return $this;
1251
+	}
1252
+
1253
+	/**
1254
+	 * Escape the data before execute query useful for security.
1255
+	 * @param  mixed $data the data to be escaped
1256
+	 * @return mixed       the data after escaped
1257
+	 */
1258
+	public function escape($data){
1259
+	  if(is_null($data)){
1260
+		return null;
1261
+	  }
1262
+	  if(! $this->pdo){
1263
+		$this->connect();
1264
+	  }
1265
+	  return $this->pdo->quote(trim($data));
1266
+	}
1267
+
1268
+	/**
1269
+	 * Return the number query executed count for the current request
1270
+	 * @return int
1271
+	 */
1272
+	public function queryCount(){
1273
+	  return $this->queryCount;
1274
+	}
1275
+
1276
+	/**
1277
+	 * Return the current query SQL string
1278
+	 * @return string
1279
+	 */
1280
+	public function getQuery(){
1281
+	  return $this->query;
1282
+	}
1283
+
1284
+	/**
1285
+	 * Return the application database name
1286
+	 * @return string
1287
+	 */
1288
+	public function getDatabaseName(){
1289
+	  return $this->databaseName;
1290
+	}
1291
+
1292
+	 /**
1293
+	  * Return the database configuration
1294
+	  * @return array
1295
+	  */
1296
+	public  function getDatabaseConfiguration(){
1297
+	  return $this->config;
1298
+	}
1299
+
1300
+	/**
1301
+	 * set the database configuration
1302
+	 * @param array $config the configuration
1303
+	 */
1304
+	public function setDatabaseConfiguration(array $config){
1305
+	  $this->config = array_merge($this->config, $config);
1306
+	  $this->prefix = $this->config['prefix'];
1307
+	  $this->databaseName = $this->config['database'];
1308
+	  $this->logger->info('The database configuration are listed below: ' . stringfy_vars(array_merge($this->config, array('password' => string_hidden($this->config['password'])))));
1309
+	  return $this;
1310
+	}
1311
+
1312
+	/**
1313
+	 * Return the PDO instance
1314
+	 * @return PDO
1315
+	 */
1316
+	public function getPdo(){
1317
+	  return $this->pdo;
1318
+	}
1319
+
1320
+	/**
1321
+	 * Set the PDO instance
1322
+	 * @param PDO $pdo the pdo object
1323
+	 */
1324
+	public function setPdo(PDO $pdo){
1325
+	  $this->pdo = $pdo;
1326
+	  return $this;
1327
+	}
1328
+
1329
+
1330
+	/**
1331
+	 * Return the Log instance
1332
+	 * @return Log
1333
+	 */
1334
+	public function getLogger(){
1335
+	  return $this->logger;
1336
+	}
1337
+
1338
+	/**
1339
+	 * Set the log instance
1340
+	 * @param Log $logger the log object
1341
+	 */
1342
+	public function setLogger($logger){
1343
+	  $this->logger = $logger;
1344
+	  return $this;
1345
+	}
1346
+
1347
+	 /**
1348
+	  * Return the cache instance
1349
+	  * @return CacheInterface
1350
+	  */
1351
+	public function getCacheInstance(){
1352
+	  return $this->cacheInstance;
1353
+	}
1354
+
1355
+	/**
1356
+	 * Set the cache instance
1357
+	 * @param CacheInterface $cache the cache object
1358
+	 */
1359
+	public function setCacheInstance($cache){
1360
+	  $this->cacheInstance = $cache;
1361
+	  return $this;
1362
+	}
1363
+
1364
+	/**
1365
+	 * Return the benchmark instance
1366
+	 * @return Benchmark
1367
+	 */
1368
+	public function getBenchmark(){
1369
+	  return $this->benchmarkInstance;
1370
+	}
1371
+
1372
+	/**
1373
+	 * Set the benchmark instance
1374
+	 * @param Benchmark $cache the cache object
1375
+	 */
1376
+	public function setBenchmark($benchmark){
1377
+	  $this->benchmarkInstance = $benchmark;
1378
+	  return $this;
1379
+	}
1380
+
1381
+	/**
1382
+	 * Return the data to be used for insert, update, etc.
1383
+	 * @return array
1384
+	 */
1385
+	public function getData(){
1386
+	  return $this->data;
1387
+	}
1388
+
1389
+	/**
1390
+	 * Set the data to be used for insert, update, etc.
1391
+	 * @param string $key the data key identified
1392
+	 * @param mixed $value the data value
1393
+	 * @param boolean $escape whether to escape or not the $value
1394
+	 * @return object        the current Database instance
1395
+	 */
1396
+	public function setData($key, $value, $escape = true){
1397
+	  $this->data[$key] = $escape ? $this->escape($value) : $value;
1250 1398
 	  return $this;
1251
-    }
1252
-
1253
-    /**
1254
-     * Escape the data before execute query useful for security.
1255
-     * @param  mixed $data the data to be escaped
1256
-     * @return mixed       the data after escaped
1257
-     */
1258
-    public function escape($data){
1259
-      if(is_null($data)){
1260
-        return null;
1261
-      }
1262
-      if(! $this->pdo){
1263
-        $this->connect();
1264
-      }
1265
-      return $this->pdo->quote(trim($data));
1266
-    }
1267
-
1268
-    /**
1269
-     * Return the number query executed count for the current request
1270
-     * @return int
1271
-     */
1272
-    public function queryCount(){
1273
-      return $this->queryCount;
1274
-    }
1275
-
1276
-    /**
1277
-     * Return the current query SQL string
1278
-     * @return string
1279
-     */
1280
-    public function getQuery(){
1281
-      return $this->query;
1282
-    }
1283
-
1284
-    /**
1285
-     * Return the application database name
1286
-     * @return string
1287
-     */
1288
-    public function getDatabaseName(){
1289
-      return $this->databaseName;
1290
-    }
1291
-
1292
-     /**
1293
-     * Return the database configuration
1294
-     * @return array
1295
-     */
1296
-    public  function getDatabaseConfiguration(){
1297
-      return $this->config;
1298
-    }
1299
-
1300
-    /**
1301
-     * set the database configuration
1302
-     * @param array $config the configuration
1303
-     */
1304
-    public function setDatabaseConfiguration(array $config){
1305
-      $this->config = array_merge($this->config, $config);
1306
-      $this->prefix = $this->config['prefix'];
1307
-      $this->databaseName = $this->config['database'];
1308
-      $this->logger->info('The database configuration are listed below: ' . stringfy_vars(array_merge($this->config, array('password' => string_hidden($this->config['password'])))));
1309
-      return $this;
1310
-    }
1311
-
1312
-    /**
1313
-     * Return the PDO instance
1314
-     * @return PDO
1315
-     */
1316
-    public function getPdo(){
1317
-      return $this->pdo;
1318
-    }
1319
-
1320
-    /**
1321
-     * Set the PDO instance
1322
-     * @param PDO $pdo the pdo object
1323
-     */
1324
-    public function setPdo(PDO $pdo){
1325
-      $this->pdo = $pdo;
1326
-      return $this;
1327
-    }
1328
-
1329
-
1330
-    /**
1331
-     * Return the Log instance
1332
-     * @return Log
1333
-     */
1334
-    public function getLogger(){
1335
-      return $this->logger;
1336
-    }
1337
-
1338
-    /**
1339
-     * Set the log instance
1340
-     * @param Log $logger the log object
1341
-     */
1342
-    public function setLogger($logger){
1343
-      $this->logger = $logger;
1344
-      return $this;
1345
-    }
1346
-
1347
-     /**
1348
-     * Return the cache instance
1349
-     * @return CacheInterface
1350
-     */
1351
-    public function getCacheInstance(){
1352
-      return $this->cacheInstance;
1353
-    }
1354
-
1355
-    /**
1356
-     * Set the cache instance
1357
-     * @param CacheInterface $cache the cache object
1358
-     */
1359
-    public function setCacheInstance($cache){
1360
-      $this->cacheInstance = $cache;
1361
-      return $this;
1362
-    }
1363
-
1364
-    /**
1365
-     * Return the benchmark instance
1366
-     * @return Benchmark
1367
-     */
1368
-    public function getBenchmark(){
1369
-      return $this->benchmarkInstance;
1370
-    }
1371
-
1372
-    /**
1373
-     * Set the benchmark instance
1374
-     * @param Benchmark $cache the cache object
1375
-     */
1376
-    public function setBenchmark($benchmark){
1377
-      $this->benchmarkInstance = $benchmark;
1378
-      return $this;
1379
-    }
1380
-
1381
-    /**
1382
-     * Return the data to be used for insert, update, etc.
1383
-     * @return array
1384
-     */
1385
-    public function getData(){
1386
-      return $this->data;
1387
-    }
1388
-
1389
-    /**
1390
-     * Set the data to be used for insert, update, etc.
1391
-     * @param string $key the data key identified
1392
-     * @param mixed $value the data value
1393
-     * @param boolean $escape whether to escape or not the $value
1394
-     * @return object        the current Database instance
1395
-     */
1396
-    public function setData($key, $value, $escape = true){
1397
-      $this->data[$key] = $escape ? $this->escape($value) : $value;
1398
-      return $this;
1399
-    }
1399
+	}
1400 1400
 
1401 1401
 
1402 1402
   /**
1403 1403
    * Reset the database class attributs to the initail values before each query.
1404 1404
    */
1405 1405
   private function reset(){
1406
-    $this->select   = '*';
1407
-    $this->from     = null;
1408
-    $this->where    = null;
1409
-    $this->limit    = null;
1410
-    $this->orderBy  = null;
1411
-    $this->groupBy  = null;
1412
-    $this->having   = null;
1413
-    $this->join     = null;
1414
-    $this->numRows  = 0;
1415
-    $this->insertId = null;
1416
-    $this->query    = null;
1417
-    $this->error    = null;
1418
-    $this->result   = array();
1419
-    $this->data     = array();
1406
+	$this->select   = '*';
1407
+	$this->from     = null;
1408
+	$this->where    = null;
1409
+	$this->limit    = null;
1410
+	$this->orderBy  = null;
1411
+	$this->groupBy  = null;
1412
+	$this->having   = null;
1413
+	$this->join     = null;
1414
+	$this->numRows  = 0;
1415
+	$this->insertId = null;
1416
+	$this->query    = null;
1417
+	$this->error    = null;
1418
+	$this->result   = array();
1419
+	$this->data     = array();
1420 1420
   }
1421 1421
 
1422 1422
   /**
1423 1423
    * The class destructor
1424 1424
    */
1425 1425
   function __destruct(){
1426
-    $this->pdo = null;
1426
+	$this->pdo = null;
1427 1427
   }
1428 1428
 
1429 1429
 }
Please login to merge, or discard this patch.
Spacing   +257 added lines, -257 removed lines patch added patch discarded remove patch
@@ -23,158 +23,158 @@  discard block
 block discarded – undo
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
-  class Database{
26
+  class Database {
27 27
 	
28 28
 	/**
29 29
 	 * The PDO instance
30 30
 	 * @var object
31 31
 	*/
32
-    private $pdo                 = null;
32
+    private $pdo = null;
33 33
     
34 34
 	/**
35 35
 	 * The database name used for the application
36 36
 	 * @var string
37 37
 	*/
38
-	private $databaseName        = null;
38
+	private $databaseName = null;
39 39
     
40 40
 	/**
41 41
 	 * The SQL SELECT statment
42 42
 	 * @var string
43 43
 	*/
44
-	private $select              = '*';
44
+	private $select = '*';
45 45
 	
46 46
 	/**
47 47
 	 * The SQL FROM statment
48 48
 	 * @var string
49 49
 	*/
50
-    private $from                = null;
50
+    private $from = null;
51 51
 	
52 52
 	/**
53 53
 	 * The SQL WHERE statment
54 54
 	 * @var string
55 55
 	*/
56
-    private $where               = null;
56
+    private $where = null;
57 57
 	
58 58
 	/**
59 59
 	 * The SQL LIMIT statment
60 60
 	 * @var string
61 61
 	*/
62
-    private $limit               = null;
62
+    private $limit = null;
63 63
 	
64 64
 	/**
65 65
 	 * The SQL JOIN statment
66 66
 	 * @var string
67 67
 	*/
68
-    private $join                = null;
68
+    private $join = null;
69 69
 	
70 70
 	/**
71 71
 	 * The SQL ORDER BY statment
72 72
 	 * @var string
73 73
 	*/
74
-    private $orderBy             = null;
74
+    private $orderBy = null;
75 75
 	
76 76
 	/**
77 77
 	 * The SQL GROUP BY statment
78 78
 	 * @var string
79 79
 	*/
80
-    private $groupBy             = null;
80
+    private $groupBy = null;
81 81
 	
82 82
 	/**
83 83
 	 * The SQL HAVING statment
84 84
 	 * @var string
85 85
 	*/
86
-    private $having              = null;
86
+    private $having = null;
87 87
 	
88 88
 	/**
89 89
 	 * The number of rows returned by the last query
90 90
 	 * @var int
91 91
 	*/
92
-    private $numRows             = 0;
92
+    private $numRows = 0;
93 93
 	
94 94
 	/**
95 95
 	 * The last insert id for the primary key column that have auto increment or sequence
96 96
 	 * @var mixed
97 97
 	*/
98
-    private $insertId            = null;
98
+    private $insertId = null;
99 99
 	
100 100
 	/**
101 101
 	 * The full SQL query statment after build for each command
102 102
 	 * @var string
103 103
 	*/
104
-    private $query               = null;
104
+    private $query = null;
105 105
 	
106 106
 	/**
107 107
 	 * The error returned for the last query
108 108
 	 * @var string
109 109
 	*/
110
-    private $error               = null;
110
+    private $error = null;
111 111
 	
112 112
 	/**
113 113
 	 * The result returned for the last query
114 114
 	 * @var mixed
115 115
 	*/
116
-    private $result              = array();
116
+    private $result = array();
117 117
 	
118 118
 	/**
119 119
 	 * The prefix used in each database table
120 120
 	 * @var string
121 121
 	*/
122
-    private $prefix              = null;
122
+    private $prefix = null;
123 123
 	
124 124
 	/**
125 125
 	 * The list of SQL valid operators
126 126
 	 * @var array
127 127
 	*/
128
-    private $operatorList        = array('=','!=','<','>','<=','>=','<>');
128
+    private $operatorList = array('=', '!=', '<', '>', '<=', '>=', '<>');
129 129
     
130 130
 	/**
131 131
 	 * The cache default time to live in second. 0 means no need to use the cache feature
132 132
 	 * @var int
133 133
 	*/
134
-	private $cacheTtl              = 0;
134
+	private $cacheTtl = 0;
135 135
 	
136 136
 	/**
137 137
 	 * The cache current time to live. 0 means no need to use the cache feature
138 138
 	 * @var int
139 139
 	*/
140
-    private $temporaryCacheTtl   = 0;
140
+    private $temporaryCacheTtl = 0;
141 141
 	
142 142
 	/**
143 143
 	 * The number of executed query for the current request
144 144
 	 * @var int
145 145
 	*/
146
-    private $queryCount          = 0;
146
+    private $queryCount = 0;
147 147
 	
148 148
 	/**
149 149
 	 * The default data to be used in the statments query INSERT, UPDATE
150 150
 	 * @var array
151 151
 	*/
152
-    private $data                = array();
152
+    private $data = array();
153 153
 	
154 154
 	/**
155 155
 	 * The database configuration
156 156
 	 * @var array
157 157
 	*/
158
-    private $config              = array();
158
+    private $config = array();
159 159
 	
160 160
 	/**
161 161
 	 * The logger instance
162 162
 	 * @var Log
163 163
 	 */
164
-    private $logger              = null;
164
+    private $logger = null;
165 165
 
166 166
 
167 167
     /**
168 168
     * The cache instance
169 169
     * @var CacheInterface
170 170
     */
171
-    private $cacheInstance       = null;
171
+    private $cacheInstance = null;
172 172
 
173 173
      /**
174 174
     * The benchmark instance
175 175
     * @var Benchmark
176 176
     */
177
-    private $benchmarkInstance   = null;
177
+    private $benchmarkInstance = null;
178 178
 
179 179
 
180 180
     /**
@@ -182,25 +182,25 @@  discard block
 block discarded – undo
182 182
      * @param array $overwriteConfig the config to overwrite with the config set in database.php
183 183
      * @param object $logger the log instance
184 184
      */
185
-    public function __construct($overwriteConfig = array(), Log $logger = null){
185
+    public function __construct($overwriteConfig = array(), Log $logger = null) {
186 186
         /**
187 187
          * instance of the Log class
188 188
          */
189
-        if(is_object($logger)){
189
+        if (is_object($logger)) {
190 190
           $this->logger = $logger;
191 191
         }
192
-        else{
193
-            $this->logger =& class_loader('Log', 'classes');
192
+        else {
193
+            $this->logger = & class_loader('Log', 'classes');
194 194
             $this->logger->setLogger('Library::Database');
195 195
         }
196 196
 
197 197
         $db = array();
198
-      	if(file_exists(CONFIG_PATH . 'database.php')){
198
+      	if (file_exists(CONFIG_PATH . 'database.php')) {
199 199
           //here don't use require_once because somewhere user can create database instance directly
200 200
       	  require CONFIG_PATH . 'database.php';
201 201
         }
202 202
           
203
-				if(! empty($overwriteConfig)){
203
+				if (!empty($overwriteConfig)) {
204 204
 				  $db = array_merge($db, $overwriteConfig);
205 205
 				}
206 206
         $config = array();
@@ -213,12 +213,12 @@  discard block
 block discarded – undo
213 213
 				$config['collation'] = isset($db['collation']) ? $db['collation'] : 'utf8_general_ci';
214 214
 				$config['prefix']    = isset($db['prefix']) ? $db['prefix'] : '';
215 215
         $port = '';
216
-        if(strstr($config['hostname'], ':')){
216
+        if (strstr($config['hostname'], ':')) {
217 217
           $p = explode(':', $config['hostname']);
218 218
           $port = isset($p[1]) ? $p[1] : '';
219 219
           $config['hostname'] = isset($p[0]) ? $p[0] : '';
220 220
         }
221
-				$config['port']      = $port;
221
+				$config['port'] = $port;
222 222
 				
223 223
 		  	$this->setDatabaseConfiguration($config);
224 224
     		$this->temporaryCacheTtl = $this->cacheTtl;
@@ -228,10 +228,10 @@  discard block
 block discarded – undo
228 228
      * This is used to connect to database
229 229
      * @return bool 
230 230
      */
231
-    public function connect(){
231
+    public function connect() {
232 232
       $config = $this->getDatabaseConfiguration();
233
-      if(! empty($config)){
234
-        try{
233
+      if (!empty($config)) {
234
+        try {
235 235
             $driverDsnMap = array(
236 236
               'mysql' => 'mysql:host=' . $config['hostname'] . ';' 
237 237
                           . (($config['port']) != '' ? 'port=' . $config['port'] . ';' : '') 
@@ -252,13 +252,13 @@  discard block
 block discarded – undo
252 252
             $this->pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_OBJ);
253 253
             return true;
254 254
           }
255
-          catch (PDOException $e){
255
+          catch (PDOException $e) {
256 256
             $this->logger->fatal($e->getMessage());
257 257
             show_error('Cannot connect to Database.');
258 258
             return false;
259 259
           }
260 260
       }
261
-      else{
261
+      else {
262 262
         show_error('Database configuration is not set.');
263 263
         return false;
264 264
       }
@@ -269,15 +269,15 @@  discard block
 block discarded – undo
269 269
      * @param  string|array $table the table name or array of table list
270 270
      * @return object        the current Database instance
271 271
      */
272
-    public function from($table){
273
-      if(is_array($table)){
272
+    public function from($table) {
273
+      if (is_array($table)) {
274 274
         $froms = '';
275
-        foreach($table as $key){
275
+        foreach ($table as $key) {
276 276
           $froms .= $this->prefix . $key . ', ';
277 277
         }
278 278
         $this->from = rtrim($froms, ', ');
279 279
       }
280
-      else{
280
+      else {
281 281
         $this->from = $this->prefix . $table;
282 282
       }
283 283
       return $this;
@@ -288,7 +288,7 @@  discard block
 block discarded – undo
288 288
      * @param  string|array $fields the field name or array of field list
289 289
      * @return object        the current Database instance
290 290
      */
291
-    public function select($fields){
291
+    public function select($fields) {
292 292
       $select = (is_array($fields) ? implode(', ', $fields) : $fields);
293 293
       $this->select = ($this->select == '*' ? $select : $this->select . ', ' . $select);
294 294
       return $this;
@@ -299,7 +299,7 @@  discard block
 block discarded – undo
299 299
      * @param  string $field the field name to distinct
300 300
      * @return object        the current Database instance
301 301
      */
302
-    public function distinct($field){
302
+    public function distinct($field) {
303 303
       $distinct = ' DISTINCT ' . $field;
304 304
       $this->select = ($this->select == '*' ? $distinct : $this->select . ', ' . $distinct);
305 305
 
@@ -312,7 +312,7 @@  discard block
 block discarded – undo
312 312
      * @param  string $name  if is not null represent the alias used for this field in the result
313 313
      * @return object        the current Database instance
314 314
      */
315
-    public function max($field, $name = null){
315
+    public function max($field, $name = null) {
316 316
       $func = 'MAX(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
317 317
       $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
318 318
       return $this;
@@ -324,7 +324,7 @@  discard block
 block discarded – undo
324 324
      * @param  string $name  if is not null represent the alias used for this field in the result
325 325
      * @return object        the current Database instance
326 326
      */
327
-    public function min($field, $name = null){
327
+    public function min($field, $name = null) {
328 328
       $func = 'MIN(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
329 329
       $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
330 330
       return $this;
@@ -336,7 +336,7 @@  discard block
 block discarded – undo
336 336
      * @param  string $name  if is not null represent the alias used for this field in the result
337 337
      * @return object        the current Database instance
338 338
      */
339
-    public function sum($field, $name = null){
339
+    public function sum($field, $name = null) {
340 340
       $func = 'SUM(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
341 341
       $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
342 342
       return $this;
@@ -348,7 +348,7 @@  discard block
 block discarded – undo
348 348
      * @param  string $name  if is not null represent the alias used for this field in the result
349 349
      * @return object        the current Database instance
350 350
      */
351
-    public function count($field = '*', $name = null){
351
+    public function count($field = '*', $name = null) {
352 352
       $func = 'COUNT(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
353 353
       $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
354 354
       return $this;
@@ -360,7 +360,7 @@  discard block
 block discarded – undo
360 360
      * @param  string $name  if is not null represent the alias used for this field in the result
361 361
      * @return object        the current Database instance
362 362
      */
363
-    public function avg($field, $name = null){
363
+    public function avg($field, $name = null) {
364 364
       $func = 'AVG(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
365 365
       $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
366 366
       return $this;
@@ -375,16 +375,16 @@  discard block
 block discarded – undo
375 375
      * @param  string $type   the type of join (INNER, LEFT, RIGHT)
376 376
      * @return object        the current Database instance
377 377
      */
378
-    public function join($table, $field1 = null, $op = null, $field2 = null, $type = ''){
378
+    public function join($table, $field1 = null, $op = null, $field2 = null, $type = '') {
379 379
       $on = $field1;
380 380
       $table = $this->prefix . $table;
381
-      if(! is_null($op)){
382
-        $on = (! in_array($op, $this->operatorList) ? $this->prefix . $field1 . ' = ' . $this->prefix . $op : $this->prefix . $field1 . ' ' . $op . ' ' . $this->prefix . $field2);
381
+      if (!is_null($op)) {
382
+        $on = (!in_array($op, $this->operatorList) ? $this->prefix . $field1 . ' = ' . $this->prefix . $op : $this->prefix . $field1 . ' ' . $op . ' ' . $this->prefix . $field2);
383 383
       }
384
-      if (is_null($this->join)){
384
+      if (is_null($this->join)) {
385 385
         $this->join = ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
386 386
       }
387
-      else{
387
+      else {
388 388
         $this->join = $this->join . ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
389 389
       }
390 390
       return $this;
@@ -395,7 +395,7 @@  discard block
 block discarded – undo
395 395
      * @see  Database::join()
396 396
      * @return object        the current Database instance
397 397
      */
398
-    public function innerJoin($table, $field1, $op = null, $field2 = ''){
398
+    public function innerJoin($table, $field1, $op = null, $field2 = '') {
399 399
       return $this->join($table, $field1, $op, $field2, 'INNER ');
400 400
     }
401 401
 
@@ -404,7 +404,7 @@  discard block
 block discarded – undo
404 404
      * @see  Database::join()
405 405
      * @return object        the current Database instance
406 406
      */
407
-    public function leftJoin($table, $field1, $op = null, $field2 = ''){
407
+    public function leftJoin($table, $field1, $op = null, $field2 = '') {
408 408
       return $this->join($table, $field1, $op, $field2, 'LEFT ');
409 409
 	}
410 410
 
@@ -413,7 +413,7 @@  discard block
 block discarded – undo
413 413
      * @see  Database::join()
414 414
      * @return object        the current Database instance
415 415
      */
416
-    public function rightJoin($table, $field1, $op = null, $field2 = ''){
416
+    public function rightJoin($table, $field1, $op = null, $field2 = '') {
417 417
       return $this->join($table, $field1, $op, $field2, 'RIGHT ');
418 418
     }
419 419
 
@@ -422,7 +422,7 @@  discard block
 block discarded – undo
422 422
      * @see  Database::join()
423 423
      * @return object        the current Database instance
424 424
      */
425
-    public function fullOuterJoin($table, $field1, $op = null, $field2 = ''){
425
+    public function fullOuterJoin($table, $field1, $op = null, $field2 = '') {
426 426
     	return $this->join($table, $field1, $op, $field2, 'FULL OUTER ');
427 427
     }
428 428
 
@@ -431,7 +431,7 @@  discard block
 block discarded – undo
431 431
      * @see  Database::join()
432 432
      * @return object        the current Database instance
433 433
      */
434
-    public function leftOuterJoin($table, $field1, $op = null, $field2 = ''){
434
+    public function leftOuterJoin($table, $field1, $op = null, $field2 = '') {
435 435
       return $this->join($table, $field1, $op, $field2, 'LEFT OUTER ');
436 436
     }
437 437
 
@@ -440,7 +440,7 @@  discard block
 block discarded – undo
440 440
      * @see  Database::join()
441 441
      * @return object        the current Database instance
442 442
      */
443
-    public function rightOuterJoin($table, $field1, $op = null, $field2 = ''){
443
+    public function rightOuterJoin($table, $field1, $op = null, $field2 = '') {
444 444
       return $this->join($table, $field1, $op, $field2, 'RIGHT OUTER ');
445 445
     }
446 446
 
@@ -450,18 +450,18 @@  discard block
 block discarded – undo
450 450
      * @param  string $andOr the separator type used 'AND', 'OR', etc.
451 451
      * @return object        the current Database instance
452 452
      */
453
-    public function whereIsNull($field, $andOr = 'AND'){
454
-      if(is_array($field)){
455
-        foreach($field as $f){
453
+    public function whereIsNull($field, $andOr = 'AND') {
454
+      if (is_array($field)) {
455
+        foreach ($field as $f) {
456 456
         	$this->whereIsNull($f, $andOr);
457 457
         }
458 458
       }
459
-      else{
460
-        if (! $this->where){
461
-          $this->where = $field.' IS NULL ';
459
+      else {
460
+        if (!$this->where) {
461
+          $this->where = $field . ' IS NULL ';
462 462
         }
463
-        else{
464
-            $this->where = $this->where . ' '.$andOr.' ' . $field.' IS NULL ';
463
+        else {
464
+            $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' IS NULL ';
465 465
           }
466 466
       }
467 467
       return $this;
@@ -473,18 +473,18 @@  discard block
 block discarded – undo
473 473
      * @param  string $andOr the separator type used 'AND', 'OR', etc.
474 474
      * @return object        the current Database instance
475 475
      */
476
-    public function whereIsNotNull($field, $andOr = 'AND'){
477
-      if(is_array($field)){
478
-        foreach($field as $f){
476
+    public function whereIsNotNull($field, $andOr = 'AND') {
477
+      if (is_array($field)) {
478
+        foreach ($field as $f) {
479 479
           $this->whereIsNotNull($f, $andOr);
480 480
         }
481 481
       }
482
-      else{
483
-        if (! $this->where){
484
-          $this->where = $field.' IS NOT NULL ';
482
+      else {
483
+        if (!$this->where) {
484
+          $this->where = $field . ' IS NOT NULL ';
485 485
         }
486
-        else{
487
-            $this->where = $this->where . ' '.$andOr.' ' . $field.' IS NOT NULL ';
486
+        else {
487
+            $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' IS NOT NULL ';
488 488
           }
489 489
       }
490 490
       return $this;
@@ -500,24 +500,24 @@  discard block
 block discarded – undo
500 500
      * @param  boolean $escape whether to escape or not the $val
501 501
      * @return object        the current Database instance
502 502
      */
503
-    public function where($where, $op = null, $val = null, $type = '', $andOr = 'AND', $escape = true){
504
-      if (is_array($where)){
503
+    public function where($where, $op = null, $val = null, $type = '', $andOr = 'AND', $escape = true) {
504
+      if (is_array($where)) {
505 505
         $_where = array();
506
-        foreach ($where as $column => $data){
507
-          if(is_null($data)){
506
+        foreach ($where as $column => $data) {
507
+          if (is_null($data)) {
508 508
             $data = '';
509 509
           }
510 510
           $_where[] = $type . $column . '=' . ($escape ? $this->escape($data) : $data);
511 511
         }
512
-        $where = implode(' '.$andOr.' ', $_where);
512
+        $where = implode(' ' . $andOr . ' ', $_where);
513 513
       }
514
-      else{
515
-        if(is_array($op)){
514
+      else {
515
+        if (is_array($op)) {
516 516
           $x = explode('?', $where);
517 517
           $w = '';
518
-          foreach($x as $k => $v){
519
-            if(! empty($v)){
520
-                if(isset($op[$k]) && is_null($op[$k])){
518
+          foreach ($x as $k => $v) {
519
+            if (!empty($v)) {
520
+                if (isset($op[$k]) && is_null($op[$k])) {
521 521
                   $op[$k] = '';
522 522
                 }
523 523
                 $w .= $type . $v . (isset($op[$k]) ? ($escape ? $this->escape($op[$k]) : $op[$k]) : '');
@@ -525,28 +525,28 @@  discard block
 block discarded – undo
525 525
           }
526 526
           $where = $w;
527 527
         }
528
-        else if (! in_array((string)$op, $this->operatorList)){
529
-          if(is_null($op)){
528
+        else if (!in_array((string) $op, $this->operatorList)) {
529
+          if (is_null($op)) {
530 530
             $op = '';
531 531
           }
532 532
         	$where = $type . $where . ' = ' . ($escape ? $this->escape($op) : $op);
533 533
         }
534
-        else{
535
-          if(is_null($val)){
534
+        else {
535
+          if (is_null($val)) {
536 536
             $val = '';
537 537
           }
538 538
         	$where = $type . $where . $op . ($escape ? $this->escape($val) : $val);
539 539
         }
540 540
       }
541
-      if (is_null($this->where)){
541
+      if (is_null($this->where)) {
542 542
         $this->where = $where;
543 543
       }
544
-      else{
545
-        if(substr($this->where, -1) == '('){
544
+      else {
545
+        if (substr($this->where, -1) == '(') {
546 546
           $this->where = $this->where . ' ' . $where;
547 547
         }
548
-        else{
549
-          $this->where = $this->where . ' '.$andOr.' ' . $where;
548
+        else {
549
+          $this->where = $this->where . ' ' . $andOr . ' ' . $where;
550 550
         }
551 551
       }
552 552
       return $this;
@@ -557,7 +557,7 @@  discard block
 block discarded – undo
557 557
      * @see  Database::where()
558 558
      * @return object        the current Database instance
559 559
      */
560
-    public function orWhere($where, $op = null, $val = null, $escape = true){
560
+    public function orWhere($where, $op = null, $val = null, $escape = true) {
561 561
       return $this->where($where, $op, $val, '', 'OR', $escape);
562 562
     }
563 563
 
@@ -567,7 +567,7 @@  discard block
 block discarded – undo
567 567
      * @see  Database::where()
568 568
      * @return object        the current Database instance
569 569
      */
570
-    public function notWhere($where, $op = null, $val = null, $escape = true){
570
+    public function notWhere($where, $op = null, $val = null, $escape = true) {
571 571
       return $this->where($where, $op, $val, 'NOT ', 'AND', $escape);
572 572
     }
573 573
 
@@ -576,7 +576,7 @@  discard block
 block discarded – undo
576 576
      * @see  Database::where()
577 577
      * @return object        the current Database instance
578 578
      */
579
-    public function orNotWhere($where, $op = null, $val = null, $escape = true){
579
+    public function orNotWhere($where, $op = null, $val = null, $escape = true) {
580 580
     	return $this->where($where, $op, $val, 'NOT ', 'OR', $escape);
581 581
     }
582 582
 
@@ -586,15 +586,15 @@  discard block
 block discarded – undo
586 586
      * @param  string $andOr the multiple conditions separator (AND, OR, etc.)
587 587
      * @return object        the current Database instance
588 588
      */
589
-    public function groupStart($type = '', $andOr = ' AND'){
590
-      if (is_null($this->where)){
589
+    public function groupStart($type = '', $andOr = ' AND') {
590
+      if (is_null($this->where)) {
591 591
         $this->where = $type . ' (';
592 592
       }
593
-      else{
594
-          if(substr($this->where, -1) == '('){
593
+      else {
594
+          if (substr($this->where, -1) == '(') {
595 595
             $this->where .= $type . ' (';
596 596
           }
597
-          else{
597
+          else {
598 598
           	$this->where .= $andOr . ' ' . $type . ' (';
599 599
           }
600 600
       }
@@ -606,7 +606,7 @@  discard block
 block discarded – undo
606 606
      * @see  Database::groupStart()
607 607
      * @return object        the current Database instance
608 608
      */
609
-    public function notGroupStart(){
609
+    public function notGroupStart() {
610 610
       return $this->groupStart('NOT');
611 611
     }
612 612
 
@@ -615,7 +615,7 @@  discard block
 block discarded – undo
615 615
      * @see  Database::groupStart()
616 616
      * @return object        the current Database instance
617 617
      */
618
-    public function orGroupStart(){
618
+    public function orGroupStart() {
619 619
       return $this->groupStart('', ' OR');
620 620
     }
621 621
 
@@ -624,7 +624,7 @@  discard block
 block discarded – undo
624 624
      * @see  Database::groupStart()
625 625
      * @return object        the current Database instance
626 626
      */
627
-    public function orNotGroupStart(){
627
+    public function orNotGroupStart() {
628 628
       return $this->groupStart('NOT', ' OR');
629 629
     }
630 630
 
@@ -632,7 +632,7 @@  discard block
 block discarded – undo
632 632
      * Close the parenthesis for the grouped SQL
633 633
      * @return object        the current Database instance
634 634
      */
635
-    public function groupEnd(){
635
+    public function groupEnd() {
636 636
       $this->where .= ')';
637 637
       return $this;
638 638
     }
@@ -646,25 +646,25 @@  discard block
 block discarded – undo
646 646
      * @param  boolean $escape whether to escape or not the values
647 647
      * @return object        the current Database instance
648 648
      */
649
-    public function in($field, array $keys, $type = '', $andOr = 'AND', $escape = true){
650
-      if (is_array($keys)){
649
+    public function in($field, array $keys, $type = '', $andOr = 'AND', $escape = true) {
650
+      if (is_array($keys)) {
651 651
         $_keys = array();
652
-        foreach ($keys as $k => $v){
653
-          if(is_null($v)){
652
+        foreach ($keys as $k => $v) {
653
+          if (is_null($v)) {
654 654
             $v = '';
655 655
           }
656 656
           $_keys[] = (is_numeric($v) ? $v : ($escape ? $this->escape($v) : $v));
657 657
         }
658 658
         $keys = implode(', ', $_keys);
659
-        if (is_null($this->where)){
659
+        if (is_null($this->where)) {
660 660
           $this->where = $field . ' ' . $type . 'IN (' . $keys . ')';
661 661
         }
662
-        else{
663
-          if(substr($this->where, -1) == '('){
664
-            $this->where = $this->where . ' ' . $field . ' '.$type.'IN (' . $keys . ')';
662
+        else {
663
+          if (substr($this->where, -1) == '(') {
664
+            $this->where = $this->where . ' ' . $field . ' ' . $type . 'IN (' . $keys . ')';
665 665
           }
666
-          else{
667
-            $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' '.$type.'IN (' . $keys . ')';
666
+          else {
667
+            $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' ' . $type . 'IN (' . $keys . ')';
668 668
           }
669 669
         }
670 670
       }
@@ -676,7 +676,7 @@  discard block
 block discarded – undo
676 676
      * @see  Database::in()
677 677
      * @return object        the current Database instance
678 678
      */
679
-    public function notIn($field, array $keys, $escape = true){
679
+    public function notIn($field, array $keys, $escape = true) {
680 680
       return $this->in($field, $keys, 'NOT ', 'AND', $escape);
681 681
     }
682 682
 
@@ -685,7 +685,7 @@  discard block
 block discarded – undo
685 685
      * @see  Database::in()
686 686
      * @return object        the current Database instance
687 687
      */
688
-    public function orIn($field, array $keys, $escape = true){
688
+    public function orIn($field, array $keys, $escape = true) {
689 689
       return $this->in($field, $keys, '', 'OR', $escape);
690 690
     }
691 691
 
@@ -694,7 +694,7 @@  discard block
 block discarded – undo
694 694
      * @see  Database::in()
695 695
      * @return object        the current Database instance
696 696
      */
697
-    public function orNotIn($field, array $keys, $escape = true){
697
+    public function orNotIn($field, array $keys, $escape = true) {
698 698
       return $this->in($field, $keys, 'NOT ', 'OR', $escape);
699 699
     }
700 700
 
@@ -708,21 +708,21 @@  discard block
 block discarded – undo
708 708
      * @param  boolean $escape whether to escape or not the values
709 709
      * @return object        the current Database instance
710 710
      */
711
-    public function between($field, $value1, $value2, $type = '', $andOr = 'AND', $escape = true){
712
-      if(is_null($value1)){
711
+    public function between($field, $value1, $value2, $type = '', $andOr = 'AND', $escape = true) {
712
+      if (is_null($value1)) {
713 713
         $value1 = '';
714 714
       }
715
-      if(is_null($value2)){
715
+      if (is_null($value2)) {
716 716
         $value2 = '';
717 717
       }
718
-      if (is_null($this->where)){
718
+      if (is_null($this->where)) {
719 719
       	$this->where = $field . ' ' . $type . 'BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
720 720
       }
721
-      else{
722
-        if(substr($this->where, -1) == '('){
721
+      else {
722
+        if (substr($this->where, -1) == '(') {
723 723
           $this->where = $this->where . ' ' . $field . ' ' . $type . 'BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
724 724
         }
725
-        else{
725
+        else {
726 726
           $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' ' . $type . 'BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
727 727
         }
728 728
       }
@@ -734,7 +734,7 @@  discard block
 block discarded – undo
734 734
      * @see  Database::between()
735 735
      * @return object        the current Database instance
736 736
      */
737
-    public function notBetween($field, $value1, $value2, $escape = true){
737
+    public function notBetween($field, $value1, $value2, $escape = true) {
738 738
       return $this->between($field, $value1, $value2, 'NOT ', 'AND', $escape);
739 739
     }
740 740
 
@@ -743,7 +743,7 @@  discard block
 block discarded – undo
743 743
      * @see  Database::between()
744 744
      * @return object        the current Database instance
745 745
      */
746
-    public function orBetween($field, $value1, $value2, $escape = true){
746
+    public function orBetween($field, $value1, $value2, $escape = true) {
747 747
       return $this->between($field, $value1, $value2, '', 'OR', $escape);
748 748
     }
749 749
 
@@ -752,7 +752,7 @@  discard block
 block discarded – undo
752 752
      * @see  Database::between()
753 753
      * @return object        the current Database instance
754 754
      */
755
-    public function orNotBetween($field, $value1, $value2, $escape = true){
755
+    public function orNotBetween($field, $value1, $value2, $escape = true) {
756 756
       return $this->between($field, $value1, $value2, 'NOT ', 'OR', $escape);
757 757
     }
758 758
 
@@ -765,20 +765,20 @@  discard block
 block discarded – undo
765 765
      * @param  boolean $escape whether to escape or not the values
766 766
      * @return object        the current Database instance
767 767
      */
768
-    public function like($field, $data, $type = '', $andOr = 'AND', $escape = true){
769
-      if(is_null($data)){
768
+    public function like($field, $data, $type = '', $andOr = 'AND', $escape = true) {
769
+      if (is_null($data)) {
770 770
         $data = '';
771 771
       }
772 772
       $like = $escape ? $this->escape($data) : $data;
773
-      if (is_null($this->where)){
773
+      if (is_null($this->where)) {
774 774
         $this->where = $field . ' ' . $type . 'LIKE ' . $like;
775 775
       }
776
-      else{
777
-        if(substr($this->where, -1) == '('){
776
+      else {
777
+        if (substr($this->where, -1) == '(') {
778 778
           $this->where = $this->where . ' ' . $field . ' ' . $type . 'LIKE ' . $like;
779 779
         }
780
-        else{
781
-          $this->where = $this->where . ' '.$andOr.' ' . $field . ' ' . $type . 'LIKE ' . $like;
780
+        else {
781
+          $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' ' . $type . 'LIKE ' . $like;
782 782
         }
783 783
       }
784 784
       return $this;
@@ -789,7 +789,7 @@  discard block
 block discarded – undo
789 789
      * @see  Database::like()
790 790
      * @return object        the current Database instance
791 791
      */
792
-    public function orLike($field, $data, $escape = true){
792
+    public function orLike($field, $data, $escape = true) {
793 793
       return $this->like($field, $data, '', 'OR', $escape);
794 794
     }
795 795
 
@@ -798,7 +798,7 @@  discard block
 block discarded – undo
798 798
      * @see  Database::like()
799 799
      * @return object        the current Database instance
800 800
      */
801
-    public function notLike($field, $data, $escape = true){
801
+    public function notLike($field, $data, $escape = true) {
802 802
       return $this->like($field, $data, 'NOT ', 'AND', $escape);
803 803
     }
804 804
 
@@ -807,7 +807,7 @@  discard block
 block discarded – undo
807 807
      * @see  Database::like()
808 808
      * @return object        the current Database instance
809 809
      */
810
-    public function orNotLike($field, $data, $escape = true){
810
+    public function orNotLike($field, $data, $escape = true) {
811 811
       return $this->like($field, $data, 'NOT ', 'OR', $escape);
812 812
     }
813 813
 
@@ -818,14 +818,14 @@  discard block
 block discarded – undo
818 818
      * @param  int $limitEnd the limit count
819 819
      * @return object        the current Database instance
820 820
      */
821
-    public function limit($limit, $limitEnd = null){
822
-      if(is_null($limit)){
821
+    public function limit($limit, $limitEnd = null) {
822
+      if (is_null($limit)) {
823 823
         return;
824 824
       }
825
-      if (! is_null($limitEnd)){
825
+      if (!is_null($limitEnd)) {
826 826
         $this->limit = $limit . ', ' . $limitEnd;
827 827
       }
828
-      else{
828
+      else {
829 829
         $this->limit = $limit;
830 830
       }
831 831
       return $this;
@@ -837,16 +837,16 @@  discard block
 block discarded – undo
837 837
      * @param  string $orderDir the order direction (ASC or DESC)
838 838
      * @return object        the current Database instance
839 839
      */
840
-    public function orderBy($orderBy, $orderDir = ' ASC'){
841
-      if (! is_null($orderDir)){
842
-        $this->orderBy = ! $this->orderBy ? ($orderBy . ' ' . strtoupper($orderDir)) : $this->orderBy . ', ' . $orderBy . ' ' . strtoupper($orderDir);
840
+    public function orderBy($orderBy, $orderDir = ' ASC') {
841
+      if (!is_null($orderDir)) {
842
+        $this->orderBy = !$this->orderBy ? ($orderBy . ' ' . strtoupper($orderDir)) : $this->orderBy . ', ' . $orderBy . ' ' . strtoupper($orderDir);
843 843
       }
844
-      else{
845
-        if(stristr($orderBy, ' ') || $orderBy == 'rand()'){
846
-          $this->orderBy = ! $this->orderBy ? $orderBy : $this->orderBy . ', ' . $orderBy;
844
+      else {
845
+        if (stristr($orderBy, ' ') || $orderBy == 'rand()') {
846
+          $this->orderBy = !$this->orderBy ? $orderBy : $this->orderBy . ', ' . $orderBy;
847 847
         }
848
-        else{
849
-          $this->orderBy = ! $this->orderBy ? ($orderBy . ' ASC') : $this->orderBy . ', ' . ($orderBy . ' ASC');
848
+        else {
849
+          $this->orderBy = !$this->orderBy ? ($orderBy . ' ASC') : $this->orderBy . ', ' . ($orderBy . ' ASC');
850 850
         }
851 851
       }
852 852
       return $this;
@@ -857,11 +857,11 @@  discard block
 block discarded – undo
857 857
      * @param  string|array $field the field name used or array of field list
858 858
      * @return object        the current Database instance
859 859
      */
860
-    public function groupBy($field){
861
-      if(is_array($field)){
860
+    public function groupBy($field) {
861
+      if (is_array($field)) {
862 862
         $this->groupBy = implode(', ', $field);
863 863
       }
864
-      else{
864
+      else {
865 865
         $this->groupBy = $field;
866 866
       }
867 867
       return $this;
@@ -875,13 +875,13 @@  discard block
 block discarded – undo
875 875
      * @param  boolean $escape whether to escape or not the values
876 876
      * @return object        the current Database instance
877 877
      */
878
-    public function having($field, $op = null, $val = null, $escape = true){
879
-      if(is_array($op)){
878
+    public function having($field, $op = null, $val = null, $escape = true) {
879
+      if (is_array($op)) {
880 880
         $x = explode('?', $field);
881 881
         $w = '';
882
-        foreach($x as $k => $v){
883
-  	      if(!empty($v)){
884
-            if(isset($op[$k]) && is_null($op[$k])){
882
+        foreach ($x as $k => $v) {
883
+  	      if (!empty($v)) {
884
+            if (isset($op[$k]) && is_null($op[$k])) {
885 885
               $op[$k] = '';
886 886
             }
887 887
   	      	$w .= $v . (isset($op[$k]) ? ($escape ? $this->escape($op[$k]) : $op[$k]) : '');
@@ -889,14 +889,14 @@  discard block
 block discarded – undo
889 889
       	}
890 890
         $this->having = $w;
891 891
       }
892
-      else if (! in_array($op, $this->operatorList)){
893
-        if(is_null($op)){
892
+      else if (!in_array($op, $this->operatorList)) {
893
+        if (is_null($op)) {
894 894
           $op = '';
895 895
         }
896 896
         $this->having = $field . ' > ' . ($escape ? $this->escape($op) : $op);
897 897
       }
898
-      else{
899
-        if(is_null($val)){
898
+      else {
899
+        if (is_null($val)) {
900 900
           $val = '';
901 901
         }
902 902
         $this->having = $field . ' ' . $op . ' ' . ($escape ? $this->escape($val) : $val);
@@ -908,7 +908,7 @@  discard block
 block discarded – undo
908 908
      * Return the number of rows returned by the current query
909 909
      * @return int
910 910
      */
911
-    public function numRows(){
911
+    public function numRows() {
912 912
       return $this->numRows;
913 913
     }
914 914
 
@@ -916,15 +916,15 @@  discard block
 block discarded – undo
916 916
      * Return the last insert id value
917 917
      * @return mixed
918 918
      */
919
-    public function insertId(){
919
+    public function insertId() {
920 920
       return $this->insertId;
921 921
     }
922 922
 
923 923
     /**
924 924
      * Show an error got from the current query (SQL command synthax error, database driver returned error, etc.)
925 925
      */
926
-    public function error(){
927
-  		if($this->error){
926
+    public function error() {
927
+  		if ($this->error) {
928 928
   			show_error('Query: "' . $this->query . '" Error: ' . $this->error, 'Database Error');
929 929
   		}
930 930
     }
@@ -935,14 +935,14 @@  discard block
 block discarded – undo
935 935
      * If is string will determine the result type "array" or "object"
936 936
      * @return mixed       the query SQL string or the record result
937 937
      */
938
-    public function get($returnSQLQueryOrResultType = false){
938
+    public function get($returnSQLQueryOrResultType = false) {
939 939
       $this->limit = 1;
940 940
       $query = $this->getAll(true);
941
-      if($returnSQLQueryOrResultType === true){
941
+      if ($returnSQLQueryOrResultType === true) {
942 942
         return $query;
943 943
       }
944
-      else{
945
-        return $this->query( $query, false, (($returnSQLQueryOrResultType == 'array') ? true : false) );
944
+      else {
945
+        return $this->query($query, false, (($returnSQLQueryOrResultType == 'array') ? true : false));
946 946
       }
947 947
     }
948 948
 
@@ -952,37 +952,37 @@  discard block
 block discarded – undo
952 952
      * If is string will determine the result type "array" or "object"
953 953
      * @return mixed       the query SQL string or the record result
954 954
      */
955
-    public function getAll($returnSQLQueryOrResultType = false){
955
+    public function getAll($returnSQLQueryOrResultType = false) {
956 956
       $query = 'SELECT ' . $this->select . ' FROM ' . $this->from;
957
-      if (! is_null($this->join)){
957
+      if (!is_null($this->join)) {
958 958
         $query .= $this->join;
959 959
       }
960 960
 	  
961
-      if (! is_null($this->where)){
961
+      if (!is_null($this->where)) {
962 962
         $query .= ' WHERE ' . $this->where;
963 963
       }
964 964
 
965
-      if (! is_null($this->groupBy)){
965
+      if (!is_null($this->groupBy)) {
966 966
         $query .= ' GROUP BY ' . $this->groupBy;
967 967
       }
968 968
 
969
-      if (! is_null($this->having)){
969
+      if (!is_null($this->having)) {
970 970
         $query .= ' HAVING ' . $this->having;
971 971
       }
972 972
 
973
-      if (! is_null($this->orderBy)){
973
+      if (!is_null($this->orderBy)) {
974 974
           $query .= ' ORDER BY ' . $this->orderBy;
975 975
       }
976 976
 
977
-      if(! is_null($this->limit)){
977
+      if (!is_null($this->limit)) {
978 978
       	$query .= ' LIMIT ' . $this->limit;
979 979
       }
980 980
 	  
981
-	  if($returnSQLQueryOrResultType === true){
981
+	  if ($returnSQLQueryOrResultType === true) {
982 982
     	return $query;
983 983
       }
984
-      else{
985
-    	return $this->query($query, true, (($returnSQLQueryOrResultType == 'array') ? true : false) );
984
+      else {
985
+    	return $this->query($query, true, (($returnSQLQueryOrResultType == 'array') ? true : false));
986 986
       }
987 987
     }
988 988
 
@@ -992,15 +992,15 @@  discard block
 block discarded – undo
992 992
      * @param  boolean $escape  whether to escape or not the values
993 993
      * @return mixed          the insert id of the new record or null
994 994
      */
995
-    public function insert($data = array(), $escape = true){
995
+    public function insert($data = array(), $escape = true) {
996 996
       $column = array();
997 997
       $val = array();
998
-      if(! $data && $this->getData()){
998
+      if (!$data && $this->getData()) {
999 999
         $columns = array_keys($this->getData());
1000 1000
         $column = implode(',', $columns);
1001 1001
         $val = implode(', ', $this->getData());
1002 1002
       }
1003
-      else{
1003
+      else {
1004 1004
         $columns = array_keys($data);
1005 1005
         $column = implode(',', $columns);
1006 1006
         $val = implode(', ', ($escape ? array_map(array($this, 'escape'), $data) : $data));
@@ -1009,14 +1009,14 @@  discard block
 block discarded – undo
1009 1009
       $query = 'INSERT INTO ' . $this->from . ' (' . $column . ') VALUES (' . $val . ')';
1010 1010
       $query = $this->query($query);
1011 1011
 
1012
-      if ($query){
1013
-        if(! $this->pdo){
1012
+      if ($query) {
1013
+        if (!$this->pdo) {
1014 1014
           $this->connect();
1015 1015
         }
1016 1016
         $this->insertId = $this->pdo->lastInsertId();
1017 1017
         return $this->insertId();
1018 1018
       }
1019
-      else{
1019
+      else {
1020 1020
 		  return false;
1021 1021
       }
1022 1022
     }
@@ -1027,29 +1027,29 @@  discard block
 block discarded – undo
1027 1027
      * @param  boolean $escape  whether to escape or not the values
1028 1028
      * @return mixed          the update status
1029 1029
      */
1030
-    public function update($data = array(), $escape = true){
1030
+    public function update($data = array(), $escape = true) {
1031 1031
       $query = 'UPDATE ' . $this->from . ' SET ';
1032 1032
       $values = array();
1033
-      if(! $data && $this->getData()){
1034
-        foreach ($this->getData() as $column => $val){
1033
+      if (!$data && $this->getData()) {
1034
+        foreach ($this->getData() as $column => $val) {
1035 1035
           $values[] = $column . ' = ' . $val;
1036 1036
         }
1037 1037
       }
1038
-      else{
1039
-        foreach ($data as $column => $val){
1038
+      else {
1039
+        foreach ($data as $column => $val) {
1040 1040
           $values[] = $column . '=' . ($escape ? $this->escape($val) : $val);
1041 1041
         }
1042 1042
       }
1043 1043
       $query .= (is_array($data) ? implode(', ', $values) : $data);
1044
-      if (! is_null($this->where)){
1044
+      if (!is_null($this->where)) {
1045 1045
         $query .= ' WHERE ' . $this->where;
1046 1046
       }
1047 1047
 
1048
-      if (! is_null($this->orderBy)){
1048
+      if (!is_null($this->orderBy)) {
1049 1049
         $query .= ' ORDER BY ' . $this->orderBy;
1050 1050
       }
1051 1051
 
1052
-      if (! is_null($this->limit)){
1052
+      if (!is_null($this->limit)) {
1053 1053
         $query .= ' LIMIT ' . $this->limit;
1054 1054
       }
1055 1055
       return $this->query($query);
@@ -1059,22 +1059,22 @@  discard block
 block discarded – undo
1059 1059
      * Delete the record in database
1060 1060
      * @return mixed the delete status
1061 1061
      */
1062
-    public function delete(){
1062
+    public function delete() {
1063 1063
     	$query = 'DELETE FROM ' . $this->from;
1064 1064
 
1065
-    	if (! is_null($this->where)){
1065
+    	if (!is_null($this->where)) {
1066 1066
     		$query .= ' WHERE ' . $this->where;
1067 1067
       	}
1068 1068
 
1069
-    	if (! is_null($this->orderBy)){
1069
+    	if (!is_null($this->orderBy)) {
1070 1070
     	  $query .= ' ORDER BY ' . $this->orderBy;
1071 1071
       	}
1072 1072
 
1073
-    	if (! is_null($this->limit)){
1073
+    	if (!is_null($this->limit)) {
1074 1074
     		$query .= ' LIMIT ' . $this->limit;
1075 1075
       	}
1076 1076
 
1077
-    	if($query == 'DELETE FROM ' . $this->from && $this->config['driver'] != 'sqlite'){  
1077
+    	if ($query == 'DELETE FROM ' . $this->from && $this->config['driver'] != 'sqlite') {  
1078 1078
     		$query = 'TRUNCATE TABLE ' . $this->from;
1079 1079
       }
1080 1080
     	return $this->query($query);
@@ -1087,13 +1087,13 @@  discard block
 block discarded – undo
1087 1087
      * @param  boolean $array return the result as array
1088 1088
      * @return mixed         the query result
1089 1089
      */
1090
-    public function query($query, $all = true, $array = false){
1090
+    public function query($query, $all = true, $array = false) {
1091 1091
       $this->reset();
1092
-      if(is_array($all)){
1092
+      if (is_array($all)) {
1093 1093
         $x = explode('?', $query);
1094 1094
         $q = '';
1095
-        foreach($x as $k => $v){
1096
-          if(! empty($v)){
1095
+        foreach ($x as $k => $v) {
1096
+          if (!empty($v)) {
1097 1097
             $q .= $v . (isset($all[$k]) ? $this->escape($all[$k]) : '');
1098 1098
           }
1099 1099
         }
@@ -1102,7 +1102,7 @@  discard block
 block discarded – undo
1102 1102
 
1103 1103
       $this->query = preg_replace('/\s\s+|\t\t+/', ' ', trim($query));
1104 1104
       $sqlSELECTQuery = stristr($this->query, 'SELECT');
1105
-      $this->logger->info('Execute SQL query ['.$this->query.'], return type: ' . ($array?'ARRAY':'OBJECT') .', return as list: ' . ($all ? 'YES':'NO'));
1105
+      $this->logger->info('Execute SQL query [' . $this->query . '], return type: ' . ($array ? 'ARRAY' : 'OBJECT') . ', return as list: ' . ($all ? 'YES' : 'NO'));
1106 1106
       //cache expire time
1107 1107
   	  $cacheExpire = $this->temporaryCacheTtl;
1108 1108
   	  
@@ -1124,34 +1124,34 @@  discard block
 block discarded – undo
1124 1124
   	  //if can use cache feature for this query
1125 1125
   	  $dbCacheStatus = $cacheEnable && $cacheExpire > 0;
1126 1126
 	  
1127
-      if ($dbCacheStatus && $sqlSELECTQuery){
1127
+      if ($dbCacheStatus && $sqlSELECTQuery) {
1128 1128
         $this->logger->info('The cache is enabled for this query, try to get result from cache'); 
1129 1129
         $cacheKey = md5($query . $all . $array);
1130
-        if(is_object($this->cacheInstance)){
1130
+        if (is_object($this->cacheInstance)) {
1131 1131
           $cacheInstance = $this->cacheInstance;
1132 1132
         }
1133
-        else{
1133
+        else {
1134 1134
           $obj = & get_instance();
1135 1135
           $cacheInstance = $obj->cache;  
1136 1136
         }
1137 1137
         $cacheContent = $cacheInstance->get($cacheKey);        
1138 1138
       }
1139
-      else{
1139
+      else {
1140 1140
 		  $this->logger->info('The cache is not enabled for this query or is not the SELECT query, get the result directly from real database');
1141 1141
       }
1142 1142
 
1143
-      if(! $this->pdo){
1143
+      if (!$this->pdo) {
1144 1144
         $this->connect();
1145 1145
       }
1146 1146
       
1147
-      if (! $cacheContent && $sqlSELECTQuery){
1147
+      if (!$cacheContent && $sqlSELECTQuery) {
1148 1148
 		    //for database query execution time
1149 1149
         $benchmarkMarkerKey = md5($query . $all . $array);
1150 1150
         $bench = null;
1151
-        if(is_object($this->benchmarkInstance)){
1151
+        if (is_object($this->benchmarkInstance)) {
1152 1152
           $bench = $this->benchmarkInstance;
1153 1153
         }
1154
-        else{
1154
+        else {
1155 1155
           $obj = & get_instance();
1156 1156
           $bench = $obj->benchmark;  
1157 1157
         }
@@ -1162,64 +1162,64 @@  discard block
 block discarded – undo
1162 1162
     		//get response time for this query
1163 1163
         $responseTime = $bench->elapsedTime('DATABASE_QUERY_START(' . $benchmarkMarkerKey . ')', 'DATABASE_QUERY_END(' . $benchmarkMarkerKey . ')');
1164 1164
 	     	//TODO use the configuration value for the high response time currently is 1 second
1165
-        if($responseTime >= 1 ){
1166
-            $this->logger->warning('High response time while processing database query [' .$query. ']. The response time is [' .$responseTime. '] sec.');
1165
+        if ($responseTime >= 1) {
1166
+            $this->logger->warning('High response time while processing database query [' . $query . ']. The response time is [' . $responseTime . '] sec.');
1167 1167
         }
1168
-        if ($sqlQuery){
1168
+        if ($sqlQuery) {
1169 1169
             //if need return all result like list of record
1170
-            if ($all){
1170
+            if ($all) {
1171 1171
     				    $this->result = ($array == false) ? $sqlQuery->fetchAll(PDO::FETCH_OBJ) : $sqlQuery->fetchAll(PDO::FETCH_ASSOC);
1172 1172
     		    }
1173
-            else{
1173
+            else {
1174 1174
 				        $this->result = ($array == false) ? $sqlQuery->fetch(PDO::FETCH_OBJ) : $sqlQuery->fetch(PDO::FETCH_ASSOC);
1175 1175
             }
1176 1176
             //Sqlite and pgsql always return 0 when using rowCount()
1177
-            if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1177
+            if (in_array($this->config['driver'], array('sqlite', 'pgsql'))) {
1178 1178
               $this->numRows = count($this->result);  
1179 1179
             }
1180
-            else{
1180
+            else {
1181 1181
               $this->numRows = $sqlQuery->rowCount(); 
1182 1182
             }
1183 1183
 
1184
-          if ($dbCacheStatus && $sqlSELECTQuery){
1185
-              $this->logger->info('Save the result for query [' .$this->query. '] into cache for future use');
1184
+          if ($dbCacheStatus && $sqlSELECTQuery) {
1185
+              $this->logger->info('Save the result for query [' . $this->query . '] into cache for future use');
1186 1186
               $cacheInstance->set($cacheKey, $this->result, $cacheExpire);
1187 1187
           }
1188 1188
         }
1189
-        else{
1189
+        else {
1190 1190
           $error = $this->pdo->errorInfo();
1191 1191
           $this->error = isset($error[2]) ? $error[2] : '';
1192 1192
           $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1193 1193
           $this->error();
1194 1194
         }
1195 1195
       }
1196
-      else if ((! $cacheContent && !$sqlSELECTQuery) || ($cacheContent && !$sqlSELECTQuery)){
1196
+      else if ((!$cacheContent && !$sqlSELECTQuery) || ($cacheContent && !$sqlSELECTQuery)) {
1197 1197
     		$queryStr = $this->pdo->query($this->query);
1198
-    		if($queryStr){
1198
+    		if ($queryStr) {
1199 1199
           //Sqlite and pgsql always return 0 when using rowCount()
1200
-          if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1200
+          if (in_array($this->config['driver'], array('sqlite', 'pgsql'))) {
1201 1201
             $this->result = 1; //to test the result for the query like UPDATE, INSERT, DELETE
1202 1202
             $this->numRows = 1;  
1203 1203
           }
1204
-          else{
1204
+          else {
1205 1205
               $this->result = $queryStr->rowCount() >= 0; //to test the result for the query like UPDATE, INSERT, DELETE
1206 1206
               $this->numRows = $queryStr->rowCount(); 
1207 1207
           }
1208 1208
     		}
1209
-        if (! $this->result){
1209
+        if (!$this->result) {
1210 1210
           $error = $this->pdo->errorInfo();
1211 1211
           $this->error = isset($error[2]) ? $error[2] : '';
1212 1212
           $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1213 1213
           $this->error();
1214 1214
         }
1215 1215
       }
1216
-      else{
1217
-        $this->logger->info('The result for query [' .$this->query. '] already cached use it');
1216
+      else {
1217
+        $this->logger->info('The result for query [' . $this->query . '] already cached use it');
1218 1218
         $this->result = $cacheContent;
1219 1219
 	     	$this->numRows = count($this->result);
1220 1220
       }
1221 1221
       $this->queryCount++;
1222
-      if(! $this->result){
1222
+      if (!$this->result) {
1223 1223
         $this->logger->info('No result where found for the query [' . $query . ']');
1224 1224
       }
1225 1225
       return $this->result;
@@ -1230,8 +1230,8 @@  discard block
 block discarded – undo
1230 1230
      * @param integer $ttl the cache time to live in second
1231 1231
      * @return object        the current Database instance
1232 1232
      */
1233
-    public function setCache($ttl = 0){
1234
-      if($ttl > 0){
1233
+    public function setCache($ttl = 0) {
1234
+      if ($ttl > 0) {
1235 1235
         $this->cacheTtl = $ttl;
1236 1236
 		    $this->temporaryCacheTtl = $ttl;
1237 1237
       }
@@ -1243,8 +1243,8 @@  discard block
 block discarded – undo
1243 1243
 	 * @param  integer $ttl the cache time to live in second
1244 1244
 	 * @return object        the current Database instance
1245 1245
 	 */
1246
-	public function cached($ttl = 0){
1247
-      if($ttl > 0){
1246
+	public function cached($ttl = 0) {
1247
+      if ($ttl > 0) {
1248 1248
         $this->temporaryCacheTtl = $ttl;
1249 1249
       }
1250 1250
 	  return $this;
@@ -1255,11 +1255,11 @@  discard block
 block discarded – undo
1255 1255
      * @param  mixed $data the data to be escaped
1256 1256
      * @return mixed       the data after escaped
1257 1257
      */
1258
-    public function escape($data){
1259
-      if(is_null($data)){
1258
+    public function escape($data) {
1259
+      if (is_null($data)) {
1260 1260
         return null;
1261 1261
       }
1262
-      if(! $this->pdo){
1262
+      if (!$this->pdo) {
1263 1263
         $this->connect();
1264 1264
       }
1265 1265
       return $this->pdo->quote(trim($data));
@@ -1269,7 +1269,7 @@  discard block
 block discarded – undo
1269 1269
      * Return the number query executed count for the current request
1270 1270
      * @return int
1271 1271
      */
1272
-    public function queryCount(){
1272
+    public function queryCount() {
1273 1273
       return $this->queryCount;
1274 1274
     }
1275 1275
 
@@ -1277,7 +1277,7 @@  discard block
 block discarded – undo
1277 1277
      * Return the current query SQL string
1278 1278
      * @return string
1279 1279
      */
1280
-    public function getQuery(){
1280
+    public function getQuery() {
1281 1281
       return $this->query;
1282 1282
     }
1283 1283
 
@@ -1285,7 +1285,7 @@  discard block
 block discarded – undo
1285 1285
      * Return the application database name
1286 1286
      * @return string
1287 1287
      */
1288
-    public function getDatabaseName(){
1288
+    public function getDatabaseName() {
1289 1289
       return $this->databaseName;
1290 1290
     }
1291 1291
 
@@ -1293,7 +1293,7 @@  discard block
 block discarded – undo
1293 1293
      * Return the database configuration
1294 1294
      * @return array
1295 1295
      */
1296
-    public  function getDatabaseConfiguration(){
1296
+    public  function getDatabaseConfiguration() {
1297 1297
       return $this->config;
1298 1298
     }
1299 1299
 
@@ -1301,7 +1301,7 @@  discard block
 block discarded – undo
1301 1301
      * set the database configuration
1302 1302
      * @param array $config the configuration
1303 1303
      */
1304
-    public function setDatabaseConfiguration(array $config){
1304
+    public function setDatabaseConfiguration(array $config) {
1305 1305
       $this->config = array_merge($this->config, $config);
1306 1306
       $this->prefix = $this->config['prefix'];
1307 1307
       $this->databaseName = $this->config['database'];
@@ -1313,7 +1313,7 @@  discard block
 block discarded – undo
1313 1313
      * Return the PDO instance
1314 1314
      * @return PDO
1315 1315
      */
1316
-    public function getPdo(){
1316
+    public function getPdo() {
1317 1317
       return $this->pdo;
1318 1318
     }
1319 1319
 
@@ -1321,7 +1321,7 @@  discard block
 block discarded – undo
1321 1321
      * Set the PDO instance
1322 1322
      * @param PDO $pdo the pdo object
1323 1323
      */
1324
-    public function setPdo(PDO $pdo){
1324
+    public function setPdo(PDO $pdo) {
1325 1325
       $this->pdo = $pdo;
1326 1326
       return $this;
1327 1327
     }
@@ -1331,7 +1331,7 @@  discard block
 block discarded – undo
1331 1331
      * Return the Log instance
1332 1332
      * @return Log
1333 1333
      */
1334
-    public function getLogger(){
1334
+    public function getLogger() {
1335 1335
       return $this->logger;
1336 1336
     }
1337 1337
 
@@ -1339,7 +1339,7 @@  discard block
 block discarded – undo
1339 1339
      * Set the log instance
1340 1340
      * @param Log $logger the log object
1341 1341
      */
1342
-    public function setLogger($logger){
1342
+    public function setLogger($logger) {
1343 1343
       $this->logger = $logger;
1344 1344
       return $this;
1345 1345
     }
@@ -1348,7 +1348,7 @@  discard block
 block discarded – undo
1348 1348
      * Return the cache instance
1349 1349
      * @return CacheInterface
1350 1350
      */
1351
-    public function getCacheInstance(){
1351
+    public function getCacheInstance() {
1352 1352
       return $this->cacheInstance;
1353 1353
     }
1354 1354
 
@@ -1356,7 +1356,7 @@  discard block
 block discarded – undo
1356 1356
      * Set the cache instance
1357 1357
      * @param CacheInterface $cache the cache object
1358 1358
      */
1359
-    public function setCacheInstance($cache){
1359
+    public function setCacheInstance($cache) {
1360 1360
       $this->cacheInstance = $cache;
1361 1361
       return $this;
1362 1362
     }
@@ -1365,7 +1365,7 @@  discard block
 block discarded – undo
1365 1365
      * Return the benchmark instance
1366 1366
      * @return Benchmark
1367 1367
      */
1368
-    public function getBenchmark(){
1368
+    public function getBenchmark() {
1369 1369
       return $this->benchmarkInstance;
1370 1370
     }
1371 1371
 
@@ -1373,7 +1373,7 @@  discard block
 block discarded – undo
1373 1373
      * Set the benchmark instance
1374 1374
      * @param Benchmark $cache the cache object
1375 1375
      */
1376
-    public function setBenchmark($benchmark){
1376
+    public function setBenchmark($benchmark) {
1377 1377
       $this->benchmarkInstance = $benchmark;
1378 1378
       return $this;
1379 1379
     }
@@ -1382,7 +1382,7 @@  discard block
 block discarded – undo
1382 1382
      * Return the data to be used for insert, update, etc.
1383 1383
      * @return array
1384 1384
      */
1385
-    public function getData(){
1385
+    public function getData() {
1386 1386
       return $this->data;
1387 1387
     }
1388 1388
 
@@ -1393,7 +1393,7 @@  discard block
 block discarded – undo
1393 1393
      * @param boolean $escape whether to escape or not the $value
1394 1394
      * @return object        the current Database instance
1395 1395
      */
1396
-    public function setData($key, $value, $escape = true){
1396
+    public function setData($key, $value, $escape = true) {
1397 1397
       $this->data[$key] = $escape ? $this->escape($value) : $value;
1398 1398
       return $this;
1399 1399
     }
@@ -1402,7 +1402,7 @@  discard block
 block discarded – undo
1402 1402
   /**
1403 1403
    * Reset the database class attributs to the initail values before each query.
1404 1404
    */
1405
-  private function reset(){
1405
+  private function reset() {
1406 1406
     $this->select   = '*';
1407 1407
     $this->from     = null;
1408 1408
     $this->where    = null;
@@ -1422,7 +1422,7 @@  discard block
 block discarded – undo
1422 1422
   /**
1423 1423
    * The class destructor
1424 1424
    */
1425
-  function __destruct(){
1425
+  function __destruct() {
1426 1426
     $this->pdo = null;
1427 1427
   }
1428 1428
 
Please login to merge, or discard this patch.
Braces   +42 added lines, -84 removed lines patch added patch discarded remove patch
@@ -188,8 +188,7 @@  discard block
 block discarded – undo
188 188
          */
189 189
         if(is_object($logger)){
190 190
           $this->logger = $logger;
191
-        }
192
-        else{
191
+        } else{
193 192
             $this->logger =& class_loader('Log', 'classes');
194 193
             $this->logger->setLogger('Library::Database');
195 194
         }
@@ -251,14 +250,12 @@  discard block
 block discarded – undo
251 250
             $this->pdo->exec("SET CHARACTER SET '" . $config['charset'] . "'");
252 251
             $this->pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_OBJ);
253 252
             return true;
254
-          }
255
-          catch (PDOException $e){
253
+          } catch (PDOException $e){
256 254
             $this->logger->fatal($e->getMessage());
257 255
             show_error('Cannot connect to Database.');
258 256
             return false;
259 257
           }
260
-      }
261
-      else{
258
+      } else{
262 259
         show_error('Database configuration is not set.');
263 260
         return false;
264 261
       }
@@ -276,8 +273,7 @@  discard block
 block discarded – undo
276 273
           $froms .= $this->prefix . $key . ', ';
277 274
         }
278 275
         $this->from = rtrim($froms, ', ');
279
-      }
280
-      else{
276
+      } else{
281 277
         $this->from = $this->prefix . $table;
282 278
       }
283 279
       return $this;
@@ -383,8 +379,7 @@  discard block
 block discarded – undo
383 379
       }
384 380
       if (is_null($this->join)){
385 381
         $this->join = ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
386
-      }
387
-      else{
382
+      } else{
388 383
         $this->join = $this->join . ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
389 384
       }
390 385
       return $this;
@@ -455,12 +450,10 @@  discard block
 block discarded – undo
455 450
         foreach($field as $f){
456 451
         	$this->whereIsNull($f, $andOr);
457 452
         }
458
-      }
459
-      else{
453
+      } else{
460 454
         if (! $this->where){
461 455
           $this->where = $field.' IS NULL ';
462
-        }
463
-        else{
456
+        } else{
464 457
             $this->where = $this->where . ' '.$andOr.' ' . $field.' IS NULL ';
465 458
           }
466 459
       }
@@ -478,12 +471,10 @@  discard block
 block discarded – undo
478 471
         foreach($field as $f){
479 472
           $this->whereIsNotNull($f, $andOr);
480 473
         }
481
-      }
482
-      else{
474
+      } else{
483 475
         if (! $this->where){
484 476
           $this->where = $field.' IS NOT NULL ';
485
-        }
486
-        else{
477
+        } else{
487 478
             $this->where = $this->where . ' '.$andOr.' ' . $field.' IS NOT NULL ';
488 479
           }
489 480
       }
@@ -510,8 +501,7 @@  discard block
 block discarded – undo
510 501
           $_where[] = $type . $column . '=' . ($escape ? $this->escape($data) : $data);
511 502
         }
512 503
         $where = implode(' '.$andOr.' ', $_where);
513
-      }
514
-      else{
504
+      } else{
515 505
         if(is_array($op)){
516 506
           $x = explode('?', $where);
517 507
           $w = '';
@@ -524,14 +514,12 @@  discard block
 block discarded – undo
524 514
             }
525 515
           }
526 516
           $where = $w;
527
-        }
528
-        else if (! in_array((string)$op, $this->operatorList)){
517
+        } else if (! in_array((string)$op, $this->operatorList)){
529 518
           if(is_null($op)){
530 519
             $op = '';
531 520
           }
532 521
         	$where = $type . $where . ' = ' . ($escape ? $this->escape($op) : $op);
533
-        }
534
-        else{
522
+        } else{
535 523
           if(is_null($val)){
536 524
             $val = '';
537 525
           }
@@ -540,12 +528,10 @@  discard block
 block discarded – undo
540 528
       }
541 529
       if (is_null($this->where)){
542 530
         $this->where = $where;
543
-      }
544
-      else{
531
+      } else{
545 532
         if(substr($this->where, -1) == '('){
546 533
           $this->where = $this->where . ' ' . $where;
547
-        }
548
-        else{
534
+        } else{
549 535
           $this->where = $this->where . ' '.$andOr.' ' . $where;
550 536
         }
551 537
       }
@@ -589,12 +575,10 @@  discard block
 block discarded – undo
589 575
     public function groupStart($type = '', $andOr = ' AND'){
590 576
       if (is_null($this->where)){
591 577
         $this->where = $type . ' (';
592
-      }
593
-      else{
578
+      } else{
594 579
           if(substr($this->where, -1) == '('){
595 580
             $this->where .= $type . ' (';
596
-          }
597
-          else{
581
+          } else{
598 582
           	$this->where .= $andOr . ' ' . $type . ' (';
599 583
           }
600 584
       }
@@ -658,12 +642,10 @@  discard block
 block discarded – undo
658 642
         $keys = implode(', ', $_keys);
659 643
         if (is_null($this->where)){
660 644
           $this->where = $field . ' ' . $type . 'IN (' . $keys . ')';
661
-        }
662
-        else{
645
+        } else{
663 646
           if(substr($this->where, -1) == '('){
664 647
             $this->where = $this->where . ' ' . $field . ' '.$type.'IN (' . $keys . ')';
665
-          }
666
-          else{
648
+          } else{
667 649
             $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' '.$type.'IN (' . $keys . ')';
668 650
           }
669 651
         }
@@ -717,12 +699,10 @@  discard block
 block discarded – undo
717 699
       }
718 700
       if (is_null($this->where)){
719 701
       	$this->where = $field . ' ' . $type . 'BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
720
-      }
721
-      else{
702
+      } else{
722 703
         if(substr($this->where, -1) == '('){
723 704
           $this->where = $this->where . ' ' . $field . ' ' . $type . 'BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
724
-        }
725
-        else{
705
+        } else{
726 706
           $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' ' . $type . 'BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
727 707
         }
728 708
       }
@@ -772,12 +752,10 @@  discard block
 block discarded – undo
772 752
       $like = $escape ? $this->escape($data) : $data;
773 753
       if (is_null($this->where)){
774 754
         $this->where = $field . ' ' . $type . 'LIKE ' . $like;
775
-      }
776
-      else{
755
+      } else{
777 756
         if(substr($this->where, -1) == '('){
778 757
           $this->where = $this->where . ' ' . $field . ' ' . $type . 'LIKE ' . $like;
779
-        }
780
-        else{
758
+        } else{
781 759
           $this->where = $this->where . ' '.$andOr.' ' . $field . ' ' . $type . 'LIKE ' . $like;
782 760
         }
783 761
       }
@@ -824,8 +802,7 @@  discard block
 block discarded – undo
824 802
       }
825 803
       if (! is_null($limitEnd)){
826 804
         $this->limit = $limit . ', ' . $limitEnd;
827
-      }
828
-      else{
805
+      } else{
829 806
         $this->limit = $limit;
830 807
       }
831 808
       return $this;
@@ -840,12 +817,10 @@  discard block
 block discarded – undo
840 817
     public function orderBy($orderBy, $orderDir = ' ASC'){
841 818
       if (! is_null($orderDir)){
842 819
         $this->orderBy = ! $this->orderBy ? ($orderBy . ' ' . strtoupper($orderDir)) : $this->orderBy . ', ' . $orderBy . ' ' . strtoupper($orderDir);
843
-      }
844
-      else{
820
+      } else{
845 821
         if(stristr($orderBy, ' ') || $orderBy == 'rand()'){
846 822
           $this->orderBy = ! $this->orderBy ? $orderBy : $this->orderBy . ', ' . $orderBy;
847
-        }
848
-        else{
823
+        } else{
849 824
           $this->orderBy = ! $this->orderBy ? ($orderBy . ' ASC') : $this->orderBy . ', ' . ($orderBy . ' ASC');
850 825
         }
851 826
       }
@@ -860,8 +835,7 @@  discard block
 block discarded – undo
860 835
     public function groupBy($field){
861 836
       if(is_array($field)){
862 837
         $this->groupBy = implode(', ', $field);
863
-      }
864
-      else{
838
+      } else{
865 839
         $this->groupBy = $field;
866 840
       }
867 841
       return $this;
@@ -888,14 +862,12 @@  discard block
 block discarded – undo
888 862
   	      }
889 863
       	}
890 864
         $this->having = $w;
891
-      }
892
-      else if (! in_array($op, $this->operatorList)){
865
+      } else if (! in_array($op, $this->operatorList)){
893 866
         if(is_null($op)){
894 867
           $op = '';
895 868
         }
896 869
         $this->having = $field . ' > ' . ($escape ? $this->escape($op) : $op);
897
-      }
898
-      else{
870
+      } else{
899 871
         if(is_null($val)){
900 872
           $val = '';
901 873
         }
@@ -940,8 +912,7 @@  discard block
 block discarded – undo
940 912
       $query = $this->getAll(true);
941 913
       if($returnSQLQueryOrResultType === true){
942 914
         return $query;
943
-      }
944
-      else{
915
+      } else{
945 916
         return $this->query( $query, false, (($returnSQLQueryOrResultType == 'array') ? true : false) );
946 917
       }
947 918
     }
@@ -980,8 +951,7 @@  discard block
 block discarded – undo
980 951
 	  
981 952
 	  if($returnSQLQueryOrResultType === true){
982 953
     	return $query;
983
-      }
984
-      else{
954
+      } else{
985 955
     	return $this->query($query, true, (($returnSQLQueryOrResultType == 'array') ? true : false) );
986 956
       }
987 957
     }
@@ -999,8 +969,7 @@  discard block
 block discarded – undo
999 969
         $columns = array_keys($this->getData());
1000 970
         $column = implode(',', $columns);
1001 971
         $val = implode(', ', $this->getData());
1002
-      }
1003
-      else{
972
+      } else{
1004 973
         $columns = array_keys($data);
1005 974
         $column = implode(',', $columns);
1006 975
         $val = implode(', ', ($escape ? array_map(array($this, 'escape'), $data) : $data));
@@ -1015,8 +984,7 @@  discard block
 block discarded – undo
1015 984
         }
1016 985
         $this->insertId = $this->pdo->lastInsertId();
1017 986
         return $this->insertId();
1018
-      }
1019
-      else{
987
+      } else{
1020 988
 		  return false;
1021 989
       }
1022 990
     }
@@ -1034,8 +1002,7 @@  discard block
 block discarded – undo
1034 1002
         foreach ($this->getData() as $column => $val){
1035 1003
           $values[] = $column . ' = ' . $val;
1036 1004
         }
1037
-      }
1038
-      else{
1005
+      } else{
1039 1006
         foreach ($data as $column => $val){
1040 1007
           $values[] = $column . '=' . ($escape ? $this->escape($val) : $val);
1041 1008
         }
@@ -1129,14 +1096,12 @@  discard block
 block discarded – undo
1129 1096
         $cacheKey = md5($query . $all . $array);
1130 1097
         if(is_object($this->cacheInstance)){
1131 1098
           $cacheInstance = $this->cacheInstance;
1132
-        }
1133
-        else{
1099
+        } else{
1134 1100
           $obj = & get_instance();
1135 1101
           $cacheInstance = $obj->cache;  
1136 1102
         }
1137 1103
         $cacheContent = $cacheInstance->get($cacheKey);        
1138
-      }
1139
-      else{
1104
+      } else{
1140 1105
 		  $this->logger->info('The cache is not enabled for this query or is not the SELECT query, get the result directly from real database');
1141 1106
       }
1142 1107
 
@@ -1150,8 +1115,7 @@  discard block
 block discarded – undo
1150 1115
         $bench = null;
1151 1116
         if(is_object($this->benchmarkInstance)){
1152 1117
           $bench = $this->benchmarkInstance;
1153
-        }
1154
-        else{
1118
+        } else{
1155 1119
           $obj = & get_instance();
1156 1120
           $bench = $obj->benchmark;  
1157 1121
         }
@@ -1169,15 +1133,13 @@  discard block
 block discarded – undo
1169 1133
             //if need return all result like list of record
1170 1134
             if ($all){
1171 1135
     				    $this->result = ($array == false) ? $sqlQuery->fetchAll(PDO::FETCH_OBJ) : $sqlQuery->fetchAll(PDO::FETCH_ASSOC);
1172
-    		    }
1173
-            else{
1136
+    		    } else{
1174 1137
 				        $this->result = ($array == false) ? $sqlQuery->fetch(PDO::FETCH_OBJ) : $sqlQuery->fetch(PDO::FETCH_ASSOC);
1175 1138
             }
1176 1139
             //Sqlite and pgsql always return 0 when using rowCount()
1177 1140
             if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1178 1141
               $this->numRows = count($this->result);  
1179
-            }
1180
-            else{
1142
+            } else{
1181 1143
               $this->numRows = $sqlQuery->rowCount(); 
1182 1144
             }
1183 1145
 
@@ -1185,23 +1147,20 @@  discard block
 block discarded – undo
1185 1147
               $this->logger->info('Save the result for query [' .$this->query. '] into cache for future use');
1186 1148
               $cacheInstance->set($cacheKey, $this->result, $cacheExpire);
1187 1149
           }
1188
-        }
1189
-        else{
1150
+        } else{
1190 1151
           $error = $this->pdo->errorInfo();
1191 1152
           $this->error = isset($error[2]) ? $error[2] : '';
1192 1153
           $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1193 1154
           $this->error();
1194 1155
         }
1195
-      }
1196
-      else if ((! $cacheContent && !$sqlSELECTQuery) || ($cacheContent && !$sqlSELECTQuery)){
1156
+      } else if ((! $cacheContent && !$sqlSELECTQuery) || ($cacheContent && !$sqlSELECTQuery)){
1197 1157
     		$queryStr = $this->pdo->query($this->query);
1198 1158
     		if($queryStr){
1199 1159
           //Sqlite and pgsql always return 0 when using rowCount()
1200 1160
           if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1201 1161
             $this->result = 1; //to test the result for the query like UPDATE, INSERT, DELETE
1202 1162
             $this->numRows = 1;  
1203
-          }
1204
-          else{
1163
+          } else{
1205 1164
               $this->result = $queryStr->rowCount() >= 0; //to test the result for the query like UPDATE, INSERT, DELETE
1206 1165
               $this->numRows = $queryStr->rowCount(); 
1207 1166
           }
@@ -1212,8 +1171,7 @@  discard block
 block discarded – undo
1212 1171
           $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1213 1172
           $this->error();
1214 1173
         }
1215
-      }
1216
-      else{
1174
+      } else{
1217 1175
         $this->logger->info('The result for query [' .$this->query. '] already cached use it');
1218 1176
         $this->result = $cacheContent;
1219 1177
 	     	$this->numRows = count($this->result);
Please login to merge, or discard this patch.
core/libraries/Upload.php 2 patches
Indentation   +791 added lines, -791 removed lines patch added patch discarded remove patch
@@ -1,797 +1,797 @@
 block discarded – undo
1 1
 <?php
2
-    defined('ROOT_PATH') or 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
-
29
-    /**
30
-    *    Upload
31
-    *
32
-    *    A complete class to upload files with php 5 or higher, but the best: very simple to use.
33
-    *
34
-    *    @author Olaf Erlandsen <[email protected]>
35
-    *    @author http://www.webdevfreelance.com/
36
-    *
37
-    *    @package FileUpload
38
-    *    @version 1.5
39
-    */
40
-    class Upload{
41
-
42
-        /**
43
-        *   Version
44
-        *
45
-        *   @since      1.5
46
-        *   @version    1.0
47
-        */
48
-        const VERSION = '1.5';
49
-
50
-        /**
51
-        *    Upload function name
52
-        *    Remember:
53
-        *        Default function: move_uploaded_file
54
-        *        Native options:
55
-        *            - move_uploaded_file (Default and best option)
56
-        *            - copy
57
-        *
58
-        *    @since        1.0
59
-        *    @version    1.0
60
-        *    @var        mixex
61
-        */
62
-        private $upload_function = 'move_uploaded_file';
63
-
64
-        /**
65
-        *    Array with the information obtained from the
66
-        *    variable $_FILES or $HTTP_POST_FILES.
67
-        *
68
-        *    @since        1.0
69
-        *    @version    1.0
70
-        *    @var        array
71
-        */
72
-        private $file_array    = array();
73
-
74
-        /**
75
-        *    If the file you are trying to upload already exists it will
76
-        *    be overwritten if you set the variable to true.
77
-        *
78
-        *    @since        1.0
79
-        *    @version    1.0
80
-        *    @var        boolean
81
-        */
82
-        private $overwrite_file = false;
83
-
84
-        /**
85
-        *    Input element
86
-        *    Example:
87
-        *        <input type="file" name="file" />
88
-        *    Result:
89
-        *        FileUpload::$input = file
90
-        *
91
-        *    @since        1.0
92
-        *    @version    1.0
93
-        *    @var        string
94
-        */
95
-        private $input;
96
-
97
-        /**
98
-        *    Path output
99
-        *
100
-        *    @since        1.0
101
-        *    @version    1.0
102
-        *    @var        string
103
-        */
104
-        private $destination_directory;
105
-
106
-        /**
107
-        *    Output filename
108
-        *
109
-        *    @since        1.0
110
-        *    @version    1.0
111
-        *    @var        string
112
-        */
113
-        private $filename;
114
-
115
-        /**
116
-        *    Max file size
117
-        *
118
-        *    @since        1.0
119
-        *    @version    1.0
120
-        *    @var        float
121
-        */
122
-        private $max_file_size= 0.0;
123
-
124
-        /**
125
-        *    List of allowed mime types
126
-        *
127
-        *    @since        1.0
128
-        *    @version    1.0
129
-        *    @var        array
130
-        */
131
-        private $allowed_mime_types = array();
132
-
133
-        /**
134
-        *    Callbacks
135
-        *
136
-        *    @since        1.0
137
-        *    @version    1.0
138
-        *    @var        array
139
-        */
140
-        private $callbacks = array('before' => null, 'after' => null);
141
-
142
-        /**
143
-        *    File object
144
-        *
145
-        *    @since        1.0
146
-        *    @version    1.0
147
-        *    @var        object
148
-        */
149
-        private $file;
150
-
151
-        /**
152
-        *    Helping mime types
153
-        *
154
-        *    @since        1.0
155
-        *    @version    1.0
156
-        *    @var        array
157
-        */
158
-        private $mime_helping = array(
159
-            'text'      =>    array('text/plain',),
160
-            'image'     =>    array(
161
-                'image/jpeg',
162
-                'image/jpg',
163
-                'image/pjpeg',
164
-                'image/png',
165
-                'image/gif',
166
-            ),
167
-            'document'  =>    array(
168
-                'application/pdf',
169
-                'application/msword',
170
-                'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
171
-                'application/vnd.openxmlformats-officedocument.presentationml.presentation',
172
-                'application/vnd.ms-powerpoint',
173
-                'application/vnd.ms-excel',
174
-                'application/vnd.oasis.opendocument.spreadsheet',
175
-                'application/vnd.oasis.opendocument.presentation',
176
-            ),
177
-            'video'    =>    array(
178
-                'video/3gpp',
179
-                'video/3gpp',
180
-                'video/x-msvideo',
181
-                'video/avi',
182
-                'video/mpeg4',
183
-                'video/mp4',
184
-                'video/mpeg',
185
-                'video/mpg',
186
-                'video/quicktime',
187
-                'video/x-sgi-movie',
188
-                'video/x-ms-wmv',
189
-                'video/x-flv',
190
-            ),
191
-        );
192
-
193
-        /**
194
-         * The upload error message
195
-         * @var array
196
-         */
197
-        public $error_messages = array();
198
-
199
-        /**
200
-         * The upload error message
201
-         * @var string
202
-         */
203
-        protected $error = null;
204
-
205
-        /**
206
-         * The logger instance
207
-         * @var Log
208
-         */
209
-        private $logger;
210
-
211
-
212
-        /**
213
-        *    Construct
214
-        *
215
-        *    @since     0.1
216
-        *    @version   1.0.1
217
-        *    @return    object
218
-        *    @method    object    __construct
219
-        */
220
-        public function __construct(){
221
-            $this->logger =& class_loader('Log', 'classes');
222
-            $this->logger->setLogger('Library::Upload');
223
-
224
-            Loader::lang('file_upload');
225
-            $obj =& get_instance();
226
-
227
-            $this->error_messages = array(
228
-                'upload_err_ini_size' => $obj->lang->get('fu_upload_err_ini_size'),
229
-                'upload_err_form_size' => $obj->lang->get('fu_upload_err_form_size'),
230
-                'upload_err_partial' => $obj->lang->get('fu_upload_err_partial'),
231
-                'upload_err_no_file' => $obj->lang->get('fu_upload_err_no_file'),
232
-                'upload_err_no_tmp_dir' => $obj->lang->get('fu_upload_err_no_tmp_dir'),
233
-                'upload_err_cant_write' => $obj->lang->get('fu_upload_err_cant_write'),
234
-                'upload_err_extension' => $obj->lang->get('fu_upload_err_extension'),
235
-                'accept_file_types' => $obj->lang->get('fu_accept_file_types'),
236
-                'file_uploads' => $obj->lang->get('fu_file_uploads_disabled'),
237
-                'max_file_size' => $obj->lang->get('fu_max_file_size'),
238
-                'overwritten_not_allowed' => $obj->lang->get('fu_overwritten_not_allowed'),
239
-            );
240
-
241
-            $this->file = array(
242
-                'status'                =>    false,    // True: success upload
243
-                'mime'                  =>    '',       // Empty string
244
-                'filename'              =>    '',       // Empty string
245
-                'original'              =>    '',       // Empty string
246
-                'size'                  =>    0,        // 0 Bytes
247
-                'sizeFormated'          =>    '0B',     // 0 Bytes
248
-                'destination'           =>    './',     // Default: ./
249
-                'allowed_mime_types'    =>    array(),  // Allowed mime types
250
-                'error'                 =>    null,        // File error
251
-            );
252
-
253
-            // Change dir to current dir
254
-            $this->destination_directory = dirname(__FILE__) . DIRECTORY_SEPARATOR;
255
-
256
-            // Set file array
257
-            if (isset($_FILES) && is_array($_FILES)) {
258
-                $this->file_array = $_FILES;
259
-            } elseif (isset($HTTP_POST_FILES) && is_array($HTTP_POST_FILES)) {
260
-                $this->file_array = $HTTP_POST_FILES;
261
-            }
262
-            $this->logger->info('The upload file information are : ' .stringfy_vars($this->file_array));
263
-        }
264
-        /**
265
-        *    Set input.
266
-        *    If you have $_FILES["file"], you must use the key "file"
267
-        *    Example:
268
-        *        $object->setInput("file");
269
-        *
270
-        *    @since     1.0
271
-        *    @version   1.0
272
-        *    @param     string      $input
273
-        *    @return    boolean
274
-        *    @method    boolean     setInput
275
-        */
276
-        public function setInput($input)
277
-        {
278
-            if (!empty($input) && (is_string($input) || is_numeric($input) )) {
279
-                $this->input = $input;
280
-            }
281
-            return $this;
282
-        }
283
-        /**
284
-        *    Set new filename
285
-        *    Example:
286
-        *        FileUpload::setFilename("new file.txt")
287
-        *    Remember:
288
-        *        Use %s to retrive file extension
289
-        *
290
-        *    @since     1.0
291
-        *    @version   1.0
292
-        *    @param     string      $filename
293
-        *    @return    boolean
294
-        *    @method    boolean     setFilename
295
-        */
296
-        public function setFilename($filename)
297
-        {
298
-            if ($this->isFilename($filename)) {
299
-                $this->filename = $filename;
300
-            }
301
-            return $this;
302
-        }
303
-        /**
304
-        *    Set automatic filename
305
-        *
306
-        *    @since     1.0
307
-        *    @version   1.5
308
-        *    @param     string      $extension
309
-        *    @return    boolean
310
-        *    @method    boolean     setAutoFilename
311
-        */
312
-        public function setAutoFilename()
313
-        {
314
-            $this->filename = sha1(mt_rand(1, 9999).uniqid());
315
-            $this->filename .= time();
316
-            return $this;
317
-        }
318
-        /**
319
-        *    Set file size limit
320
-        *
321
-        *    @since     1.0
322
-        *    @version   1.0
323
-        *    @param     integer     $file_size
324
-        *    @return    boolean
325
-        *    @method    boolean     setMaxFileSize
326
-        */
327
-        public function setMaxFileSize($file_size)
328
-        {
329
-            $file_size = $this->sizeInBytes($file_size);
330
-            if (is_numeric($file_size) && $file_size > -1) {
331
-                // Get php config
332
-                $php_size = $this->sizeInBytes(ini_get('upload_max_filesize'));
333
-                // Calculate difference
334
-                if ($php_size < $file_size) {
335
-                    $this->logger->warning('The upload max file size you set [' .$file_size. '] is greather than the PHP configuration for upload max file size [' .$php_size. ']');
336
-                }
337
-                $this->max_file_size = $file_size;
338
-            }
339
-            return $this;
340
-        }
341
-        /**
342
-        *    Set array mime types
343
-        *
344
-        *    @since     1.0
345
-        *    @version   1.0
346
-        *    @param     array       $mimes
347
-        *    @return    boolean
348
-        *    @method    boolean     setAllowedMimeTypes
349
-        */
350
-        public function setAllowedMimeTypes(array $mimes)
351
-        {
352
-            if (count($mimes) > 0) {
353
-                array_map(array($this , 'setAllowMimeType'), $mimes);
354
-            }
355
-            return $this;
356
-        }
357
-        /**
358
-        *    Set input callback
359
-        *
360
-        *    @since     1.0
361
-        *    @version   1.0
362
-        *    @param     mixed       $callback
363
-        *    @return    boolean
364
-        *    @method    boolean     setCallbackInput
365
-        */
366
-        public function setCallbackInput($callback)
367
-        {
368
-            if (is_callable($callback, false)) {
369
-                $this->callbacks['input'] = $callback;
370
-            }
371
-            return $this;
372
-        }
373
-        /**
374
-        *    Set output callback
375
-        *
376
-        *    @since     1.0
377
-        *    @version   1.0
378
-        *    @param     mixed       $callback
379
-        *    @return    boolean
380
-        *    @method    boolean     setCallbackOutput
381
-        */
382
-        public function setCallbackOutput($callback)
383
-        {
384
-            if (is_callable($callback, false)) {
385
-                $this->callbacks['output'] = $callback;
386
-            }
387
-            return $this;
388
-        }
389
-        /**
390
-        *    Append a mime type to allowed mime types
391
-        *
392
-        *    @since     1.0
393
-        *    @version   1.0.1
394
-        *    @param     string      $mime
395
-        *    @return    boolean
396
-        *    @method    boolean     setAllowMimeType
397
-        */
398
-        public function setAllowMimeType($mime)
399
-        {
400
-            if (!empty($mime) && is_string($mime)) {
401
-                $this->allowed_mime_types[] = strtolower($mime);
402
-                $this->file['allowed_mime_types'][] = strtolower($mime);
403
-            } 
404
-            return $this;
405
-        }
406
-        /**
407
-        *    Set allowed mime types from mime helping
408
-        *
409
-        *    @since     1.0.1
410
-        *    @version   1.0.1
411
-        *    @return    boolean
412
-        *    @method    boolean    setMimeHelping
413
-        */
414
-        public function setMimeHelping($name)
415
-        {
416
-            if (!empty($name) && is_string($name)) {
417
-                if (array_key_exists($name, $this->mime_helping)) {
418
-                    return $this->setAllowedMimeTypes($this->mime_helping[ $name ]);
419
-                }
420
-            }
421
-            return $this;
422
-        }
423
-        /**
424
-        *    Set function to upload file
425
-        *    Examples:
426
-        *        1.- FileUpload::setUploadFunction("move_uploaded_file");
427
-        *        2.- FileUpload::setUploadFunction("copy");
428
-        *
429
-        *    @since     1.0
430
-        *    @version   1.0
431
-        *    @param     string      $mime
432
-        *    @return    boolean
433
-        *    @method    boolean     setUploadFunction
434
-        */
435
-        public function setUploadFunction($function)
436
-        {
437
-            if (!empty($function) && (is_array($function) || is_string($function) )) {
438
-                if (is_callable( $function)) {
439
-                    $this->upload_function = $function;
440
-                }
441
-            }
442
-            return $this;
443
-        }
444
-        /**
445
-        *    Clear allowed mime types cache
446
-        *
447
-        *    @since     1.0
448
-        *    @version   1.0
449
-        *    @return    boolean
450
-        *    @method    boolean    clearAllowedMimeTypes
451
-        */
452
-        public function clearAllowedMimeTypes()
453
-        {
454
-            $this->allowed_mime_types = array();
455
-            $this->file['allowed_mime_types'] = array();
456
-            return $this;
457
-        }
458
-        /**
459
-        *    Set destination output
460
-        *
461
-        *    @since     1.0
462
-        *    @version   1.0
463
-        *    @param     string      $destination_directory      Destination path
464
-        *    @param     boolean     $create_if_not_exist
465
-        *    @return    boolean
466
-        *    @method    boolean     setDestinationDirectory
467
-        */
468
-        public function setDestinationDirectory($destination_directory, $create_if_not_exist = false) {
469
-            $destination_directory = realpath($destination_directory);
470
-            if (substr($destination_directory, -1) != DIRECTORY_SEPARATOR) {
471
-                $destination_directory .= DIRECTORY_SEPARATOR;
472
-            }
473
-
474
-            if ($this->isDirpath($destination_directory)) {
475
-                if ($this->dirExists($destination_directory)) {
476
-                    $this->destination_directory = $destination_directory;
477
-                    if (substr($this->destination_directory, -1) != DIRECTORY_SEPARATOR) {
478
-                        $this->destination_directory .= DIRECTORY_SEPARATOR;
479
-                    }
480
-                    chdir($destination_directory);
481
-                } elseif ($create_if_not_exist === true) {
482
-                    if (mkdir($destination_directory, 0775, true)) {
483
-                        if ($this->dirExists($destination_directory)) {
484
-                            $this->destination_directory = $destination_directory;
485
-                            if (substr($this->destination_directory, -1) != DIRECTORY_SEPARATOR) {
486
-                                $this->destination_directory .= DIRECTORY_SEPARATOR;
487
-                            }
488
-                            chdir($destination_directory);
489
-                        }
490
-                    }
491
-                    else{
492
-                        $this->logger->warning('Can not create the upload directory [' .$destination_directory. ']');
493
-                    }
494
-                }
495
-            }
496
-            return $this;
497
-        }
498
-        /**
499
-        *    Check file exists
500
-        *
501
-        *    @since      1.0
502
-        *    @version    1.0.1
503
-        *    @param      string     $file_destination
504
-        *    @return     boolean
505
-        *    @method     boolean    fileExists
506
-        */
507
-        public function fileExists($file_destination)
508
-        {
509
-            if ($this->isFilename($file_destination)) {
510
-                return (file_exists($file_destination) && is_file($file_destination));
511
-            }
512
-            return false;
513
-        }
514
-        /**
515
-        *    Check dir exists
516
-        *
517
-        *    @since        1.0
518
-        *    @version    1.0.1
519
-        *    @param      string     $path
520
-        *    @return     boolean
521
-        *    @method     boolean    dirExists
522
-        */
523
-        public function dirExists($path)
524
-        {
525
-            if ($this->isDirpath($path)) {
526
-                return (file_exists($path) && is_dir($path));
527
-            }
528
-            return false;
529
-        }
530
-        /**
531
-        *    Check valid filename
532
-        *
533
-        *    @since     1.0
534
-        *    @version   1.0.1
535
-        *    @param     string      $filename
536
-        *    @return    boolean
537
-        *    @method    boolean     isFilename
538
-        */
539
-        public function isFilename($filename)
540
-        {
541
-            $filename = basename($filename);
542
-            return (!empty($filename) && (is_string( $filename) || is_numeric($filename)));
543
-        }
544
-        /**
545
-        *    Validate mime type with allowed mime types,
546
-        *    but if allowed mime types is empty, this method return true
547
-        *
548
-        *    @since     1.0
549
-        *    @version   1.0
550
-        *    @param     string      $mime
551
-        *    @return    boolean
552
-        *    @method    boolean     checkMimeType
553
-        */
554
-        public function checkMimeType($mime)
555
-        {
556
-            if (count($this->allowed_mime_types) == 0) {
557
-                return true;
558
-            }
559
-            return in_array(strtolower($mime), $this->allowed_mime_types);
560
-        }
561
-        /**
562
-        *    Retrive status of upload
563
-        *
564
-        *    @since     1.0
565
-        *    @version   1.0
566
-        *    @return    boolean
567
-        *    @method    boolean    getStatus
568
-        */
569
-        public function getStatus()
570
-        {
571
-            return $this->file['status'];
572
-        }
573
-        /**
574
-        *    Check valid path
575
-        *
576
-        *    @since        1.0
577
-        *    @version    1.0.1
578
-        *    @param        string    $filename
579
-        *    @return     boolean
580
-        *    @method     boolean    isDirpath
581
-        */
582
-        public function isDirpath($path)
583
-        {
584
-            if (!empty( $path) && (is_string( $path) || is_numeric($path) )) {
585
-                if (DIRECTORY_SEPARATOR == '/') {
586
-                    return (preg_match( '/^[^*?"<>|:]*$/' , $path) == 1 );
587
-                } else {
588
-                    return (preg_match( "/^[^*?\"<>|:]*$/" , substr($path,2) ) == 1);
589
-                }
590
-            }
591
-            return false;
592
-        }
593
-        /**
594
-        *    Allow overwriting files
595
-        *
596
-        *    @since      1.0
597
-        *    @version    1.0
598
-        *    @return     boolean
599
-        *    @method     boolean    allowOverwriting
600
-        */
601
-        public function allowOverwriting()
602
-        {
603
-            $this->overwrite_file = true;
604
-            return $this;
605
-        }
606
-        /**
607
-        *    File info
608
-        *
609
-        *    @since      1.0
610
-        *    @version    1.0
611
-        *    @return     object
612
-        *    @method     object    getInfo
613
-        */
614
-        public function getInfo()
615
-        {
616
-            return (object)$this->file;
617
-        }
618
-
619
-        public function isUploaded(){
620
-            return isset($this->file_array[$this->input])
621
-            &&
622
-            is_uploaded_file($this->file_array[$this->input]['tmp_name']);
623
-        }
624
-        /**
625
-        *    Upload file
626
-        *
627
-        *    @since     1.0
628
-        *    @version   1.0.1
629
-        *    @return    boolean
630
-        *    @method    boolean    save
631
-        */
632
-        public function save(){
633
-            //check if file upload is  allowed in the configuration
634
-            if(! ini_get('file_uploads')){
635
-                $this->setError($this->error_messages['file_uploads']);
636
-                return false;
637
-            }
638
-            if (count($this->file_array) > 0) {
639
-                if (array_key_exists($this->input, $this->file_array)) {
640
-                    // set original filename if not have a new name
641
-                    if (empty($this->filename)) {
642
-                        $this->filename = $this->file_array[$this->input]['name'];
643
-                    }
644
-                    else{
645
-                        // Replace %s for extension in filename
646
-                        // Before: /[\w\d]*(.[\d\w]+)$/i
647
-                        // After: /^[\s[:alnum:]\-\_\.]*\.([\d\w]+)$/iu
648
-                        // Support unicode(utf-8) characters
649
-                        // Example: "русские.jpeg" is valid; "Zhōngguó.jpeg" is valid; "Tønsberg.jpeg" is valid
650
-                        $extension = preg_replace(
651
-                            '/^[\p{L}\d\s\-\_\.\(\)]*\.([\d\w]+)$/iu',
652
-                            '$1',
653
-                            $this->file_array[$this->input]['name']
654
-                        );
655
-                        $this->filename = $this->filename.'.'.$extension;
656
-                    }
657
-
658
-                    // set file info
659
-                    $this->file['mime']         = $this->file_array[$this->input]['type'];
660
-                    $this->file['tmp']          = $this->file_array[$this->input]['tmp_name'];
661
-                    $this->file['original']     = $this->file_array[$this->input]['name'];
662
-                    $this->file['size']         = $this->file_array[$this->input]['size'];
663
-                    $this->file['sizeFormated'] = $this->sizeFormat($this->file['size']);
664
-                    $this->file['destination']  = $this->destination_directory . $this->filename;
665
-                    $this->file['filename']     = $this->filename;
666
-                    $this->file['error']        = $this->file_array[$this->input]['error'];
667
-
668
-                    $this->logger->info('The upload file information to process is : ' .stringfy_vars($this->file));
669
-
670
-                    //check for php upload error
671
-                    if(is_numeric($this->file['error']) && $this->file['error'] > 0){
672
-                        $this->setError($this->getPhpUploadErrorMessageByCode($this->file['error']));
673
-                        return false;
674
-                    }
2
+	defined('ROOT_PATH') or 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
+
29
+	/**
30
+	 *    Upload
31
+	 *
32
+	 *    A complete class to upload files with php 5 or higher, but the best: very simple to use.
33
+	 *
34
+	 *    @author Olaf Erlandsen <[email protected]>
35
+	 *    @author http://www.webdevfreelance.com/
36
+	 *
37
+	 *    @package FileUpload
38
+	 *    @version 1.5
39
+	 */
40
+	class Upload{
41
+
42
+		/**
43
+		 *   Version
44
+		 *
45
+		 *   @since      1.5
46
+		 *   @version    1.0
47
+		 */
48
+		const VERSION = '1.5';
49
+
50
+		/**
51
+		 *    Upload function name
52
+		 *    Remember:
53
+		 *        Default function: move_uploaded_file
54
+		 *        Native options:
55
+		 *            - move_uploaded_file (Default and best option)
56
+		 *            - copy
57
+		 *
58
+		 *    @since        1.0
59
+		 *    @version    1.0
60
+		 *    @var        mixex
61
+		 */
62
+		private $upload_function = 'move_uploaded_file';
63
+
64
+		/**
65
+		 *    Array with the information obtained from the
66
+		 *    variable $_FILES or $HTTP_POST_FILES.
67
+		 *
68
+		 *    @since        1.0
69
+		 *    @version    1.0
70
+		 *    @var        array
71
+		 */
72
+		private $file_array    = array();
73
+
74
+		/**
75
+		 *    If the file you are trying to upload already exists it will
76
+		 *    be overwritten if you set the variable to true.
77
+		 *
78
+		 *    @since        1.0
79
+		 *    @version    1.0
80
+		 *    @var        boolean
81
+		 */
82
+		private $overwrite_file = false;
83
+
84
+		/**
85
+		 *    Input element
86
+		 *    Example:
87
+		 *        <input type="file" name="file" />
88
+		 *    Result:
89
+		 *        FileUpload::$input = file
90
+		 *
91
+		 *    @since        1.0
92
+		 *    @version    1.0
93
+		 *    @var        string
94
+		 */
95
+		private $input;
96
+
97
+		/**
98
+		 *    Path output
99
+		 *
100
+		 *    @since        1.0
101
+		 *    @version    1.0
102
+		 *    @var        string
103
+		 */
104
+		private $destination_directory;
105
+
106
+		/**
107
+		 *    Output filename
108
+		 *
109
+		 *    @since        1.0
110
+		 *    @version    1.0
111
+		 *    @var        string
112
+		 */
113
+		private $filename;
114
+
115
+		/**
116
+		 *    Max file size
117
+		 *
118
+		 *    @since        1.0
119
+		 *    @version    1.0
120
+		 *    @var        float
121
+		 */
122
+		private $max_file_size= 0.0;
123
+
124
+		/**
125
+		 *    List of allowed mime types
126
+		 *
127
+		 *    @since        1.0
128
+		 *    @version    1.0
129
+		 *    @var        array
130
+		 */
131
+		private $allowed_mime_types = array();
132
+
133
+		/**
134
+		 *    Callbacks
135
+		 *
136
+		 *    @since        1.0
137
+		 *    @version    1.0
138
+		 *    @var        array
139
+		 */
140
+		private $callbacks = array('before' => null, 'after' => null);
141
+
142
+		/**
143
+		 *    File object
144
+		 *
145
+		 *    @since        1.0
146
+		 *    @version    1.0
147
+		 *    @var        object
148
+		 */
149
+		private $file;
150
+
151
+		/**
152
+		 *    Helping mime types
153
+		 *
154
+		 *    @since        1.0
155
+		 *    @version    1.0
156
+		 *    @var        array
157
+		 */
158
+		private $mime_helping = array(
159
+			'text'      =>    array('text/plain',),
160
+			'image'     =>    array(
161
+				'image/jpeg',
162
+				'image/jpg',
163
+				'image/pjpeg',
164
+				'image/png',
165
+				'image/gif',
166
+			),
167
+			'document'  =>    array(
168
+				'application/pdf',
169
+				'application/msword',
170
+				'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
171
+				'application/vnd.openxmlformats-officedocument.presentationml.presentation',
172
+				'application/vnd.ms-powerpoint',
173
+				'application/vnd.ms-excel',
174
+				'application/vnd.oasis.opendocument.spreadsheet',
175
+				'application/vnd.oasis.opendocument.presentation',
176
+			),
177
+			'video'    =>    array(
178
+				'video/3gpp',
179
+				'video/3gpp',
180
+				'video/x-msvideo',
181
+				'video/avi',
182
+				'video/mpeg4',
183
+				'video/mp4',
184
+				'video/mpeg',
185
+				'video/mpg',
186
+				'video/quicktime',
187
+				'video/x-sgi-movie',
188
+				'video/x-ms-wmv',
189
+				'video/x-flv',
190
+			),
191
+		);
192
+
193
+		/**
194
+		 * The upload error message
195
+		 * @var array
196
+		 */
197
+		public $error_messages = array();
198
+
199
+		/**
200
+		 * The upload error message
201
+		 * @var string
202
+		 */
203
+		protected $error = null;
204
+
205
+		/**
206
+		 * The logger instance
207
+		 * @var Log
208
+		 */
209
+		private $logger;
210
+
211
+
212
+		/**
213
+		 *    Construct
214
+		 *
215
+		 *    @since     0.1
216
+		 *    @version   1.0.1
217
+		 *    @return    object
218
+		 *    @method    object    __construct
219
+		 */
220
+		public function __construct(){
221
+			$this->logger =& class_loader('Log', 'classes');
222
+			$this->logger->setLogger('Library::Upload');
223
+
224
+			Loader::lang('file_upload');
225
+			$obj =& get_instance();
226
+
227
+			$this->error_messages = array(
228
+				'upload_err_ini_size' => $obj->lang->get('fu_upload_err_ini_size'),
229
+				'upload_err_form_size' => $obj->lang->get('fu_upload_err_form_size'),
230
+				'upload_err_partial' => $obj->lang->get('fu_upload_err_partial'),
231
+				'upload_err_no_file' => $obj->lang->get('fu_upload_err_no_file'),
232
+				'upload_err_no_tmp_dir' => $obj->lang->get('fu_upload_err_no_tmp_dir'),
233
+				'upload_err_cant_write' => $obj->lang->get('fu_upload_err_cant_write'),
234
+				'upload_err_extension' => $obj->lang->get('fu_upload_err_extension'),
235
+				'accept_file_types' => $obj->lang->get('fu_accept_file_types'),
236
+				'file_uploads' => $obj->lang->get('fu_file_uploads_disabled'),
237
+				'max_file_size' => $obj->lang->get('fu_max_file_size'),
238
+				'overwritten_not_allowed' => $obj->lang->get('fu_overwritten_not_allowed'),
239
+			);
240
+
241
+			$this->file = array(
242
+				'status'                =>    false,    // True: success upload
243
+				'mime'                  =>    '',       // Empty string
244
+				'filename'              =>    '',       // Empty string
245
+				'original'              =>    '',       // Empty string
246
+				'size'                  =>    0,        // 0 Bytes
247
+				'sizeFormated'          =>    '0B',     // 0 Bytes
248
+				'destination'           =>    './',     // Default: ./
249
+				'allowed_mime_types'    =>    array(),  // Allowed mime types
250
+				'error'                 =>    null,        // File error
251
+			);
252
+
253
+			// Change dir to current dir
254
+			$this->destination_directory = dirname(__FILE__) . DIRECTORY_SEPARATOR;
255
+
256
+			// Set file array
257
+			if (isset($_FILES) && is_array($_FILES)) {
258
+				$this->file_array = $_FILES;
259
+			} elseif (isset($HTTP_POST_FILES) && is_array($HTTP_POST_FILES)) {
260
+				$this->file_array = $HTTP_POST_FILES;
261
+			}
262
+			$this->logger->info('The upload file information are : ' .stringfy_vars($this->file_array));
263
+		}
264
+		/**
265
+		 *    Set input.
266
+		 *    If you have $_FILES["file"], you must use the key "file"
267
+		 *    Example:
268
+		 *        $object->setInput("file");
269
+		 *
270
+		 *    @since     1.0
271
+		 *    @version   1.0
272
+		 *    @param     string      $input
273
+		 *    @return    boolean
274
+		 *    @method    boolean     setInput
275
+		 */
276
+		public function setInput($input)
277
+		{
278
+			if (!empty($input) && (is_string($input) || is_numeric($input) )) {
279
+				$this->input = $input;
280
+			}
281
+			return $this;
282
+		}
283
+		/**
284
+		 *    Set new filename
285
+		 *    Example:
286
+		 *        FileUpload::setFilename("new file.txt")
287
+		 *    Remember:
288
+		 *        Use %s to retrive file extension
289
+		 *
290
+		 *    @since     1.0
291
+		 *    @version   1.0
292
+		 *    @param     string      $filename
293
+		 *    @return    boolean
294
+		 *    @method    boolean     setFilename
295
+		 */
296
+		public function setFilename($filename)
297
+		{
298
+			if ($this->isFilename($filename)) {
299
+				$this->filename = $filename;
300
+			}
301
+			return $this;
302
+		}
303
+		/**
304
+		 *    Set automatic filename
305
+		 *
306
+		 *    @since     1.0
307
+		 *    @version   1.5
308
+		 *    @param     string      $extension
309
+		 *    @return    boolean
310
+		 *    @method    boolean     setAutoFilename
311
+		 */
312
+		public function setAutoFilename()
313
+		{
314
+			$this->filename = sha1(mt_rand(1, 9999).uniqid());
315
+			$this->filename .= time();
316
+			return $this;
317
+		}
318
+		/**
319
+		 *    Set file size limit
320
+		 *
321
+		 *    @since     1.0
322
+		 *    @version   1.0
323
+		 *    @param     integer     $file_size
324
+		 *    @return    boolean
325
+		 *    @method    boolean     setMaxFileSize
326
+		 */
327
+		public function setMaxFileSize($file_size)
328
+		{
329
+			$file_size = $this->sizeInBytes($file_size);
330
+			if (is_numeric($file_size) && $file_size > -1) {
331
+				// Get php config
332
+				$php_size = $this->sizeInBytes(ini_get('upload_max_filesize'));
333
+				// Calculate difference
334
+				if ($php_size < $file_size) {
335
+					$this->logger->warning('The upload max file size you set [' .$file_size. '] is greather than the PHP configuration for upload max file size [' .$php_size. ']');
336
+				}
337
+				$this->max_file_size = $file_size;
338
+			}
339
+			return $this;
340
+		}
341
+		/**
342
+		 *    Set array mime types
343
+		 *
344
+		 *    @since     1.0
345
+		 *    @version   1.0
346
+		 *    @param     array       $mimes
347
+		 *    @return    boolean
348
+		 *    @method    boolean     setAllowedMimeTypes
349
+		 */
350
+		public function setAllowedMimeTypes(array $mimes)
351
+		{
352
+			if (count($mimes) > 0) {
353
+				array_map(array($this , 'setAllowMimeType'), $mimes);
354
+			}
355
+			return $this;
356
+		}
357
+		/**
358
+		 *    Set input callback
359
+		 *
360
+		 *    @since     1.0
361
+		 *    @version   1.0
362
+		 *    @param     mixed       $callback
363
+		 *    @return    boolean
364
+		 *    @method    boolean     setCallbackInput
365
+		 */
366
+		public function setCallbackInput($callback)
367
+		{
368
+			if (is_callable($callback, false)) {
369
+				$this->callbacks['input'] = $callback;
370
+			}
371
+			return $this;
372
+		}
373
+		/**
374
+		 *    Set output callback
375
+		 *
376
+		 *    @since     1.0
377
+		 *    @version   1.0
378
+		 *    @param     mixed       $callback
379
+		 *    @return    boolean
380
+		 *    @method    boolean     setCallbackOutput
381
+		 */
382
+		public function setCallbackOutput($callback)
383
+		{
384
+			if (is_callable($callback, false)) {
385
+				$this->callbacks['output'] = $callback;
386
+			}
387
+			return $this;
388
+		}
389
+		/**
390
+		 *    Append a mime type to allowed mime types
391
+		 *
392
+		 *    @since     1.0
393
+		 *    @version   1.0.1
394
+		 *    @param     string      $mime
395
+		 *    @return    boolean
396
+		 *    @method    boolean     setAllowMimeType
397
+		 */
398
+		public function setAllowMimeType($mime)
399
+		{
400
+			if (!empty($mime) && is_string($mime)) {
401
+				$this->allowed_mime_types[] = strtolower($mime);
402
+				$this->file['allowed_mime_types'][] = strtolower($mime);
403
+			} 
404
+			return $this;
405
+		}
406
+		/**
407
+		 *    Set allowed mime types from mime helping
408
+		 *
409
+		 *    @since     1.0.1
410
+		 *    @version   1.0.1
411
+		 *    @return    boolean
412
+		 *    @method    boolean    setMimeHelping
413
+		 */
414
+		public function setMimeHelping($name)
415
+		{
416
+			if (!empty($name) && is_string($name)) {
417
+				if (array_key_exists($name, $this->mime_helping)) {
418
+					return $this->setAllowedMimeTypes($this->mime_helping[ $name ]);
419
+				}
420
+			}
421
+			return $this;
422
+		}
423
+		/**
424
+		 *    Set function to upload file
425
+		 *    Examples:
426
+		 *        1.- FileUpload::setUploadFunction("move_uploaded_file");
427
+		 *        2.- FileUpload::setUploadFunction("copy");
428
+		 *
429
+		 *    @since     1.0
430
+		 *    @version   1.0
431
+		 *    @param     string      $mime
432
+		 *    @return    boolean
433
+		 *    @method    boolean     setUploadFunction
434
+		 */
435
+		public function setUploadFunction($function)
436
+		{
437
+			if (!empty($function) && (is_array($function) || is_string($function) )) {
438
+				if (is_callable( $function)) {
439
+					$this->upload_function = $function;
440
+				}
441
+			}
442
+			return $this;
443
+		}
444
+		/**
445
+		 *    Clear allowed mime types cache
446
+		 *
447
+		 *    @since     1.0
448
+		 *    @version   1.0
449
+		 *    @return    boolean
450
+		 *    @method    boolean    clearAllowedMimeTypes
451
+		 */
452
+		public function clearAllowedMimeTypes()
453
+		{
454
+			$this->allowed_mime_types = array();
455
+			$this->file['allowed_mime_types'] = array();
456
+			return $this;
457
+		}
458
+		/**
459
+		 *    Set destination output
460
+		 *
461
+		 *    @since     1.0
462
+		 *    @version   1.0
463
+		 *    @param     string      $destination_directory      Destination path
464
+		 *    @param     boolean     $create_if_not_exist
465
+		 *    @return    boolean
466
+		 *    @method    boolean     setDestinationDirectory
467
+		 */
468
+		public function setDestinationDirectory($destination_directory, $create_if_not_exist = false) {
469
+			$destination_directory = realpath($destination_directory);
470
+			if (substr($destination_directory, -1) != DIRECTORY_SEPARATOR) {
471
+				$destination_directory .= DIRECTORY_SEPARATOR;
472
+			}
473
+
474
+			if ($this->isDirpath($destination_directory)) {
475
+				if ($this->dirExists($destination_directory)) {
476
+					$this->destination_directory = $destination_directory;
477
+					if (substr($this->destination_directory, -1) != DIRECTORY_SEPARATOR) {
478
+						$this->destination_directory .= DIRECTORY_SEPARATOR;
479
+					}
480
+					chdir($destination_directory);
481
+				} elseif ($create_if_not_exist === true) {
482
+					if (mkdir($destination_directory, 0775, true)) {
483
+						if ($this->dirExists($destination_directory)) {
484
+							$this->destination_directory = $destination_directory;
485
+							if (substr($this->destination_directory, -1) != DIRECTORY_SEPARATOR) {
486
+								$this->destination_directory .= DIRECTORY_SEPARATOR;
487
+							}
488
+							chdir($destination_directory);
489
+						}
490
+					}
491
+					else{
492
+						$this->logger->warning('Can not create the upload directory [' .$destination_directory. ']');
493
+					}
494
+				}
495
+			}
496
+			return $this;
497
+		}
498
+		/**
499
+		 *    Check file exists
500
+		 *
501
+		 *    @since      1.0
502
+		 *    @version    1.0.1
503
+		 *    @param      string     $file_destination
504
+		 *    @return     boolean
505
+		 *    @method     boolean    fileExists
506
+		 */
507
+		public function fileExists($file_destination)
508
+		{
509
+			if ($this->isFilename($file_destination)) {
510
+				return (file_exists($file_destination) && is_file($file_destination));
511
+			}
512
+			return false;
513
+		}
514
+		/**
515
+		 *    Check dir exists
516
+		 *
517
+		 *    @since        1.0
518
+		 *    @version    1.0.1
519
+		 *    @param      string     $path
520
+		 *    @return     boolean
521
+		 *    @method     boolean    dirExists
522
+		 */
523
+		public function dirExists($path)
524
+		{
525
+			if ($this->isDirpath($path)) {
526
+				return (file_exists($path) && is_dir($path));
527
+			}
528
+			return false;
529
+		}
530
+		/**
531
+		 *    Check valid filename
532
+		 *
533
+		 *    @since     1.0
534
+		 *    @version   1.0.1
535
+		 *    @param     string      $filename
536
+		 *    @return    boolean
537
+		 *    @method    boolean     isFilename
538
+		 */
539
+		public function isFilename($filename)
540
+		{
541
+			$filename = basename($filename);
542
+			return (!empty($filename) && (is_string( $filename) || is_numeric($filename)));
543
+		}
544
+		/**
545
+		 *    Validate mime type with allowed mime types,
546
+		 *    but if allowed mime types is empty, this method return true
547
+		 *
548
+		 *    @since     1.0
549
+		 *    @version   1.0
550
+		 *    @param     string      $mime
551
+		 *    @return    boolean
552
+		 *    @method    boolean     checkMimeType
553
+		 */
554
+		public function checkMimeType($mime)
555
+		{
556
+			if (count($this->allowed_mime_types) == 0) {
557
+				return true;
558
+			}
559
+			return in_array(strtolower($mime), $this->allowed_mime_types);
560
+		}
561
+		/**
562
+		 *    Retrive status of upload
563
+		 *
564
+		 *    @since     1.0
565
+		 *    @version   1.0
566
+		 *    @return    boolean
567
+		 *    @method    boolean    getStatus
568
+		 */
569
+		public function getStatus()
570
+		{
571
+			return $this->file['status'];
572
+		}
573
+		/**
574
+		 *    Check valid path
575
+		 *
576
+		 *    @since        1.0
577
+		 *    @version    1.0.1
578
+		 *    @param        string    $filename
579
+		 *    @return     boolean
580
+		 *    @method     boolean    isDirpath
581
+		 */
582
+		public function isDirpath($path)
583
+		{
584
+			if (!empty( $path) && (is_string( $path) || is_numeric($path) )) {
585
+				if (DIRECTORY_SEPARATOR == '/') {
586
+					return (preg_match( '/^[^*?"<>|:]*$/' , $path) == 1 );
587
+				} else {
588
+					return (preg_match( "/^[^*?\"<>|:]*$/" , substr($path,2) ) == 1);
589
+				}
590
+			}
591
+			return false;
592
+		}
593
+		/**
594
+		 *    Allow overwriting files
595
+		 *
596
+		 *    @since      1.0
597
+		 *    @version    1.0
598
+		 *    @return     boolean
599
+		 *    @method     boolean    allowOverwriting
600
+		 */
601
+		public function allowOverwriting()
602
+		{
603
+			$this->overwrite_file = true;
604
+			return $this;
605
+		}
606
+		/**
607
+		 *    File info
608
+		 *
609
+		 *    @since      1.0
610
+		 *    @version    1.0
611
+		 *    @return     object
612
+		 *    @method     object    getInfo
613
+		 */
614
+		public function getInfo()
615
+		{
616
+			return (object)$this->file;
617
+		}
618
+
619
+		public function isUploaded(){
620
+			return isset($this->file_array[$this->input])
621
+			&&
622
+			is_uploaded_file($this->file_array[$this->input]['tmp_name']);
623
+		}
624
+		/**
625
+		 *    Upload file
626
+		 *
627
+		 *    @since     1.0
628
+		 *    @version   1.0.1
629
+		 *    @return    boolean
630
+		 *    @method    boolean    save
631
+		 */
632
+		public function save(){
633
+			//check if file upload is  allowed in the configuration
634
+			if(! ini_get('file_uploads')){
635
+				$this->setError($this->error_messages['file_uploads']);
636
+				return false;
637
+			}
638
+			if (count($this->file_array) > 0) {
639
+				if (array_key_exists($this->input, $this->file_array)) {
640
+					// set original filename if not have a new name
641
+					if (empty($this->filename)) {
642
+						$this->filename = $this->file_array[$this->input]['name'];
643
+					}
644
+					else{
645
+						// Replace %s for extension in filename
646
+						// Before: /[\w\d]*(.[\d\w]+)$/i
647
+						// After: /^[\s[:alnum:]\-\_\.]*\.([\d\w]+)$/iu
648
+						// Support unicode(utf-8) characters
649
+						// Example: "русские.jpeg" is valid; "Zhōngguó.jpeg" is valid; "Tønsberg.jpeg" is valid
650
+						$extension = preg_replace(
651
+							'/^[\p{L}\d\s\-\_\.\(\)]*\.([\d\w]+)$/iu',
652
+							'$1',
653
+							$this->file_array[$this->input]['name']
654
+						);
655
+						$this->filename = $this->filename.'.'.$extension;
656
+					}
657
+
658
+					// set file info
659
+					$this->file['mime']         = $this->file_array[$this->input]['type'];
660
+					$this->file['tmp']          = $this->file_array[$this->input]['tmp_name'];
661
+					$this->file['original']     = $this->file_array[$this->input]['name'];
662
+					$this->file['size']         = $this->file_array[$this->input]['size'];
663
+					$this->file['sizeFormated'] = $this->sizeFormat($this->file['size']);
664
+					$this->file['destination']  = $this->destination_directory . $this->filename;
665
+					$this->file['filename']     = $this->filename;
666
+					$this->file['error']        = $this->file_array[$this->input]['error'];
667
+
668
+					$this->logger->info('The upload file information to process is : ' .stringfy_vars($this->file));
669
+
670
+					//check for php upload error
671
+					if(is_numeric($this->file['error']) && $this->file['error'] > 0){
672
+						$this->setError($this->getPhpUploadErrorMessageByCode($this->file['error']));
673
+						return false;
674
+					}
675 675
                     
676
-                    //check for mime type
677
-                    if (!$this->checkMimeType($this->file['mime'])) {
678
-                        $this->setError($this->error_messages['accept_file_types']);
679
-                        return false;
680
-                    }
681
-
682
-                     // Check file size
683
-                    if ($this->max_file_size > 0) {
684
-                        if ($this->max_file_size < $this->file['size']) {
685
-                            $this->setError(sprintf($this->error_messages['max_file_size'], $this->sizeFormat($this->max_file_size)));
686
-                            return false;
687
-                        }
688
-                    }
689
-
690
-                    // Check if exists file
691
-                    if ($this->fileExists($this->destination_directory . $this->filename)) {
692
-                        // Check if overwrite file
693
-                        if ($this->overwrite_file === false) {
694
-                            $this->setError($this->error_messages['overwritten_not_allowed']);
695
-                            return false;
696
-                        }
697
-                    }
698
-
699
-                    // Execute input callback
700
-                    if (!empty( $this->callbacks['input'])) {
701
-                        call_user_func($this->callbacks['input'], (object)$this->file);
702
-                    }
676
+					//check for mime type
677
+					if (!$this->checkMimeType($this->file['mime'])) {
678
+						$this->setError($this->error_messages['accept_file_types']);
679
+						return false;
680
+					}
681
+
682
+					 // Check file size
683
+					if ($this->max_file_size > 0) {
684
+						if ($this->max_file_size < $this->file['size']) {
685
+							$this->setError(sprintf($this->error_messages['max_file_size'], $this->sizeFormat($this->max_file_size)));
686
+							return false;
687
+						}
688
+					}
689
+
690
+					// Check if exists file
691
+					if ($this->fileExists($this->destination_directory . $this->filename)) {
692
+						// Check if overwrite file
693
+						if ($this->overwrite_file === false) {
694
+							$this->setError($this->error_messages['overwritten_not_allowed']);
695
+							return false;
696
+						}
697
+					}
698
+
699
+					// Execute input callback
700
+					if (!empty( $this->callbacks['input'])) {
701
+						call_user_func($this->callbacks['input'], (object)$this->file);
702
+					}
703 703
                    
704 704
 
705
-                    $this->file['status'] = call_user_func_array(
706
-                        $this->upload_function, array(
707
-                            $this->file_array[$this->input]['tmp_name'],
708
-                            $this->destination_directory . $this->filename
709
-                        )
710
-                    );
711
-
712
-                    // Execute output callback
713
-                    if (!empty( $this->callbacks['output'])) {
714
-                        call_user_func($this->callbacks['output'], (object)$this->file);
715
-                    }
716
-                    return $this->file['status'];
717
-                }
718
-            }
719
-        }
720
-
721
-        /**
722
-        *    File size for humans.
723
-        *
724
-        *    @since      1.0
725
-        *    @version    1.0
726
-        *    @param      integer    $bytes
727
-        *    @param      integer    $precision
728
-        *    @return     string
729
-        *    @method     string     sizeFormat
730
-        */
731
-        public function sizeFormat($size, $precision = 2)
732
-        {
733
-            if($size > 0){
734
-                $base       = log($size) / log(1024);
735
-                $suffixes   = array('B', 'K', 'M', 'G', 'T');
736
-                return round(pow(1024, $base - floor($base)), $precision) . ( isset($suffixes[floor($base)]) ? $suffixes[floor($base)] : '');
737
-            }
738
-            return null;
739
-        }
705
+					$this->file['status'] = call_user_func_array(
706
+						$this->upload_function, array(
707
+							$this->file_array[$this->input]['tmp_name'],
708
+							$this->destination_directory . $this->filename
709
+						)
710
+					);
711
+
712
+					// Execute output callback
713
+					if (!empty( $this->callbacks['output'])) {
714
+						call_user_func($this->callbacks['output'], (object)$this->file);
715
+					}
716
+					return $this->file['status'];
717
+				}
718
+			}
719
+		}
720
+
721
+		/**
722
+		 *    File size for humans.
723
+		 *
724
+		 *    @since      1.0
725
+		 *    @version    1.0
726
+		 *    @param      integer    $bytes
727
+		 *    @param      integer    $precision
728
+		 *    @return     string
729
+		 *    @method     string     sizeFormat
730
+		 */
731
+		public function sizeFormat($size, $precision = 2)
732
+		{
733
+			if($size > 0){
734
+				$base       = log($size) / log(1024);
735
+				$suffixes   = array('B', 'K', 'M', 'G', 'T');
736
+				return round(pow(1024, $base - floor($base)), $precision) . ( isset($suffixes[floor($base)]) ? $suffixes[floor($base)] : '');
737
+			}
738
+			return null;
739
+		}
740 740
 
741 741
         
742
-        /**
743
-        *    Convert human file size to bytes
744
-        *
745
-        *    @since      1.0
746
-        *    @version    1.0.1
747
-        *    @param      integer    $size
748
-        *    @return     string
749
-        *    @method     string     sizeInBytes
750
-        */
751
-        public function sizeInBytes($size)
752
-        {
753
-            $unit = 'B';
754
-            $units = array('B' => 0, 'K' => 1, 'M' => 2, 'G' => 3, 'T' => 4);
755
-            $matches = array();
756
-            preg_match('/(?<size>[\d\.]+)\s*(?<unit>b|k|m|g|t)?/i', $size, $matches);
757
-            if (array_key_exists('unit', $matches)) {
758
-                $unit = strtoupper($matches['unit']);
759
-            }
760
-            return (floatval($matches['size']) * pow(1024, $units[$unit]) ) ;
761
-        }
762
-
763
-        /**
764
-         * Get the upload error message
765
-         * @return string
766
-         */
767
-        public function getError(){
768
-            return $this->error;
769
-        }
770
-
771
-        /**
772
-         * Set the upload error message
773
-         * @param string $message the upload error message to set
774
-         */
775
-        public function setError($message){
776
-            $this->logger->info('The upload got error : ' . $message);
777
-            $this->error = $message;
778
-        }
779
-
780
-        /**
781
-         * Get the PHP upload error message for the given code
782
-         * @param  int $code the error code
783
-         * @return string the error message
784
-         */
785
-        private function getPhpUploadErrorMessageByCode($code){
786
-            $codeMessageMaps = array(
787
-                1 => $this->error_messages['upload_err_ini_size'],
788
-                2 => $this->error_messages['upload_err_form_size'],
789
-                3 => $this->error_messages['upload_err_partial'],
790
-                4 => $this->error_messages['upload_err_no_file'],
791
-                6 => $this->error_messages['upload_err_no_tmp_dir'],
792
-                7 => $this->error_messages['upload_err_cant_write'],
793
-                8 => $this->error_messages['upload_err_extension'],
794
-            );
795
-            return isset($codeMessageMaps[$code]) ? $codeMessageMaps[$code] : null;
796
-        }
797
-    }
742
+		/**
743
+		 *    Convert human file size to bytes
744
+		 *
745
+		 *    @since      1.0
746
+		 *    @version    1.0.1
747
+		 *    @param      integer    $size
748
+		 *    @return     string
749
+		 *    @method     string     sizeInBytes
750
+		 */
751
+		public function sizeInBytes($size)
752
+		{
753
+			$unit = 'B';
754
+			$units = array('B' => 0, 'K' => 1, 'M' => 2, 'G' => 3, 'T' => 4);
755
+			$matches = array();
756
+			preg_match('/(?<size>[\d\.]+)\s*(?<unit>b|k|m|g|t)?/i', $size, $matches);
757
+			if (array_key_exists('unit', $matches)) {
758
+				$unit = strtoupper($matches['unit']);
759
+			}
760
+			return (floatval($matches['size']) * pow(1024, $units[$unit]) ) ;
761
+		}
762
+
763
+		/**
764
+		 * Get the upload error message
765
+		 * @return string
766
+		 */
767
+		public function getError(){
768
+			return $this->error;
769
+		}
770
+
771
+		/**
772
+		 * Set the upload error message
773
+		 * @param string $message the upload error message to set
774
+		 */
775
+		public function setError($message){
776
+			$this->logger->info('The upload got error : ' . $message);
777
+			$this->error = $message;
778
+		}
779
+
780
+		/**
781
+		 * Get the PHP upload error message for the given code
782
+		 * @param  int $code the error code
783
+		 * @return string the error message
784
+		 */
785
+		private function getPhpUploadErrorMessageByCode($code){
786
+			$codeMessageMaps = array(
787
+				1 => $this->error_messages['upload_err_ini_size'],
788
+				2 => $this->error_messages['upload_err_form_size'],
789
+				3 => $this->error_messages['upload_err_partial'],
790
+				4 => $this->error_messages['upload_err_no_file'],
791
+				6 => $this->error_messages['upload_err_no_tmp_dir'],
792
+				7 => $this->error_messages['upload_err_cant_write'],
793
+				8 => $this->error_messages['upload_err_extension'],
794
+			);
795
+			return isset($codeMessageMaps[$code]) ? $codeMessageMaps[$code] : null;
796
+		}
797
+	}
Please login to merge, or discard this patch.
Spacing   +47 added lines, -47 removed lines patch added patch discarded remove patch
@@ -37,7 +37,7 @@  discard block
 block discarded – undo
37 37
     *    @package FileUpload
38 38
     *    @version 1.5
39 39
     */
40
-    class Upload{
40
+    class Upload {
41 41
 
42 42
         /**
43 43
         *   Version
@@ -69,7 +69,7 @@  discard block
 block discarded – undo
69 69
         *    @version    1.0
70 70
         *    @var        array
71 71
         */
72
-        private $file_array    = array();
72
+        private $file_array = array();
73 73
 
74 74
         /**
75 75
         *    If the file you are trying to upload already exists it will
@@ -119,7 +119,7 @@  discard block
 block discarded – undo
119 119
         *    @version    1.0
120 120
         *    @var        float
121 121
         */
122
-        private $max_file_size= 0.0;
122
+        private $max_file_size = 0.0;
123 123
 
124 124
         /**
125 125
         *    List of allowed mime types
@@ -217,12 +217,12 @@  discard block
 block discarded – undo
217 217
         *    @return    object
218 218
         *    @method    object    __construct
219 219
         */
220
-        public function __construct(){
221
-            $this->logger =& class_loader('Log', 'classes');
220
+        public function __construct() {
221
+            $this->logger = & class_loader('Log', 'classes');
222 222
             $this->logger->setLogger('Library::Upload');
223 223
 
224 224
             Loader::lang('file_upload');
225
-            $obj =& get_instance();
225
+            $obj = & get_instance();
226 226
 
227 227
             $this->error_messages = array(
228 228
                 'upload_err_ini_size' => $obj->lang->get('fu_upload_err_ini_size'),
@@ -239,15 +239,15 @@  discard block
 block discarded – undo
239 239
             );
240 240
 
241 241
             $this->file = array(
242
-                'status'                =>    false,    // True: success upload
243
-                'mime'                  =>    '',       // Empty string
244
-                'filename'              =>    '',       // Empty string
245
-                'original'              =>    '',       // Empty string
246
-                'size'                  =>    0,        // 0 Bytes
247
-                'sizeFormated'          =>    '0B',     // 0 Bytes
248
-                'destination'           =>    './',     // Default: ./
249
-                'allowed_mime_types'    =>    array(),  // Allowed mime types
250
-                'error'                 =>    null,        // File error
242
+                'status'                =>    false, // True: success upload
243
+                'mime'                  =>    '', // Empty string
244
+                'filename'              =>    '', // Empty string
245
+                'original'              =>    '', // Empty string
246
+                'size'                  =>    0, // 0 Bytes
247
+                'sizeFormated'          =>    '0B', // 0 Bytes
248
+                'destination'           =>    './', // Default: ./
249
+                'allowed_mime_types'    =>    array(), // Allowed mime types
250
+                'error'                 =>    null, // File error
251 251
             );
252 252
 
253 253
             // Change dir to current dir
@@ -259,7 +259,7 @@  discard block
 block discarded – undo
259 259
             } elseif (isset($HTTP_POST_FILES) && is_array($HTTP_POST_FILES)) {
260 260
                 $this->file_array = $HTTP_POST_FILES;
261 261
             }
262
-            $this->logger->info('The upload file information are : ' .stringfy_vars($this->file_array));
262
+            $this->logger->info('The upload file information are : ' . stringfy_vars($this->file_array));
263 263
         }
264 264
         /**
265 265
         *    Set input.
@@ -275,7 +275,7 @@  discard block
 block discarded – undo
275 275
         */
276 276
         public function setInput($input)
277 277
         {
278
-            if (!empty($input) && (is_string($input) || is_numeric($input) )) {
278
+            if (!empty($input) && (is_string($input) || is_numeric($input))) {
279 279
                 $this->input = $input;
280 280
             }
281 281
             return $this;
@@ -311,7 +311,7 @@  discard block
 block discarded – undo
311 311
         */
312 312
         public function setAutoFilename()
313 313
         {
314
-            $this->filename = sha1(mt_rand(1, 9999).uniqid());
314
+            $this->filename = sha1(mt_rand(1, 9999) . uniqid());
315 315
             $this->filename .= time();
316 316
             return $this;
317 317
         }
@@ -332,7 +332,7 @@  discard block
 block discarded – undo
332 332
                 $php_size = $this->sizeInBytes(ini_get('upload_max_filesize'));
333 333
                 // Calculate difference
334 334
                 if ($php_size < $file_size) {
335
-                    $this->logger->warning('The upload max file size you set [' .$file_size. '] is greather than the PHP configuration for upload max file size [' .$php_size. ']');
335
+                    $this->logger->warning('The upload max file size you set [' . $file_size . '] is greather than the PHP configuration for upload max file size [' . $php_size . ']');
336 336
                 }
337 337
                 $this->max_file_size = $file_size;
338 338
             }
@@ -350,7 +350,7 @@  discard block
 block discarded – undo
350 350
         public function setAllowedMimeTypes(array $mimes)
351 351
         {
352 352
             if (count($mimes) > 0) {
353
-                array_map(array($this , 'setAllowMimeType'), $mimes);
353
+                array_map(array($this, 'setAllowMimeType'), $mimes);
354 354
             }
355 355
             return $this;
356 356
         }
@@ -415,7 +415,7 @@  discard block
 block discarded – undo
415 415
         {
416 416
             if (!empty($name) && is_string($name)) {
417 417
                 if (array_key_exists($name, $this->mime_helping)) {
418
-                    return $this->setAllowedMimeTypes($this->mime_helping[ $name ]);
418
+                    return $this->setAllowedMimeTypes($this->mime_helping[$name]);
419 419
                 }
420 420
             }
421 421
             return $this;
@@ -434,8 +434,8 @@  discard block
 block discarded – undo
434 434
         */
435 435
         public function setUploadFunction($function)
436 436
         {
437
-            if (!empty($function) && (is_array($function) || is_string($function) )) {
438
-                if (is_callable( $function)) {
437
+            if (!empty($function) && (is_array($function) || is_string($function))) {
438
+                if (is_callable($function)) {
439 439
                     $this->upload_function = $function;
440 440
                 }
441 441
             }
@@ -488,8 +488,8 @@  discard block
 block discarded – undo
488 488
                             chdir($destination_directory);
489 489
                         }
490 490
                     }
491
-                    else{
492
-                        $this->logger->warning('Can not create the upload directory [' .$destination_directory. ']');
491
+                    else {
492
+                        $this->logger->warning('Can not create the upload directory [' . $destination_directory . ']');
493 493
                     }
494 494
                 }
495 495
             }
@@ -539,7 +539,7 @@  discard block
 block discarded – undo
539 539
         public function isFilename($filename)
540 540
         {
541 541
             $filename = basename($filename);
542
-            return (!empty($filename) && (is_string( $filename) || is_numeric($filename)));
542
+            return (!empty($filename) && (is_string($filename) || is_numeric($filename)));
543 543
         }
544 544
         /**
545 545
         *    Validate mime type with allowed mime types,
@@ -581,11 +581,11 @@  discard block
 block discarded – undo
581 581
         */
582 582
         public function isDirpath($path)
583 583
         {
584
-            if (!empty( $path) && (is_string( $path) || is_numeric($path) )) {
584
+            if (!empty($path) && (is_string($path) || is_numeric($path))) {
585 585
                 if (DIRECTORY_SEPARATOR == '/') {
586
-                    return (preg_match( '/^[^*?"<>|:]*$/' , $path) == 1 );
586
+                    return (preg_match('/^[^*?"<>|:]*$/', $path) == 1);
587 587
                 } else {
588
-                    return (preg_match( "/^[^*?\"<>|:]*$/" , substr($path,2) ) == 1);
588
+                    return (preg_match("/^[^*?\"<>|:]*$/", substr($path, 2)) == 1);
589 589
                 }
590 590
             }
591 591
             return false;
@@ -613,10 +613,10 @@  discard block
 block discarded – undo
613 613
         */
614 614
         public function getInfo()
615 615
         {
616
-            return (object)$this->file;
616
+            return (object) $this->file;
617 617
         }
618 618
 
619
-        public function isUploaded(){
619
+        public function isUploaded() {
620 620
             return isset($this->file_array[$this->input])
621 621
             &&
622 622
             is_uploaded_file($this->file_array[$this->input]['tmp_name']);
@@ -629,9 +629,9 @@  discard block
 block discarded – undo
629 629
         *    @return    boolean
630 630
         *    @method    boolean    save
631 631
         */
632
-        public function save(){
632
+        public function save() {
633 633
             //check if file upload is  allowed in the configuration
634
-            if(! ini_get('file_uploads')){
634
+            if (!ini_get('file_uploads')) {
635 635
                 $this->setError($this->error_messages['file_uploads']);
636 636
                 return false;
637 637
             }
@@ -641,7 +641,7 @@  discard block
 block discarded – undo
641 641
                     if (empty($this->filename)) {
642 642
                         $this->filename = $this->file_array[$this->input]['name'];
643 643
                     }
644
-                    else{
644
+                    else {
645 645
                         // Replace %s for extension in filename
646 646
                         // Before: /[\w\d]*(.[\d\w]+)$/i
647 647
                         // After: /^[\s[:alnum:]\-\_\.]*\.([\d\w]+)$/iu
@@ -652,7 +652,7 @@  discard block
 block discarded – undo
652 652
                             '$1',
653 653
                             $this->file_array[$this->input]['name']
654 654
                         );
655
-                        $this->filename = $this->filename.'.'.$extension;
655
+                        $this->filename = $this->filename . '.' . $extension;
656 656
                     }
657 657
 
658 658
                     // set file info
@@ -665,10 +665,10 @@  discard block
 block discarded – undo
665 665
                     $this->file['filename']     = $this->filename;
666 666
                     $this->file['error']        = $this->file_array[$this->input]['error'];
667 667
 
668
-                    $this->logger->info('The upload file information to process is : ' .stringfy_vars($this->file));
668
+                    $this->logger->info('The upload file information to process is : ' . stringfy_vars($this->file));
669 669
 
670 670
                     //check for php upload error
671
-                    if(is_numeric($this->file['error']) && $this->file['error'] > 0){
671
+                    if (is_numeric($this->file['error']) && $this->file['error'] > 0) {
672 672
                         $this->setError($this->getPhpUploadErrorMessageByCode($this->file['error']));
673 673
                         return false;
674 674
                     }
@@ -697,8 +697,8 @@  discard block
 block discarded – undo
697 697
                     }
698 698
 
699 699
                     // Execute input callback
700
-                    if (!empty( $this->callbacks['input'])) {
701
-                        call_user_func($this->callbacks['input'], (object)$this->file);
700
+                    if (!empty($this->callbacks['input'])) {
701
+                        call_user_func($this->callbacks['input'], (object) $this->file);
702 702
                     }
703 703
                    
704 704
 
@@ -710,8 +710,8 @@  discard block
 block discarded – undo
710 710
                     );
711 711
 
712 712
                     // Execute output callback
713
-                    if (!empty( $this->callbacks['output'])) {
714
-                        call_user_func($this->callbacks['output'], (object)$this->file);
713
+                    if (!empty($this->callbacks['output'])) {
714
+                        call_user_func($this->callbacks['output'], (object) $this->file);
715 715
                     }
716 716
                     return $this->file['status'];
717 717
                 }
@@ -730,10 +730,10 @@  discard block
 block discarded – undo
730 730
         */
731 731
         public function sizeFormat($size, $precision = 2)
732 732
         {
733
-            if($size > 0){
733
+            if ($size > 0) {
734 734
                 $base       = log($size) / log(1024);
735 735
                 $suffixes   = array('B', 'K', 'M', 'G', 'T');
736
-                return round(pow(1024, $base - floor($base)), $precision) . ( isset($suffixes[floor($base)]) ? $suffixes[floor($base)] : '');
736
+                return round(pow(1024, $base - floor($base)), $precision) . (isset($suffixes[floor($base)]) ? $suffixes[floor($base)] : '');
737 737
             }
738 738
             return null;
739 739
         }
@@ -757,14 +757,14 @@  discard block
 block discarded – undo
757 757
             if (array_key_exists('unit', $matches)) {
758 758
                 $unit = strtoupper($matches['unit']);
759 759
             }
760
-            return (floatval($matches['size']) * pow(1024, $units[$unit]) ) ;
760
+            return (floatval($matches['size']) * pow(1024, $units[$unit]));
761 761
         }
762 762
 
763 763
         /**
764 764
          * Get the upload error message
765 765
          * @return string
766 766
          */
767
-        public function getError(){
767
+        public function getError() {
768 768
             return $this->error;
769 769
         }
770 770
 
@@ -772,7 +772,7 @@  discard block
 block discarded – undo
772 772
          * Set the upload error message
773 773
          * @param string $message the upload error message to set
774 774
          */
775
-        public function setError($message){
775
+        public function setError($message) {
776 776
             $this->logger->info('The upload got error : ' . $message);
777 777
             $this->error = $message;
778 778
         }
@@ -782,7 +782,7 @@  discard block
 block discarded – undo
782 782
          * @param  int $code the error code
783 783
          * @return string the error message
784 784
          */
785
-        private function getPhpUploadErrorMessageByCode($code){
785
+        private function getPhpUploadErrorMessageByCode($code) {
786 786
             $codeMessageMaps = array(
787 787
                 1 => $this->error_messages['upload_err_ini_size'],
788 788
                 2 => $this->error_messages['upload_err_form_size'],
Please login to merge, or discard this patch.