Test Failed
Push — 1.0.0-dev ( c7a39c...6c2ad2 )
by nguereza
03:29
created
core/classes/Config.php 2 patches
Spacing   +30 added lines, -30 removed lines patch added patch discarded remove patch
@@ -24,7 +24,7 @@  discard block
 block discarded – undo
24 24
 	 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
25 25
 	*/
26 26
 
27
-	class Config{
27
+	class Config {
28 28
 		
29 29
 		/**
30 30
 		 * The list of loaded configuration
@@ -42,10 +42,10 @@  discard block
 block discarded – undo
42 42
 		 * The signleton of the logger
43 43
 		 * @return Object the Log instance
44 44
 		 */
45
-		private static function getLogger(){
46
-			if(self::$logger == null){
45
+		private static function getLogger() {
46
+			if (self::$logger == null) {
47 47
 				$logger = array();
48
-				$logger[0] =& class_loader('Log', 'classes');
48
+				$logger[0] = & class_loader('Log', 'classes');
49 49
 				$logger[0]->setLogger('Library::Config');
50 50
 				self::$logger = $logger[0];
51 51
 			}
@@ -57,7 +57,7 @@  discard block
 block discarded – undo
57 57
 		 * @param Log $logger the log object
58 58
 		 * @return Log the log instance
59 59
 		 */
60
-		public static function setLogger($logger){
60
+		public static function setLogger($logger) {
61 61
 			self::$logger = $logger;
62 62
 			return self::$logger;
63 63
 		}
@@ -65,12 +65,12 @@  discard block
 block discarded – undo
65 65
 		/**
66 66
 		 * Initialize the configuration by loading all the configuration from config file
67 67
 		 */
68
-		public static function init(){
68
+		public static function init() {
69 69
 			$logger = static::getLogger();
70 70
 			$logger->debug('Initialization of the configuration');
71 71
 			self::$config = & load_configurations();
72 72
 			self::setBaseUrlUsingServerVar();
73
-			if(ENVIRONMENT == 'production' && in_array(strtolower(self::$config['log_level']), array('debug', 'info','all'))){
73
+			if (ENVIRONMENT == 'production' && in_array(strtolower(self::$config['log_level']), array('debug', 'info', 'all'))) {
74 74
 				$logger->warning('You are in production environment, please set log level to WARNING, ERROR, FATAL to increase the application performance');
75 75
 			}
76 76
 			$logger->info('Configuration initialized successfully');
@@ -83,12 +83,12 @@  discard block
 block discarded – undo
83 83
 		 * @param  mixed $default the default value to use if can not find the config item in the list
84 84
 		 * @return mixed          the config value if exist or the default value
85 85
 		 */
86
-		public static function get($item, $default = null){
86
+		public static function get($item, $default = null) {
87 87
 			$logger = static::getLogger();
88
-			if(array_key_exists($item, self::$config)){
88
+			if (array_key_exists($item, self::$config)) {
89 89
 				return self::$config[$item];
90 90
 			}
91
-			$logger->warning('Cannot find config item ['.$item.'] using the default value ['.$default.']');
91
+			$logger->warning('Cannot find config item [' . $item . '] using the default value [' . $default . ']');
92 92
 			return $default;
93 93
 		}
94 94
 
@@ -97,7 +97,7 @@  discard block
 block discarded – undo
97 97
 		 * @param string $item  the config item name to set
98 98
 		 * @param mixed $value the config item value
99 99
 		 */
100
-		public static function set($item, $value){
100
+		public static function set($item, $value) {
101 101
 			self::$config[$item] = $value;
102 102
 		}
103 103
 
@@ -105,7 +105,7 @@  discard block
 block discarded – undo
105 105
 		 * Get all the configuration values
106 106
 		 * @return array the config values
107 107
 		 */
108
-		public static function getAll(){
108
+		public static function getAll() {
109 109
 			return self::$config;
110 110
 		}
111 111
 
@@ -113,7 +113,7 @@  discard block
 block discarded – undo
113 113
 		 * Set the configuration values bu merged with the existing configuration
114 114
 		 * @param array $config the config values to add in the configuration list
115 115
 		 */
116
-		public static function setAll(array $config = array()){
116
+		public static function setAll(array $config = array()) {
117 117
 			self::$config = array_merge(self::$config, $config);
118 118
 		}
119 119
 
@@ -122,15 +122,15 @@  discard block
 block discarded – undo
122 122
 		 * @param  string $item the config item name to be deleted
123 123
 		 * @return boolean true if the item exists and is deleted successfully otherwise will return false.
124 124
 		 */
125
-		public static function delete($item){
125
+		public static function delete($item) {
126 126
 			$logger = static::getLogger();
127
-			if(array_key_exists($item, self::$config)){
128
-				$logger->info('Delete config item ['.$item.']');
127
+			if (array_key_exists($item, self::$config)) {
128
+				$logger->info('Delete config item [' . $item . ']');
129 129
 				unset(self::$config[$item]);
130 130
 				return true;
131 131
 			}
132
-			else{
133
-				$logger->warning('Config item ['.$item.'] to be deleted does not exists');
132
+			else {
133
+				$logger->warning('Config item [' . $item . '] to be deleted does not exists');
134 134
 				return false;
135 135
 			}
136 136
 		}
@@ -139,37 +139,37 @@  discard block
 block discarded – undo
139 139
 		 * Load the configuration file. This an alias to Loader::config()
140 140
 		 * @param  string $config the config name to be loaded
141 141
 		 */
142
-		public static function load($config){
142
+		public static function load($config) {
143 143
 			Loader::config($config);
144 144
 		}
145 145
 
146 146
 		/**
147 147
 		 * Set the configuration for "base_url" if is not set in the configuration
148 148
 		 */
149
-		private static function setBaseUrlUsingServerVar(){
150
-			if (! isset(self::$config['base_url']) || ! is_url(self::$config['base_url'])){
151
-				if(ENVIRONMENT == 'production'){
149
+		private static function setBaseUrlUsingServerVar() {
150
+			if (!isset(self::$config['base_url']) || !is_url(self::$config['base_url'])) {
151
+				if (ENVIRONMENT == 'production') {
152 152
 					$logger->warning('Application base URL is not set or invalid, please set application base URL to increase the application loading time');
153 153
 				}
154 154
 				$baseUrl = null;
155
-				if (isset($_SERVER['SERVER_ADDR'])){
155
+				if (isset($_SERVER['SERVER_ADDR'])) {
156 156
 					//check if the server is running under IPv6
157
-					if (strpos($_SERVER['SERVER_ADDR'], ':') !== FALSE){
158
-						$baseUrl = '['.$_SERVER['SERVER_ADDR'].']';
157
+					if (strpos($_SERVER['SERVER_ADDR'], ':') !== FALSE) {
158
+						$baseUrl = '[' . $_SERVER['SERVER_ADDR'] . ']';
159 159
 					}
160
-					else{
160
+					else {
161 161
 						$baseUrl = $_SERVER['SERVER_ADDR'];
162 162
 					}
163
-					$port = ((isset($_SERVER['SERVER_PORT']) && ($_SERVER['SERVER_PORT'] != '80' && ! is_https() || $_SERVER['SERVER_PORT'] != '443' && is_https()) ) ? ':' . $_SERVER['SERVER_PORT'] : '');
164
-					$baseUrl = (is_https() ? 'https' : 'http').'://' . $baseUrl . $port
163
+					$port = ((isset($_SERVER['SERVER_PORT']) && ($_SERVER['SERVER_PORT'] != '80' && !is_https() || $_SERVER['SERVER_PORT'] != '443' && is_https())) ? ':' . $_SERVER['SERVER_PORT'] : '');
164
+					$baseUrl = (is_https() ? 'https' : 'http') . '://' . $baseUrl . $port
165 165
 						. substr($_SERVER['SCRIPT_NAME'], 0, strpos($_SERVER['SCRIPT_NAME'], basename($_SERVER['SCRIPT_FILENAME'])));
166 166
 				}
167
-				else{
167
+				else {
168 168
 					$logger->warning('Can not determine the application base URL automatically, use http://localhost as default');
169 169
 					$baseUrl = 'http://localhost/';
170 170
 				}
171 171
 				self::set('base_url', $baseUrl);
172 172
 			}
173
-			self::$config['base_url'] = rtrim(self::$config['base_url'], '/') .'/';
173
+			self::$config['base_url'] = rtrim(self::$config['base_url'], '/') . '/';
174 174
 		}
175 175
 	}
Please login to merge, or discard this patch.
Braces   +3 added lines, -6 removed lines patch added patch discarded remove patch
@@ -128,8 +128,7 @@  discard block
 block discarded – undo
128 128
 				$logger->info('Delete config item ['.$item.']');
129 129
 				unset(self::$config[$item]);
130 130
 				return true;
131
-			}
132
-			else{
131
+			} else{
133 132
 				$logger->warning('Config item ['.$item.'] to be deleted does not exists');
134 133
 				return false;
135 134
 			}
@@ -156,15 +155,13 @@  discard block
 block discarded – undo
156 155
 					//check if the server is running under IPv6
157 156
 					if (strpos($_SERVER['SERVER_ADDR'], ':') !== FALSE){
158 157
 						$baseUrl = '['.$_SERVER['SERVER_ADDR'].']';
159
-					}
160
-					else{
158
+					} else{
161 159
 						$baseUrl = $_SERVER['SERVER_ADDR'];
162 160
 					}
163 161
 					$port = ((isset($_SERVER['SERVER_PORT']) && ($_SERVER['SERVER_PORT'] != '80' && ! is_https() || $_SERVER['SERVER_PORT'] != '443' && is_https()) ) ? ':' . $_SERVER['SERVER_PORT'] : '');
164 162
 					$baseUrl = (is_https() ? 'https' : 'http').'://' . $baseUrl . $port
165 163
 						. substr($_SERVER['SCRIPT_NAME'], 0, strpos($_SERVER['SCRIPT_NAME'], basename($_SERVER['SCRIPT_FILENAME'])));
166
-				}
167
-				else{
164
+				} else{
168 165
 					$logger->warning('Can not determine the application base URL automatically, use http://localhost as default');
169 166
 					$baseUrl = 'http://localhost/';
170 167
 				}
Please login to merge, or discard this patch.
core/classes/EventInfo.php 1 patch
Spacing   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -27,7 +27,7 @@  discard block
 block discarded – undo
27 27
 	/**
28 28
 	 * This class represent the event detail to dispatch to correspond listener
29 29
 	 */
30
-	class EventInfo{
30
+	class EventInfo {
31 31
 		
32 32
 		/**
33 33
 		 * The event name
@@ -54,7 +54,7 @@  discard block
 block discarded – undo
54 54
 		 */
55 55
 		public $stop;
56 56
 		
57
-		public function __construct($name, $payload = array(), $returnBack = false, $stop = false){
57
+		public function __construct($name, $payload = array(), $returnBack = false, $stop = false) {
58 58
 			$this->name = $name;
59 59
 			$this->payload = $payload;
60 60
 			$this->returnBack = $returnBack;
Please login to merge, or discard this patch.
core/classes/EventDispatcher.php 2 patches
Spacing   +39 added lines, -39 removed lines patch added patch discarded remove patch
@@ -29,7 +29,7 @@  discard block
 block discarded – undo
29 29
 	 * also to dispatch the event
30 30
 	 */
31 31
 	
32
-	class EventDispatcher{
32
+	class EventDispatcher {
33 33
 		
34 34
 		/**
35 35
 		 * The list of the registered listeners
@@ -44,8 +44,8 @@  discard block
 block discarded – undo
44 44
 		 */
45 45
 		private $logger;
46 46
 
47
-		public function __construct(){
48
-			$this->logger =& class_loader('Log', 'classes');
47
+		public function __construct() {
48
+			$this->logger = & class_loader('Log', 'classes');
49 49
 			$this->logger->setLogger('Library::EventDispatcher');
50 50
 		}
51 51
 
@@ -54,13 +54,13 @@  discard block
 block discarded – undo
54 54
 		 * @param string   $eventName the name of the event to register for
55 55
 		 * @param callable $listener  the function or class method to receive the event information after dispatch
56 56
 		 */
57
-		public function addListener($eventName, callable $listener){
58
-			$this->logger->debug('Adding new event listener for the event name [' .$eventName. '], listener [' .stringfy_vars($listener). ']');
59
-			if(! isset($this->listeners[$eventName])){
57
+		public function addListener($eventName, callable $listener) {
58
+			$this->logger->debug('Adding new event listener for the event name [' . $eventName . '], listener [' . stringfy_vars($listener) . ']');
59
+			if (!isset($this->listeners[$eventName])) {
60 60
 				$this->logger->info('This event does not have the registered event listener before, adding new one');
61 61
 				$this->listeners[$eventName] = array();
62 62
 			}
63
-			else{
63
+			else {
64 64
 				$this->logger->info('This event already have the registered listener, add this listener to the list');
65 65
 			}
66 66
 			$this->listeners[$eventName][] = $listener;
@@ -71,19 +71,19 @@  discard block
 block discarded – undo
71 71
 		 * @param  string   $eventName the event name
72 72
 		 * @param  callable $listener  the listener callback
73 73
 		 */
74
-		public function removeListener($eventName, callable $listener){
75
-			$this->logger->debug('Removing of the event listener, the event name [' .$eventName. '], listener [' .stringfy_vars($listener). ']');
76
-			if(isset($this->listeners[$eventName])){
74
+		public function removeListener($eventName, callable $listener) {
75
+			$this->logger->debug('Removing of the event listener, the event name [' . $eventName . '], listener [' . stringfy_vars($listener) . ']');
76
+			if (isset($this->listeners[$eventName])) {
77 77
 				$this->logger->info('This event have the listeners, check if this listener exists');
78
-				if(false !== $index = array_search($listener, $this->listeners[$eventName], true)){
79
-					$this->logger->info('Found the listener at index [' .$index. '] remove it');
78
+				if (false !== $index = array_search($listener, $this->listeners[$eventName], true)) {
79
+					$this->logger->info('Found the listener at index [' . $index . '] remove it');
80 80
 					unset($this->listeners[$eventName][$index]);
81 81
 				}
82
-				else{
82
+				else {
83 83
 					$this->logger->info('Cannot found this listener in the event listener list');
84 84
 				}
85 85
 			}
86
-			else{
86
+			else {
87 87
 				$this->logger->info('This event does not have this listener ignore remove');
88 88
 			}
89 89
 		}
@@ -93,13 +93,13 @@  discard block
 block discarded – undo
93 93
 		 * remove all listeners for this event
94 94
 		 * @param  string $eventName the event name
95 95
 		 */
96
-		public function removeAllListener($eventName = null){
97
-			$this->logger->debug('Removing of all event listener, the event name [' .$eventName. ']');
98
-			if($eventName !== null && isset($this->listeners[$eventName])){
96
+		public function removeAllListener($eventName = null) {
97
+			$this->logger->debug('Removing of all event listener, the event name [' . $eventName . ']');
98
+			if ($eventName !== null && isset($this->listeners[$eventName])) {
99 99
 				$this->logger->info('The event name is set of exist in the listener just remove all event listener for this event');
100 100
 				unset($this->listeners[$eventName]);
101 101
 			}
102
-			else{
102
+			else {
103 103
 				$this->logger->info('The event name is not set or does not exist in the listener, so remove all event listener');
104 104
 				$this->listeners = array();
105 105
 			}
@@ -110,7 +110,7 @@  discard block
 block discarded – undo
110 110
 		 * @param string $eventName the event name
111 111
 		 * @return array the listeners for this event or empty array if this event does not contain any listener
112 112
 		 */
113
-		public function getListeners($eventName){
113
+		public function getListeners($eventName) {
114 114
 			return isset($this->listeners[$eventName]) ? $this->listeners[$eventName] : array();
115 115
 		}
116 116
 		
@@ -119,21 +119,21 @@  discard block
 block discarded – undo
119 119
 		 * @param  mixed|object $event the event information
120 120
 		 * @return void|object if event need return, will return the final EventInfo object.
121 121
 		 */	
122
-		public function dispatch($event){
123
-			if(! $event || !$event instanceof EventInfo){
122
+		public function dispatch($event) {
123
+			if (!$event || !$event instanceof EventInfo) {
124 124
 				$this->logger->info('The event is not set or is not an instance of "EventInfo" create the default "EventInfo" object to use instead of.');
125 125
 				$event = new EventInfo((string) $event);
126 126
 			}			
127
-			$this->logger->debug('Dispatch to the event listener, the event [' .stringfy_vars($event). ']');
128
-			if(isset($event->stop) && $event->stop){
127
+			$this->logger->debug('Dispatch to the event listener, the event [' . stringfy_vars($event) . ']');
128
+			if (isset($event->stop) && $event->stop) {
129 129
 				$this->logger->info('This event need stopped, no need call any listener');
130 130
 				return;
131 131
 			}
132
-			if($event->returnBack){
132
+			if ($event->returnBack) {
133 133
 				$this->logger->info('This event need return back, return the result for future use');
134 134
 				return $this->dispatchToListerners($event);
135 135
 			}
136
-			else{
136
+			else {
137 137
 				$this->logger->info('This event no need return back the result, just dispatch it');
138 138
 				$this->dispatchToListerners($event);
139 139
 			}
@@ -144,38 +144,38 @@  discard block
 block discarded – undo
144 144
 		 * @param  object EventInfo $event  the event information
145 145
 		 * @return void|object if event need return, will return the final EventInfo instance.
146 146
 		 */	
147
-		private function dispatchToListerners(EventInfo $event){
147
+		private function dispatchToListerners(EventInfo $event) {
148 148
 			$eBackup = $event;
149 149
 			$list = $this->getListeners($event->name);
150
-			if(empty($list)){
151
-				$this->logger->info('No event listener is registered for the event [' .$event->name. '] skipping.');
152
-				if($event->returnBack){
150
+			if (empty($list)) {
151
+				$this->logger->info('No event listener is registered for the event [' . $event->name . '] skipping.');
152
+				if ($event->returnBack) {
153 153
 					return $event;
154 154
 				}
155 155
 				return;
156 156
 			}
157
-			else{
158
-				$this->logger->info('Found the registered event listener for the event [' .$event->name. '] the list are: ' . stringfy_vars($list));
157
+			else {
158
+				$this->logger->info('Found the registered event listener for the event [' . $event->name . '] the list are: ' . stringfy_vars($list));
159 159
 			}
160
-			foreach($list as $listener){
161
-				if($eBackup->returnBack){
160
+			foreach ($list as $listener) {
161
+				if ($eBackup->returnBack) {
162 162
 					$returnedEvent = call_user_func_array($listener, array($event));
163
-					if($returnedEvent instanceof EventInfo){
163
+					if ($returnedEvent instanceof EventInfo) {
164 164
 						$event = $returnedEvent;
165 165
 					}
166
-					else{
167
-						show_error('This event [' .$event->name. '] need you return the event object after processing');
166
+					else {
167
+						show_error('This event [' . $event->name . '] need you return the event object after processing');
168 168
 					}
169 169
 				}
170
-				else{
170
+				else {
171 171
 					call_user_func_array($listener, array($event));
172 172
 				}
173
-				if($event->stop){
173
+				if ($event->stop) {
174 174
 					break;
175 175
 				}
176 176
 			}
177 177
 			//only test for original event may be during the flow some listeners change this parameter
178
-			if($eBackup->returnBack){
178
+			if ($eBackup->returnBack) {
179 179
 				return $event;
180 180
 			}
181 181
 		}
Please login to merge, or discard this patch.
Braces   +8 added lines, -16 removed lines patch added patch discarded remove patch
@@ -59,8 +59,7 @@  discard block
 block discarded – undo
59 59
 			if(! isset($this->listeners[$eventName])){
60 60
 				$this->logger->info('This event does not have the registered event listener before, adding new one');
61 61
 				$this->listeners[$eventName] = array();
62
-			}
63
-			else{
62
+			} else{
64 63
 				$this->logger->info('This event already have the registered listener, add this listener to the list');
65 64
 			}
66 65
 			$this->listeners[$eventName][] = $listener;
@@ -78,12 +77,10 @@  discard block
 block discarded – undo
78 77
 				if(false !== $index = array_search($listener, $this->listeners[$eventName], true)){
79 78
 					$this->logger->info('Found the listener at index [' .$index. '] remove it');
80 79
 					unset($this->listeners[$eventName][$index]);
81
-				}
82
-				else{
80
+				} else{
83 81
 					$this->logger->info('Cannot found this listener in the event listener list');
84 82
 				}
85
-			}
86
-			else{
83
+			} else{
87 84
 				$this->logger->info('This event does not have this listener ignore remove');
88 85
 			}
89 86
 		}
@@ -98,8 +95,7 @@  discard block
 block discarded – undo
98 95
 			if($eventName !== null && isset($this->listeners[$eventName])){
99 96
 				$this->logger->info('The event name is set of exist in the listener just remove all event listener for this event');
100 97
 				unset($this->listeners[$eventName]);
101
-			}
102
-			else{
98
+			} else{
103 99
 				$this->logger->info('The event name is not set or does not exist in the listener, so remove all event listener');
104 100
 				$this->listeners = array();
105 101
 			}
@@ -132,8 +128,7 @@  discard block
 block discarded – undo
132 128
 			if($event->returnBack){
133 129
 				$this->logger->info('This event need return back, return the result for future use');
134 130
 				return $this->dispatchToListerners($event);
135
-			}
136
-			else{
131
+			} else{
137 132
 				$this->logger->info('This event no need return back the result, just dispatch it');
138 133
 				$this->dispatchToListerners($event);
139 134
 			}
@@ -153,8 +148,7 @@  discard block
 block discarded – undo
153 148
 					return $event;
154 149
 				}
155 150
 				return;
156
-			}
157
-			else{
151
+			} else{
158 152
 				$this->logger->info('Found the registered event listener for the event [' .$event->name. '] the list are: ' . stringfy_vars($list));
159 153
 			}
160 154
 			foreach($list as $listener){
@@ -162,12 +156,10 @@  discard block
 block discarded – undo
162 156
 					$returnedEvent = call_user_func_array($listener, array($event));
163 157
 					if($returnedEvent instanceof EventInfo){
164 158
 						$event = $returnedEvent;
165
-					}
166
-					else{
159
+					} else{
167 160
 						show_error('This event [' .$event->name. '] need you return the event object after processing');
168 161
 					}
169
-				}
170
-				else{
162
+				} else{
171 163
 					call_user_func_array($listener, array($event));
172 164
 				}
173 165
 				if($event->stop){
Please login to merge, or discard this patch.
core/classes/Database.php 3 patches
Indentation   +1289 added lines, -1289 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,1198 +22,1198 @@  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;
164
+	private $logger              = null;
165 165
 
166 166
 
167
-    /**
168
-    * The cache instance
169
-    * @var CacheInterface
170
-    */
171
-    private $cacheInstance       = null;
167
+	/**
168
+	 * The cache instance
169
+	 * @var CacheInterface
170
+	 */
171
+	private $cacheInstance       = null;
172 172
 
173
-     /**
174
-    * The benchmark instance
175
-    * @var Benchmark
176
-    */
177
-    private $benchmarkInstance   = null;
173
+	 /**
174
+	  * The benchmark instance
175
+	  * @var Benchmark
176
+	  */
177
+	private $benchmarkInstance   = null;
178 178
 
179 179
 
180
-    /**
181
-     * Construct new database
182
-     * @param array $overwriteConfig the config to overwrite with the config set in database.php
183
-     */
184
-    public function __construct($overwriteConfig = array()){
185
-        //Set Log instance to use
186
-        $this->setLoggerFromParamOrCreateNewInstance(null);
180
+	/**
181
+	 * Construct new database
182
+	 * @param array $overwriteConfig the config to overwrite with the config set in database.php
183
+	 */
184
+	public function __construct($overwriteConfig = array()){
185
+		//Set Log instance to use
186
+		$this->setLoggerFromParamOrCreateNewInstance(null);
187 187
 
188
-        //Set global configuration using the config file
189
-        $this->setDatabaseConfigurationFromConfigFile($overwriteConfig);
188
+		//Set global configuration using the config file
189
+		$this->setDatabaseConfigurationFromConfigFile($overwriteConfig);
190 190
         
191
-    		$this->temporaryCacheTtl = $this->cacheTtl;
192
-    }
193
-
194
-    /**
195
-     * This is used to connect to database
196
-     * @return bool 
197
-     */
198
-    public function connect(){
199
-      $config = $this->getDatabaseConfiguration();
200
-      if(! empty($config)){
201
-        try{
202
-            $this->pdo = new PDO($this->getDsnFromDriver(), $config['username'], $config['password']);
203
-            $this->pdo->exec("SET NAMES '" . $config['charset'] . "' COLLATE '" . $config['collation'] . "'");
204
-            $this->pdo->exec("SET CHARACTER SET '" . $config['charset'] . "'");
205
-            $this->pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_OBJ);
206
-            return true;
207
-          }
208
-          catch (PDOException $e){
209
-            $this->logger->fatal($e->getMessage());
210
-            show_error('Cannot connect to Database.');
211
-            return false;
212
-          }
213
-      }
214
-      else{
215
-        show_error('Database configuration is not set.');
216
-        return false;
217
-      }
218
-    }
219
-
220
-    /**
221
-     * Set the SQL FROM statment
222
-     * @param  string|array $table the table name or array of table list
223
-     * @return object        the current Database instance
224
-     */
225
-    public function from($table){
226
-      if(is_array($table)){
227
-        $froms = '';
228
-        foreach($table as $key){
229
-          $froms .= $this->prefix . $key . ', ';
230
-        }
231
-        $this->from = rtrim($froms, ', ');
232
-      }
233
-      else{
234
-        $this->from = $this->prefix . $table;
235
-      }
236
-      return $this;
237
-    }
238
-
239
-    /**
240
-     * Set the SQL SELECT statment
241
-     * @param  string|array $fields the field name or array of field list
242
-     * @return object        the current Database instance
243
-     */
244
-    public function select($fields){
245
-      $select = (is_array($fields) ? implode(', ', $fields) : $fields);
246
-      $this->select = ($this->select == '*' ? $select : $this->select . ', ' . $select);
247
-      return $this;
248
-    }
249
-
250
-    /**
251
-     * Set the SQL SELECT DISTINCT statment
252
-     * @param  string $field the field name to distinct
253
-     * @return object        the current Database instance
254
-     */
255
-    public function distinct($field){
256
-      $distinct = ' DISTINCT ' . $field;
257
-      $this->select = ($this->select == '*' ? $distinct : $this->select . ', ' . $distinct);
258
-
259
-      return $this;
260
-    }
261
-
262
-    /**
263
-     * Set the SQL function MAX in SELECT statment
264
-     * @param  string $field the field name
265
-     * @param  string $name  if is not null represent the alias used for this field in the result
266
-     * @return object        the current Database instance
267
-     */
268
-    public function max($field, $name = null){
269
-      $func = 'MAX(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
270
-      $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
271
-      return $this;
272
-    }
273
-
274
-    /**
275
-     * Set the SQL function MIN in SELECT statment
276
-     * @param  string $field the field name
277
-     * @param  string $name  if is not null represent the alias used for this field in the result
278
-     * @return object        the current Database instance
279
-     */
280
-    public function min($field, $name = null){
281
-      $func = 'MIN(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
282
-      $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
283
-      return $this;
284
-    }
285
-
286
-    /**
287
-     * Set the SQL function SUM in SELECT statment
288
-     * @param  string $field the field name
289
-     * @param  string $name  if is not null represent the alias used for this field in the result
290
-     * @return object        the current Database instance
291
-     */
292
-    public function sum($field, $name = null){
293
-      $func = 'SUM(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
294
-      $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
295
-      return $this;
296
-    }
297
-
298
-    /**
299
-     * Set the SQL function COUNT in SELECT statment
300
-     * @param  string $field the field name
301
-     * @param  string $name  if is not null represent the alias used for this field in the result
302
-     * @return object        the current Database instance
303
-     */
304
-    public function count($field = '*', $name = null){
305
-      $func = 'COUNT(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
306
-      $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
307
-      return $this;
308
-    }
309
-
310
-    /**
311
-     * Set the SQL function AVG in SELECT statment
312
-     * @param  string $field the field name
313
-     * @param  string $name  if is not null represent the alias used for this field in the result
314
-     * @return object        the current Database instance
315
-     */
316
-    public function avg($field, $name = null){
317
-      $func = 'AVG(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
318
-      $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
319
-      return $this;
320
-    }
321
-
322
-    /**
323
-     * Set the SQL JOIN statment
324
-     * @param  string $table  the join table name
325
-     * @param  string $field1 the first field for join conditions	
326
-     * @param  string $op     the join condition operator. If is null the default will be "="
327
-     * @param  string $field2 the second field for join conditions
328
-     * @param  string $type   the type of join (INNER, LEFT, RIGHT)
329
-     * @return object        the current Database instance
330
-     */
331
-    public function join($table, $field1 = null, $op = null, $field2 = null, $type = ''){
332
-      $on = $field1;
333
-      $table = $this->prefix . $table;
334
-      if(! is_null($op)){
335
-        $on = (! in_array($op, $this->operatorList) ? $this->prefix . $field1 . ' = ' . $this->prefix . $op : $this->prefix . $field1 . ' ' . $op . ' ' . $this->prefix . $field2);
336
-      }
337
-      if (empty($this->join)){
338
-        $this->join = ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
339
-      }
340
-      else{
341
-        $this->join = $this->join . ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
342
-      }
343
-      return $this;
344
-    }
345
-
346
-    /**
347
-     * Set the SQL INNER JOIN statment
348
-     * @see  Database::join()
349
-     * @return object        the current Database instance
350
-     */
351
-    public function innerJoin($table, $field1, $op = null, $field2 = ''){
352
-      return $this->join($table, $field1, $op, $field2, 'INNER ');
353
-    }
354
-
355
-    /**
356
-     * Set the SQL LEFT JOIN statment
357
-     * @see  Database::join()
358
-     * @return object        the current Database instance
359
-     */
360
-    public function leftJoin($table, $field1, $op = null, $field2 = ''){
361
-      return $this->join($table, $field1, $op, $field2, 'LEFT ');
362
-	}
363
-
364
-	/**
365
-     * Set the SQL RIGHT JOIN statment
366
-     * @see  Database::join()
367
-     * @return object        the current Database instance
368
-     */
369
-    public function rightJoin($table, $field1, $op = null, $field2 = ''){
370
-      return $this->join($table, $field1, $op, $field2, 'RIGHT ');
371
-    }
372
-
373
-    /**
374
-     * Set the SQL FULL OUTER JOIN statment
375
-     * @see  Database::join()
376
-     * @return object        the current Database instance
377
-     */
378
-    public function fullOuterJoin($table, $field1, $op = null, $field2 = ''){
379
-    	return $this->join($table, $field1, $op, $field2, 'FULL OUTER ');
380
-    }
381
-
382
-    /**
383
-     * Set the SQL LEFT OUTER JOIN statment
384
-     * @see  Database::join()
385
-     * @return object        the current Database instance
386
-     */
387
-    public function leftOuterJoin($table, $field1, $op = null, $field2 = ''){
388
-      return $this->join($table, $field1, $op, $field2, 'LEFT OUTER ');
389
-    }
390
-
391
-    /**
392
-     * Set the SQL RIGHT OUTER JOIN statment
393
-     * @see  Database::join()
394
-     * @return object        the current Database instance
395
-     */
396
-    public function rightOuterJoin($table, $field1, $op = null, $field2 = ''){
397
-      return $this->join($table, $field1, $op, $field2, 'RIGHT OUTER ');
398
-    }
399
-
400
-    /**
401
-     * Set the SQL WHERE CLAUSE for IS NULL
402
-     * @param  string|array $field  the field name or array of field list
403
-     * @param  string $andOr the separator type used 'AND', 'OR', etc.
404
-     * @return object        the current Database instance
405
-     */
406
-    public function whereIsNull($field, $andOr = 'AND'){
407
-      if(is_array($field)){
408
-        foreach($field as $f){
409
-        	$this->whereIsNull($f, $andOr);
410
-        }
411
-      }
412
-      else{
413
-        if (! $this->where){
414
-          $this->where = $field.' IS NULL ';
415
-        }
416
-        else{
417
-            $this->where = $this->where . ' '.$andOr.' ' . $field.' IS NULL ';
418
-          }
419
-      }
420
-      return $this;
421
-    }
422
-
423
-    /**
424
-     * Set the SQL WHERE CLAUSE for IS NOT NULL
425
-     * @param  string|array $field  the field name or array of field list
426
-     * @param  string $andOr the separator type used 'AND', 'OR', etc.
427
-     * @return object        the current Database instance
428
-     */
429
-    public function whereIsNotNull($field, $andOr = 'AND'){
430
-      if(is_array($field)){
431
-        foreach($field as $f){
432
-          $this->whereIsNotNull($f, $andOr);
433
-        }
434
-      }
435
-      else{
436
-        if (! $this->where){
437
-          $this->where = $field.' IS NOT NULL ';
438
-        }
439
-        else{
440
-            $this->where = $this->where . ' '.$andOr.' ' . $field.' IS NOT NULL ';
441
-          }
442
-      }
443
-      return $this;
444
-    }
445
-
446
-    /**
447
-     * Get the SQL WHERE clause using array column => value
448
-     * @see Database::where
449
-     *
450
-     * @return string
451
-     */
452
-    protected function getWhereStrIfIsArray(array $where, $type = '', $andOr = 'AND', $escape = true){
453
-        $_where = array();
454
-        foreach ($where as $column => $data){
455
-          if(is_null($data)){
456
-            $data = '';
457
-          }
458
-          $_where[] = $type . $column . ' = ' . ($escape ? $this->escape($data) : $data);
459
-        }
460
-        $where = implode(' '.$andOr.' ', $_where);
461
-        return $where;
462
-    }
463
-
464
-     /**
465
-     * Get the SQL WHERE clause when operator argument is an array
466
-     * @see Database::where
467
-     *
468
-     * @return string
469
-     */
470
-    protected function getWhereStrIfOperatorIsArray($where, array $op, $type = '', $escape = true){
471
-       $x = explode('?', $where);
472
-       $w = '';
473
-        foreach($x as $k => $v){
474
-          if(! empty($v)){
475
-              if(isset($op[$k]) && is_null($op[$k])){
476
-                $op[$k] = '';
477
-              }
478
-              $w .= $type . $v . (isset($op[$k]) ? ($escape ? $this->escape($op[$k]) : $op[$k]) : '');
479
-          }
480
-        }
481
-        return $w;
482
-    }
483
-
484
-    /**
485
-     * Get the default SQL WHERE clause using operator = or the operator argument
486
-     * @see Database::where
487
-     *
488
-     * @return string
489
-     */
490
-    protected function getWhereStrForOperator($where, $op = null, $val = null, $type = '', $escape = true){
491
-       $w = '';
492
-       if (! in_array((string)$op, $this->operatorList)){
493
-          if(is_null($op)){
494
-            $op = '';
495
-          }
496
-          $w = $type . $where . ' = ' . ($escape ? $this->escape($op) : $op);
497
-        }
498
-        else{
499
-          if(is_null($val)){
500
-            $val = '';
501
-          }
502
-          $w = $type . $where . $op . ($escape ? $this->escape($val) : $val);
503
-        }
504
-        return $w;
505
-      }
506
-
507
-      /**
508
-       * Set the $this->where property 
509
-       * @param string $whereStr the WHERE clause string
510
-       * @param  string  $andOr the separator type used 'AND', 'OR', etc.
511
-       */
512
-      protected function setWhereStr($whereStr, $andOr = 'AND'){
513
-        if (empty($this->where)){
514
-          $this->where = $whereStr;
515
-        }
516
-        else{
517
-          if(substr($this->where, -1) == '('){
518
-            $this->where = $this->where . ' ' . $whereStr;
519
-          }
520
-          else{
521
-            $this->where = $this->where . ' '.$andOr.' ' . $whereStr;
522
-          }
523
-        }
524
-      }
191
+			$this->temporaryCacheTtl = $this->cacheTtl;
192
+	}
193
+
194
+	/**
195
+	 * This is used to connect to database
196
+	 * @return bool 
197
+	 */
198
+	public function connect(){
199
+	  $config = $this->getDatabaseConfiguration();
200
+	  if(! empty($config)){
201
+		try{
202
+			$this->pdo = new PDO($this->getDsnFromDriver(), $config['username'], $config['password']);
203
+			$this->pdo->exec("SET NAMES '" . $config['charset'] . "' COLLATE '" . $config['collation'] . "'");
204
+			$this->pdo->exec("SET CHARACTER SET '" . $config['charset'] . "'");
205
+			$this->pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_OBJ);
206
+			return true;
207
+		  }
208
+		  catch (PDOException $e){
209
+			$this->logger->fatal($e->getMessage());
210
+			show_error('Cannot connect to Database.');
211
+			return false;
212
+		  }
213
+	  }
214
+	  else{
215
+		show_error('Database configuration is not set.');
216
+		return false;
217
+	  }
218
+	}
219
+
220
+	/**
221
+	 * Set the SQL FROM statment
222
+	 * @param  string|array $table the table name or array of table list
223
+	 * @return object        the current Database instance
224
+	 */
225
+	public function from($table){
226
+	  if(is_array($table)){
227
+		$froms = '';
228
+		foreach($table as $key){
229
+		  $froms .= $this->prefix . $key . ', ';
230
+		}
231
+		$this->from = rtrim($froms, ', ');
232
+	  }
233
+	  else{
234
+		$this->from = $this->prefix . $table;
235
+	  }
236
+	  return $this;
237
+	}
238
+
239
+	/**
240
+	 * Set the SQL SELECT statment
241
+	 * @param  string|array $fields the field name or array of field list
242
+	 * @return object        the current Database instance
243
+	 */
244
+	public function select($fields){
245
+	  $select = (is_array($fields) ? implode(', ', $fields) : $fields);
246
+	  $this->select = ($this->select == '*' ? $select : $this->select . ', ' . $select);
247
+	  return $this;
248
+	}
249
+
250
+	/**
251
+	 * Set the SQL SELECT DISTINCT statment
252
+	 * @param  string $field the field name to distinct
253
+	 * @return object        the current Database instance
254
+	 */
255
+	public function distinct($field){
256
+	  $distinct = ' DISTINCT ' . $field;
257
+	  $this->select = ($this->select == '*' ? $distinct : $this->select . ', ' . $distinct);
258
+
259
+	  return $this;
260
+	}
261
+
262
+	/**
263
+	 * Set the SQL function MAX in SELECT statment
264
+	 * @param  string $field the field name
265
+	 * @param  string $name  if is not null represent the alias used for this field in the result
266
+	 * @return object        the current Database instance
267
+	 */
268
+	public function max($field, $name = null){
269
+	  $func = 'MAX(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
270
+	  $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
271
+	  return $this;
272
+	}
273
+
274
+	/**
275
+	 * Set the SQL function MIN in SELECT statment
276
+	 * @param  string $field the field name
277
+	 * @param  string $name  if is not null represent the alias used for this field in the result
278
+	 * @return object        the current Database instance
279
+	 */
280
+	public function min($field, $name = null){
281
+	  $func = 'MIN(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
282
+	  $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
283
+	  return $this;
284
+	}
285
+
286
+	/**
287
+	 * Set the SQL function SUM in SELECT statment
288
+	 * @param  string $field the field name
289
+	 * @param  string $name  if is not null represent the alias used for this field in the result
290
+	 * @return object        the current Database instance
291
+	 */
292
+	public function sum($field, $name = null){
293
+	  $func = 'SUM(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
294
+	  $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
295
+	  return $this;
296
+	}
297
+
298
+	/**
299
+	 * Set the SQL function COUNT in SELECT statment
300
+	 * @param  string $field the field name
301
+	 * @param  string $name  if is not null represent the alias used for this field in the result
302
+	 * @return object        the current Database instance
303
+	 */
304
+	public function count($field = '*', $name = null){
305
+	  $func = 'COUNT(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
306
+	  $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
307
+	  return $this;
308
+	}
309
+
310
+	/**
311
+	 * Set the SQL function AVG in SELECT statment
312
+	 * @param  string $field the field name
313
+	 * @param  string $name  if is not null represent the alias used for this field in the result
314
+	 * @return object        the current Database instance
315
+	 */
316
+	public function avg($field, $name = null){
317
+	  $func = 'AVG(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
318
+	  $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
319
+	  return $this;
320
+	}
321
+
322
+	/**
323
+	 * Set the SQL JOIN statment
324
+	 * @param  string $table  the join table name
325
+	 * @param  string $field1 the first field for join conditions	
326
+	 * @param  string $op     the join condition operator. If is null the default will be "="
327
+	 * @param  string $field2 the second field for join conditions
328
+	 * @param  string $type   the type of join (INNER, LEFT, RIGHT)
329
+	 * @return object        the current Database instance
330
+	 */
331
+	public function join($table, $field1 = null, $op = null, $field2 = null, $type = ''){
332
+	  $on = $field1;
333
+	  $table = $this->prefix . $table;
334
+	  if(! is_null($op)){
335
+		$on = (! in_array($op, $this->operatorList) ? $this->prefix . $field1 . ' = ' . $this->prefix . $op : $this->prefix . $field1 . ' ' . $op . ' ' . $this->prefix . $field2);
336
+	  }
337
+	  if (empty($this->join)){
338
+		$this->join = ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
339
+	  }
340
+	  else{
341
+		$this->join = $this->join . ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
342
+	  }
343
+	  return $this;
344
+	}
345
+
346
+	/**
347
+	 * Set the SQL INNER JOIN statment
348
+	 * @see  Database::join()
349
+	 * @return object        the current Database instance
350
+	 */
351
+	public function innerJoin($table, $field1, $op = null, $field2 = ''){
352
+	  return $this->join($table, $field1, $op, $field2, 'INNER ');
353
+	}
354
+
355
+	/**
356
+	 * Set the SQL LEFT JOIN statment
357
+	 * @see  Database::join()
358
+	 * @return object        the current Database instance
359
+	 */
360
+	public function leftJoin($table, $field1, $op = null, $field2 = ''){
361
+	  return $this->join($table, $field1, $op, $field2, 'LEFT ');
362
+	}
363
+
364
+	/**
365
+	 * Set the SQL RIGHT JOIN statment
366
+	 * @see  Database::join()
367
+	 * @return object        the current Database instance
368
+	 */
369
+	public function rightJoin($table, $field1, $op = null, $field2 = ''){
370
+	  return $this->join($table, $field1, $op, $field2, 'RIGHT ');
371
+	}
372
+
373
+	/**
374
+	 * Set the SQL FULL OUTER JOIN statment
375
+	 * @see  Database::join()
376
+	 * @return object        the current Database instance
377
+	 */
378
+	public function fullOuterJoin($table, $field1, $op = null, $field2 = ''){
379
+		return $this->join($table, $field1, $op, $field2, 'FULL OUTER ');
380
+	}
381
+
382
+	/**
383
+	 * Set the SQL LEFT OUTER JOIN statment
384
+	 * @see  Database::join()
385
+	 * @return object        the current Database instance
386
+	 */
387
+	public function leftOuterJoin($table, $field1, $op = null, $field2 = ''){
388
+	  return $this->join($table, $field1, $op, $field2, 'LEFT OUTER ');
389
+	}
390
+
391
+	/**
392
+	 * Set the SQL RIGHT OUTER JOIN statment
393
+	 * @see  Database::join()
394
+	 * @return object        the current Database instance
395
+	 */
396
+	public function rightOuterJoin($table, $field1, $op = null, $field2 = ''){
397
+	  return $this->join($table, $field1, $op, $field2, 'RIGHT OUTER ');
398
+	}
399
+
400
+	/**
401
+	 * Set the SQL WHERE CLAUSE for IS NULL
402
+	 * @param  string|array $field  the field name or array of field list
403
+	 * @param  string $andOr the separator type used 'AND', 'OR', etc.
404
+	 * @return object        the current Database instance
405
+	 */
406
+	public function whereIsNull($field, $andOr = 'AND'){
407
+	  if(is_array($field)){
408
+		foreach($field as $f){
409
+			$this->whereIsNull($f, $andOr);
410
+		}
411
+	  }
412
+	  else{
413
+		if (! $this->where){
414
+		  $this->where = $field.' IS NULL ';
415
+		}
416
+		else{
417
+			$this->where = $this->where . ' '.$andOr.' ' . $field.' IS NULL ';
418
+		  }
419
+	  }
420
+	  return $this;
421
+	}
422
+
423
+	/**
424
+	 * Set the SQL WHERE CLAUSE for IS NOT NULL
425
+	 * @param  string|array $field  the field name or array of field list
426
+	 * @param  string $andOr the separator type used 'AND', 'OR', etc.
427
+	 * @return object        the current Database instance
428
+	 */
429
+	public function whereIsNotNull($field, $andOr = 'AND'){
430
+	  if(is_array($field)){
431
+		foreach($field as $f){
432
+		  $this->whereIsNotNull($f, $andOr);
433
+		}
434
+	  }
435
+	  else{
436
+		if (! $this->where){
437
+		  $this->where = $field.' IS NOT NULL ';
438
+		}
439
+		else{
440
+			$this->where = $this->where . ' '.$andOr.' ' . $field.' IS NOT NULL ';
441
+		  }
442
+	  }
443
+	  return $this;
444
+	}
445
+
446
+	/**
447
+	 * Get the SQL WHERE clause using array column => value
448
+	 * @see Database::where
449
+	 *
450
+	 * @return string
451
+	 */
452
+	protected function getWhereStrIfIsArray(array $where, $type = '', $andOr = 'AND', $escape = true){
453
+		$_where = array();
454
+		foreach ($where as $column => $data){
455
+		  if(is_null($data)){
456
+			$data = '';
457
+		  }
458
+		  $_where[] = $type . $column . ' = ' . ($escape ? $this->escape($data) : $data);
459
+		}
460
+		$where = implode(' '.$andOr.' ', $_where);
461
+		return $where;
462
+	}
463
+
464
+	 /**
465
+	  * Get the SQL WHERE clause when operator argument is an array
466
+	  * @see Database::where
467
+	  *
468
+	  * @return string
469
+	  */
470
+	protected function getWhereStrIfOperatorIsArray($where, array $op, $type = '', $escape = true){
471
+	   $x = explode('?', $where);
472
+	   $w = '';
473
+		foreach($x as $k => $v){
474
+		  if(! empty($v)){
475
+			  if(isset($op[$k]) && is_null($op[$k])){
476
+				$op[$k] = '';
477
+			  }
478
+			  $w .= $type . $v . (isset($op[$k]) ? ($escape ? $this->escape($op[$k]) : $op[$k]) : '');
479
+		  }
480
+		}
481
+		return $w;
482
+	}
483
+
484
+	/**
485
+	 * Get the default SQL WHERE clause using operator = or the operator argument
486
+	 * @see Database::where
487
+	 *
488
+	 * @return string
489
+	 */
490
+	protected function getWhereStrForOperator($where, $op = null, $val = null, $type = '', $escape = true){
491
+	   $w = '';
492
+	   if (! in_array((string)$op, $this->operatorList)){
493
+		  if(is_null($op)){
494
+			$op = '';
495
+		  }
496
+		  $w = $type . $where . ' = ' . ($escape ? $this->escape($op) : $op);
497
+		}
498
+		else{
499
+		  if(is_null($val)){
500
+			$val = '';
501
+		  }
502
+		  $w = $type . $where . $op . ($escape ? $this->escape($val) : $val);
503
+		}
504
+		return $w;
505
+	  }
506
+
507
+	  /**
508
+	   * Set the $this->where property 
509
+	   * @param string $whereStr the WHERE clause string
510
+	   * @param  string  $andOr the separator type used 'AND', 'OR', etc.
511
+	   */
512
+	  protected function setWhereStr($whereStr, $andOr = 'AND'){
513
+		if (empty($this->where)){
514
+		  $this->where = $whereStr;
515
+		}
516
+		else{
517
+		  if(substr($this->where, -1) == '('){
518
+			$this->where = $this->where . ' ' . $whereStr;
519
+		  }
520
+		  else{
521
+			$this->where = $this->where . ' '.$andOr.' ' . $whereStr;
522
+		  }
523
+		}
524
+	  }
525 525
     
526
-    /**
527
-     * Set the SQL WHERE CLAUSE statment
528
-     * @param  string|array  $where the where field or array of field list
529
-     * @param  array|string  $op     the condition operator. If is null the default will be "="
530
-     * @param  mixed  $val    the where value
531
-     * @param  string  $type   the type used for this where clause (NOT, etc.)
532
-     * @param  string  $andOr the separator type used 'AND', 'OR', etc.
533
-     * @param  boolean $escape whether to escape or not the $val
534
-     * @return object        the current Database instance
535
-     */
536
-    public function where($where, $op = null, $val = null, $type = '', $andOr = 'AND', $escape = true){
537
-      $whereStr = '';
538
-      if (is_array($where)){
539
-        $whereStr = $this->getWhereStrIfIsArray($where, $type, $andOr, $escape);
540
-      }
541
-      else{
542
-        if(is_array($op)){
543
-          $whereStr = $this->getWhereStrIfOperatorIsArray($where, $op, $type, $escape);
544
-        } else {
545
-          $whereStr = $this->getWhereStrForOperator($where, $op, $val, $type, $escape = true);
546
-        }
547
-      }
548
-      $this->setWhereStr($whereStr, $andOr);
549
-      return $this;
550
-    }
551
-
552
-    /**
553
-     * Set the SQL WHERE CLAUSE statment using OR
554
-     * @see  Database::where()
555
-     * @return object        the current Database instance
556
-     */
557
-    public function orWhere($where, $op = null, $val = null, $escape = true){
558
-      return $this->where($where, $op, $val, '', 'OR', $escape);
559
-    }
560
-
561
-
562
-    /**
563
-     * Set the SQL WHERE CLAUSE statment using AND and NOT
564
-     * @see  Database::where()
565
-     * @return object        the current Database instance
566
-     */
567
-    public function notWhere($where, $op = null, $val = null, $escape = true){
568
-      return $this->where($where, $op, $val, 'NOT ', 'AND', $escape);
569
-    }
570
-
571
-    /**
572
-     * Set the SQL WHERE CLAUSE statment using OR and NOT
573
-     * @see  Database::where()
574
-     * @return object        the current Database instance
575
-     */
576
-    public function orNotWhere($where, $op = null, $val = null, $escape = true){
577
-    	return $this->where($where, $op, $val, 'NOT ', 'OR', $escape);
578
-    }
579
-
580
-    /**
581
-     * Set the opened parenthesis for the complex SQL query
582
-     * @param  string $type   the type of this grouped (NOT, etc.)
583
-     * @param  string $andOr the multiple conditions separator (AND, OR, etc.)
584
-     * @return object        the current Database instance
585
-     */
586
-    public function groupStart($type = '', $andOr = ' AND'){
587
-      if (empty($this->where)){
588
-        $this->where = $type . ' (';
589
-      }
590
-      else{
591
-          if(substr($this->where, -1) == '('){
592
-            $this->where .= $type . ' (';
593
-          }
594
-          else{
595
-          	$this->where .= $andOr . ' ' . $type . ' (';
596
-          }
597
-      }
598
-      return $this;
599
-    }
600
-
601
-    /**
602
-     * Set the opened parenthesis for the complex SQL query using NOT type
603
-     * @see  Database::groupStart()
604
-     * @return object        the current Database instance
605
-     */
606
-    public function notGroupStart(){
607
-      return $this->groupStart('NOT');
608
-    }
609
-
610
-    /**
611
-     * Set the opened parenthesis for the complex SQL query using OR for separator
612
-     * @see  Database::groupStart()
613
-     * @return object        the current Database instance
614
-     */
615
-    public function orGroupStart(){
616
-      return $this->groupStart('', ' OR');
617
-    }
618
-
619
-     /**
620
-     * Set the opened parenthesis for the complex SQL query using OR for separator and NOT for type
621
-     * @see  Database::groupStart()
622
-     * @return object        the current Database instance
623
-     */
624
-    public function orNotGroupStart(){
625
-      return $this->groupStart('NOT', ' OR');
626
-    }
627
-
628
-    /**
629
-     * Close the parenthesis for the grouped SQL
630
-     * @return object        the current Database instance
631
-     */
632
-    public function groupEnd(){
633
-      $this->where .= ')';
634
-      return $this;
635
-    }
636
-
637
-    /**
638
-     * Set the SQL WHERE CLAUSE statment for IN
639
-     * @param  string  $field  the field name for IN statment
640
-     * @param  array   $keys   the list of values used
641
-     * @param  string  $type   the condition separator type (NOT)
642
-     * @param  string  $andOr the multiple conditions separator (OR, AND)
643
-     * @param  boolean $escape whether to escape or not the values
644
-     * @return object        the current Database instance
645
-     */
646
-    public function in($field, array $keys, $type = '', $andOr = 'AND', $escape = true){
647
-      $_keys = array();
648
-      foreach ($keys as $k => $v){
649
-        if(is_null($v)){
650
-          $v = '';
651
-        }
652
-        $_keys[] = (is_numeric($v) ? $v : ($escape ? $this->escape($v) : $v));
653
-      }
654
-      $keys = implode(', ', $_keys);
655
-      $whereStr = $field . ' ' . $type . ' IN (' . $keys . ')';
656
-      $this->setWhereStr($whereStr, $andOr);
657
-      return $this;
658
-    }
659
-
660
-    /**
661
-     * Set the SQL WHERE CLAUSE statment for NOT IN with AND separator
662
-     * @see  Database::in()
663
-     * @return object        the current Database instance
664
-     */
665
-    public function notIn($field, array $keys, $escape = true){
666
-      return $this->in($field, $keys, 'NOT ', 'AND', $escape);
667
-    }
668
-
669
-    /**
670
-     * Set the SQL WHERE CLAUSE statment for IN with OR separator
671
-     * @see  Database::in()
672
-     * @return object        the current Database instance
673
-     */
674
-    public function orIn($field, array $keys, $escape = true){
675
-      return $this->in($field, $keys, '', 'OR', $escape);
676
-    }
677
-
678
-    /**
679
-     * Set the SQL WHERE CLAUSE statment for NOT IN with OR separator
680
-     * @see  Database::in()
681
-     * @return object        the current Database instance
682
-     */
683
-    public function orNotIn($field, array $keys, $escape = true){
684
-      return $this->in($field, $keys, 'NOT ', 'OR', $escape);
685
-    }
686
-
687
-    /**
688
-     * Set the SQL WHERE CLAUSE statment for BETWEEN
689
-     * @param  string  $field  the field used for the BETWEEN statment
690
-     * @param  mixed  $value1 the BETWEEN begin value
691
-     * @param  mixed  $value2 the BETWEEN end value
692
-     * @param  string  $type   the condition separator type (NOT)
693
-     * @param  string  $andOr the multiple conditions separator (OR, AND)
694
-     * @param  boolean $escape whether to escape or not the values
695
-     * @return object        the current Database instance
696
-     */
697
-    public function between($field, $value1, $value2, $type = '', $andOr = 'AND', $escape = true){
698
-      if(is_null($value1)){
699
-        $value1 = '';
700
-      }
701
-      if(is_null($value2)){
702
-        $value2 = '';
703
-      }
704
-      $whereStr = $field . ' ' . $type . ' BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
705
-      $this->setWhereStr($whereStr, $andOr);
706
-      return $this;
707
-    }
708
-
709
-    /**
710
-     * Set the SQL WHERE CLAUSE statment for BETWEEN with NOT type and AND separator
711
-     * @see  Database::between()
712
-     * @return object        the current Database instance
713
-     */
714
-    public function notBetween($field, $value1, $value2, $escape = true){
715
-      return $this->between($field, $value1, $value2, 'NOT ', 'AND', $escape);
716
-    }
717
-
718
-    /**
719
-     * Set the SQL WHERE CLAUSE statment for BETWEEN with OR separator
720
-     * @see  Database::between()
721
-     * @return object        the current Database instance
722
-     */
723
-    public function orBetween($field, $value1, $value2, $escape = true){
724
-      return $this->between($field, $value1, $value2, '', 'OR', $escape);
725
-    }
726
-
727
-    /**
728
-     * Set the SQL WHERE CLAUSE statment for BETWEEN with NOT type and OR separator
729
-     * @see  Database::between()
730
-     * @return object        the current Database instance
731
-     */
732
-    public function orNotBetween($field, $value1, $value2, $escape = true){
733
-      return $this->between($field, $value1, $value2, 'NOT ', 'OR', $escape);
734
-    }
735
-
736
-    /**
737
-     * Set the SQL WHERE CLAUSE statment for LIKE
738
-     * @param  string  $field  the field name used in LIKE statment
739
-     * @param  string  $data   the LIKE value for this field including the '%', and '_' part
740
-     * @param  string  $type   the condition separator type (NOT)
741
-     * @param  string  $andOr the multiple conditions separator (OR, AND)
742
-     * @param  boolean $escape whether to escape or not the values
743
-     * @return object        the current Database instance
744
-     */
745
-    public function like($field, $data, $type = '', $andOr = 'AND', $escape = true){
746
-      if(empty($data)){
747
-        $data = '';
748
-      }
749
-      $like = $escape ? $this->escape($data) : $data;
750
-      if (empty($this->where)){
751
-        $this->where = $field . ' ' . $type . 'LIKE ' . $like;
752
-      }
753
-      else{
754
-        if(substr($this->where, -1) == '('){
755
-          $this->where = $this->where . ' ' . $field . ' ' . $type . 'LIKE ' . $like;
756
-        }
757
-        else{
758
-          $this->where = $this->where . ' '.$andOr.' ' . $field . ' ' . $type . 'LIKE ' . $like;
759
-        }
760
-      }
761
-      return $this;
762
-    }
763
-
764
-    /**
765
-     * Set the SQL WHERE CLAUSE statment for LIKE with OR separator
766
-     * @see  Database::like()
767
-     * @return object        the current Database instance
768
-     */
769
-    public function orLike($field, $data, $escape = true){
770
-      return $this->like($field, $data, '', 'OR', $escape);
771
-    }
772
-
773
-    /**
774
-     * Set the SQL WHERE CLAUSE statment for LIKE with NOT type and AND separator
775
-     * @see  Database::like()
776
-     * @return object        the current Database instance
777
-     */
778
-    public function notLike($field, $data, $escape = true){
779
-      return $this->like($field, $data, 'NOT ', 'AND', $escape);
780
-    }
781
-
782
-    /**
783
-     * Set the SQL WHERE CLAUSE statment for LIKE with NOT type and OR separator
784
-     * @see  Database::like()
785
-     * @return object        the current Database instance
786
-     */
787
-    public function orNotLike($field, $data, $escape = true){
788
-      return $this->like($field, $data, 'NOT ', 'OR', $escape);
789
-    }
790
-
791
-    /**
792
-     * Set the SQL LIMIT statment
793
-     * @param  int $limit    the limit offset. If $limitEnd is null this will be the limit count
794
-     * like LIMIT n;
795
-     * @param  int $limitEnd the limit count
796
-     * @return object        the current Database instance
797
-     */
798
-    public function limit($limit, $limitEnd = null){
799
-      if(empty($limit)){
800
-        return;
801
-      }
802
-      if (! is_null($limitEnd)){
803
-        $this->limit = $limit . ', ' . $limitEnd;
804
-      }
805
-      else{
806
-        $this->limit = $limit;
807
-      }
808
-      return $this;
809
-    }
810
-
811
-    /**
812
-     * Set the SQL ORDER BY CLAUSE statment
813
-     * @param  string $orderBy   the field name used for order
814
-     * @param  string $orderDir the order direction (ASC or DESC)
815
-     * @return object        the current Database instance
816
-     */
817
-    public function orderBy($orderBy, $orderDir = ' ASC'){
818
-      if (! empty($orderDir)){
819
-        $this->orderBy = ! $this->orderBy ? ($orderBy . ' ' . strtoupper($orderDir)) : $this->orderBy . ', ' . $orderBy . ' ' . strtoupper($orderDir);
820
-      }
821
-      else{
822
-        if(stristr($orderBy, ' ') || $orderBy == 'rand()'){
823
-          $this->orderBy = ! $this->orderBy ? $orderBy : $this->orderBy . ', ' . $orderBy;
824
-        }
825
-        else{
826
-          $this->orderBy = ! $this->orderBy ? ($orderBy . ' ASC') : $this->orderBy . ', ' . ($orderBy . ' ASC');
827
-        }
828
-      }
829
-      return $this;
830
-    }
831
-
832
-    /**
833
-     * Set the SQL GROUP BY CLAUSE statment
834
-     * @param  string|array $field the field name used or array of field list
835
-     * @return object        the current Database instance
836
-     */
837
-    public function groupBy($field){
838
-      if(is_array($field)){
839
-        $this->groupBy = implode(', ', $field);
840
-      }
841
-      else{
842
-        $this->groupBy = $field;
843
-      }
844
-      return $this;
845
-    }
846
-
847
-    /**
848
-     * Set the SQL HAVING CLAUSE statment
849
-     * @param  string  $field  the field name used for HAVING statment
850
-     * @param  string|array  $op     the operator used or array
851
-     * @param  mixed  $val    the value for HAVING comparaison
852
-     * @param  boolean $escape whether to escape or not the values
853
-     * @return object        the current Database instance
854
-     */
855
-    public function having($field, $op = null, $val = null, $escape = true){
856
-      if(is_array($op)){
857
-        $x = explode('?', $field);
858
-        $w = '';
859
-        foreach($x as $k => $v){
860
-  	      if(!empty($v)){
861
-            if(isset($op[$k]) && is_null($op[$k])){
862
-              $op[$k] = '';
863
-            }
864
-  	      	$w .= $v . (isset($op[$k]) ? ($escape ? $this->escape($op[$k]) : $op[$k]) : '');
865
-  	      }
866
-      	}
867
-        $this->having = $w;
868
-      }
869
-      else if (! in_array($op, $this->operatorList)){
870
-        if(is_null($op)){
871
-          $op = '';
872
-        }
873
-        $this->having = $field . ' > ' . ($escape ? $this->escape($op) : $op);
874
-      }
875
-      else{
876
-        if(is_null($val)){
877
-          $val = '';
878
-        }
879
-        $this->having = $field . ' ' . $op . ' ' . ($escape ? $this->escape($val) : $val);
880
-      }
881
-      return $this;
882
-    }
883
-
884
-    /**
885
-     * Return the number of rows returned by the current query
886
-     * @return int
887
-     */
888
-    public function numRows(){
889
-      return $this->numRows;
890
-    }
891
-
892
-    /**
893
-     * Return the last insert id value
894
-     * @return mixed
895
-     */
896
-    public function insertId(){
897
-      return $this->insertId;
898
-    }
899
-
900
-    /**
901
-     * Show an error got from the current query (SQL command synthax error, database driver returned error, etc.)
902
-     */
903
-    public function error(){
526
+	/**
527
+	 * Set the SQL WHERE CLAUSE statment
528
+	 * @param  string|array  $where the where field or array of field list
529
+	 * @param  array|string  $op     the condition operator. If is null the default will be "="
530
+	 * @param  mixed  $val    the where value
531
+	 * @param  string  $type   the type used for this where clause (NOT, etc.)
532
+	 * @param  string  $andOr the separator type used 'AND', 'OR', etc.
533
+	 * @param  boolean $escape whether to escape or not the $val
534
+	 * @return object        the current Database instance
535
+	 */
536
+	public function where($where, $op = null, $val = null, $type = '', $andOr = 'AND', $escape = true){
537
+	  $whereStr = '';
538
+	  if (is_array($where)){
539
+		$whereStr = $this->getWhereStrIfIsArray($where, $type, $andOr, $escape);
540
+	  }
541
+	  else{
542
+		if(is_array($op)){
543
+		  $whereStr = $this->getWhereStrIfOperatorIsArray($where, $op, $type, $escape);
544
+		} else {
545
+		  $whereStr = $this->getWhereStrForOperator($where, $op, $val, $type, $escape = true);
546
+		}
547
+	  }
548
+	  $this->setWhereStr($whereStr, $andOr);
549
+	  return $this;
550
+	}
551
+
552
+	/**
553
+	 * Set the SQL WHERE CLAUSE statment using OR
554
+	 * @see  Database::where()
555
+	 * @return object        the current Database instance
556
+	 */
557
+	public function orWhere($where, $op = null, $val = null, $escape = true){
558
+	  return $this->where($where, $op, $val, '', 'OR', $escape);
559
+	}
560
+
561
+
562
+	/**
563
+	 * Set the SQL WHERE CLAUSE statment using AND and NOT
564
+	 * @see  Database::where()
565
+	 * @return object        the current Database instance
566
+	 */
567
+	public function notWhere($where, $op = null, $val = null, $escape = true){
568
+	  return $this->where($where, $op, $val, 'NOT ', 'AND', $escape);
569
+	}
570
+
571
+	/**
572
+	 * Set the SQL WHERE CLAUSE statment using OR and NOT
573
+	 * @see  Database::where()
574
+	 * @return object        the current Database instance
575
+	 */
576
+	public function orNotWhere($where, $op = null, $val = null, $escape = true){
577
+		return $this->where($where, $op, $val, 'NOT ', 'OR', $escape);
578
+	}
579
+
580
+	/**
581
+	 * Set the opened parenthesis for the complex SQL query
582
+	 * @param  string $type   the type of this grouped (NOT, etc.)
583
+	 * @param  string $andOr the multiple conditions separator (AND, OR, etc.)
584
+	 * @return object        the current Database instance
585
+	 */
586
+	public function groupStart($type = '', $andOr = ' AND'){
587
+	  if (empty($this->where)){
588
+		$this->where = $type . ' (';
589
+	  }
590
+	  else{
591
+		  if(substr($this->where, -1) == '('){
592
+			$this->where .= $type . ' (';
593
+		  }
594
+		  else{
595
+		  	$this->where .= $andOr . ' ' . $type . ' (';
596
+		  }
597
+	  }
598
+	  return $this;
599
+	}
600
+
601
+	/**
602
+	 * Set the opened parenthesis for the complex SQL query using NOT type
603
+	 * @see  Database::groupStart()
604
+	 * @return object        the current Database instance
605
+	 */
606
+	public function notGroupStart(){
607
+	  return $this->groupStart('NOT');
608
+	}
609
+
610
+	/**
611
+	 * Set the opened parenthesis for the complex SQL query using OR for separator
612
+	 * @see  Database::groupStart()
613
+	 * @return object        the current Database instance
614
+	 */
615
+	public function orGroupStart(){
616
+	  return $this->groupStart('', ' OR');
617
+	}
618
+
619
+	 /**
620
+	  * Set the opened parenthesis for the complex SQL query using OR for separator and NOT for type
621
+	  * @see  Database::groupStart()
622
+	  * @return object        the current Database instance
623
+	  */
624
+	public function orNotGroupStart(){
625
+	  return $this->groupStart('NOT', ' OR');
626
+	}
627
+
628
+	/**
629
+	 * Close the parenthesis for the grouped SQL
630
+	 * @return object        the current Database instance
631
+	 */
632
+	public function groupEnd(){
633
+	  $this->where .= ')';
634
+	  return $this;
635
+	}
636
+
637
+	/**
638
+	 * Set the SQL WHERE CLAUSE statment for IN
639
+	 * @param  string  $field  the field name for IN statment
640
+	 * @param  array   $keys   the list of values used
641
+	 * @param  string  $type   the condition separator type (NOT)
642
+	 * @param  string  $andOr the multiple conditions separator (OR, AND)
643
+	 * @param  boolean $escape whether to escape or not the values
644
+	 * @return object        the current Database instance
645
+	 */
646
+	public function in($field, array $keys, $type = '', $andOr = 'AND', $escape = true){
647
+	  $_keys = array();
648
+	  foreach ($keys as $k => $v){
649
+		if(is_null($v)){
650
+		  $v = '';
651
+		}
652
+		$_keys[] = (is_numeric($v) ? $v : ($escape ? $this->escape($v) : $v));
653
+	  }
654
+	  $keys = implode(', ', $_keys);
655
+	  $whereStr = $field . ' ' . $type . ' IN (' . $keys . ')';
656
+	  $this->setWhereStr($whereStr, $andOr);
657
+	  return $this;
658
+	}
659
+
660
+	/**
661
+	 * Set the SQL WHERE CLAUSE statment for NOT IN with AND separator
662
+	 * @see  Database::in()
663
+	 * @return object        the current Database instance
664
+	 */
665
+	public function notIn($field, array $keys, $escape = true){
666
+	  return $this->in($field, $keys, 'NOT ', 'AND', $escape);
667
+	}
668
+
669
+	/**
670
+	 * Set the SQL WHERE CLAUSE statment for IN with OR separator
671
+	 * @see  Database::in()
672
+	 * @return object        the current Database instance
673
+	 */
674
+	public function orIn($field, array $keys, $escape = true){
675
+	  return $this->in($field, $keys, '', 'OR', $escape);
676
+	}
677
+
678
+	/**
679
+	 * Set the SQL WHERE CLAUSE statment for NOT IN with OR separator
680
+	 * @see  Database::in()
681
+	 * @return object        the current Database instance
682
+	 */
683
+	public function orNotIn($field, array $keys, $escape = true){
684
+	  return $this->in($field, $keys, 'NOT ', 'OR', $escape);
685
+	}
686
+
687
+	/**
688
+	 * Set the SQL WHERE CLAUSE statment for BETWEEN
689
+	 * @param  string  $field  the field used for the BETWEEN statment
690
+	 * @param  mixed  $value1 the BETWEEN begin value
691
+	 * @param  mixed  $value2 the BETWEEN end value
692
+	 * @param  string  $type   the condition separator type (NOT)
693
+	 * @param  string  $andOr the multiple conditions separator (OR, AND)
694
+	 * @param  boolean $escape whether to escape or not the values
695
+	 * @return object        the current Database instance
696
+	 */
697
+	public function between($field, $value1, $value2, $type = '', $andOr = 'AND', $escape = true){
698
+	  if(is_null($value1)){
699
+		$value1 = '';
700
+	  }
701
+	  if(is_null($value2)){
702
+		$value2 = '';
703
+	  }
704
+	  $whereStr = $field . ' ' . $type . ' BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
705
+	  $this->setWhereStr($whereStr, $andOr);
706
+	  return $this;
707
+	}
708
+
709
+	/**
710
+	 * Set the SQL WHERE CLAUSE statment for BETWEEN with NOT type and AND separator
711
+	 * @see  Database::between()
712
+	 * @return object        the current Database instance
713
+	 */
714
+	public function notBetween($field, $value1, $value2, $escape = true){
715
+	  return $this->between($field, $value1, $value2, 'NOT ', 'AND', $escape);
716
+	}
717
+
718
+	/**
719
+	 * Set the SQL WHERE CLAUSE statment for BETWEEN with OR separator
720
+	 * @see  Database::between()
721
+	 * @return object        the current Database instance
722
+	 */
723
+	public function orBetween($field, $value1, $value2, $escape = true){
724
+	  return $this->between($field, $value1, $value2, '', 'OR', $escape);
725
+	}
726
+
727
+	/**
728
+	 * Set the SQL WHERE CLAUSE statment for BETWEEN with NOT type and OR separator
729
+	 * @see  Database::between()
730
+	 * @return object        the current Database instance
731
+	 */
732
+	public function orNotBetween($field, $value1, $value2, $escape = true){
733
+	  return $this->between($field, $value1, $value2, 'NOT ', 'OR', $escape);
734
+	}
735
+
736
+	/**
737
+	 * Set the SQL WHERE CLAUSE statment for LIKE
738
+	 * @param  string  $field  the field name used in LIKE statment
739
+	 * @param  string  $data   the LIKE value for this field including the '%', and '_' part
740
+	 * @param  string  $type   the condition separator type (NOT)
741
+	 * @param  string  $andOr the multiple conditions separator (OR, AND)
742
+	 * @param  boolean $escape whether to escape or not the values
743
+	 * @return object        the current Database instance
744
+	 */
745
+	public function like($field, $data, $type = '', $andOr = 'AND', $escape = true){
746
+	  if(empty($data)){
747
+		$data = '';
748
+	  }
749
+	  $like = $escape ? $this->escape($data) : $data;
750
+	  if (empty($this->where)){
751
+		$this->where = $field . ' ' . $type . 'LIKE ' . $like;
752
+	  }
753
+	  else{
754
+		if(substr($this->where, -1) == '('){
755
+		  $this->where = $this->where . ' ' . $field . ' ' . $type . 'LIKE ' . $like;
756
+		}
757
+		else{
758
+		  $this->where = $this->where . ' '.$andOr.' ' . $field . ' ' . $type . 'LIKE ' . $like;
759
+		}
760
+	  }
761
+	  return $this;
762
+	}
763
+
764
+	/**
765
+	 * Set the SQL WHERE CLAUSE statment for LIKE with OR separator
766
+	 * @see  Database::like()
767
+	 * @return object        the current Database instance
768
+	 */
769
+	public function orLike($field, $data, $escape = true){
770
+	  return $this->like($field, $data, '', 'OR', $escape);
771
+	}
772
+
773
+	/**
774
+	 * Set the SQL WHERE CLAUSE statment for LIKE with NOT type and AND separator
775
+	 * @see  Database::like()
776
+	 * @return object        the current Database instance
777
+	 */
778
+	public function notLike($field, $data, $escape = true){
779
+	  return $this->like($field, $data, 'NOT ', 'AND', $escape);
780
+	}
781
+
782
+	/**
783
+	 * Set the SQL WHERE CLAUSE statment for LIKE with NOT type and OR separator
784
+	 * @see  Database::like()
785
+	 * @return object        the current Database instance
786
+	 */
787
+	public function orNotLike($field, $data, $escape = true){
788
+	  return $this->like($field, $data, 'NOT ', 'OR', $escape);
789
+	}
790
+
791
+	/**
792
+	 * Set the SQL LIMIT statment
793
+	 * @param  int $limit    the limit offset. If $limitEnd is null this will be the limit count
794
+	 * like LIMIT n;
795
+	 * @param  int $limitEnd the limit count
796
+	 * @return object        the current Database instance
797
+	 */
798
+	public function limit($limit, $limitEnd = null){
799
+	  if(empty($limit)){
800
+		return;
801
+	  }
802
+	  if (! is_null($limitEnd)){
803
+		$this->limit = $limit . ', ' . $limitEnd;
804
+	  }
805
+	  else{
806
+		$this->limit = $limit;
807
+	  }
808
+	  return $this;
809
+	}
810
+
811
+	/**
812
+	 * Set the SQL ORDER BY CLAUSE statment
813
+	 * @param  string $orderBy   the field name used for order
814
+	 * @param  string $orderDir the order direction (ASC or DESC)
815
+	 * @return object        the current Database instance
816
+	 */
817
+	public function orderBy($orderBy, $orderDir = ' ASC'){
818
+	  if (! empty($orderDir)){
819
+		$this->orderBy = ! $this->orderBy ? ($orderBy . ' ' . strtoupper($orderDir)) : $this->orderBy . ', ' . $orderBy . ' ' . strtoupper($orderDir);
820
+	  }
821
+	  else{
822
+		if(stristr($orderBy, ' ') || $orderBy == 'rand()'){
823
+		  $this->orderBy = ! $this->orderBy ? $orderBy : $this->orderBy . ', ' . $orderBy;
824
+		}
825
+		else{
826
+		  $this->orderBy = ! $this->orderBy ? ($orderBy . ' ASC') : $this->orderBy . ', ' . ($orderBy . ' ASC');
827
+		}
828
+	  }
829
+	  return $this;
830
+	}
831
+
832
+	/**
833
+	 * Set the SQL GROUP BY CLAUSE statment
834
+	 * @param  string|array $field the field name used or array of field list
835
+	 * @return object        the current Database instance
836
+	 */
837
+	public function groupBy($field){
838
+	  if(is_array($field)){
839
+		$this->groupBy = implode(', ', $field);
840
+	  }
841
+	  else{
842
+		$this->groupBy = $field;
843
+	  }
844
+	  return $this;
845
+	}
846
+
847
+	/**
848
+	 * Set the SQL HAVING CLAUSE statment
849
+	 * @param  string  $field  the field name used for HAVING statment
850
+	 * @param  string|array  $op     the operator used or array
851
+	 * @param  mixed  $val    the value for HAVING comparaison
852
+	 * @param  boolean $escape whether to escape or not the values
853
+	 * @return object        the current Database instance
854
+	 */
855
+	public function having($field, $op = null, $val = null, $escape = true){
856
+	  if(is_array($op)){
857
+		$x = explode('?', $field);
858
+		$w = '';
859
+		foreach($x as $k => $v){
860
+  		  if(!empty($v)){
861
+			if(isset($op[$k]) && is_null($op[$k])){
862
+			  $op[$k] = '';
863
+			}
864
+  		  	$w .= $v . (isset($op[$k]) ? ($escape ? $this->escape($op[$k]) : $op[$k]) : '');
865
+  		  }
866
+	  	}
867
+		$this->having = $w;
868
+	  }
869
+	  else if (! in_array($op, $this->operatorList)){
870
+		if(is_null($op)){
871
+		  $op = '';
872
+		}
873
+		$this->having = $field . ' > ' . ($escape ? $this->escape($op) : $op);
874
+	  }
875
+	  else{
876
+		if(is_null($val)){
877
+		  $val = '';
878
+		}
879
+		$this->having = $field . ' ' . $op . ' ' . ($escape ? $this->escape($val) : $val);
880
+	  }
881
+	  return $this;
882
+	}
883
+
884
+	/**
885
+	 * Return the number of rows returned by the current query
886
+	 * @return int
887
+	 */
888
+	public function numRows(){
889
+	  return $this->numRows;
890
+	}
891
+
892
+	/**
893
+	 * Return the last insert id value
894
+	 * @return mixed
895
+	 */
896
+	public function insertId(){
897
+	  return $this->insertId;
898
+	}
899
+
900
+	/**
901
+	 * Show an error got from the current query (SQL command synthax error, database driver returned error, etc.)
902
+	 */
903
+	public function error(){
904 904
   		if($this->error){
905 905
   			show_error('Query: "' . $this->query . '" Error: ' . $this->error, 'Database Error');
906 906
   		}
907
-    }
908
-
909
-    /**
910
-     * Get the result of one record rows returned by the current query
911
-     * @param  boolean $returnSQLQueryOrResultType if is boolean and true will return the SQL query string.
912
-     * If is string will determine the result type "array" or "object"
913
-     * @return mixed       the query SQL string or the record result
914
-     */
915
-    public function get($returnSQLQueryOrResultType = false){
916
-      $this->limit = 1;
917
-      $query = $this->getAll(true);
918
-      if($returnSQLQueryOrResultType === true){
919
-        return $query;
920
-      }
921
-      else{
922
-        return $this->query( $query, false, (($returnSQLQueryOrResultType == 'array') ? true : false) );
923
-      }
924
-    }
925
-
926
-    /**
927
-     * Get the result of record rows list returned by the current query
928
-     * @param  boolean $returnSQLQueryOrResultType if is boolean and true will return the SQL query string.
929
-     * If is string will determine the result type "array" or "object"
930
-     * @return mixed       the query SQL string or the record result
931
-     */
932
-    public function getAll($returnSQLQueryOrResultType = false){
933
-      $query = 'SELECT ' . $this->select . ' FROM ' . $this->from;
934
-      if (! empty($this->join)){
935
-        $query .= $this->join;
936
-      }
907
+	}
908
+
909
+	/**
910
+	 * Get the result of one record rows returned by the current query
911
+	 * @param  boolean $returnSQLQueryOrResultType if is boolean and true will return the SQL query string.
912
+	 * If is string will determine the result type "array" or "object"
913
+	 * @return mixed       the query SQL string or the record result
914
+	 */
915
+	public function get($returnSQLQueryOrResultType = false){
916
+	  $this->limit = 1;
917
+	  $query = $this->getAll(true);
918
+	  if($returnSQLQueryOrResultType === true){
919
+		return $query;
920
+	  }
921
+	  else{
922
+		return $this->query( $query, false, (($returnSQLQueryOrResultType == 'array') ? true : false) );
923
+	  }
924
+	}
925
+
926
+	/**
927
+	 * Get the result of record rows list returned by the current query
928
+	 * @param  boolean $returnSQLQueryOrResultType if is boolean and true will return the SQL query string.
929
+	 * If is string will determine the result type "array" or "object"
930
+	 * @return mixed       the query SQL string or the record result
931
+	 */
932
+	public function getAll($returnSQLQueryOrResultType = false){
933
+	  $query = 'SELECT ' . $this->select . ' FROM ' . $this->from;
934
+	  if (! empty($this->join)){
935
+		$query .= $this->join;
936
+	  }
937 937
 	  
938
-      if (! empty($this->where)){
939
-        $query .= ' WHERE ' . $this->where;
940
-      }
938
+	  if (! empty($this->where)){
939
+		$query .= ' WHERE ' . $this->where;
940
+	  }
941 941
 
942
-      if (! empty($this->groupBy)){
943
-        $query .= ' GROUP BY ' . $this->groupBy;
944
-      }
942
+	  if (! empty($this->groupBy)){
943
+		$query .= ' GROUP BY ' . $this->groupBy;
944
+	  }
945 945
 
946
-      if (! empty($this->having)){
947
-        $query .= ' HAVING ' . $this->having;
948
-      }
946
+	  if (! empty($this->having)){
947
+		$query .= ' HAVING ' . $this->having;
948
+	  }
949 949
 
950
-      if (! empty($this->orderBy)){
951
-          $query .= ' ORDER BY ' . $this->orderBy;
952
-      }
950
+	  if (! empty($this->orderBy)){
951
+		  $query .= ' ORDER BY ' . $this->orderBy;
952
+	  }
953 953
 
954
-      if(! empty($this->limit)){
955
-      	$query .= ' LIMIT ' . $this->limit;
956
-      }
954
+	  if(! empty($this->limit)){
955
+	  	$query .= ' LIMIT ' . $this->limit;
956
+	  }
957 957
 	  
958 958
 	   if($returnSQLQueryOrResultType === true){
959
-      	return $query;
960
-      }
961
-      else{
962
-    	   return $this->query($query, true, (($returnSQLQueryOrResultType == 'array') ? true : false) );
963
-      }
964
-    }
965
-
966
-    /**
967
-     * Insert new record in the database
968
-     * @param  array   $data   the record data if is empty will use the $this->data array.
969
-     * @param  boolean $escape  whether to escape or not the values
970
-     * @return mixed          the insert id of the new record or null
971
-     */
972
-    public function insert($data = array(), $escape = true){
973
-      $column = array();
974
-      $val = array();
975
-      if(empty($data) && $this->getData()){
976
-        $columns = array_keys($this->getData());
977
-        $column = implode(',', $columns);
978
-        $val = implode(', ', $this->getData());
979
-      }
980
-      else{
981
-        $columns = array_keys($data);
982
-        $column = implode(',', $columns);
983
-        $val = implode(', ', ($escape ? array_map(array($this, 'escape'), $data) : $data));
984
-      }
985
-
986
-      $query = 'INSERT INTO ' . $this->from . ' (' . $column . ') VALUES (' . $val . ')';
987
-      $query = $this->query($query);
988
-
989
-      if ($query){
990
-        if(! $this->pdo){
991
-          $this->connect();
992
-        }
993
-        $this->insertId = $this->pdo->lastInsertId();
994
-        return $this->insertId();
995
-      }
996
-      else{
959
+	  	return $query;
960
+	  }
961
+	  else{
962
+		   return $this->query($query, true, (($returnSQLQueryOrResultType == 'array') ? true : false) );
963
+	  }
964
+	}
965
+
966
+	/**
967
+	 * Insert new record in the database
968
+	 * @param  array   $data   the record data if is empty will use the $this->data array.
969
+	 * @param  boolean $escape  whether to escape or not the values
970
+	 * @return mixed          the insert id of the new record or null
971
+	 */
972
+	public function insert($data = array(), $escape = true){
973
+	  $column = array();
974
+	  $val = array();
975
+	  if(empty($data) && $this->getData()){
976
+		$columns = array_keys($this->getData());
977
+		$column = implode(',', $columns);
978
+		$val = implode(', ', $this->getData());
979
+	  }
980
+	  else{
981
+		$columns = array_keys($data);
982
+		$column = implode(',', $columns);
983
+		$val = implode(', ', ($escape ? array_map(array($this, 'escape'), $data) : $data));
984
+	  }
985
+
986
+	  $query = 'INSERT INTO ' . $this->from . ' (' . $column . ') VALUES (' . $val . ')';
987
+	  $query = $this->query($query);
988
+
989
+	  if ($query){
990
+		if(! $this->pdo){
991
+		  $this->connect();
992
+		}
993
+		$this->insertId = $this->pdo->lastInsertId();
994
+		return $this->insertId();
995
+	  }
996
+	  else{
997 997
 		  return false;
998
-      }
999
-    }
1000
-
1001
-    /**
1002
-     * Update record in the database
1003
-     * @param  array   $data   the record data if is empty will use the $this->data array.
1004
-     * @param  boolean $escape  whether to escape or not the values
1005
-     * @return mixed          the update status
1006
-     */
1007
-    public function update($data = array(), $escape = true){
1008
-      $query = 'UPDATE ' . $this->from . ' SET ';
1009
-      $values = array();
1010
-      if(empty($data) && $this->getData()){
1011
-        foreach ($this->getData() as $column => $val){
1012
-          $values[] = $column . ' = ' . $val;
1013
-        }
1014
-      }
1015
-      else{
1016
-        foreach ($data as $column => $val){
1017
-          $values[] = $column . '=' . ($escape ? $this->escape($val) : $val);
1018
-        }
1019
-      }
1020
-      $query .= implode(', ', $values);
1021
-      if (! empty($this->where)){
1022
-        $query .= ' WHERE ' . $this->where;
1023
-      }
1024
-
1025
-      if (! empty($this->orderBy)){
1026
-        $query .= ' ORDER BY ' . $this->orderBy;
1027
-      }
1028
-
1029
-      if (! empty($this->limit)){
1030
-        $query .= ' LIMIT ' . $this->limit;
1031
-      }
1032
-      return $this->query($query);
1033
-    }
1034
-
1035
-    /**
1036
-     * Delete the record in database
1037
-     * @return mixed the delete status
1038
-     */
1039
-    public function delete(){
1040
-    	$query = 'DELETE FROM ' . $this->from;
1041
-
1042
-    	if (! empty($this->where)){
1043
-    		$query .= ' WHERE ' . $this->where;
1044
-      	}
1045
-
1046
-    	if (! empty($this->orderBy)){
1047
-    	  $query .= ' ORDER BY ' . $this->orderBy;
1048
-      	}
1049
-
1050
-    	if (! empty($this->limit)){
1051
-    		$query .= ' LIMIT ' . $this->limit;
1052
-      	}
1053
-
1054
-    	if($query == 'DELETE FROM ' . $this->from && $this->config['driver'] != 'sqlite'){  
1055
-    		$query = 'TRUNCATE TABLE ' . $this->from;
1056
-      }
1057
-    	return $this->query($query);
1058
-    }
1059
-
1060
-    /**
1061
-     * Execute an SQL query
1062
-     * @param  string  $query the query SQL string
1063
-     * @param  boolean $all   whether to return all record or not
1064
-     * @param  boolean $array return the result as array
1065
-     * @return mixed         the query result
1066
-     */
1067
-    public function query($query, $all = true, $array = false){
1068
-      $this->reset();
1069
-      if(is_array($all)){
1070
-        $x = explode('?', $query);
1071
-        $q = '';
1072
-        foreach($x as $k => $v){
1073
-          if(! empty($v)){
1074
-            $q .= $v . (isset($all[$k]) ? $this->escape($all[$k]) : '');
1075
-          }
1076
-        }
1077
-        $query = $q;
1078
-      }
1079
-
1080
-      $this->query = preg_replace('/\s\s+|\t\t+/', ' ', trim($query));
1081
-      $sqlSELECTQuery = stristr($this->query, 'SELECT');
1082
-      $this->logger->info('Execute SQL query ['.$this->query.'], return type: ' . ($array?'ARRAY':'OBJECT') .', return as list: ' . ($all ? 'YES':'NO'));
1083
-      //cache expire time
998
+	  }
999
+	}
1000
+
1001
+	/**
1002
+	 * Update record in the database
1003
+	 * @param  array   $data   the record data if is empty will use the $this->data array.
1004
+	 * @param  boolean $escape  whether to escape or not the values
1005
+	 * @return mixed          the update status
1006
+	 */
1007
+	public function update($data = array(), $escape = true){
1008
+	  $query = 'UPDATE ' . $this->from . ' SET ';
1009
+	  $values = array();
1010
+	  if(empty($data) && $this->getData()){
1011
+		foreach ($this->getData() as $column => $val){
1012
+		  $values[] = $column . ' = ' . $val;
1013
+		}
1014
+	  }
1015
+	  else{
1016
+		foreach ($data as $column => $val){
1017
+		  $values[] = $column . '=' . ($escape ? $this->escape($val) : $val);
1018
+		}
1019
+	  }
1020
+	  $query .= implode(', ', $values);
1021
+	  if (! empty($this->where)){
1022
+		$query .= ' WHERE ' . $this->where;
1023
+	  }
1024
+
1025
+	  if (! empty($this->orderBy)){
1026
+		$query .= ' ORDER BY ' . $this->orderBy;
1027
+	  }
1028
+
1029
+	  if (! empty($this->limit)){
1030
+		$query .= ' LIMIT ' . $this->limit;
1031
+	  }
1032
+	  return $this->query($query);
1033
+	}
1034
+
1035
+	/**
1036
+	 * Delete the record in database
1037
+	 * @return mixed the delete status
1038
+	 */
1039
+	public function delete(){
1040
+		$query = 'DELETE FROM ' . $this->from;
1041
+
1042
+		if (! empty($this->where)){
1043
+			$query .= ' WHERE ' . $this->where;
1044
+	  	}
1045
+
1046
+		if (! empty($this->orderBy)){
1047
+		  $query .= ' ORDER BY ' . $this->orderBy;
1048
+	  	}
1049
+
1050
+		if (! empty($this->limit)){
1051
+			$query .= ' LIMIT ' . $this->limit;
1052
+	  	}
1053
+
1054
+		if($query == 'DELETE FROM ' . $this->from && $this->config['driver'] != 'sqlite'){  
1055
+			$query = 'TRUNCATE TABLE ' . $this->from;
1056
+	  }
1057
+		return $this->query($query);
1058
+	}
1059
+
1060
+	/**
1061
+	 * Execute an SQL query
1062
+	 * @param  string  $query the query SQL string
1063
+	 * @param  boolean $all   whether to return all record or not
1064
+	 * @param  boolean $array return the result as array
1065
+	 * @return mixed         the query result
1066
+	 */
1067
+	public function query($query, $all = true, $array = false){
1068
+	  $this->reset();
1069
+	  if(is_array($all)){
1070
+		$x = explode('?', $query);
1071
+		$q = '';
1072
+		foreach($x as $k => $v){
1073
+		  if(! empty($v)){
1074
+			$q .= $v . (isset($all[$k]) ? $this->escape($all[$k]) : '');
1075
+		  }
1076
+		}
1077
+		$query = $q;
1078
+	  }
1079
+
1080
+	  $this->query = preg_replace('/\s\s+|\t\t+/', ' ', trim($query));
1081
+	  $sqlSELECTQuery = stristr($this->query, 'SELECT');
1082
+	  $this->logger->info('Execute SQL query ['.$this->query.'], return type: ' . ($array?'ARRAY':'OBJECT') .', return as list: ' . ($all ? 'YES':'NO'));
1083
+	  //cache expire time
1084 1084
   	  $cacheExpire = $this->temporaryCacheTtl;
1085 1085
   	  
1086 1086
   	  //return to the initial cache time
1087 1087
   	  $this->temporaryCacheTtl = $this->cacheTtl;
1088 1088
   	  
1089 1089
   	  //config for cache
1090
-        $cacheEnable = get_config('cache_enable');
1090
+		$cacheEnable = get_config('cache_enable');
1091 1091
   	  
1092 1092
   	  //the database cache content
1093
-        $cacheContent = null;
1093
+		$cacheContent = null;
1094 1094
   	  
1095 1095
   	  //this database query cache key
1096
-        $cacheKey = null;
1096
+		$cacheKey = null;
1097 1097
   	  
1098 1098
   	  //the cache manager instance
1099
-      $cacheInstance = null;
1099
+	  $cacheInstance = null;
1100 1100
   	  
1101 1101
   	  //if can use cache feature for this query
1102 1102
   	  $dbCacheStatus = $cacheEnable && $cacheExpire > 0;
1103 1103
 	  
1104
-      if ($dbCacheStatus && $sqlSELECTQuery){
1105
-        $this->logger->info('The cache is enabled for this query, try to get result from cache'); 
1106
-        $cacheKey = md5($query . $all . $array);
1107
-        if(is_object($this->cacheInstance)){
1108
-          $cacheInstance = $this->cacheInstance;
1109
-        }
1110
-        else{
1111
-          $obj = & get_instance();
1112
-          $cacheInstance = $obj->cache;  
1113
-        }
1114
-        $cacheContent = $cacheInstance->get($cacheKey);        
1115
-      }
1116
-      else{
1104
+	  if ($dbCacheStatus && $sqlSELECTQuery){
1105
+		$this->logger->info('The cache is enabled for this query, try to get result from cache'); 
1106
+		$cacheKey = md5($query . $all . $array);
1107
+		if(is_object($this->cacheInstance)){
1108
+		  $cacheInstance = $this->cacheInstance;
1109
+		}
1110
+		else{
1111
+		  $obj = & get_instance();
1112
+		  $cacheInstance = $obj->cache;  
1113
+		}
1114
+		$cacheContent = $cacheInstance->get($cacheKey);        
1115
+	  }
1116
+	  else{
1117 1117
 		  $this->logger->info('The cache is not enabled for this query or is not the SELECT query, get the result directly from real database');
1118
-      }
1118
+	  }
1119 1119
 
1120
-      if(! $this->pdo){
1121
-        $this->connect();
1122
-      }
1120
+	  if(! $this->pdo){
1121
+		$this->connect();
1122
+	  }
1123 1123
       
1124
-      if (! $cacheContent && $sqlSELECTQuery){
1125
-		    //for database query execution time
1126
-        $benchmarkMarkerKey = md5($query . $all . $array);
1127
-        $bench = null;
1128
-        if(is_object($this->benchmarkInstance)){
1129
-          $bench = $this->benchmarkInstance;
1130
-        }
1131
-        else{
1132
-          $obj = & get_instance();
1133
-          $bench = $obj->benchmark;  
1134
-        }
1135
-        $bench->mark('DATABASE_QUERY_START(' . $benchmarkMarkerKey . ')');
1136
-        //Now execute the query
1137
-		    $sqlQuery = $this->pdo->query($this->query);
1124
+	  if (! $cacheContent && $sqlSELECTQuery){
1125
+			//for database query execution time
1126
+		$benchmarkMarkerKey = md5($query . $all . $array);
1127
+		$bench = null;
1128
+		if(is_object($this->benchmarkInstance)){
1129
+		  $bench = $this->benchmarkInstance;
1130
+		}
1131
+		else{
1132
+		  $obj = & get_instance();
1133
+		  $bench = $obj->benchmark;  
1134
+		}
1135
+		$bench->mark('DATABASE_QUERY_START(' . $benchmarkMarkerKey . ')');
1136
+		//Now execute the query
1137
+			$sqlQuery = $this->pdo->query($this->query);
1138 1138
         
1139
-    		//get response time for this query
1140
-        $responseTime = $bench->elapsedTime('DATABASE_QUERY_START(' . $benchmarkMarkerKey . ')', 'DATABASE_QUERY_END(' . $benchmarkMarkerKey . ')');
1141
-	     	//TODO use the configuration value for the high response time currently is 1 second
1142
-        if($responseTime >= 1 ){
1143
-            $this->logger->warning('High response time while processing database query [' .$query. ']. The response time is [' .$responseTime. '] sec.');
1144
-        }
1145
-        if ($sqlQuery){
1146
-            //if need return all result like list of record
1147
-            if ($all){
1148
-    				    $this->result = ($array === false) ? $sqlQuery->fetchAll(PDO::FETCH_OBJ) : $sqlQuery->fetchAll(PDO::FETCH_ASSOC);
1149
-    		    }
1150
-            else{
1151
-				        $this->result = ($array === false) ? $sqlQuery->fetch(PDO::FETCH_OBJ) : $sqlQuery->fetch(PDO::FETCH_ASSOC);
1152
-            }
1153
-            //Sqlite and pgsql always return 0 when using rowCount()
1154
-            if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1155
-              $this->numRows = count($this->result);  
1156
-            }
1157
-            else{
1158
-              $this->numRows = $sqlQuery->rowCount(); 
1159
-            }
1160
-
1161
-          if ($dbCacheStatus && $sqlSELECTQuery){
1162
-              $this->logger->info('Save the result for query [' .$this->query. '] into cache for future use');
1163
-              $cacheInstance->set($cacheKey, $this->result, $cacheExpire);
1164
-          }
1165
-        }
1166
-        else{
1167
-          $error = $this->pdo->errorInfo();
1168
-          $this->error = isset($error[2]) ? $error[2] : '';
1169
-          $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1170
-          $this->error();
1171
-        }
1172
-      }
1173
-      else if ((! $cacheContent && !$sqlSELECTQuery) || ($cacheContent && !$sqlSELECTQuery)){
1174
-    		$queryStr = $this->pdo->query($this->query);
1175
-    		if($queryStr){
1176
-          //Sqlite and pgsql always return 0 when using rowCount()
1177
-          if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1178
-            $this->result = 1; //to test the result for the query like UPDATE, INSERT, DELETE
1179
-            $this->numRows = 1;  
1180
-          }
1181
-          else{
1182
-              $this->result = $queryStr->rowCount() >= 0; //to test the result for the query like UPDATE, INSERT, DELETE
1183
-              $this->numRows = $queryStr->rowCount(); 
1184
-          }
1185
-    		}
1186
-        if (! $this->result){
1187
-          $error = $this->pdo->errorInfo();
1188
-          $this->error = isset($error[2]) ? $error[2] : '';
1189
-          $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1190
-          $this->error();
1191
-        }
1192
-      }
1193
-      else{
1194
-        $this->logger->info('The result for query [' .$this->query. '] already cached use it');
1195
-        $this->result = $cacheContent;
1196
-	     	$this->numRows = count($this->result);
1197
-      }
1198
-      $this->queryCount++;
1199
-      if(! $this->result){
1200
-        $this->logger->info('No result where found for the query [' . $query . ']');
1201
-      }
1202
-      return $this->result;
1203
-    }
1204
-
1205
-    /**
1206
-     * Set database cache time to live
1207
-     * @param integer $ttl the cache time to live in second
1208
-     * @return object        the current Database instance
1209
-     */
1210
-    public function setCache($ttl = 0){
1211
-      if($ttl > 0){
1212
-        $this->cacheTtl = $ttl;
1213
-		    $this->temporaryCacheTtl = $ttl;
1214
-      }
1215
-      return $this;
1216
-    }
1139
+			//get response time for this query
1140
+		$responseTime = $bench->elapsedTime('DATABASE_QUERY_START(' . $benchmarkMarkerKey . ')', 'DATABASE_QUERY_END(' . $benchmarkMarkerKey . ')');
1141
+		 	//TODO use the configuration value for the high response time currently is 1 second
1142
+		if($responseTime >= 1 ){
1143
+			$this->logger->warning('High response time while processing database query [' .$query. ']. The response time is [' .$responseTime. '] sec.');
1144
+		}
1145
+		if ($sqlQuery){
1146
+			//if need return all result like list of record
1147
+			if ($all){
1148
+						$this->result = ($array === false) ? $sqlQuery->fetchAll(PDO::FETCH_OBJ) : $sqlQuery->fetchAll(PDO::FETCH_ASSOC);
1149
+				}
1150
+			else{
1151
+						$this->result = ($array === false) ? $sqlQuery->fetch(PDO::FETCH_OBJ) : $sqlQuery->fetch(PDO::FETCH_ASSOC);
1152
+			}
1153
+			//Sqlite and pgsql always return 0 when using rowCount()
1154
+			if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1155
+			  $this->numRows = count($this->result);  
1156
+			}
1157
+			else{
1158
+			  $this->numRows = $sqlQuery->rowCount(); 
1159
+			}
1160
+
1161
+		  if ($dbCacheStatus && $sqlSELECTQuery){
1162
+			  $this->logger->info('Save the result for query [' .$this->query. '] into cache for future use');
1163
+			  $cacheInstance->set($cacheKey, $this->result, $cacheExpire);
1164
+		  }
1165
+		}
1166
+		else{
1167
+		  $error = $this->pdo->errorInfo();
1168
+		  $this->error = isset($error[2]) ? $error[2] : '';
1169
+		  $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1170
+		  $this->error();
1171
+		}
1172
+	  }
1173
+	  else if ((! $cacheContent && !$sqlSELECTQuery) || ($cacheContent && !$sqlSELECTQuery)){
1174
+			$queryStr = $this->pdo->query($this->query);
1175
+			if($queryStr){
1176
+		  //Sqlite and pgsql always return 0 when using rowCount()
1177
+		  if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1178
+			$this->result = 1; //to test the result for the query like UPDATE, INSERT, DELETE
1179
+			$this->numRows = 1;  
1180
+		  }
1181
+		  else{
1182
+			  $this->result = $queryStr->rowCount() >= 0; //to test the result for the query like UPDATE, INSERT, DELETE
1183
+			  $this->numRows = $queryStr->rowCount(); 
1184
+		  }
1185
+			}
1186
+		if (! $this->result){
1187
+		  $error = $this->pdo->errorInfo();
1188
+		  $this->error = isset($error[2]) ? $error[2] : '';
1189
+		  $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1190
+		  $this->error();
1191
+		}
1192
+	  }
1193
+	  else{
1194
+		$this->logger->info('The result for query [' .$this->query. '] already cached use it');
1195
+		$this->result = $cacheContent;
1196
+		 	$this->numRows = count($this->result);
1197
+	  }
1198
+	  $this->queryCount++;
1199
+	  if(! $this->result){
1200
+		$this->logger->info('No result where found for the query [' . $query . ']');
1201
+	  }
1202
+	  return $this->result;
1203
+	}
1204
+
1205
+	/**
1206
+	 * Set database cache time to live
1207
+	 * @param integer $ttl the cache time to live in second
1208
+	 * @return object        the current Database instance
1209
+	 */
1210
+	public function setCache($ttl = 0){
1211
+	  if($ttl > 0){
1212
+		$this->cacheTtl = $ttl;
1213
+			$this->temporaryCacheTtl = $ttl;
1214
+	  }
1215
+	  return $this;
1216
+	}
1217 1217
 	
1218 1218
 	/**
1219 1219
 	 * Enabled cache temporary for the current query not globally	
@@ -1221,258 +1221,258 @@  discard block
 block discarded – undo
1221 1221
 	 * @return object        the current Database instance
1222 1222
 	 */
1223 1223
 	public function cached($ttl = 0){
1224
-      if($ttl > 0){
1225
-        $this->temporaryCacheTtl = $ttl;
1226
-      }
1224
+	  if($ttl > 0){
1225
+		$this->temporaryCacheTtl = $ttl;
1226
+	  }
1227
+	  return $this;
1228
+	}
1229
+
1230
+	/**
1231
+	 * Escape the data before execute query useful for security.
1232
+	 * @param  mixed $data the data to be escaped
1233
+	 * @return mixed       the data after escaped
1234
+	 */
1235
+	public function escape($data){
1236
+	  if(is_null($data)){
1237
+		return null;
1238
+	  }
1239
+	  if(! $this->pdo){
1240
+		$this->connect();
1241
+	  }
1242
+	  return $this->pdo->quote(trim($data));
1243
+	}
1244
+
1245
+	/**
1246
+	 * Return the number query executed count for the current request
1247
+	 * @return int
1248
+	 */
1249
+	public function queryCount(){
1250
+	  return $this->queryCount;
1251
+	}
1252
+
1253
+	/**
1254
+	 * Return the current query SQL string
1255
+	 * @return string
1256
+	 */
1257
+	public function getQuery(){
1258
+	  return $this->query;
1259
+	}
1260
+
1261
+	/**
1262
+	 * Return the application database name
1263
+	 * @return string
1264
+	 */
1265
+	public function getDatabaseName(){
1266
+	  return $this->databaseName;
1267
+	}
1268
+
1269
+	 /**
1270
+	  * Return the database configuration
1271
+	  * @return array
1272
+	  */
1273
+	public  function getDatabaseConfiguration(){
1274
+	  return $this->config;
1275
+	}
1276
+
1277
+	/**
1278
+	 * set the database configuration
1279
+	 * @param array $config the configuration
1280
+	 */
1281
+	public function setDatabaseConfiguration(array $config){
1282
+	  $this->config = array_merge($this->config, $config);
1283
+	  $this->prefix = $this->config['prefix'];
1284
+	  $this->databaseName = $this->config['database'];
1285
+	  $this->logger->info('The database configuration are listed below: ' . stringfy_vars(array_merge($this->config, array('password' => string_hidden($this->config['password'])))));
1227 1286
 	  return $this;
1228
-    }
1229
-
1230
-    /**
1231
-     * Escape the data before execute query useful for security.
1232
-     * @param  mixed $data the data to be escaped
1233
-     * @return mixed       the data after escaped
1234
-     */
1235
-    public function escape($data){
1236
-      if(is_null($data)){
1237
-        return null;
1238
-      }
1239
-      if(! $this->pdo){
1240
-        $this->connect();
1241
-      }
1242
-      return $this->pdo->quote(trim($data));
1243
-    }
1244
-
1245
-    /**
1246
-     * Return the number query executed count for the current request
1247
-     * @return int
1248
-     */
1249
-    public function queryCount(){
1250
-      return $this->queryCount;
1251
-    }
1252
-
1253
-    /**
1254
-     * Return the current query SQL string
1255
-     * @return string
1256
-     */
1257
-    public function getQuery(){
1258
-      return $this->query;
1259
-    }
1260
-
1261
-    /**
1262
-     * Return the application database name
1263
-     * @return string
1264
-     */
1265
-    public function getDatabaseName(){
1266
-      return $this->databaseName;
1267
-    }
1268
-
1269
-     /**
1270
-     * Return the database configuration
1271
-     * @return array
1272
-     */
1273
-    public  function getDatabaseConfiguration(){
1274
-      return $this->config;
1275
-    }
1276
-
1277
-    /**
1278
-     * set the database configuration
1279
-     * @param array $config the configuration
1280
-     */
1281
-    public function setDatabaseConfiguration(array $config){
1282
-      $this->config = array_merge($this->config, $config);
1283
-      $this->prefix = $this->config['prefix'];
1284
-      $this->databaseName = $this->config['database'];
1285
-      $this->logger->info('The database configuration are listed below: ' . stringfy_vars(array_merge($this->config, array('password' => string_hidden($this->config['password'])))));
1286
-      return $this;
1287
-    }
1288
-
1289
-    /**
1290
-     * Return the PDO instance
1291
-     * @return PDO
1292
-     */
1293
-    public function getPdo(){
1294
-      return $this->pdo;
1295
-    }
1296
-
1297
-    /**
1298
-     * Set the PDO instance
1299
-     * @param PDO $pdo the pdo object
1300
-     */
1301
-    public function setPdo(PDO $pdo){
1302
-      $this->pdo = $pdo;
1303
-      return $this;
1304
-    }
1305
-
1306
-
1307
-    /**
1308
-     * Return the Log instance
1309
-     * @return Log
1310
-     */
1311
-    public function getLogger(){
1312
-      return $this->logger;
1313
-    }
1314
-
1315
-    /**
1316
-     * Set the log instance
1317
-     * @param Log $logger the log object
1318
-     */
1319
-    public function setLogger($logger){
1320
-      $this->logger = $logger;
1321
-      return $this;
1322
-    }
1323
-
1324
-     /**
1325
-     * Return the cache instance
1326
-     * @return CacheInterface
1327
-     */
1328
-    public function getCacheInstance(){
1329
-      return $this->cacheInstance;
1330
-    }
1331
-
1332
-    /**
1333
-     * Set the cache instance
1334
-     * @param CacheInterface $cache the cache object
1335
-     */
1336
-    public function setCacheInstance($cache){
1337
-      $this->cacheInstance = $cache;
1338
-      return $this;
1339
-    }
1340
-
1341
-    /**
1342
-     * Return the benchmark instance
1343
-     * @return Benchmark
1344
-     */
1345
-    public function getBenchmark(){
1346
-      return $this->benchmarkInstance;
1347
-    }
1348
-
1349
-    /**
1350
-     * Set the benchmark instance
1351
-     * @param Benchmark $cache the cache object
1352
-     */
1353
-    public function setBenchmark($benchmark){
1354
-      $this->benchmarkInstance = $benchmark;
1355
-      return $this;
1356
-    }
1357
-
1358
-    /**
1359
-     * Return the data to be used for insert, update, etc.
1360
-     * @return array
1361
-     */
1362
-    public function getData(){
1363
-      return $this->data;
1364
-    }
1365
-
1366
-    /**
1367
-     * Set the data to be used for insert, update, etc.
1368
-     * @param string $key the data key identified
1369
-     * @param mixed $value the data value
1370
-     * @param boolean $escape whether to escape or not the $value
1371
-     * @return object        the current Database instance
1372
-     */
1373
-    public function setData($key, $value, $escape = true){
1374
-      $this->data[$key] = $escape ? $this->escape($value) : $value;
1375
-      return $this;
1376
-    }
1377
-
1378
-    /**
1379
-     * Set the Log instance using argument or create new instance
1380
-     * @param object $logger the Log instance if not null
1381
-     */
1382
-    protected function setLoggerFromParamOrCreateNewInstance(Log $logger = null){
1383
-      if($logger !== null){
1384
-        $this->logger = $logger;
1385
-      }
1386
-      else{
1387
-          $this->logger =& class_loader('Log', 'classes');
1388
-          $this->logger->setLogger('Library::Database');
1389
-      }
1390
-    }
1287
+	}
1288
+
1289
+	/**
1290
+	 * Return the PDO instance
1291
+	 * @return PDO
1292
+	 */
1293
+	public function getPdo(){
1294
+	  return $this->pdo;
1295
+	}
1296
+
1297
+	/**
1298
+	 * Set the PDO instance
1299
+	 * @param PDO $pdo the pdo object
1300
+	 */
1301
+	public function setPdo(PDO $pdo){
1302
+	  $this->pdo = $pdo;
1303
+	  return $this;
1304
+	}
1305
+
1306
+
1307
+	/**
1308
+	 * Return the Log instance
1309
+	 * @return Log
1310
+	 */
1311
+	public function getLogger(){
1312
+	  return $this->logger;
1313
+	}
1314
+
1315
+	/**
1316
+	 * Set the log instance
1317
+	 * @param Log $logger the log object
1318
+	 */
1319
+	public function setLogger($logger){
1320
+	  $this->logger = $logger;
1321
+	  return $this;
1322
+	}
1323
+
1324
+	 /**
1325
+	  * Return the cache instance
1326
+	  * @return CacheInterface
1327
+	  */
1328
+	public function getCacheInstance(){
1329
+	  return $this->cacheInstance;
1330
+	}
1331
+
1332
+	/**
1333
+	 * Set the cache instance
1334
+	 * @param CacheInterface $cache the cache object
1335
+	 */
1336
+	public function setCacheInstance($cache){
1337
+	  $this->cacheInstance = $cache;
1338
+	  return $this;
1339
+	}
1340
+
1341
+	/**
1342
+	 * Return the benchmark instance
1343
+	 * @return Benchmark
1344
+	 */
1345
+	public function getBenchmark(){
1346
+	  return $this->benchmarkInstance;
1347
+	}
1348
+
1349
+	/**
1350
+	 * Set the benchmark instance
1351
+	 * @param Benchmark $cache the cache object
1352
+	 */
1353
+	public function setBenchmark($benchmark){
1354
+	  $this->benchmarkInstance = $benchmark;
1355
+	  return $this;
1356
+	}
1357
+
1358
+	/**
1359
+	 * Return the data to be used for insert, update, etc.
1360
+	 * @return array
1361
+	 */
1362
+	public function getData(){
1363
+	  return $this->data;
1364
+	}
1365
+
1366
+	/**
1367
+	 * Set the data to be used for insert, update, etc.
1368
+	 * @param string $key the data key identified
1369
+	 * @param mixed $value the data value
1370
+	 * @param boolean $escape whether to escape or not the $value
1371
+	 * @return object        the current Database instance
1372
+	 */
1373
+	public function setData($key, $value, $escape = true){
1374
+	  $this->data[$key] = $escape ? $this->escape($value) : $value;
1375
+	  return $this;
1376
+	}
1377
+
1378
+	/**
1379
+	 * Set the Log instance using argument or create new instance
1380
+	 * @param object $logger the Log instance if not null
1381
+	 */
1382
+	protected function setLoggerFromParamOrCreateNewInstance(Log $logger = null){
1383
+	  if($logger !== null){
1384
+		$this->logger = $logger;
1385
+	  }
1386
+	  else{
1387
+		  $this->logger =& class_loader('Log', 'classes');
1388
+		  $this->logger->setLogger('Library::Database');
1389
+	  }
1390
+	}
1391 1391
 
1392 1392
    /**
1393 1393
     * Setting the database configuration using the configuration file
1394 1394
     * @param array $overwriteConfig the additional configuration to overwrite with the existing one
1395 1395
     */
1396
-    protected function setDatabaseConfigurationFromConfigFile(array $overwriteConfig = array()){
1397
-        $db = array();
1398
-        if(file_exists(CONFIG_PATH . 'database.php')){
1399
-            //here don't use require_once because somewhere user can create database instance directly
1400
-            require CONFIG_PATH . 'database.php';
1401
-        }
1396
+	protected function setDatabaseConfigurationFromConfigFile(array $overwriteConfig = array()){
1397
+		$db = array();
1398
+		if(file_exists(CONFIG_PATH . 'database.php')){
1399
+			//here don't use require_once because somewhere user can create database instance directly
1400
+			require CONFIG_PATH . 'database.php';
1401
+		}
1402 1402
           
1403
-        if(! empty($overwriteConfig)){
1404
-          $db = array_merge($db, $overwriteConfig);
1405
-        }
1406
-        $config = array();
1407
-        $config['driver']    = isset($db['driver']) ? $db['driver'] : 'mysql';
1408
-        $config['username']  = isset($db['username']) ? $db['username'] : 'root';
1409
-        $config['password']  = isset($db['password']) ? $db['password'] : '';
1410
-        $config['database']  = isset($db['database']) ? $db['database'] : '';
1411
-        $config['hostname']  = isset($db['hostname']) ? $db['hostname'] : 'localhost';
1412
-        $config['charset']   = isset($db['charset']) ? $db['charset'] : 'utf8';
1413
-        $config['collation'] = isset($db['collation']) ? $db['collation'] : 'utf8_general_ci';
1414
-        $config['prefix']    = isset($db['prefix']) ? $db['prefix'] : '';
1415
-        $port = '';
1416
-        if(strstr($config['hostname'], ':')){
1417
-          $p = explode(':', $config['hostname']);
1418
-          $port = isset($p[1]) ? $p[1] : '';
1419
-          $config['hostname'] = isset($p[0]) ? $p[0] : '';
1420
-        }
1421
-        $config['port']      = $port;
1422
-        $this->setDatabaseConfiguration($config);  
1423
-    }
1424
-
1425
-    /**
1426
-     * This method is used to get the PDO DSN string using th configured driver
1427
-     * @return string the DSN string
1428
-     */
1429
-    protected function getDsnFromDriver(){
1430
-      $config = $this->getDatabaseConfiguration();
1431
-      if(! empty($config)){
1432
-            $driverDsnMap = array(
1433
-                                    'mysql' => 'mysql:host=' . $config['hostname'] . ';' 
1434
-                                                . (($config['port']) != '' ? 'port=' . $config['port'] . ';' : '') 
1435
-                                                . 'dbname=' . $config['database'],
1436
-                                    'pgsql' => 'pgsql:host=' . $config['hostname'] . ';' 
1437
-                                                . (($config['port']) != '' ? 'port=' . $config['port'] . ';' : '')
1438
-                                                . 'dbname=' . $config['database'],
1439
-                                    'sqlite' => 'sqlite:' . $config['database'],
1440
-                                    'oracle' => 'oci:dbname=' . $config['hostname'] 
1441
-                                                . (($config['port']) != '' ? ':' . $config['port'] : '')
1442
-                                                . '/' . $config['database']
1443
-                                  );
1444
-            return isset($driverDsnMap[$config['driver']]) ? $driverDsnMap[$config['driver']] : '';
1445
-      } 
1403
+		if(! empty($overwriteConfig)){
1404
+		  $db = array_merge($db, $overwriteConfig);
1405
+		}
1406
+		$config = array();
1407
+		$config['driver']    = isset($db['driver']) ? $db['driver'] : 'mysql';
1408
+		$config['username']  = isset($db['username']) ? $db['username'] : 'root';
1409
+		$config['password']  = isset($db['password']) ? $db['password'] : '';
1410
+		$config['database']  = isset($db['database']) ? $db['database'] : '';
1411
+		$config['hostname']  = isset($db['hostname']) ? $db['hostname'] : 'localhost';
1412
+		$config['charset']   = isset($db['charset']) ? $db['charset'] : 'utf8';
1413
+		$config['collation'] = isset($db['collation']) ? $db['collation'] : 'utf8_general_ci';
1414
+		$config['prefix']    = isset($db['prefix']) ? $db['prefix'] : '';
1415
+		$port = '';
1416
+		if(strstr($config['hostname'], ':')){
1417
+		  $p = explode(':', $config['hostname']);
1418
+		  $port = isset($p[1]) ? $p[1] : '';
1419
+		  $config['hostname'] = isset($p[0]) ? $p[0] : '';
1420
+		}
1421
+		$config['port']      = $port;
1422
+		$this->setDatabaseConfiguration($config);  
1423
+	}
1424
+
1425
+	/**
1426
+	 * This method is used to get the PDO DSN string using th configured driver
1427
+	 * @return string the DSN string
1428
+	 */
1429
+	protected function getDsnFromDriver(){
1430
+	  $config = $this->getDatabaseConfiguration();
1431
+	  if(! empty($config)){
1432
+			$driverDsnMap = array(
1433
+									'mysql' => 'mysql:host=' . $config['hostname'] . ';' 
1434
+												. (($config['port']) != '' ? 'port=' . $config['port'] . ';' : '') 
1435
+												. 'dbname=' . $config['database'],
1436
+									'pgsql' => 'pgsql:host=' . $config['hostname'] . ';' 
1437
+												. (($config['port']) != '' ? 'port=' . $config['port'] . ';' : '')
1438
+												. 'dbname=' . $config['database'],
1439
+									'sqlite' => 'sqlite:' . $config['database'],
1440
+									'oracle' => 'oci:dbname=' . $config['hostname'] 
1441
+												. (($config['port']) != '' ? ':' . $config['port'] : '')
1442
+												. '/' . $config['database']
1443
+								  );
1444
+			return isset($driverDsnMap[$config['driver']]) ? $driverDsnMap[$config['driver']] : '';
1445
+	  } 
1446 1446
                             
1447
-      return null;
1448
-    }
1447
+	  return null;
1448
+	}
1449 1449
 
1450 1450
 
1451 1451
   /**
1452 1452
    * Reset the database class attributs to the initail values before each query.
1453 1453
    */
1454 1454
   private function reset(){
1455
-    $this->select   = '*';
1456
-    $this->from     = null;
1457
-    $this->where    = null;
1458
-    $this->limit    = null;
1459
-    $this->orderBy  = null;
1460
-    $this->groupBy  = null;
1461
-    $this->having   = null;
1462
-    $this->join     = null;
1463
-    $this->numRows  = 0;
1464
-    $this->insertId = null;
1465
-    $this->query    = null;
1466
-    $this->error    = null;
1467
-    $this->result   = array();
1468
-    $this->data     = array();
1455
+	$this->select   = '*';
1456
+	$this->from     = null;
1457
+	$this->where    = null;
1458
+	$this->limit    = null;
1459
+	$this->orderBy  = null;
1460
+	$this->groupBy  = null;
1461
+	$this->having   = null;
1462
+	$this->join     = null;
1463
+	$this->numRows  = 0;
1464
+	$this->insertId = null;
1465
+	$this->query    = null;
1466
+	$this->error    = null;
1467
+	$this->result   = array();
1468
+	$this->data     = array();
1469 1469
   }
1470 1470
 
1471 1471
   /**
1472 1472
    * The class destructor
1473 1473
    */
1474 1474
   public function __destruct(){
1475
-    $this->pdo = null;
1475
+	$this->pdo = null;
1476 1476
   }
1477 1477
 
1478 1478
 }
Please login to merge, or discard this patch.
Spacing   +254 added lines, -254 removed lines patch added patch discarded remove patch
@@ -23,165 +23,165 @@  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
     /**
181 181
      * Construct new database
182 182
      * @param array $overwriteConfig the config to overwrite with the config set in database.php
183 183
      */
184
-    public function __construct($overwriteConfig = array()){
184
+    public function __construct($overwriteConfig = array()) {
185 185
         //Set Log instance to use
186 186
         $this->setLoggerFromParamOrCreateNewInstance(null);
187 187
 
@@ -195,23 +195,23 @@  discard block
 block discarded – undo
195 195
      * This is used to connect to database
196 196
      * @return bool 
197 197
      */
198
-    public function connect(){
198
+    public function connect() {
199 199
       $config = $this->getDatabaseConfiguration();
200
-      if(! empty($config)){
201
-        try{
200
+      if (!empty($config)) {
201
+        try {
202 202
             $this->pdo = new PDO($this->getDsnFromDriver(), $config['username'], $config['password']);
203 203
             $this->pdo->exec("SET NAMES '" . $config['charset'] . "' COLLATE '" . $config['collation'] . "'");
204 204
             $this->pdo->exec("SET CHARACTER SET '" . $config['charset'] . "'");
205 205
             $this->pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_OBJ);
206 206
             return true;
207 207
           }
208
-          catch (PDOException $e){
208
+          catch (PDOException $e) {
209 209
             $this->logger->fatal($e->getMessage());
210 210
             show_error('Cannot connect to Database.');
211 211
             return false;
212 212
           }
213 213
       }
214
-      else{
214
+      else {
215 215
         show_error('Database configuration is not set.');
216 216
         return false;
217 217
       }
@@ -222,15 +222,15 @@  discard block
 block discarded – undo
222 222
      * @param  string|array $table the table name or array of table list
223 223
      * @return object        the current Database instance
224 224
      */
225
-    public function from($table){
226
-      if(is_array($table)){
225
+    public function from($table) {
226
+      if (is_array($table)) {
227 227
         $froms = '';
228
-        foreach($table as $key){
228
+        foreach ($table as $key) {
229 229
           $froms .= $this->prefix . $key . ', ';
230 230
         }
231 231
         $this->from = rtrim($froms, ', ');
232 232
       }
233
-      else{
233
+      else {
234 234
         $this->from = $this->prefix . $table;
235 235
       }
236 236
       return $this;
@@ -241,7 +241,7 @@  discard block
 block discarded – undo
241 241
      * @param  string|array $fields the field name or array of field list
242 242
      * @return object        the current Database instance
243 243
      */
244
-    public function select($fields){
244
+    public function select($fields) {
245 245
       $select = (is_array($fields) ? implode(', ', $fields) : $fields);
246 246
       $this->select = ($this->select == '*' ? $select : $this->select . ', ' . $select);
247 247
       return $this;
@@ -252,7 +252,7 @@  discard block
 block discarded – undo
252 252
      * @param  string $field the field name to distinct
253 253
      * @return object        the current Database instance
254 254
      */
255
-    public function distinct($field){
255
+    public function distinct($field) {
256 256
       $distinct = ' DISTINCT ' . $field;
257 257
       $this->select = ($this->select == '*' ? $distinct : $this->select . ', ' . $distinct);
258 258
 
@@ -265,7 +265,7 @@  discard block
 block discarded – undo
265 265
      * @param  string $name  if is not null represent the alias used for this field in the result
266 266
      * @return object        the current Database instance
267 267
      */
268
-    public function max($field, $name = null){
268
+    public function max($field, $name = null) {
269 269
       $func = 'MAX(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
270 270
       $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
271 271
       return $this;
@@ -277,7 +277,7 @@  discard block
 block discarded – undo
277 277
      * @param  string $name  if is not null represent the alias used for this field in the result
278 278
      * @return object        the current Database instance
279 279
      */
280
-    public function min($field, $name = null){
280
+    public function min($field, $name = null) {
281 281
       $func = 'MIN(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
282 282
       $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
283 283
       return $this;
@@ -289,7 +289,7 @@  discard block
 block discarded – undo
289 289
      * @param  string $name  if is not null represent the alias used for this field in the result
290 290
      * @return object        the current Database instance
291 291
      */
292
-    public function sum($field, $name = null){
292
+    public function sum($field, $name = null) {
293 293
       $func = 'SUM(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
294 294
       $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
295 295
       return $this;
@@ -301,7 +301,7 @@  discard block
 block discarded – undo
301 301
      * @param  string $name  if is not null represent the alias used for this field in the result
302 302
      * @return object        the current Database instance
303 303
      */
304
-    public function count($field = '*', $name = null){
304
+    public function count($field = '*', $name = null) {
305 305
       $func = 'COUNT(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
306 306
       $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
307 307
       return $this;
@@ -313,7 +313,7 @@  discard block
 block discarded – undo
313 313
      * @param  string $name  if is not null represent the alias used for this field in the result
314 314
      * @return object        the current Database instance
315 315
      */
316
-    public function avg($field, $name = null){
316
+    public function avg($field, $name = null) {
317 317
       $func = 'AVG(' . $field . ')' . (!is_null($name) ? ' AS ' . $name : '');
318 318
       $this->select = ($this->select == '*' ? $func : $this->select . ', ' . $func);
319 319
       return $this;
@@ -328,16 +328,16 @@  discard block
 block discarded – undo
328 328
      * @param  string $type   the type of join (INNER, LEFT, RIGHT)
329 329
      * @return object        the current Database instance
330 330
      */
331
-    public function join($table, $field1 = null, $op = null, $field2 = null, $type = ''){
331
+    public function join($table, $field1 = null, $op = null, $field2 = null, $type = '') {
332 332
       $on = $field1;
333 333
       $table = $this->prefix . $table;
334
-      if(! is_null($op)){
335
-        $on = (! in_array($op, $this->operatorList) ? $this->prefix . $field1 . ' = ' . $this->prefix . $op : $this->prefix . $field1 . ' ' . $op . ' ' . $this->prefix . $field2);
334
+      if (!is_null($op)) {
335
+        $on = (!in_array($op, $this->operatorList) ? $this->prefix . $field1 . ' = ' . $this->prefix . $op : $this->prefix . $field1 . ' ' . $op . ' ' . $this->prefix . $field2);
336 336
       }
337
-      if (empty($this->join)){
337
+      if (empty($this->join)) {
338 338
         $this->join = ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
339 339
       }
340
-      else{
340
+      else {
341 341
         $this->join = $this->join . ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
342 342
       }
343 343
       return $this;
@@ -348,7 +348,7 @@  discard block
 block discarded – undo
348 348
      * @see  Database::join()
349 349
      * @return object        the current Database instance
350 350
      */
351
-    public function innerJoin($table, $field1, $op = null, $field2 = ''){
351
+    public function innerJoin($table, $field1, $op = null, $field2 = '') {
352 352
       return $this->join($table, $field1, $op, $field2, 'INNER ');
353 353
     }
354 354
 
@@ -357,7 +357,7 @@  discard block
 block discarded – undo
357 357
      * @see  Database::join()
358 358
      * @return object        the current Database instance
359 359
      */
360
-    public function leftJoin($table, $field1, $op = null, $field2 = ''){
360
+    public function leftJoin($table, $field1, $op = null, $field2 = '') {
361 361
       return $this->join($table, $field1, $op, $field2, 'LEFT ');
362 362
 	}
363 363
 
@@ -366,7 +366,7 @@  discard block
 block discarded – undo
366 366
      * @see  Database::join()
367 367
      * @return object        the current Database instance
368 368
      */
369
-    public function rightJoin($table, $field1, $op = null, $field2 = ''){
369
+    public function rightJoin($table, $field1, $op = null, $field2 = '') {
370 370
       return $this->join($table, $field1, $op, $field2, 'RIGHT ');
371 371
     }
372 372
 
@@ -375,7 +375,7 @@  discard block
 block discarded – undo
375 375
      * @see  Database::join()
376 376
      * @return object        the current Database instance
377 377
      */
378
-    public function fullOuterJoin($table, $field1, $op = null, $field2 = ''){
378
+    public function fullOuterJoin($table, $field1, $op = null, $field2 = '') {
379 379
     	return $this->join($table, $field1, $op, $field2, 'FULL OUTER ');
380 380
     }
381 381
 
@@ -384,7 +384,7 @@  discard block
 block discarded – undo
384 384
      * @see  Database::join()
385 385
      * @return object        the current Database instance
386 386
      */
387
-    public function leftOuterJoin($table, $field1, $op = null, $field2 = ''){
387
+    public function leftOuterJoin($table, $field1, $op = null, $field2 = '') {
388 388
       return $this->join($table, $field1, $op, $field2, 'LEFT OUTER ');
389 389
     }
390 390
 
@@ -393,7 +393,7 @@  discard block
 block discarded – undo
393 393
      * @see  Database::join()
394 394
      * @return object        the current Database instance
395 395
      */
396
-    public function rightOuterJoin($table, $field1, $op = null, $field2 = ''){
396
+    public function rightOuterJoin($table, $field1, $op = null, $field2 = '') {
397 397
       return $this->join($table, $field1, $op, $field2, 'RIGHT OUTER ');
398 398
     }
399 399
 
@@ -403,18 +403,18 @@  discard block
 block discarded – undo
403 403
      * @param  string $andOr the separator type used 'AND', 'OR', etc.
404 404
      * @return object        the current Database instance
405 405
      */
406
-    public function whereIsNull($field, $andOr = 'AND'){
407
-      if(is_array($field)){
408
-        foreach($field as $f){
406
+    public function whereIsNull($field, $andOr = 'AND') {
407
+      if (is_array($field)) {
408
+        foreach ($field as $f) {
409 409
         	$this->whereIsNull($f, $andOr);
410 410
         }
411 411
       }
412
-      else{
413
-        if (! $this->where){
414
-          $this->where = $field.' IS NULL ';
412
+      else {
413
+        if (!$this->where) {
414
+          $this->where = $field . ' IS NULL ';
415 415
         }
416
-        else{
417
-            $this->where = $this->where . ' '.$andOr.' ' . $field.' IS NULL ';
416
+        else {
417
+            $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' IS NULL ';
418 418
           }
419 419
       }
420 420
       return $this;
@@ -426,18 +426,18 @@  discard block
 block discarded – undo
426 426
      * @param  string $andOr the separator type used 'AND', 'OR', etc.
427 427
      * @return object        the current Database instance
428 428
      */
429
-    public function whereIsNotNull($field, $andOr = 'AND'){
430
-      if(is_array($field)){
431
-        foreach($field as $f){
429
+    public function whereIsNotNull($field, $andOr = 'AND') {
430
+      if (is_array($field)) {
431
+        foreach ($field as $f) {
432 432
           $this->whereIsNotNull($f, $andOr);
433 433
         }
434 434
       }
435
-      else{
436
-        if (! $this->where){
437
-          $this->where = $field.' IS NOT NULL ';
435
+      else {
436
+        if (!$this->where) {
437
+          $this->where = $field . ' IS NOT NULL ';
438 438
         }
439
-        else{
440
-            $this->where = $this->where . ' '.$andOr.' ' . $field.' IS NOT NULL ';
439
+        else {
440
+            $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' IS NOT NULL ';
441 441
           }
442 442
       }
443 443
       return $this;
@@ -449,15 +449,15 @@  discard block
 block discarded – undo
449 449
      *
450 450
      * @return string
451 451
      */
452
-    protected function getWhereStrIfIsArray(array $where, $type = '', $andOr = 'AND', $escape = true){
452
+    protected function getWhereStrIfIsArray(array $where, $type = '', $andOr = 'AND', $escape = true) {
453 453
         $_where = array();
454
-        foreach ($where as $column => $data){
455
-          if(is_null($data)){
454
+        foreach ($where as $column => $data) {
455
+          if (is_null($data)) {
456 456
             $data = '';
457 457
           }
458 458
           $_where[] = $type . $column . ' = ' . ($escape ? $this->escape($data) : $data);
459 459
         }
460
-        $where = implode(' '.$andOr.' ', $_where);
460
+        $where = implode(' ' . $andOr . ' ', $_where);
461 461
         return $where;
462 462
     }
463 463
 
@@ -467,12 +467,12 @@  discard block
 block discarded – undo
467 467
      *
468 468
      * @return string
469 469
      */
470
-    protected function getWhereStrIfOperatorIsArray($where, array $op, $type = '', $escape = true){
470
+    protected function getWhereStrIfOperatorIsArray($where, array $op, $type = '', $escape = true) {
471 471
        $x = explode('?', $where);
472 472
        $w = '';
473
-        foreach($x as $k => $v){
474
-          if(! empty($v)){
475
-              if(isset($op[$k]) && is_null($op[$k])){
473
+        foreach ($x as $k => $v) {
474
+          if (!empty($v)) {
475
+              if (isset($op[$k]) && is_null($op[$k])) {
476 476
                 $op[$k] = '';
477 477
               }
478 478
               $w .= $type . $v . (isset($op[$k]) ? ($escape ? $this->escape($op[$k]) : $op[$k]) : '');
@@ -487,16 +487,16 @@  discard block
 block discarded – undo
487 487
      *
488 488
      * @return string
489 489
      */
490
-    protected function getWhereStrForOperator($where, $op = null, $val = null, $type = '', $escape = true){
490
+    protected function getWhereStrForOperator($where, $op = null, $val = null, $type = '', $escape = true) {
491 491
        $w = '';
492
-       if (! in_array((string)$op, $this->operatorList)){
493
-          if(is_null($op)){
492
+       if (!in_array((string) $op, $this->operatorList)) {
493
+          if (is_null($op)) {
494 494
             $op = '';
495 495
           }
496 496
           $w = $type . $where . ' = ' . ($escape ? $this->escape($op) : $op);
497 497
         }
498
-        else{
499
-          if(is_null($val)){
498
+        else {
499
+          if (is_null($val)) {
500 500
             $val = '';
501 501
           }
502 502
           $w = $type . $where . $op . ($escape ? $this->escape($val) : $val);
@@ -509,16 +509,16 @@  discard block
 block discarded – undo
509 509
        * @param string $whereStr the WHERE clause string
510 510
        * @param  string  $andOr the separator type used 'AND', 'OR', etc.
511 511
        */
512
-      protected function setWhereStr($whereStr, $andOr = 'AND'){
513
-        if (empty($this->where)){
512
+      protected function setWhereStr($whereStr, $andOr = 'AND') {
513
+        if (empty($this->where)) {
514 514
           $this->where = $whereStr;
515 515
         }
516
-        else{
517
-          if(substr($this->where, -1) == '('){
516
+        else {
517
+          if (substr($this->where, -1) == '(') {
518 518
             $this->where = $this->where . ' ' . $whereStr;
519 519
           }
520
-          else{
521
-            $this->where = $this->where . ' '.$andOr.' ' . $whereStr;
520
+          else {
521
+            $this->where = $this->where . ' ' . $andOr . ' ' . $whereStr;
522 522
           }
523 523
         }
524 524
       }
@@ -533,13 +533,13 @@  discard block
 block discarded – undo
533 533
      * @param  boolean $escape whether to escape or not the $val
534 534
      * @return object        the current Database instance
535 535
      */
536
-    public function where($where, $op = null, $val = null, $type = '', $andOr = 'AND', $escape = true){
536
+    public function where($where, $op = null, $val = null, $type = '', $andOr = 'AND', $escape = true) {
537 537
       $whereStr = '';
538
-      if (is_array($where)){
538
+      if (is_array($where)) {
539 539
         $whereStr = $this->getWhereStrIfIsArray($where, $type, $andOr, $escape);
540 540
       }
541
-      else{
542
-        if(is_array($op)){
541
+      else {
542
+        if (is_array($op)) {
543 543
           $whereStr = $this->getWhereStrIfOperatorIsArray($where, $op, $type, $escape);
544 544
         } else {
545 545
           $whereStr = $this->getWhereStrForOperator($where, $op, $val, $type, $escape = true);
@@ -554,7 +554,7 @@  discard block
 block discarded – undo
554 554
      * @see  Database::where()
555 555
      * @return object        the current Database instance
556 556
      */
557
-    public function orWhere($where, $op = null, $val = null, $escape = true){
557
+    public function orWhere($where, $op = null, $val = null, $escape = true) {
558 558
       return $this->where($where, $op, $val, '', 'OR', $escape);
559 559
     }
560 560
 
@@ -564,7 +564,7 @@  discard block
 block discarded – undo
564 564
      * @see  Database::where()
565 565
      * @return object        the current Database instance
566 566
      */
567
-    public function notWhere($where, $op = null, $val = null, $escape = true){
567
+    public function notWhere($where, $op = null, $val = null, $escape = true) {
568 568
       return $this->where($where, $op, $val, 'NOT ', 'AND', $escape);
569 569
     }
570 570
 
@@ -573,7 +573,7 @@  discard block
 block discarded – undo
573 573
      * @see  Database::where()
574 574
      * @return object        the current Database instance
575 575
      */
576
-    public function orNotWhere($where, $op = null, $val = null, $escape = true){
576
+    public function orNotWhere($where, $op = null, $val = null, $escape = true) {
577 577
     	return $this->where($where, $op, $val, 'NOT ', 'OR', $escape);
578 578
     }
579 579
 
@@ -583,15 +583,15 @@  discard block
 block discarded – undo
583 583
      * @param  string $andOr the multiple conditions separator (AND, OR, etc.)
584 584
      * @return object        the current Database instance
585 585
      */
586
-    public function groupStart($type = '', $andOr = ' AND'){
587
-      if (empty($this->where)){
586
+    public function groupStart($type = '', $andOr = ' AND') {
587
+      if (empty($this->where)) {
588 588
         $this->where = $type . ' (';
589 589
       }
590
-      else{
591
-          if(substr($this->where, -1) == '('){
590
+      else {
591
+          if (substr($this->where, -1) == '(') {
592 592
             $this->where .= $type . ' (';
593 593
           }
594
-          else{
594
+          else {
595 595
           	$this->where .= $andOr . ' ' . $type . ' (';
596 596
           }
597 597
       }
@@ -603,7 +603,7 @@  discard block
 block discarded – undo
603 603
      * @see  Database::groupStart()
604 604
      * @return object        the current Database instance
605 605
      */
606
-    public function notGroupStart(){
606
+    public function notGroupStart() {
607 607
       return $this->groupStart('NOT');
608 608
     }
609 609
 
@@ -612,7 +612,7 @@  discard block
 block discarded – undo
612 612
      * @see  Database::groupStart()
613 613
      * @return object        the current Database instance
614 614
      */
615
-    public function orGroupStart(){
615
+    public function orGroupStart() {
616 616
       return $this->groupStart('', ' OR');
617 617
     }
618 618
 
@@ -621,7 +621,7 @@  discard block
 block discarded – undo
621 621
      * @see  Database::groupStart()
622 622
      * @return object        the current Database instance
623 623
      */
624
-    public function orNotGroupStart(){
624
+    public function orNotGroupStart() {
625 625
       return $this->groupStart('NOT', ' OR');
626 626
     }
627 627
 
@@ -629,7 +629,7 @@  discard block
 block discarded – undo
629 629
      * Close the parenthesis for the grouped SQL
630 630
      * @return object        the current Database instance
631 631
      */
632
-    public function groupEnd(){
632
+    public function groupEnd() {
633 633
       $this->where .= ')';
634 634
       return $this;
635 635
     }
@@ -643,10 +643,10 @@  discard block
 block discarded – undo
643 643
      * @param  boolean $escape whether to escape or not the values
644 644
      * @return object        the current Database instance
645 645
      */
646
-    public function in($field, array $keys, $type = '', $andOr = 'AND', $escape = true){
646
+    public function in($field, array $keys, $type = '', $andOr = 'AND', $escape = true) {
647 647
       $_keys = array();
648
-      foreach ($keys as $k => $v){
649
-        if(is_null($v)){
648
+      foreach ($keys as $k => $v) {
649
+        if (is_null($v)) {
650 650
           $v = '';
651 651
         }
652 652
         $_keys[] = (is_numeric($v) ? $v : ($escape ? $this->escape($v) : $v));
@@ -662,7 +662,7 @@  discard block
 block discarded – undo
662 662
      * @see  Database::in()
663 663
      * @return object        the current Database instance
664 664
      */
665
-    public function notIn($field, array $keys, $escape = true){
665
+    public function notIn($field, array $keys, $escape = true) {
666 666
       return $this->in($field, $keys, 'NOT ', 'AND', $escape);
667 667
     }
668 668
 
@@ -671,7 +671,7 @@  discard block
 block discarded – undo
671 671
      * @see  Database::in()
672 672
      * @return object        the current Database instance
673 673
      */
674
-    public function orIn($field, array $keys, $escape = true){
674
+    public function orIn($field, array $keys, $escape = true) {
675 675
       return $this->in($field, $keys, '', 'OR', $escape);
676 676
     }
677 677
 
@@ -680,7 +680,7 @@  discard block
 block discarded – undo
680 680
      * @see  Database::in()
681 681
      * @return object        the current Database instance
682 682
      */
683
-    public function orNotIn($field, array $keys, $escape = true){
683
+    public function orNotIn($field, array $keys, $escape = true) {
684 684
       return $this->in($field, $keys, 'NOT ', 'OR', $escape);
685 685
     }
686 686
 
@@ -694,11 +694,11 @@  discard block
 block discarded – undo
694 694
      * @param  boolean $escape whether to escape or not the values
695 695
      * @return object        the current Database instance
696 696
      */
697
-    public function between($field, $value1, $value2, $type = '', $andOr = 'AND', $escape = true){
698
-      if(is_null($value1)){
697
+    public function between($field, $value1, $value2, $type = '', $andOr = 'AND', $escape = true) {
698
+      if (is_null($value1)) {
699 699
         $value1 = '';
700 700
       }
701
-      if(is_null($value2)){
701
+      if (is_null($value2)) {
702 702
         $value2 = '';
703 703
       }
704 704
       $whereStr = $field . ' ' . $type . ' BETWEEN ' . ($escape ? $this->escape($value1) : $value1) . ' AND ' . ($escape ? $this->escape($value2) : $value2);
@@ -711,7 +711,7 @@  discard block
 block discarded – undo
711 711
      * @see  Database::between()
712 712
      * @return object        the current Database instance
713 713
      */
714
-    public function notBetween($field, $value1, $value2, $escape = true){
714
+    public function notBetween($field, $value1, $value2, $escape = true) {
715 715
       return $this->between($field, $value1, $value2, 'NOT ', 'AND', $escape);
716 716
     }
717 717
 
@@ -720,7 +720,7 @@  discard block
 block discarded – undo
720 720
      * @see  Database::between()
721 721
      * @return object        the current Database instance
722 722
      */
723
-    public function orBetween($field, $value1, $value2, $escape = true){
723
+    public function orBetween($field, $value1, $value2, $escape = true) {
724 724
       return $this->between($field, $value1, $value2, '', 'OR', $escape);
725 725
     }
726 726
 
@@ -729,7 +729,7 @@  discard block
 block discarded – undo
729 729
      * @see  Database::between()
730 730
      * @return object        the current Database instance
731 731
      */
732
-    public function orNotBetween($field, $value1, $value2, $escape = true){
732
+    public function orNotBetween($field, $value1, $value2, $escape = true) {
733 733
       return $this->between($field, $value1, $value2, 'NOT ', 'OR', $escape);
734 734
     }
735 735
 
@@ -742,20 +742,20 @@  discard block
 block discarded – undo
742 742
      * @param  boolean $escape whether to escape or not the values
743 743
      * @return object        the current Database instance
744 744
      */
745
-    public function like($field, $data, $type = '', $andOr = 'AND', $escape = true){
746
-      if(empty($data)){
745
+    public function like($field, $data, $type = '', $andOr = 'AND', $escape = true) {
746
+      if (empty($data)) {
747 747
         $data = '';
748 748
       }
749 749
       $like = $escape ? $this->escape($data) : $data;
750
-      if (empty($this->where)){
750
+      if (empty($this->where)) {
751 751
         $this->where = $field . ' ' . $type . 'LIKE ' . $like;
752 752
       }
753
-      else{
754
-        if(substr($this->where, -1) == '('){
753
+      else {
754
+        if (substr($this->where, -1) == '(') {
755 755
           $this->where = $this->where . ' ' . $field . ' ' . $type . 'LIKE ' . $like;
756 756
         }
757
-        else{
758
-          $this->where = $this->where . ' '.$andOr.' ' . $field . ' ' . $type . 'LIKE ' . $like;
757
+        else {
758
+          $this->where = $this->where . ' ' . $andOr . ' ' . $field . ' ' . $type . 'LIKE ' . $like;
759 759
         }
760 760
       }
761 761
       return $this;
@@ -766,7 +766,7 @@  discard block
 block discarded – undo
766 766
      * @see  Database::like()
767 767
      * @return object        the current Database instance
768 768
      */
769
-    public function orLike($field, $data, $escape = true){
769
+    public function orLike($field, $data, $escape = true) {
770 770
       return $this->like($field, $data, '', 'OR', $escape);
771 771
     }
772 772
 
@@ -775,7 +775,7 @@  discard block
 block discarded – undo
775 775
      * @see  Database::like()
776 776
      * @return object        the current Database instance
777 777
      */
778
-    public function notLike($field, $data, $escape = true){
778
+    public function notLike($field, $data, $escape = true) {
779 779
       return $this->like($field, $data, 'NOT ', 'AND', $escape);
780 780
     }
781 781
 
@@ -784,7 +784,7 @@  discard block
 block discarded – undo
784 784
      * @see  Database::like()
785 785
      * @return object        the current Database instance
786 786
      */
787
-    public function orNotLike($field, $data, $escape = true){
787
+    public function orNotLike($field, $data, $escape = true) {
788 788
       return $this->like($field, $data, 'NOT ', 'OR', $escape);
789 789
     }
790 790
 
@@ -795,14 +795,14 @@  discard block
 block discarded – undo
795 795
      * @param  int $limitEnd the limit count
796 796
      * @return object        the current Database instance
797 797
      */
798
-    public function limit($limit, $limitEnd = null){
799
-      if(empty($limit)){
798
+    public function limit($limit, $limitEnd = null) {
799
+      if (empty($limit)) {
800 800
         return;
801 801
       }
802
-      if (! is_null($limitEnd)){
802
+      if (!is_null($limitEnd)) {
803 803
         $this->limit = $limit . ', ' . $limitEnd;
804 804
       }
805
-      else{
805
+      else {
806 806
         $this->limit = $limit;
807 807
       }
808 808
       return $this;
@@ -814,16 +814,16 @@  discard block
 block discarded – undo
814 814
      * @param  string $orderDir the order direction (ASC or DESC)
815 815
      * @return object        the current Database instance
816 816
      */
817
-    public function orderBy($orderBy, $orderDir = ' ASC'){
818
-      if (! empty($orderDir)){
819
-        $this->orderBy = ! $this->orderBy ? ($orderBy . ' ' . strtoupper($orderDir)) : $this->orderBy . ', ' . $orderBy . ' ' . strtoupper($orderDir);
817
+    public function orderBy($orderBy, $orderDir = ' ASC') {
818
+      if (!empty($orderDir)) {
819
+        $this->orderBy = !$this->orderBy ? ($orderBy . ' ' . strtoupper($orderDir)) : $this->orderBy . ', ' . $orderBy . ' ' . strtoupper($orderDir);
820 820
       }
821
-      else{
822
-        if(stristr($orderBy, ' ') || $orderBy == 'rand()'){
823
-          $this->orderBy = ! $this->orderBy ? $orderBy : $this->orderBy . ', ' . $orderBy;
821
+      else {
822
+        if (stristr($orderBy, ' ') || $orderBy == 'rand()') {
823
+          $this->orderBy = !$this->orderBy ? $orderBy : $this->orderBy . ', ' . $orderBy;
824 824
         }
825
-        else{
826
-          $this->orderBy = ! $this->orderBy ? ($orderBy . ' ASC') : $this->orderBy . ', ' . ($orderBy . ' ASC');
825
+        else {
826
+          $this->orderBy = !$this->orderBy ? ($orderBy . ' ASC') : $this->orderBy . ', ' . ($orderBy . ' ASC');
827 827
         }
828 828
       }
829 829
       return $this;
@@ -834,11 +834,11 @@  discard block
 block discarded – undo
834 834
      * @param  string|array $field the field name used or array of field list
835 835
      * @return object        the current Database instance
836 836
      */
837
-    public function groupBy($field){
838
-      if(is_array($field)){
837
+    public function groupBy($field) {
838
+      if (is_array($field)) {
839 839
         $this->groupBy = implode(', ', $field);
840 840
       }
841
-      else{
841
+      else {
842 842
         $this->groupBy = $field;
843 843
       }
844 844
       return $this;
@@ -852,13 +852,13 @@  discard block
 block discarded – undo
852 852
      * @param  boolean $escape whether to escape or not the values
853 853
      * @return object        the current Database instance
854 854
      */
855
-    public function having($field, $op = null, $val = null, $escape = true){
856
-      if(is_array($op)){
855
+    public function having($field, $op = null, $val = null, $escape = true) {
856
+      if (is_array($op)) {
857 857
         $x = explode('?', $field);
858 858
         $w = '';
859
-        foreach($x as $k => $v){
860
-  	      if(!empty($v)){
861
-            if(isset($op[$k]) && is_null($op[$k])){
859
+        foreach ($x as $k => $v) {
860
+  	      if (!empty($v)) {
861
+            if (isset($op[$k]) && is_null($op[$k])) {
862 862
               $op[$k] = '';
863 863
             }
864 864
   	      	$w .= $v . (isset($op[$k]) ? ($escape ? $this->escape($op[$k]) : $op[$k]) : '');
@@ -866,14 +866,14 @@  discard block
 block discarded – undo
866 866
       	}
867 867
         $this->having = $w;
868 868
       }
869
-      else if (! in_array($op, $this->operatorList)){
870
-        if(is_null($op)){
869
+      else if (!in_array($op, $this->operatorList)) {
870
+        if (is_null($op)) {
871 871
           $op = '';
872 872
         }
873 873
         $this->having = $field . ' > ' . ($escape ? $this->escape($op) : $op);
874 874
       }
875
-      else{
876
-        if(is_null($val)){
875
+      else {
876
+        if (is_null($val)) {
877 877
           $val = '';
878 878
         }
879 879
         $this->having = $field . ' ' . $op . ' ' . ($escape ? $this->escape($val) : $val);
@@ -885,7 +885,7 @@  discard block
 block discarded – undo
885 885
      * Return the number of rows returned by the current query
886 886
      * @return int
887 887
      */
888
-    public function numRows(){
888
+    public function numRows() {
889 889
       return $this->numRows;
890 890
     }
891 891
 
@@ -893,15 +893,15 @@  discard block
 block discarded – undo
893 893
      * Return the last insert id value
894 894
      * @return mixed
895 895
      */
896
-    public function insertId(){
896
+    public function insertId() {
897 897
       return $this->insertId;
898 898
     }
899 899
 
900 900
     /**
901 901
      * Show an error got from the current query (SQL command synthax error, database driver returned error, etc.)
902 902
      */
903
-    public function error(){
904
-  		if($this->error){
903
+    public function error() {
904
+  		if ($this->error) {
905 905
   			show_error('Query: "' . $this->query . '" Error: ' . $this->error, 'Database Error');
906 906
   		}
907 907
     }
@@ -912,14 +912,14 @@  discard block
 block discarded – undo
912 912
      * If is string will determine the result type "array" or "object"
913 913
      * @return mixed       the query SQL string or the record result
914 914
      */
915
-    public function get($returnSQLQueryOrResultType = false){
915
+    public function get($returnSQLQueryOrResultType = false) {
916 916
       $this->limit = 1;
917 917
       $query = $this->getAll(true);
918
-      if($returnSQLQueryOrResultType === true){
918
+      if ($returnSQLQueryOrResultType === true) {
919 919
         return $query;
920 920
       }
921
-      else{
922
-        return $this->query( $query, false, (($returnSQLQueryOrResultType == 'array') ? true : false) );
921
+      else {
922
+        return $this->query($query, false, (($returnSQLQueryOrResultType == 'array') ? true : false));
923 923
       }
924 924
     }
925 925
 
@@ -929,37 +929,37 @@  discard block
 block discarded – undo
929 929
      * If is string will determine the result type "array" or "object"
930 930
      * @return mixed       the query SQL string or the record result
931 931
      */
932
-    public function getAll($returnSQLQueryOrResultType = false){
932
+    public function getAll($returnSQLQueryOrResultType = false) {
933 933
       $query = 'SELECT ' . $this->select . ' FROM ' . $this->from;
934
-      if (! empty($this->join)){
934
+      if (!empty($this->join)) {
935 935
         $query .= $this->join;
936 936
       }
937 937
 	  
938
-      if (! empty($this->where)){
938
+      if (!empty($this->where)) {
939 939
         $query .= ' WHERE ' . $this->where;
940 940
       }
941 941
 
942
-      if (! empty($this->groupBy)){
942
+      if (!empty($this->groupBy)) {
943 943
         $query .= ' GROUP BY ' . $this->groupBy;
944 944
       }
945 945
 
946
-      if (! empty($this->having)){
946
+      if (!empty($this->having)) {
947 947
         $query .= ' HAVING ' . $this->having;
948 948
       }
949 949
 
950
-      if (! empty($this->orderBy)){
950
+      if (!empty($this->orderBy)) {
951 951
           $query .= ' ORDER BY ' . $this->orderBy;
952 952
       }
953 953
 
954
-      if(! empty($this->limit)){
954
+      if (!empty($this->limit)) {
955 955
       	$query .= ' LIMIT ' . $this->limit;
956 956
       }
957 957
 	  
958
-	   if($returnSQLQueryOrResultType === true){
958
+	   if ($returnSQLQueryOrResultType === true) {
959 959
       	return $query;
960 960
       }
961
-      else{
962
-    	   return $this->query($query, true, (($returnSQLQueryOrResultType == 'array') ? true : false) );
961
+      else {
962
+    	   return $this->query($query, true, (($returnSQLQueryOrResultType == 'array') ? true : false));
963 963
       }
964 964
     }
965 965
 
@@ -969,15 +969,15 @@  discard block
 block discarded – undo
969 969
      * @param  boolean $escape  whether to escape or not the values
970 970
      * @return mixed          the insert id of the new record or null
971 971
      */
972
-    public function insert($data = array(), $escape = true){
972
+    public function insert($data = array(), $escape = true) {
973 973
       $column = array();
974 974
       $val = array();
975
-      if(empty($data) && $this->getData()){
975
+      if (empty($data) && $this->getData()) {
976 976
         $columns = array_keys($this->getData());
977 977
         $column = implode(',', $columns);
978 978
         $val = implode(', ', $this->getData());
979 979
       }
980
-      else{
980
+      else {
981 981
         $columns = array_keys($data);
982 982
         $column = implode(',', $columns);
983 983
         $val = implode(', ', ($escape ? array_map(array($this, 'escape'), $data) : $data));
@@ -986,14 +986,14 @@  discard block
 block discarded – undo
986 986
       $query = 'INSERT INTO ' . $this->from . ' (' . $column . ') VALUES (' . $val . ')';
987 987
       $query = $this->query($query);
988 988
 
989
-      if ($query){
990
-        if(! $this->pdo){
989
+      if ($query) {
990
+        if (!$this->pdo) {
991 991
           $this->connect();
992 992
         }
993 993
         $this->insertId = $this->pdo->lastInsertId();
994 994
         return $this->insertId();
995 995
       }
996
-      else{
996
+      else {
997 997
 		  return false;
998 998
       }
999 999
     }
@@ -1004,29 +1004,29 @@  discard block
 block discarded – undo
1004 1004
      * @param  boolean $escape  whether to escape or not the values
1005 1005
      * @return mixed          the update status
1006 1006
      */
1007
-    public function update($data = array(), $escape = true){
1007
+    public function update($data = array(), $escape = true) {
1008 1008
       $query = 'UPDATE ' . $this->from . ' SET ';
1009 1009
       $values = array();
1010
-      if(empty($data) && $this->getData()){
1011
-        foreach ($this->getData() as $column => $val){
1010
+      if (empty($data) && $this->getData()) {
1011
+        foreach ($this->getData() as $column => $val) {
1012 1012
           $values[] = $column . ' = ' . $val;
1013 1013
         }
1014 1014
       }
1015
-      else{
1016
-        foreach ($data as $column => $val){
1015
+      else {
1016
+        foreach ($data as $column => $val) {
1017 1017
           $values[] = $column . '=' . ($escape ? $this->escape($val) : $val);
1018 1018
         }
1019 1019
       }
1020 1020
       $query .= implode(', ', $values);
1021
-      if (! empty($this->where)){
1021
+      if (!empty($this->where)) {
1022 1022
         $query .= ' WHERE ' . $this->where;
1023 1023
       }
1024 1024
 
1025
-      if (! empty($this->orderBy)){
1025
+      if (!empty($this->orderBy)) {
1026 1026
         $query .= ' ORDER BY ' . $this->orderBy;
1027 1027
       }
1028 1028
 
1029
-      if (! empty($this->limit)){
1029
+      if (!empty($this->limit)) {
1030 1030
         $query .= ' LIMIT ' . $this->limit;
1031 1031
       }
1032 1032
       return $this->query($query);
@@ -1036,22 +1036,22 @@  discard block
 block discarded – undo
1036 1036
      * Delete the record in database
1037 1037
      * @return mixed the delete status
1038 1038
      */
1039
-    public function delete(){
1039
+    public function delete() {
1040 1040
     	$query = 'DELETE FROM ' . $this->from;
1041 1041
 
1042
-    	if (! empty($this->where)){
1042
+    	if (!empty($this->where)) {
1043 1043
     		$query .= ' WHERE ' . $this->where;
1044 1044
       	}
1045 1045
 
1046
-    	if (! empty($this->orderBy)){
1046
+    	if (!empty($this->orderBy)) {
1047 1047
     	  $query .= ' ORDER BY ' . $this->orderBy;
1048 1048
       	}
1049 1049
 
1050
-    	if (! empty($this->limit)){
1050
+    	if (!empty($this->limit)) {
1051 1051
     		$query .= ' LIMIT ' . $this->limit;
1052 1052
       	}
1053 1053
 
1054
-    	if($query == 'DELETE FROM ' . $this->from && $this->config['driver'] != 'sqlite'){  
1054
+    	if ($query == 'DELETE FROM ' . $this->from && $this->config['driver'] != 'sqlite') {  
1055 1055
     		$query = 'TRUNCATE TABLE ' . $this->from;
1056 1056
       }
1057 1057
     	return $this->query($query);
@@ -1064,13 +1064,13 @@  discard block
 block discarded – undo
1064 1064
      * @param  boolean $array return the result as array
1065 1065
      * @return mixed         the query result
1066 1066
      */
1067
-    public function query($query, $all = true, $array = false){
1067
+    public function query($query, $all = true, $array = false) {
1068 1068
       $this->reset();
1069
-      if(is_array($all)){
1069
+      if (is_array($all)) {
1070 1070
         $x = explode('?', $query);
1071 1071
         $q = '';
1072
-        foreach($x as $k => $v){
1073
-          if(! empty($v)){
1072
+        foreach ($x as $k => $v) {
1073
+          if (!empty($v)) {
1074 1074
             $q .= $v . (isset($all[$k]) ? $this->escape($all[$k]) : '');
1075 1075
           }
1076 1076
         }
@@ -1079,7 +1079,7 @@  discard block
 block discarded – undo
1079 1079
 
1080 1080
       $this->query = preg_replace('/\s\s+|\t\t+/', ' ', trim($query));
1081 1081
       $sqlSELECTQuery = stristr($this->query, 'SELECT');
1082
-      $this->logger->info('Execute SQL query ['.$this->query.'], return type: ' . ($array?'ARRAY':'OBJECT') .', return as list: ' . ($all ? 'YES':'NO'));
1082
+      $this->logger->info('Execute SQL query [' . $this->query . '], return type: ' . ($array ? 'ARRAY' : 'OBJECT') . ', return as list: ' . ($all ? 'YES' : 'NO'));
1083 1083
       //cache expire time
1084 1084
   	  $cacheExpire = $this->temporaryCacheTtl;
1085 1085
   	  
@@ -1101,34 +1101,34 @@  discard block
 block discarded – undo
1101 1101
   	  //if can use cache feature for this query
1102 1102
   	  $dbCacheStatus = $cacheEnable && $cacheExpire > 0;
1103 1103
 	  
1104
-      if ($dbCacheStatus && $sqlSELECTQuery){
1104
+      if ($dbCacheStatus && $sqlSELECTQuery) {
1105 1105
         $this->logger->info('The cache is enabled for this query, try to get result from cache'); 
1106 1106
         $cacheKey = md5($query . $all . $array);
1107
-        if(is_object($this->cacheInstance)){
1107
+        if (is_object($this->cacheInstance)) {
1108 1108
           $cacheInstance = $this->cacheInstance;
1109 1109
         }
1110
-        else{
1110
+        else {
1111 1111
           $obj = & get_instance();
1112 1112
           $cacheInstance = $obj->cache;  
1113 1113
         }
1114 1114
         $cacheContent = $cacheInstance->get($cacheKey);        
1115 1115
       }
1116
-      else{
1116
+      else {
1117 1117
 		  $this->logger->info('The cache is not enabled for this query or is not the SELECT query, get the result directly from real database');
1118 1118
       }
1119 1119
 
1120
-      if(! $this->pdo){
1120
+      if (!$this->pdo) {
1121 1121
         $this->connect();
1122 1122
       }
1123 1123
       
1124
-      if (! $cacheContent && $sqlSELECTQuery){
1124
+      if (!$cacheContent && $sqlSELECTQuery) {
1125 1125
 		    //for database query execution time
1126 1126
         $benchmarkMarkerKey = md5($query . $all . $array);
1127 1127
         $bench = null;
1128
-        if(is_object($this->benchmarkInstance)){
1128
+        if (is_object($this->benchmarkInstance)) {
1129 1129
           $bench = $this->benchmarkInstance;
1130 1130
         }
1131
-        else{
1131
+        else {
1132 1132
           $obj = & get_instance();
1133 1133
           $bench = $obj->benchmark;  
1134 1134
         }
@@ -1139,64 +1139,64 @@  discard block
 block discarded – undo
1139 1139
     		//get response time for this query
1140 1140
         $responseTime = $bench->elapsedTime('DATABASE_QUERY_START(' . $benchmarkMarkerKey . ')', 'DATABASE_QUERY_END(' . $benchmarkMarkerKey . ')');
1141 1141
 	     	//TODO use the configuration value for the high response time currently is 1 second
1142
-        if($responseTime >= 1 ){
1143
-            $this->logger->warning('High response time while processing database query [' .$query. ']. The response time is [' .$responseTime. '] sec.');
1142
+        if ($responseTime >= 1) {
1143
+            $this->logger->warning('High response time while processing database query [' . $query . ']. The response time is [' . $responseTime . '] sec.');
1144 1144
         }
1145
-        if ($sqlQuery){
1145
+        if ($sqlQuery) {
1146 1146
             //if need return all result like list of record
1147
-            if ($all){
1147
+            if ($all) {
1148 1148
     				    $this->result = ($array === false) ? $sqlQuery->fetchAll(PDO::FETCH_OBJ) : $sqlQuery->fetchAll(PDO::FETCH_ASSOC);
1149 1149
     		    }
1150
-            else{
1150
+            else {
1151 1151
 				        $this->result = ($array === false) ? $sqlQuery->fetch(PDO::FETCH_OBJ) : $sqlQuery->fetch(PDO::FETCH_ASSOC);
1152 1152
             }
1153 1153
             //Sqlite and pgsql always return 0 when using rowCount()
1154
-            if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1154
+            if (in_array($this->config['driver'], array('sqlite', 'pgsql'))) {
1155 1155
               $this->numRows = count($this->result);  
1156 1156
             }
1157
-            else{
1157
+            else {
1158 1158
               $this->numRows = $sqlQuery->rowCount(); 
1159 1159
             }
1160 1160
 
1161
-          if ($dbCacheStatus && $sqlSELECTQuery){
1162
-              $this->logger->info('Save the result for query [' .$this->query. '] into cache for future use');
1161
+          if ($dbCacheStatus && $sqlSELECTQuery) {
1162
+              $this->logger->info('Save the result for query [' . $this->query . '] into cache for future use');
1163 1163
               $cacheInstance->set($cacheKey, $this->result, $cacheExpire);
1164 1164
           }
1165 1165
         }
1166
-        else{
1166
+        else {
1167 1167
           $error = $this->pdo->errorInfo();
1168 1168
           $this->error = isset($error[2]) ? $error[2] : '';
1169 1169
           $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1170 1170
           $this->error();
1171 1171
         }
1172 1172
       }
1173
-      else if ((! $cacheContent && !$sqlSELECTQuery) || ($cacheContent && !$sqlSELECTQuery)){
1173
+      else if ((!$cacheContent && !$sqlSELECTQuery) || ($cacheContent && !$sqlSELECTQuery)) {
1174 1174
     		$queryStr = $this->pdo->query($this->query);
1175
-    		if($queryStr){
1175
+    		if ($queryStr) {
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->result = 1; //to test the result for the query like UPDATE, INSERT, DELETE
1179 1179
             $this->numRows = 1;  
1180 1180
           }
1181
-          else{
1181
+          else {
1182 1182
               $this->result = $queryStr->rowCount() >= 0; //to test the result for the query like UPDATE, INSERT, DELETE
1183 1183
               $this->numRows = $queryStr->rowCount(); 
1184 1184
           }
1185 1185
     		}
1186
-        if (! $this->result){
1186
+        if (!$this->result) {
1187 1187
           $error = $this->pdo->errorInfo();
1188 1188
           $this->error = isset($error[2]) ? $error[2] : '';
1189 1189
           $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1190 1190
           $this->error();
1191 1191
         }
1192 1192
       }
1193
-      else{
1194
-        $this->logger->info('The result for query [' .$this->query. '] already cached use it');
1193
+      else {
1194
+        $this->logger->info('The result for query [' . $this->query . '] already cached use it');
1195 1195
         $this->result = $cacheContent;
1196 1196
 	     	$this->numRows = count($this->result);
1197 1197
       }
1198 1198
       $this->queryCount++;
1199
-      if(! $this->result){
1199
+      if (!$this->result) {
1200 1200
         $this->logger->info('No result where found for the query [' . $query . ']');
1201 1201
       }
1202 1202
       return $this->result;
@@ -1207,8 +1207,8 @@  discard block
 block discarded – undo
1207 1207
      * @param integer $ttl the cache time to live in second
1208 1208
      * @return object        the current Database instance
1209 1209
      */
1210
-    public function setCache($ttl = 0){
1211
-      if($ttl > 0){
1210
+    public function setCache($ttl = 0) {
1211
+      if ($ttl > 0) {
1212 1212
         $this->cacheTtl = $ttl;
1213 1213
 		    $this->temporaryCacheTtl = $ttl;
1214 1214
       }
@@ -1220,8 +1220,8 @@  discard block
 block discarded – undo
1220 1220
 	 * @param  integer $ttl the cache time to live in second
1221 1221
 	 * @return object        the current Database instance
1222 1222
 	 */
1223
-	public function cached($ttl = 0){
1224
-      if($ttl > 0){
1223
+	public function cached($ttl = 0) {
1224
+      if ($ttl > 0) {
1225 1225
         $this->temporaryCacheTtl = $ttl;
1226 1226
       }
1227 1227
 	  return $this;
@@ -1232,11 +1232,11 @@  discard block
 block discarded – undo
1232 1232
      * @param  mixed $data the data to be escaped
1233 1233
      * @return mixed       the data after escaped
1234 1234
      */
1235
-    public function escape($data){
1236
-      if(is_null($data)){
1235
+    public function escape($data) {
1236
+      if (is_null($data)) {
1237 1237
         return null;
1238 1238
       }
1239
-      if(! $this->pdo){
1239
+      if (!$this->pdo) {
1240 1240
         $this->connect();
1241 1241
       }
1242 1242
       return $this->pdo->quote(trim($data));
@@ -1246,7 +1246,7 @@  discard block
 block discarded – undo
1246 1246
      * Return the number query executed count for the current request
1247 1247
      * @return int
1248 1248
      */
1249
-    public function queryCount(){
1249
+    public function queryCount() {
1250 1250
       return $this->queryCount;
1251 1251
     }
1252 1252
 
@@ -1254,7 +1254,7 @@  discard block
 block discarded – undo
1254 1254
      * Return the current query SQL string
1255 1255
      * @return string
1256 1256
      */
1257
-    public function getQuery(){
1257
+    public function getQuery() {
1258 1258
       return $this->query;
1259 1259
     }
1260 1260
 
@@ -1262,7 +1262,7 @@  discard block
 block discarded – undo
1262 1262
      * Return the application database name
1263 1263
      * @return string
1264 1264
      */
1265
-    public function getDatabaseName(){
1265
+    public function getDatabaseName() {
1266 1266
       return $this->databaseName;
1267 1267
     }
1268 1268
 
@@ -1270,7 +1270,7 @@  discard block
 block discarded – undo
1270 1270
      * Return the database configuration
1271 1271
      * @return array
1272 1272
      */
1273
-    public  function getDatabaseConfiguration(){
1273
+    public  function getDatabaseConfiguration() {
1274 1274
       return $this->config;
1275 1275
     }
1276 1276
 
@@ -1278,7 +1278,7 @@  discard block
 block discarded – undo
1278 1278
      * set the database configuration
1279 1279
      * @param array $config the configuration
1280 1280
      */
1281
-    public function setDatabaseConfiguration(array $config){
1281
+    public function setDatabaseConfiguration(array $config) {
1282 1282
       $this->config = array_merge($this->config, $config);
1283 1283
       $this->prefix = $this->config['prefix'];
1284 1284
       $this->databaseName = $this->config['database'];
@@ -1290,7 +1290,7 @@  discard block
 block discarded – undo
1290 1290
      * Return the PDO instance
1291 1291
      * @return PDO
1292 1292
      */
1293
-    public function getPdo(){
1293
+    public function getPdo() {
1294 1294
       return $this->pdo;
1295 1295
     }
1296 1296
 
@@ -1298,7 +1298,7 @@  discard block
 block discarded – undo
1298 1298
      * Set the PDO instance
1299 1299
      * @param PDO $pdo the pdo object
1300 1300
      */
1301
-    public function setPdo(PDO $pdo){
1301
+    public function setPdo(PDO $pdo) {
1302 1302
       $this->pdo = $pdo;
1303 1303
       return $this;
1304 1304
     }
@@ -1308,7 +1308,7 @@  discard block
 block discarded – undo
1308 1308
      * Return the Log instance
1309 1309
      * @return Log
1310 1310
      */
1311
-    public function getLogger(){
1311
+    public function getLogger() {
1312 1312
       return $this->logger;
1313 1313
     }
1314 1314
 
@@ -1316,7 +1316,7 @@  discard block
 block discarded – undo
1316 1316
      * Set the log instance
1317 1317
      * @param Log $logger the log object
1318 1318
      */
1319
-    public function setLogger($logger){
1319
+    public function setLogger($logger) {
1320 1320
       $this->logger = $logger;
1321 1321
       return $this;
1322 1322
     }
@@ -1325,7 +1325,7 @@  discard block
 block discarded – undo
1325 1325
      * Return the cache instance
1326 1326
      * @return CacheInterface
1327 1327
      */
1328
-    public function getCacheInstance(){
1328
+    public function getCacheInstance() {
1329 1329
       return $this->cacheInstance;
1330 1330
     }
1331 1331
 
@@ -1333,7 +1333,7 @@  discard block
 block discarded – undo
1333 1333
      * Set the cache instance
1334 1334
      * @param CacheInterface $cache the cache object
1335 1335
      */
1336
-    public function setCacheInstance($cache){
1336
+    public function setCacheInstance($cache) {
1337 1337
       $this->cacheInstance = $cache;
1338 1338
       return $this;
1339 1339
     }
@@ -1342,7 +1342,7 @@  discard block
 block discarded – undo
1342 1342
      * Return the benchmark instance
1343 1343
      * @return Benchmark
1344 1344
      */
1345
-    public function getBenchmark(){
1345
+    public function getBenchmark() {
1346 1346
       return $this->benchmarkInstance;
1347 1347
     }
1348 1348
 
@@ -1350,7 +1350,7 @@  discard block
 block discarded – undo
1350 1350
      * Set the benchmark instance
1351 1351
      * @param Benchmark $cache the cache object
1352 1352
      */
1353
-    public function setBenchmark($benchmark){
1353
+    public function setBenchmark($benchmark) {
1354 1354
       $this->benchmarkInstance = $benchmark;
1355 1355
       return $this;
1356 1356
     }
@@ -1359,7 +1359,7 @@  discard block
 block discarded – undo
1359 1359
      * Return the data to be used for insert, update, etc.
1360 1360
      * @return array
1361 1361
      */
1362
-    public function getData(){
1362
+    public function getData() {
1363 1363
       return $this->data;
1364 1364
     }
1365 1365
 
@@ -1370,7 +1370,7 @@  discard block
 block discarded – undo
1370 1370
      * @param boolean $escape whether to escape or not the $value
1371 1371
      * @return object        the current Database instance
1372 1372
      */
1373
-    public function setData($key, $value, $escape = true){
1373
+    public function setData($key, $value, $escape = true) {
1374 1374
       $this->data[$key] = $escape ? $this->escape($value) : $value;
1375 1375
       return $this;
1376 1376
     }
@@ -1379,12 +1379,12 @@  discard block
 block discarded – undo
1379 1379
      * Set the Log instance using argument or create new instance
1380 1380
      * @param object $logger the Log instance if not null
1381 1381
      */
1382
-    protected function setLoggerFromParamOrCreateNewInstance(Log $logger = null){
1383
-      if($logger !== null){
1382
+    protected function setLoggerFromParamOrCreateNewInstance(Log $logger = null) {
1383
+      if ($logger !== null) {
1384 1384
         $this->logger = $logger;
1385 1385
       }
1386
-      else{
1387
-          $this->logger =& class_loader('Log', 'classes');
1386
+      else {
1387
+          $this->logger = & class_loader('Log', 'classes');
1388 1388
           $this->logger->setLogger('Library::Database');
1389 1389
       }
1390 1390
     }
@@ -1393,14 +1393,14 @@  discard block
 block discarded – undo
1393 1393
     * Setting the database configuration using the configuration file
1394 1394
     * @param array $overwriteConfig the additional configuration to overwrite with the existing one
1395 1395
     */
1396
-    protected function setDatabaseConfigurationFromConfigFile(array $overwriteConfig = array()){
1396
+    protected function setDatabaseConfigurationFromConfigFile(array $overwriteConfig = array()) {
1397 1397
         $db = array();
1398
-        if(file_exists(CONFIG_PATH . 'database.php')){
1398
+        if (file_exists(CONFIG_PATH . 'database.php')) {
1399 1399
             //here don't use require_once because somewhere user can create database instance directly
1400 1400
             require CONFIG_PATH . 'database.php';
1401 1401
         }
1402 1402
           
1403
-        if(! empty($overwriteConfig)){
1403
+        if (!empty($overwriteConfig)) {
1404 1404
           $db = array_merge($db, $overwriteConfig);
1405 1405
         }
1406 1406
         $config = array();
@@ -1413,12 +1413,12 @@  discard block
 block discarded – undo
1413 1413
         $config['collation'] = isset($db['collation']) ? $db['collation'] : 'utf8_general_ci';
1414 1414
         $config['prefix']    = isset($db['prefix']) ? $db['prefix'] : '';
1415 1415
         $port = '';
1416
-        if(strstr($config['hostname'], ':')){
1416
+        if (strstr($config['hostname'], ':')) {
1417 1417
           $p = explode(':', $config['hostname']);
1418 1418
           $port = isset($p[1]) ? $p[1] : '';
1419 1419
           $config['hostname'] = isset($p[0]) ? $p[0] : '';
1420 1420
         }
1421
-        $config['port']      = $port;
1421
+        $config['port'] = $port;
1422 1422
         $this->setDatabaseConfiguration($config);  
1423 1423
     }
1424 1424
 
@@ -1426,9 +1426,9 @@  discard block
 block discarded – undo
1426 1426
      * This method is used to get the PDO DSN string using th configured driver
1427 1427
      * @return string the DSN string
1428 1428
      */
1429
-    protected function getDsnFromDriver(){
1429
+    protected function getDsnFromDriver() {
1430 1430
       $config = $this->getDatabaseConfiguration();
1431
-      if(! empty($config)){
1431
+      if (!empty($config)) {
1432 1432
             $driverDsnMap = array(
1433 1433
                                     'mysql' => 'mysql:host=' . $config['hostname'] . ';' 
1434 1434
                                                 . (($config['port']) != '' ? 'port=' . $config['port'] . ';' : '') 
@@ -1451,7 +1451,7 @@  discard block
 block discarded – undo
1451 1451
   /**
1452 1452
    * Reset the database class attributs to the initail values before each query.
1453 1453
    */
1454
-  private function reset(){
1454
+  private function reset() {
1455 1455
     $this->select   = '*';
1456 1456
     $this->from     = null;
1457 1457
     $this->where    = null;
@@ -1471,7 +1471,7 @@  discard block
 block discarded – undo
1471 1471
   /**
1472 1472
    * The class destructor
1473 1473
    */
1474
-  public function __destruct(){
1474
+  public function __destruct() {
1475 1475
     $this->pdo = null;
1476 1476
   }
1477 1477
 
Please login to merge, or discard this patch.
Braces   +37 added lines, -74 removed lines patch added patch discarded remove patch
@@ -204,14 +204,12 @@  discard block
 block discarded – undo
204 204
             $this->pdo->exec("SET CHARACTER SET '" . $config['charset'] . "'");
205 205
             $this->pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_OBJ);
206 206
             return true;
207
-          }
208
-          catch (PDOException $e){
207
+          } catch (PDOException $e){
209 208
             $this->logger->fatal($e->getMessage());
210 209
             show_error('Cannot connect to Database.');
211 210
             return false;
212 211
           }
213
-      }
214
-      else{
212
+      } else{
215 213
         show_error('Database configuration is not set.');
216 214
         return false;
217 215
       }
@@ -229,8 +227,7 @@  discard block
 block discarded – undo
229 227
           $froms .= $this->prefix . $key . ', ';
230 228
         }
231 229
         $this->from = rtrim($froms, ', ');
232
-      }
233
-      else{
230
+      } else{
234 231
         $this->from = $this->prefix . $table;
235 232
       }
236 233
       return $this;
@@ -336,8 +333,7 @@  discard block
 block discarded – undo
336 333
       }
337 334
       if (empty($this->join)){
338 335
         $this->join = ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
339
-      }
340
-      else{
336
+      } else{
341 337
         $this->join = $this->join . ' ' . $type . 'JOIN' . ' ' . $table . ' ON ' . $on;
342 338
       }
343 339
       return $this;
@@ -408,12 +404,10 @@  discard block
 block discarded – undo
408 404
         foreach($field as $f){
409 405
         	$this->whereIsNull($f, $andOr);
410 406
         }
411
-      }
412
-      else{
407
+      } else{
413 408
         if (! $this->where){
414 409
           $this->where = $field.' IS NULL ';
415
-        }
416
-        else{
410
+        } else{
417 411
             $this->where = $this->where . ' '.$andOr.' ' . $field.' IS NULL ';
418 412
           }
419 413
       }
@@ -431,12 +425,10 @@  discard block
 block discarded – undo
431 425
         foreach($field as $f){
432 426
           $this->whereIsNotNull($f, $andOr);
433 427
         }
434
-      }
435
-      else{
428
+      } else{
436 429
         if (! $this->where){
437 430
           $this->where = $field.' IS NOT NULL ';
438
-        }
439
-        else{
431
+        } else{
440 432
             $this->where = $this->where . ' '.$andOr.' ' . $field.' IS NOT NULL ';
441 433
           }
442 434
       }
@@ -494,8 +486,7 @@  discard block
 block discarded – undo
494 486
             $op = '';
495 487
           }
496 488
           $w = $type . $where . ' = ' . ($escape ? $this->escape($op) : $op);
497
-        }
498
-        else{
489
+        } else{
499 490
           if(is_null($val)){
500 491
             $val = '';
501 492
           }
@@ -512,12 +503,10 @@  discard block
 block discarded – undo
512 503
       protected function setWhereStr($whereStr, $andOr = 'AND'){
513 504
         if (empty($this->where)){
514 505
           $this->where = $whereStr;
515
-        }
516
-        else{
506
+        } else{
517 507
           if(substr($this->where, -1) == '('){
518 508
             $this->where = $this->where . ' ' . $whereStr;
519
-          }
520
-          else{
509
+          } else{
521 510
             $this->where = $this->where . ' '.$andOr.' ' . $whereStr;
522 511
           }
523 512
         }
@@ -537,8 +526,7 @@  discard block
 block discarded – undo
537 526
       $whereStr = '';
538 527
       if (is_array($where)){
539 528
         $whereStr = $this->getWhereStrIfIsArray($where, $type, $andOr, $escape);
540
-      }
541
-      else{
529
+      } else{
542 530
         if(is_array($op)){
543 531
           $whereStr = $this->getWhereStrIfOperatorIsArray($where, $op, $type, $escape);
544 532
         } else {
@@ -586,12 +574,10 @@  discard block
 block discarded – undo
586 574
     public function groupStart($type = '', $andOr = ' AND'){
587 575
       if (empty($this->where)){
588 576
         $this->where = $type . ' (';
589
-      }
590
-      else{
577
+      } else{
591 578
           if(substr($this->where, -1) == '('){
592 579
             $this->where .= $type . ' (';
593
-          }
594
-          else{
580
+          } else{
595 581
           	$this->where .= $andOr . ' ' . $type . ' (';
596 582
           }
597 583
       }
@@ -749,12 +735,10 @@  discard block
 block discarded – undo
749 735
       $like = $escape ? $this->escape($data) : $data;
750 736
       if (empty($this->where)){
751 737
         $this->where = $field . ' ' . $type . 'LIKE ' . $like;
752
-      }
753
-      else{
738
+      } else{
754 739
         if(substr($this->where, -1) == '('){
755 740
           $this->where = $this->where . ' ' . $field . ' ' . $type . 'LIKE ' . $like;
756
-        }
757
-        else{
741
+        } else{
758 742
           $this->where = $this->where . ' '.$andOr.' ' . $field . ' ' . $type . 'LIKE ' . $like;
759 743
         }
760 744
       }
@@ -801,8 +785,7 @@  discard block
 block discarded – undo
801 785
       }
802 786
       if (! is_null($limitEnd)){
803 787
         $this->limit = $limit . ', ' . $limitEnd;
804
-      }
805
-      else{
788
+      } else{
806 789
         $this->limit = $limit;
807 790
       }
808 791
       return $this;
@@ -817,12 +800,10 @@  discard block
 block discarded – undo
817 800
     public function orderBy($orderBy, $orderDir = ' ASC'){
818 801
       if (! empty($orderDir)){
819 802
         $this->orderBy = ! $this->orderBy ? ($orderBy . ' ' . strtoupper($orderDir)) : $this->orderBy . ', ' . $orderBy . ' ' . strtoupper($orderDir);
820
-      }
821
-      else{
803
+      } else{
822 804
         if(stristr($orderBy, ' ') || $orderBy == 'rand()'){
823 805
           $this->orderBy = ! $this->orderBy ? $orderBy : $this->orderBy . ', ' . $orderBy;
824
-        }
825
-        else{
806
+        } else{
826 807
           $this->orderBy = ! $this->orderBy ? ($orderBy . ' ASC') : $this->orderBy . ', ' . ($orderBy . ' ASC');
827 808
         }
828 809
       }
@@ -837,8 +818,7 @@  discard block
 block discarded – undo
837 818
     public function groupBy($field){
838 819
       if(is_array($field)){
839 820
         $this->groupBy = implode(', ', $field);
840
-      }
841
-      else{
821
+      } else{
842 822
         $this->groupBy = $field;
843 823
       }
844 824
       return $this;
@@ -865,14 +845,12 @@  discard block
 block discarded – undo
865 845
   	      }
866 846
       	}
867 847
         $this->having = $w;
868
-      }
869
-      else if (! in_array($op, $this->operatorList)){
848
+      } else if (! in_array($op, $this->operatorList)){
870 849
         if(is_null($op)){
871 850
           $op = '';
872 851
         }
873 852
         $this->having = $field . ' > ' . ($escape ? $this->escape($op) : $op);
874
-      }
875
-      else{
853
+      } else{
876 854
         if(is_null($val)){
877 855
           $val = '';
878 856
         }
@@ -917,8 +895,7 @@  discard block
 block discarded – undo
917 895
       $query = $this->getAll(true);
918 896
       if($returnSQLQueryOrResultType === true){
919 897
         return $query;
920
-      }
921
-      else{
898
+      } else{
922 899
         return $this->query( $query, false, (($returnSQLQueryOrResultType == 'array') ? true : false) );
923 900
       }
924 901
     }
@@ -957,8 +934,7 @@  discard block
 block discarded – undo
957 934
 	  
958 935
 	   if($returnSQLQueryOrResultType === true){
959 936
       	return $query;
960
-      }
961
-      else{
937
+      } else{
962 938
     	   return $this->query($query, true, (($returnSQLQueryOrResultType == 'array') ? true : false) );
963 939
       }
964 940
     }
@@ -976,8 +952,7 @@  discard block
 block discarded – undo
976 952
         $columns = array_keys($this->getData());
977 953
         $column = implode(',', $columns);
978 954
         $val = implode(', ', $this->getData());
979
-      }
980
-      else{
955
+      } else{
981 956
         $columns = array_keys($data);
982 957
         $column = implode(',', $columns);
983 958
         $val = implode(', ', ($escape ? array_map(array($this, 'escape'), $data) : $data));
@@ -992,8 +967,7 @@  discard block
 block discarded – undo
992 967
         }
993 968
         $this->insertId = $this->pdo->lastInsertId();
994 969
         return $this->insertId();
995
-      }
996
-      else{
970
+      } else{
997 971
 		  return false;
998 972
       }
999 973
     }
@@ -1011,8 +985,7 @@  discard block
 block discarded – undo
1011 985
         foreach ($this->getData() as $column => $val){
1012 986
           $values[] = $column . ' = ' . $val;
1013 987
         }
1014
-      }
1015
-      else{
988
+      } else{
1016 989
         foreach ($data as $column => $val){
1017 990
           $values[] = $column . '=' . ($escape ? $this->escape($val) : $val);
1018 991
         }
@@ -1106,14 +1079,12 @@  discard block
 block discarded – undo
1106 1079
         $cacheKey = md5($query . $all . $array);
1107 1080
         if(is_object($this->cacheInstance)){
1108 1081
           $cacheInstance = $this->cacheInstance;
1109
-        }
1110
-        else{
1082
+        } else{
1111 1083
           $obj = & get_instance();
1112 1084
           $cacheInstance = $obj->cache;  
1113 1085
         }
1114 1086
         $cacheContent = $cacheInstance->get($cacheKey);        
1115
-      }
1116
-      else{
1087
+      } else{
1117 1088
 		  $this->logger->info('The cache is not enabled for this query or is not the SELECT query, get the result directly from real database');
1118 1089
       }
1119 1090
 
@@ -1127,8 +1098,7 @@  discard block
 block discarded – undo
1127 1098
         $bench = null;
1128 1099
         if(is_object($this->benchmarkInstance)){
1129 1100
           $bench = $this->benchmarkInstance;
1130
-        }
1131
-        else{
1101
+        } else{
1132 1102
           $obj = & get_instance();
1133 1103
           $bench = $obj->benchmark;  
1134 1104
         }
@@ -1146,15 +1116,13 @@  discard block
 block discarded – undo
1146 1116
             //if need return all result like list of record
1147 1117
             if ($all){
1148 1118
     				    $this->result = ($array === false) ? $sqlQuery->fetchAll(PDO::FETCH_OBJ) : $sqlQuery->fetchAll(PDO::FETCH_ASSOC);
1149
-    		    }
1150
-            else{
1119
+    		    } else{
1151 1120
 				        $this->result = ($array === false) ? $sqlQuery->fetch(PDO::FETCH_OBJ) : $sqlQuery->fetch(PDO::FETCH_ASSOC);
1152 1121
             }
1153 1122
             //Sqlite and pgsql always return 0 when using rowCount()
1154 1123
             if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1155 1124
               $this->numRows = count($this->result);  
1156
-            }
1157
-            else{
1125
+            } else{
1158 1126
               $this->numRows = $sqlQuery->rowCount(); 
1159 1127
             }
1160 1128
 
@@ -1162,23 +1130,20 @@  discard block
 block discarded – undo
1162 1130
               $this->logger->info('Save the result for query [' .$this->query. '] into cache for future use');
1163 1131
               $cacheInstance->set($cacheKey, $this->result, $cacheExpire);
1164 1132
           }
1165
-        }
1166
-        else{
1133
+        } else{
1167 1134
           $error = $this->pdo->errorInfo();
1168 1135
           $this->error = isset($error[2]) ? $error[2] : '';
1169 1136
           $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1170 1137
           $this->error();
1171 1138
         }
1172
-      }
1173
-      else if ((! $cacheContent && !$sqlSELECTQuery) || ($cacheContent && !$sqlSELECTQuery)){
1139
+      } else if ((! $cacheContent && !$sqlSELECTQuery) || ($cacheContent && !$sqlSELECTQuery)){
1174 1140
     		$queryStr = $this->pdo->query($this->query);
1175 1141
     		if($queryStr){
1176 1142
           //Sqlite and pgsql always return 0 when using rowCount()
1177 1143
           if(in_array($this->config['driver'], array('sqlite', 'pgsql'))){
1178 1144
             $this->result = 1; //to test the result for the query like UPDATE, INSERT, DELETE
1179 1145
             $this->numRows = 1;  
1180
-          }
1181
-          else{
1146
+          } else{
1182 1147
               $this->result = $queryStr->rowCount() >= 0; //to test the result for the query like UPDATE, INSERT, DELETE
1183 1148
               $this->numRows = $queryStr->rowCount(); 
1184 1149
           }
@@ -1189,8 +1154,7 @@  discard block
 block discarded – undo
1189 1154
           $this->logger->fatal('The database query execution got error: ' . stringfy_vars($error));
1190 1155
           $this->error();
1191 1156
         }
1192
-      }
1193
-      else{
1157
+      } else{
1194 1158
         $this->logger->info('The result for query [' .$this->query. '] already cached use it');
1195 1159
         $this->result = $cacheContent;
1196 1160
 	     	$this->numRows = count($this->result);
@@ -1382,8 +1346,7 @@  discard block
 block discarded – undo
1382 1346
     protected function setLoggerFromParamOrCreateNewInstance(Log $logger = null){
1383 1347
       if($logger !== null){
1384 1348
         $this->logger = $logger;
1385
-      }
1386
-      else{
1349
+      } else{
1387 1350
           $this->logger =& class_loader('Log', 'classes');
1388 1351
           $this->logger->setLogger('Library::Database');
1389 1352
       }
Please login to merge, or discard this patch.
core/classes/Response.php 1 patch
Spacing   +74 added lines, -74 removed lines patch added patch discarded remove patch
@@ -24,7 +24,7 @@  discard block
 block discarded – undo
24 24
 	 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
25 25
 	*/
26 26
 
27
-	class Response{
27
+	class Response {
28 28
 
29 29
 		/**
30 30
 		 * The list of request header to send with response
@@ -65,9 +65,9 @@  discard block
 block discarded – undo
65 65
 		/**
66 66
 		 * Construct new response instance
67 67
 		 */
68
-		public function __construct(){
69
-			$this->_currentUrl =  (! empty($_SERVER['REQUEST_URI']) ? $_SERVER['REQUEST_URI'] : '' )
70
-					. (! empty($_SERVER['QUERY_STRING']) ? ('?' . $_SERVER['QUERY_STRING']) : '' );
68
+		public function __construct() {
69
+			$this->_currentUrl = (!empty($_SERVER['REQUEST_URI']) ? $_SERVER['REQUEST_URI'] : '')
70
+					. (!empty($_SERVER['QUERY_STRING']) ? ('?' . $_SERVER['QUERY_STRING']) : '');
71 71
 					
72 72
 			$this->_currentUrlCacheKey = md5($this->_currentUrl);
73 73
 			
@@ -82,9 +82,9 @@  discard block
 block discarded – undo
82 82
 		 * Get the logger singleton instance
83 83
 		 * @return Log the logger instance
84 84
 		 */
85
-		private static function getLogger(){
86
-			if(self::$logger == null){
87
-				self::$logger[0] =& class_loader('Log', 'classes');
85
+		private static function getLogger() {
86
+			if (self::$logger == null) {
87
+				self::$logger[0] = & class_loader('Log', 'classes');
88 88
 				self::$logger[0]->setLogger('Library::Response');
89 89
 			}
90 90
 			return self::$logger[0];
@@ -95,12 +95,12 @@  discard block
 block discarded – undo
95 95
 		 * @param  integer $httpCode the HTTP status code
96 96
 		 * @param  array   $headers   the additional headers to add to the existing headers list
97 97
 		 */
98
-		public static function sendHeaders($httpCode = 200, array $headers = array()){
98
+		public static function sendHeaders($httpCode = 200, array $headers = array()) {
99 99
 			set_http_status_header($httpCode);
100 100
 			self::setHeaders($headers);
101
-			if(! headers_sent()){
102
-				foreach(self::getHeaders() as $key => $value){
103
-					header($key .': '.$value);
101
+			if (!headers_sent()) {
102
+				foreach (self::getHeaders() as $key => $value) {
103
+					header($key . ': ' . $value);
104 104
 				}
105 105
 			}
106 106
 		}
@@ -109,7 +109,7 @@  discard block
 block discarded – undo
109 109
 		 * Get the list of the headers
110 110
 		 * @return array the headers list
111 111
 		 */
112
-		public static function getHeaders(){
112
+		public static function getHeaders() {
113 113
 			return self::$headers;
114 114
 		}
115 115
 
@@ -118,7 +118,7 @@  discard block
 block discarded – undo
118 118
 		 * @param  string $name the header name
119 119
 		 * @return string       the header value
120 120
 		 */
121
-		public static function getHeader($name){
121
+		public static function getHeader($name) {
122 122
 			return array_key_exists($name, self::$headers) ? self::$headers[$name] : null;
123 123
 		}
124 124
 
@@ -128,7 +128,7 @@  discard block
 block discarded – undo
128 128
 		 * @param string $name  the header name
129 129
 		 * @param string $value the header value to be set
130 130
 		 */
131
-		public static function setHeader($name, $value){
131
+		public static function setHeader($name, $value) {
132 132
 			self::$headers[$name] = $value;
133 133
 		}
134 134
 
@@ -137,7 +137,7 @@  discard block
 block discarded – undo
137 137
 		 * @param array $headers the list of the headers to set. 
138 138
 		 * Note: this will merge with the existing headers
139 139
 		 */
140
-		public static function setHeaders(array $headers){
140
+		public static function setHeaders(array $headers) {
141 141
 			self::$headers = array_merge(self::getHeaders(), $headers);
142 142
 		}
143 143
 		
@@ -145,17 +145,17 @@  discard block
 block discarded – undo
145 145
 		 * Redirect user in the specified page
146 146
 		 * @param  string $path the URL or URI to be redirect to
147 147
 		 */
148
-		public static function redirect($path = ''){
148
+		public static function redirect($path = '') {
149 149
 			$logger = self::getLogger();
150 150
 			$url = Url::site_url($path);
151
-			$logger->info('Redirect to URL [' .$url. ']');
152
-			if(! headers_sent()){
153
-				header('Location: '.$url);
151
+			$logger->info('Redirect to URL [' . $url . ']');
152
+			if (!headers_sent()) {
153
+				header('Location: ' . $url);
154 154
 				exit;
155 155
 			}
156
-			else{
156
+			else {
157 157
 				echo '<script>
158
-						location.href = "'.$url.'";
158
+						location.href = "'.$url . '";
159 159
 					</script>';
160 160
 			}
161 161
 		}
@@ -168,10 +168,10 @@  discard block
 block discarded – undo
168 168
 		 * @return void|string          if $return is true will return the view content otherwise
169 169
 		 * will display the view content.
170 170
 		 */
171
-		public function render($view, $data = null, $return = false){
171
+		public function render($view, $data = null, $return = false) {
172 172
 			$logger = self::getLogger();
173 173
 			//convert data to an array
174
-			$data = ! is_array($data) ? (array) $data : $data;
174
+			$data = !is_array($data) ? (array) $data : $data;
175 175
 			$view = str_ireplace('.php', '', $view);
176 176
 			$view = trim($view, '/\\');
177 177
 			$viewFile = $view . '.php';
@@ -180,42 +180,42 @@  discard block
 block discarded – undo
180 180
 			//super instance
181 181
 			$obj = & get_instance();
182 182
 			
183
-			if(Module::hasModule()){
183
+			if (Module::hasModule()) {
184 184
 				//check in module first
185 185
 				$logger->debug('Checking the view [' . $view . '] from module list ...');
186 186
 				$mod = null;
187 187
 				//check if the request class contains module name
188
-				if(strpos($view, '/') !== false){
188
+				if (strpos($view, '/') !== false) {
189 189
 					$viewPath = explode('/', $view);
190
-					if(isset($viewPath[0]) && in_array($viewPath[0], Module::getModuleList())){
190
+					if (isset($viewPath[0]) && in_array($viewPath[0], Module::getModuleList())) {
191 191
 						$mod = $viewPath[0];
192 192
 						array_shift($viewPath);
193 193
 						$view = implode('/', $viewPath);
194 194
 						$viewFile = $view . '.php';
195 195
 					}
196 196
 				}
197
-				if(! $mod && !empty($obj->moduleName)){
197
+				if (!$mod && !empty($obj->moduleName)) {
198 198
 					$mod = $obj->moduleName;
199 199
 				}
200
-				if($mod){
200
+				if ($mod) {
201 201
 					$moduleViewPath = Module::findViewFullPath($view, $mod);
202
-					if($moduleViewPath){
202
+					if ($moduleViewPath) {
203 203
 						$path = $moduleViewPath;
204
-						$logger->info('Found view [' . $view . '] in module [' .$mod. '], the file path is [' .$moduleViewPath. '] we will used it');
204
+						$logger->info('Found view [' . $view . '] in module [' . $mod . '], the file path is [' . $moduleViewPath . '] we will used it');
205 205
 					}
206
-					else{
207
-						$logger->info('Cannot find view [' . $view . '] in module [' .$mod. '] using the default location');
206
+					else {
207
+						$logger->info('Cannot find view [' . $view . '] in module [' . $mod . '] using the default location');
208 208
 					}
209 209
 				}
210
-				else{
210
+				else {
211 211
 					$logger->info('The current request does not use module using the default location.');
212 212
 				}
213 213
 			}
214 214
 			$logger->info('The view file path to be loaded is [' . $path . ']');
215 215
 			$found = false;
216
-			if(file_exists($path)){
217
-				foreach(get_object_vars($obj) as $key => $value){
218
-					if(! isset($this->{$key})){
216
+			if (file_exists($path)) {
217
+				foreach (get_object_vars($obj) as $key => $value) {
218
+					if (!isset($this->{$key})) {
219 219
 						$this->{$key} = & $obj->{$key};
220 220
 					}
221 221
 				}
@@ -224,39 +224,39 @@  discard block
 block discarded – undo
224 224
 				//need use require() instead of require_once because can load this view many time
225 225
 				require $path;
226 226
 				$content = ob_get_clean();
227
-				if($return){
227
+				if ($return) {
228 228
 					return $content;
229 229
 				}
230 230
 				$this->_pageRender .= $content;
231 231
 				$found = true;
232 232
 			}
233
-			if(! $found){
234
-				show_error('Unable to find view [' .$view . ']');
233
+			if (!$found) {
234
+				show_error('Unable to find view [' . $view . ']');
235 235
 			}
236 236
 		}
237 237
 		
238 238
 		/**
239 239
 		* Send the final page output to user
240 240
 		*/
241
-		public function renderFinalPage(){
241
+		public function renderFinalPage() {
242 242
 			$logger = self::getLogger();
243 243
 			$obj = & get_instance();
244 244
 			$cachePageStatus = get_config('cache_enable', false) && !empty($obj->view_cache_enable);
245 245
 			$dispatcher = $obj->eventdispatcher;
246 246
 			$content = $this->_pageRender;
247
-			if(! $content){
247
+			if (!$content) {
248 248
 				$logger->warning('The final view content is empty.');
249 249
 				return;
250 250
 			}
251 251
 			//dispatch
252 252
 			$event = $dispatcher->dispatch(new EventInfo('FINAL_VIEW_READY', $content, true));
253
-			$content = ! empty($event->payload) ? $event->payload : null;
254
-			if(empty($content)){
253
+			$content = !empty($event->payload) ? $event->payload : null;
254
+			if (empty($content)) {
255 255
 				$logger->warning('The view content is empty after dispatch to event listeners.');
256 256
 			}
257 257
 			
258 258
 			//check whether need save the page into cache.
259
-			if($cachePageStatus){
259
+			if ($cachePageStatus) {
260 260
 				//current page URL
261 261
 				$url = $this->_currentUrl;
262 262
 				//Cache view Time to live in second
@@ -271,14 +271,14 @@  discard block
 block discarded – undo
271 271
 				
272 272
 				//get the cache information to prepare header to send to browser
273 273
 				$cacheInfo = $cacheInstance->getInfo($cacheKey);
274
-				if($cacheInfo){
274
+				if ($cacheInfo) {
275 275
 					$lastModified = $cacheInfo['mtime'];
276 276
 					$expire = $cacheInfo['expire'];
277 277
 					$maxAge = $expire - time();
278 278
 					self::setHeader('Pragma', 'public');
279 279
 					self::setHeader('Cache-Control', 'max-age=' . $maxAge . ', public');
280
-					self::setHeader('Expires', gmdate('D, d M Y H:i:s', $expire).' GMT');
281
-					self::setHeader('Last-modified', gmdate('D, d M Y H:i:s', $lastModified).' GMT');	
280
+					self::setHeader('Expires', gmdate('D, d M Y H:i:s', $expire) . ' GMT');
281
+					self::setHeader('Last-modified', gmdate('D, d M Y H:i:s', $lastModified) . ' GMT');	
282 282
 				}
283 283
 			}
284 284
 			
@@ -289,10 +289,10 @@  discard block
 block discarded – undo
289 289
 			$content = str_replace(array('{elapsed_time}', '{memory_usage}'), array($elapsedTime, $memoryUsage), $content);
290 290
 			
291 291
 			//compress the output if is available
292
-			if (self::$_canCompressOutput){
292
+			if (self::$_canCompressOutput) {
293 293
 				ob_start('ob_gzhandler');
294 294
 			}
295
-			else{
295
+			else {
296 296
 				ob_start();
297 297
 			}
298 298
 			self::sendHeaders(200);
@@ -303,7 +303,7 @@  discard block
 block discarded – undo
303 303
 		/**
304 304
 		* Send the final page output to user if is cached
305 305
 		*/
306
-		public function renderFinalPageFromCache(&$cache){
306
+		public function renderFinalPageFromCache(&$cache) {
307 307
 			$logger = self::getLogger();
308 308
 			$url = $this->_currentUrl;					
309 309
 			//the current page cache key for identification
@@ -312,25 +312,25 @@  discard block
 block discarded – undo
312 312
 			$logger->debug('Checking if the page content for the URL [' . $url . '] is cached ...');
313 313
 			//get the cache information to prepare header to send to browser
314 314
 			$cacheInfo = $cache->getInfo($pageCacheKey);
315
-			if($cacheInfo){
315
+			if ($cacheInfo) {
316 316
 				$lastModified = $cacheInfo['mtime'];
317 317
 				$expire = $cacheInfo['expire'];
318 318
 				$maxAge = $expire - $_SERVER['REQUEST_TIME'];
319 319
 				self::setHeader('Pragma', 'public');
320 320
 				self::setHeader('Cache-Control', 'max-age=' . $maxAge . ', public');
321
-				self::setHeader('Expires', gmdate('D, d M Y H:i:s', $expire).' GMT');
322
-				self::setHeader('Last-modified', gmdate('D, d M Y H:i:s', $lastModified).' GMT');
323
-				if (isset($_SERVER['HTTP_IF_MODIFIED_SINCE']) && $lastModified <= strtotime($_SERVER['HTTP_IF_MODIFIED_SINCE'])){
321
+				self::setHeader('Expires', gmdate('D, d M Y H:i:s', $expire) . ' GMT');
322
+				self::setHeader('Last-modified', gmdate('D, d M Y H:i:s', $lastModified) . ' GMT');
323
+				if (isset($_SERVER['HTTP_IF_MODIFIED_SINCE']) && $lastModified <= strtotime($_SERVER['HTTP_IF_MODIFIED_SINCE'])) {
324 324
 					$logger->info('The cache page content is not yet expire for the URL [' . $url . '] send 304 header to browser');
325 325
 					self::sendHeaders(304);
326 326
 					return;
327 327
 				}
328
-				else{
328
+				else {
329 329
 					$logger->info('The cache page content is expired or the browser don\'t send the HTTP_IF_MODIFIED_SINCE header for the URL [' . $url . '] send cache headers to tell the browser');
330 330
 					self::sendHeaders(200);
331 331
 					//get the cache content
332 332
 					$content = $cache->get($pageCacheKey);
333
-					if($content){
333
+					if ($content) {
334 334
 						$logger->info('The page content for the URL [' . $url . '] already cached just display it');
335 335
 						//load benchmark class
336 336
 						$benchmark = & class_loader('Benchmark');
@@ -343,17 +343,17 @@  discard block
 block discarded – undo
343 343
 						
344 344
 						///display the final output
345 345
 						//compress the output if is available
346
-						if (self::$_canCompressOutput){
346
+						if (self::$_canCompressOutput) {
347 347
 							ob_start('ob_gzhandler');
348 348
 						}
349
-						else{
349
+						else {
350 350
 							ob_start();
351 351
 						}
352 352
 						echo $content;
353 353
 						ob_end_flush();
354 354
 						return;
355 355
 					}
356
-					else{
356
+					else {
357 357
 						$logger->info('The page cache content for the URL [' . $url . '] is not valid may be already expired');
358 358
 						$cache->delete($pageCacheKey);
359 359
 					}
@@ -365,7 +365,7 @@  discard block
 block discarded – undo
365 365
 		* Get the final page to be rendered
366 366
 		* @return string
367 367
 		*/
368
-		public function getFinalPageRendered(){
368
+		public function getFinalPageRendered() {
369 369
 			return $this->_pageRender;
370 370
 		}
371 371
 
@@ -373,14 +373,14 @@  discard block
 block discarded – undo
373 373
 		 * Send the HTTP 404 error if can not found the 
374 374
 		 * routing information for the current request
375 375
 		 */
376
-		public static function send404(){
376
+		public static function send404() {
377 377
 			/********* for logs **************/
378 378
 			//can't use $obj = & get_instance()  here because the global super object will be available until
379 379
 			//the main controller is loaded even for Loader::library('xxxx');
380 380
 			$logger = self::getLogger();
381
-			$request =& class_loader('Request', 'classes');
382
-			$userAgent =& class_loader('Browser');
383
-			$browser = $userAgent->getPlatform().', '.$userAgent->getBrowser().' '.$userAgent->getVersion();
381
+			$request = & class_loader('Request', 'classes');
382
+			$userAgent = & class_loader('Browser');
383
+			$browser = $userAgent->getPlatform() . ', ' . $userAgent->getBrowser() . ' ' . $userAgent->getVersion();
384 384
 			
385 385
 			//here can't use Loader::functions just include the helper manually
386 386
 			require_once CORE_FUNCTIONS_PATH . 'function_user_agent.php';
@@ -390,12 +390,12 @@  discard block
 block discarded – undo
390 390
 			$logger->error($str);
391 391
 			/***********************************/
392 392
 			$path = CORE_VIEWS_PATH . '404.php';
393
-			if(file_exists($path)){
393
+			if (file_exists($path)) {
394 394
 				//compress the output if is available
395
-				if (self::$_canCompressOutput){
395
+				if (self::$_canCompressOutput) {
396 396
 					ob_start('ob_gzhandler');
397 397
 				}
398
-				else{
398
+				else {
399 399
 					ob_start();
400 400
 				}
401 401
 				require_once $path;
@@ -403,8 +403,8 @@  discard block
 block discarded – undo
403 403
 				self::sendHeaders(404);
404 404
 				echo $output;
405 405
 			}
406
-			else{
407
-				show_error('The 404 view [' .$path. '] does not exist');
406
+			else {
407
+				show_error('The 404 view [' . $path . '] does not exist');
408 408
 			}
409 409
 		}
410 410
 
@@ -412,14 +412,14 @@  discard block
 block discarded – undo
412 412
 		 * Display the error to user
413 413
 		 * @param  array  $data the error information
414 414
 		 */
415
-		public static function sendError(array $data = array()){
415
+		public static function sendError(array $data = array()) {
416 416
 			$path = CORE_VIEWS_PATH . 'errors.php';
417
-			if(file_exists($path)){
417
+			if (file_exists($path)) {
418 418
 				//compress the output if exists
419
-				if (self::$_canCompressOutput){
419
+				if (self::$_canCompressOutput) {
420 420
 					ob_start('ob_gzhandler');
421 421
 				}
422
-				else{
422
+				else {
423 423
 					ob_start();
424 424
 				}
425 425
 				extract($data);
@@ -428,7 +428,7 @@  discard block
 block discarded – undo
428 428
 				self::sendHeaders(503);
429 429
 				echo $output;
430 430
 			}
431
-			else{
431
+			else {
432 432
 				//can't use show_error() at this time because some dependencies not yet loaded and to prevent loop
433 433
 				set_http_status_header(503);
434 434
 				echo 'The error view [' . $path . '] does not exist';
Please login to merge, or discard this patch.
core/classes/Controller.php 3 patches
Indentation   +6 added lines, -6 removed lines patch added patch discarded remove patch
@@ -22,7 +22,7 @@  discard block
 block discarded – undo
22 22
 	 * You should have received a copy of the GNU General Public License
23 23
 	 * along with this program; if not, write to the Free Software
24 24
 	 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
25
-	*/
25
+	 */
26 26
 
27 27
 	class Controller{
28 28
 		
@@ -114,12 +114,12 @@  discard block
 block discarded – undo
114 114
 		 */
115 115
 		protected function setLoggerFromParamOrCreateNewInstance(Log $logger = null){
116 116
 			if($logger !== null){
117
-	          $this->logger = $logger;
118
-	        }
119
-	        else{
120
-	            $this->logger =& class_loader('Log', 'classes');
117
+			  $this->logger = $logger;
118
+			}
119
+			else{
120
+				$this->logger =& class_loader('Log', 'classes');
121 121
 				$this->logger->setLogger('MainController');
122
-	        }
122
+			}
123 123
 		}
124 124
 
125 125
 		/**
Please login to merge, or discard this patch.
Spacing   +20 added lines, -20 removed lines patch added patch discarded remove patch
@@ -24,7 +24,7 @@  discard block
 block discarded – undo
24 24
 	 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
25 25
 	*/
26 26
 
27
-	class Controller{
27
+	class Controller {
28 28
 		
29 29
 		/**
30 30
 		 * The name of the module if this controller belong to an module
@@ -48,7 +48,7 @@  discard block
 block discarded – undo
48 48
 		 * Class constructor
49 49
 		 * @param object $logger the Log instance to use if is null will create one
50 50
 		 */
51
-		public function __construct(Log $logger = null){
51
+		public function __construct(Log $logger = null) {
52 52
 			//setting the Log instance
53 53
 			$this->setLoggerFromParamOrCreateNewInstance(null);
54 54
 			
@@ -84,9 +84,9 @@  discard block
 block discarded – undo
84 84
 		/**
85 85
 		 * This method is used to set the module name
86 86
 		 */
87
-		protected function setModuleNameFromRouter(){
87
+		protected function setModuleNameFromRouter() {
88 88
 			//determine the current module
89
-			if(isset($this->router) && $this->router->getModule()){
89
+			if (isset($this->router) && $this->router->getModule()) {
90 90
 				$this->moduleName = $this->router->getModule();
91 91
 			}
92 92
 		}
@@ -95,13 +95,13 @@  discard block
 block discarded – undo
95 95
 		 * Set the cache using the argument otherwise will use the configuration
96 96
 		 * @param CacheInterface $cache the implementation of CacheInterface if null will use the configured
97 97
 		 */
98
-		protected function setCacheFromParamOrConfig(CacheInterface $cache = null){
98
+		protected function setCacheFromParamOrConfig(CacheInterface $cache = null) {
99 99
 			$this->logger->debug('Setting the cache handler instance');
100 100
 			//set cache handler instance
101
-			if(get_config('cache_enable', false)){
102
-				if ($cache !== null){
101
+			if (get_config('cache_enable', false)) {
102
+				if ($cache !== null) {
103 103
 					$this->cache = $cache;
104
-				} else if (isset($this->{strtolower(get_config('cache_handler'))})){
104
+				} else if (isset($this->{strtolower(get_config('cache_handler'))})) {
105 105
 					$this->cache = $this->{strtolower(get_config('cache_handler'))};
106 106
 					unset($this->{strtolower(get_config('cache_handler'))});
107 107
 				} 
@@ -112,12 +112,12 @@  discard block
 block discarded – undo
112 112
 		 * Set the Log instance using argument or create new instance
113 113
 		 * @param object $logger the Log instance if not null
114 114
 		 */
115
-		protected function setLoggerFromParamOrCreateNewInstance(Log $logger = null){
116
-			if($logger !== null){
115
+		protected function setLoggerFromParamOrCreateNewInstance(Log $logger = null) {
116
+			if ($logger !== null) {
117 117
 	          $this->logger = $logger;
118 118
 	        }
119
-	        else{
120
-	            $this->logger =& class_loader('Log', 'classes');
119
+	        else {
120
+	            $this->logger = & class_loader('Log', 'classes');
121 121
 				$this->logger->setLogger('MainController');
122 122
 	        }
123 123
 		}
@@ -126,20 +126,20 @@  discard block
 block discarded – undo
126 126
 		 * This method is used to load the required resources for framework to work
127 127
 		 * @return void 
128 128
 		 */
129
-		private function loadRequiredResources(){
129
+		private function loadRequiredResources() {
130 130
 			$this->logger->debug('Adding the loaded classes to the super instance');
131
-			foreach (class_loaded() as $var => $class){
132
-				$this->$var =& class_loader($class);
131
+			foreach (class_loaded() as $var => $class) {
132
+				$this->$var = & class_loader($class);
133 133
 			}
134 134
 
135 135
 			$this->logger->debug('Loading the required classes into super instance');
136
-			$this->eventdispatcher =& class_loader('EventDispatcher', 'classes');
137
-			$this->loader =& class_loader('Loader', 'classes');
138
-			$this->lang =& class_loader('Lang', 'classes');
139
-			$this->request =& class_loader('Request', 'classes');
136
+			$this->eventdispatcher = & class_loader('EventDispatcher', 'classes');
137
+			$this->loader = & class_loader('Loader', 'classes');
138
+			$this->lang = & class_loader('Lang', 'classes');
139
+			$this->request = & class_loader('Request', 'classes');
140 140
 			//dispatch the request instance created event
141 141
 			$this->eventdispatcher->dispatch('REQUEST_CREATED');
142
-			$this->response =& class_loader('Response', 'classes', 'classes');
142
+			$this->response = & class_loader('Response', 'classes', 'classes');
143 143
 		}
144 144
 
145 145
 	}
Please login to merge, or discard this patch.
Braces   +1 added lines, -2 removed lines patch added patch discarded remove patch
@@ -115,8 +115,7 @@
 block discarded – undo
115 115
 		protected function setLoggerFromParamOrCreateNewInstance(Log $logger = null){
116 116
 			if($logger !== null){
117 117
 	          $this->logger = $logger;
118
-	        }
119
-	        else{
118
+	        } else{
120 119
 	            $this->logger =& class_loader('Log', 'classes');
121 120
 				$this->logger->setLogger('MainController');
122 121
 	        }
Please login to merge, or discard this patch.
core/libraries/FormValidation.php 1 patch
Indentation   +875 added lines, -875 removed lines patch added patch discarded remove patch
@@ -1,917 +1,917 @@
 block discarded – undo
1 1
 <?php
2
-    defined('ROOT_PATH') || exit('Access denied');
3
-    /**
4
-     * TNH Framework
5
-     *
6
-     * A simple PHP framework using HMVC architecture
7
-     *
8
-     * This content is released under the GNU GPL License (GPL)
9
-     *
10
-     * Copyright (C) 2017 Tony NGUEREZA
11
-     *
12
-     * This program is free software; you can redistribute it and/or
13
-     * modify it under the terms of the GNU General Public License
14
-     * as published by the Free Software Foundation; either version 3
15
-     * of the License, or (at your option) any later version.
16
-     *
17
-     * This program is distributed in the hope that it will be useful,
18
-     * but WITHOUT ANY WARRANTY; without even the implied warranty of
19
-     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
20
-     * GNU General Public License for more details.
21
-     *
22
-     * You should have received a copy of the GNU General Public License
23
-     * along with this program; if not, write to the Free Software
24
-     * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
25
-    */
26
-
27
-
28
-     class FormValidation{
2
+	defined('ROOT_PATH') || exit('Access denied');
3
+	/**
4
+	 * TNH Framework
5
+	 *
6
+	 * A simple PHP framework using HMVC architecture
7
+	 *
8
+	 * This content is released under the GNU GPL License (GPL)
9
+	 *
10
+	 * Copyright (C) 2017 Tony NGUEREZA
11
+	 *
12
+	 * This program is free software; you can redistribute it and/or
13
+	 * modify it under the terms of the GNU General Public License
14
+	 * as published by the Free Software Foundation; either version 3
15
+	 * of the License, or (at your option) any later version.
16
+	 *
17
+	 * This program is distributed in the hope that it will be useful,
18
+	 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19
+	 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
20
+	 * GNU General Public License for more details.
21
+	 *
22
+	 * You should have received a copy of the GNU General Public License
23
+	 * along with this program; if not, write to the Free Software
24
+	 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
25
+	 */
26
+
27
+
28
+	 class FormValidation{
29 29
 		 
30
-        /**
31
-         * The form validation status
32
-         * @var boolean
33
-         */
34
-        protected $_success  = false;
35
-
36
-        /**
37
-         * The list of errors messages
38
-         * @var array
39
-         */
40
-        protected $_errorsMessages = array();
30
+		/**
31
+		 * The form validation status
32
+		 * @var boolean
33
+		 */
34
+		protected $_success  = false;
35
+
36
+		/**
37
+		 * The list of errors messages
38
+		 * @var array
39
+		 */
40
+		protected $_errorsMessages = array();
41 41
         
42
-        // Array of rule sets, fieldName => PIPE seperated ruleString
43
-        protected $_rules             = array();
42
+		// Array of rule sets, fieldName => PIPE seperated ruleString
43
+		protected $_rules             = array();
44 44
         
45
-        // Array of errors, niceName => Error Message
46
-        protected $_errors             = array();
45
+		// Array of errors, niceName => Error Message
46
+		protected $_errors             = array();
47 47
         
48
-        // Array of post Key => Nice name labels
49
-        protected $_labels          = array();
48
+		// Array of post Key => Nice name labels
49
+		protected $_labels          = array();
50 50
         
51
-        /**
52
-         * The errors delimiters
53
-         * @var array
54
-         */
55
-        protected $_allErrorsDelimiter   = array('<div class="error">', '</div>');
56
-
57
-        /**
58
-         * The each error delimiter
59
-         * @var array
60
-         */
61
-        protected $_eachErrorDelimiter   = array('<p class="error">', '</p>');
51
+		/**
52
+		 * The errors delimiters
53
+		 * @var array
54
+		 */
55
+		protected $_allErrorsDelimiter   = array('<div class="error">', '</div>');
56
+
57
+		/**
58
+		 * The each error delimiter
59
+		 * @var array
60
+		 */
61
+		protected $_eachErrorDelimiter   = array('<p class="error">', '</p>');
62 62
         
63 63
 		/**
64
-         * Indicated if need force the validation to be failed
65
-         * @var boolean
66
-         */
67
-        protected $_forceFail            = false;
68
-
69
-        /**
70
-         * The list of the error messages overrides by the original
71
-         * @var array
72
-         */
73
-        protected $_errorPhraseOverrides = array();
74
-
75
-        /**
76
-         * The logger instance
77
-         * @var Log
78
-         */
79
-        private $logger;
80
-
81
-        /**
82
-         * The data to be validated, the default is to use $_POST
83
-         * @var array
84
-         */
85
-        private $data = array();
86
-
87
-        /**
88
-         * Whether to check the CSRF. This attribute is just a way to allow custom change of the 
64
+		 * Indicated if need force the validation to be failed
65
+		 * @var boolean
66
+		 */
67
+		protected $_forceFail            = false;
68
+
69
+		/**
70
+		 * The list of the error messages overrides by the original
71
+		 * @var array
72
+		 */
73
+		protected $_errorPhraseOverrides = array();
74
+
75
+		/**
76
+		 * The logger instance
77
+		 * @var Log
78
+		 */
79
+		private $logger;
80
+
81
+		/**
82
+		 * The data to be validated, the default is to use $_POST
83
+		 * @var array
84
+		 */
85
+		private $data = array();
86
+
87
+		/**
88
+		 * Whether to check the CSRF. This attribute is just a way to allow custom change of the 
89 89
 		 * CSRF global configuration
90 90
 		 *
91
-         * @var boolean
92
-         */
93
-        public $enableCsrfCheck = false;
94
-
95
-        /**
96
-         * Set all errors and rule sets empty, and sets success to false.
97
-         *
98
-         * @return void
99
-         */
100
-        public function __construct() {
101
-            $this->logger =& class_loader('Log', 'classes');
102
-            $this->logger->setLogger('Library::FormValidation');
91
+		 * @var boolean
92
+		 */
93
+		public $enableCsrfCheck = false;
94
+
95
+		/**
96
+		 * Set all errors and rule sets empty, and sets success to false.
97
+		 *
98
+		 * @return void
99
+		 */
100
+		public function __construct() {
101
+			$this->logger =& class_loader('Log', 'classes');
102
+			$this->logger->setLogger('Library::FormValidation');
103 103
            
104 104
 		   //Load form validation language message
105
-            Loader::lang('form_validation');
106
-            $obj = & get_instance();
107
-            $this->_errorsMessages  = array(
108
-                        'required'         => $obj->lang->get('fv_required'),
109
-                        'min_length'       => $obj->lang->get('fv_min_length'),
110
-                        'max_length'       => $obj->lang->get('fv_max_length'),
111
-                        'exact_length'     => $obj->lang->get('fv_exact_length'),
112
-                        'less_than'        => $obj->lang->get('fv_less_than'),
113
-                        'greater_than'     => $obj->lang->get('fv_greater_than'),
114
-                        'matches'          => $obj->lang->get('fv_matches'),
115
-                        'valid_email'      => $obj->lang->get('fv_valid_email'),
116
-                        'not_equal'        => array(
117
-                                                'post:key' => $obj->lang->get('fv_not_equal_post_key'),
118
-                                                'string'   => $obj->lang->get('fv_not_equal_string')
119
-                                            ),
120
-                        'depends'          => $obj->lang->get('fv_depends'),
121
-                        'is_unique'        => $obj->lang->get('fv_is_unique'),
122
-                        'is_unique_update' => $obj->lang->get('fv_is_unique_update'),
123
-                        'exists'           => $obj->lang->get('fv_exists'),
124
-                        'regex'            => $obj->lang->get('fv_regex'),
125
-                        'in_list'          => $obj->lang->get('fv_in_list'),
126
-                        'numeric'          => $obj->lang->get('fv_numeric'),
127
-                        'callback'         => $obj->lang->get('fv_callback'),
128
-                    );
129
-            $this->_resetValidation();
130
-            $this->setData($obj->request->post(null));
131
-        }
132
-
133
-        /**
134
-         * Reset the form validation instance
135
-         */
136
-        protected function _resetValidation() {
137
-            $this->_rules                = array();
138
-            $this->_labels               = array();
139
-            $this->_errorPhraseOverrides = array();
140
-            $this->_errors               = array();
141
-            $this->_success              = false;
142
-            $this->_forceFail            = false;
143
-            $this->data                  = array();
105
+			Loader::lang('form_validation');
106
+			$obj = & get_instance();
107
+			$this->_errorsMessages  = array(
108
+						'required'         => $obj->lang->get('fv_required'),
109
+						'min_length'       => $obj->lang->get('fv_min_length'),
110
+						'max_length'       => $obj->lang->get('fv_max_length'),
111
+						'exact_length'     => $obj->lang->get('fv_exact_length'),
112
+						'less_than'        => $obj->lang->get('fv_less_than'),
113
+						'greater_than'     => $obj->lang->get('fv_greater_than'),
114
+						'matches'          => $obj->lang->get('fv_matches'),
115
+						'valid_email'      => $obj->lang->get('fv_valid_email'),
116
+						'not_equal'        => array(
117
+												'post:key' => $obj->lang->get('fv_not_equal_post_key'),
118
+												'string'   => $obj->lang->get('fv_not_equal_string')
119
+											),
120
+						'depends'          => $obj->lang->get('fv_depends'),
121
+						'is_unique'        => $obj->lang->get('fv_is_unique'),
122
+						'is_unique_update' => $obj->lang->get('fv_is_unique_update'),
123
+						'exists'           => $obj->lang->get('fv_exists'),
124
+						'regex'            => $obj->lang->get('fv_regex'),
125
+						'in_list'          => $obj->lang->get('fv_in_list'),
126
+						'numeric'          => $obj->lang->get('fv_numeric'),
127
+						'callback'         => $obj->lang->get('fv_callback'),
128
+					);
129
+			$this->_resetValidation();
130
+			$this->setData($obj->request->post(null));
131
+		}
132
+
133
+		/**
134
+		 * Reset the form validation instance
135
+		 */
136
+		protected function _resetValidation() {
137
+			$this->_rules                = array();
138
+			$this->_labels               = array();
139
+			$this->_errorPhraseOverrides = array();
140
+			$this->_errors               = array();
141
+			$this->_success              = false;
142
+			$this->_forceFail            = false;
143
+			$this->data                  = array();
144 144
 			$this->enableCsrfCheck       = false;
145
-        }
145
+		}
146 146
 
147
-        /**
148
-         * Set the form validation data
149
-         * @param array $data the values to be validated
147
+		/**
148
+		 * Set the form validation data
149
+		 * @param array $data the values to be validated
150 150
 		 *
151
-         * @return FormValidation Current instance of object.
152
-         */
153
-        public function setData(array $data){
154
-            $this->logger->debug('Setting the form validation data, the values are: ' . stringfy_vars($data));
155
-            $this->data = $data;
151
+		 * @return FormValidation Current instance of object.
152
+		 */
153
+		public function setData(array $data){
154
+			$this->logger->debug('Setting the form validation data, the values are: ' . stringfy_vars($data));
155
+			$this->data = $data;
156 156
 			return $this;
157
-        }
158
-
159
-        /**
160
-         * Get the form validation data
161
-         * @return array the form validation data to be validated
162
-         */
163
-        public function getData(){
164
-            return $this->data;
165
-        }
166
-
167
-		/**
168
-		* Get the validation function name to validate a rule
169
-		*
170
-		* @return string the function name
171
-		*/
172
-        protected function _toCallCase($funcName, $prefix='_validate') {
173
-            $funcName = strtolower($funcName);
174
-            $finalFuncName = $prefix;
175
-            foreach (explode('_', $funcName) as $funcNamePart) {
176
-                $finalFuncName .= strtoupper($funcNamePart[0]) . substr($funcNamePart, 1);
177
-            }
178
-            return $finalFuncName;
179
-        }
180
-
181
-        /**
182
-         * Returns the boolean of the data status success. It goes by the simple
183
-         *
184
-         * @return boolean Whether or not the data validation has succeeded
185
-         */
186
-        public function isSuccess() {
187
-            return $this->_success;
188
-        }
189
-
190
-        /**
191
-         * Checks if the request method is POST or the Data to be validated is set
192
-         *
193
-         * @return boolean Whether or not the form has been submitted or the data is available for validation.
194
-         */
195
-        public function canDoValidation() {
196
-            return get_instance()->request->method() === 'POST' || ! empty($this->data);
197
-        }
198
-
199
-        /**
200
-         * Runs _run once POST data has been submitted or data is set manually.
201
-         *
202
-         * @return boolean
203
-         */
204
-        public function run() {
205
-            if ($this->canDoValidation()) {
206
-                $this->logger->info('The data to validate are listed below: ' . stringfy_vars($this->getData()));
207
-                $this->_run();
208
-            }
209
-            return $this->isSuccess();
210
-        }
211
-
212
-        /**
213
-         * Takes and trims each data, if it has any rules, we parse the rule string and run
214
-         * each rule against the data value. Sets _success to true if there are no errors
215
-         * afterwards.
216
-         */
217
-        protected function _run() {
218
-            if(get_instance()->request->method() == 'POST' || $this->enableCsrfCheck){
219
-                $this->logger->debug('Check if CSRF is enabled in configuration');
220
-                //first check for CSRF
221
-                if( get_config('csrf_enable', false) || $this->enableCsrfCheck){
222
-                     $this->logger->info('Check the CSRF value if is valid');
223
-                    if(! Security::validateCSRF()){
224
-                        show_error('Invalide data, Cross Site Request Forgery do his job, the data to validate is corrupted.');
225
-                    }
226
-                }
227
-                else{
228
-                    $this->logger->info('CSRF is not enabled in configuration or not set manully, no need to check it');
229
-                }
230
-            }
231
-            /////////////////////////////////////////////
232
-            $this->_forceFail = false;
233
-
234
-            foreach ($this->getData() as $inputName => $inputVal) {
235
-    			if(is_array($this->data[$inputName])){
236
-    				$this->data[$inputName] = array_map('trim', $this->data[$inputName]);
237
-    			}
238
-    			else{
239
-    				$this->data[$inputName] = trim($this->data[$inputName]);
240
-    			}
241
-
242
-                if (array_key_exists($inputName, $this->_rules)) {
243
-                    foreach ($this->_parseRuleString($this->_rules[$inputName]) as $eachRule) {
244
-                        $this->_validateRule($inputName, $this->data[$inputName], $eachRule);
245
-                    }
246
-                }
247
-            }
248
-
249
-            if (empty($this->_errors) && $this->_forceFail === false) {
250
-                $this->_success = true;
251
-            }
252
-        }
253
-
254
-        /**
255
-         * Adds a rule to a form data validation field.
256
-         *
257
-         * @param string $inputField Name of the field or the data key to add a rule to
258
-         * @param string $ruleSets PIPE seperated string of rules
259
-		 *
260
-         * @return FormValidation Current instance of object.
261
-         */
262
-        public function setRule($inputField, $inputLabel, $ruleSets) {
263
-            $this->_rules[$inputField] = $ruleSets;
264
-            $this->_labels[$inputField] = $inputLabel;
265
-            $this->logger->info('Set the field rule: name [' .$inputField. '], label [' .$inputLabel. '], rules [' .$ruleSets. ']');
266
-            return $this;
267
-        }
268
-
269
-        /**
270
-         * Takes an array of rules and uses setRule() to set them, accepts an array
271
-         * of rule names rather than a pipe-delimited string as well.
272
-         * @param array $ruleSets
157
+		}
158
+
159
+		/**
160
+		 * Get the form validation data
161
+		 * @return array the form validation data to be validated
162
+		 */
163
+		public function getData(){
164
+			return $this->data;
165
+		}
166
+
167
+		/**
168
+		 * Get the validation function name to validate a rule
169
+		 *
170
+		 * @return string the function name
171
+		 */
172
+		protected function _toCallCase($funcName, $prefix='_validate') {
173
+			$funcName = strtolower($funcName);
174
+			$finalFuncName = $prefix;
175
+			foreach (explode('_', $funcName) as $funcNamePart) {
176
+				$finalFuncName .= strtoupper($funcNamePart[0]) . substr($funcNamePart, 1);
177
+			}
178
+			return $finalFuncName;
179
+		}
180
+
181
+		/**
182
+		 * Returns the boolean of the data status success. It goes by the simple
183
+		 *
184
+		 * @return boolean Whether or not the data validation has succeeded
185
+		 */
186
+		public function isSuccess() {
187
+			return $this->_success;
188
+		}
189
+
190
+		/**
191
+		 * Checks if the request method is POST or the Data to be validated is set
192
+		 *
193
+		 * @return boolean Whether or not the form has been submitted or the data is available for validation.
194
+		 */
195
+		public function canDoValidation() {
196
+			return get_instance()->request->method() === 'POST' || ! empty($this->data);
197
+		}
198
+
199
+		/**
200
+		 * Runs _run once POST data has been submitted or data is set manually.
201
+		 *
202
+		 * @return boolean
203
+		 */
204
+		public function run() {
205
+			if ($this->canDoValidation()) {
206
+				$this->logger->info('The data to validate are listed below: ' . stringfy_vars($this->getData()));
207
+				$this->_run();
208
+			}
209
+			return $this->isSuccess();
210
+		}
211
+
212
+		/**
213
+		 * Takes and trims each data, if it has any rules, we parse the rule string and run
214
+		 * each rule against the data value. Sets _success to true if there are no errors
215
+		 * afterwards.
216
+		 */
217
+		protected function _run() {
218
+			if(get_instance()->request->method() == 'POST' || $this->enableCsrfCheck){
219
+				$this->logger->debug('Check if CSRF is enabled in configuration');
220
+				//first check for CSRF
221
+				if( get_config('csrf_enable', false) || $this->enableCsrfCheck){
222
+					 $this->logger->info('Check the CSRF value if is valid');
223
+					if(! Security::validateCSRF()){
224
+						show_error('Invalide data, Cross Site Request Forgery do his job, the data to validate is corrupted.');
225
+					}
226
+				}
227
+				else{
228
+					$this->logger->info('CSRF is not enabled in configuration or not set manully, no need to check it');
229
+				}
230
+			}
231
+			/////////////////////////////////////////////
232
+			$this->_forceFail = false;
233
+
234
+			foreach ($this->getData() as $inputName => $inputVal) {
235
+				if(is_array($this->data[$inputName])){
236
+					$this->data[$inputName] = array_map('trim', $this->data[$inputName]);
237
+				}
238
+				else{
239
+					$this->data[$inputName] = trim($this->data[$inputName]);
240
+				}
241
+
242
+				if (array_key_exists($inputName, $this->_rules)) {
243
+					foreach ($this->_parseRuleString($this->_rules[$inputName]) as $eachRule) {
244
+						$this->_validateRule($inputName, $this->data[$inputName], $eachRule);
245
+					}
246
+				}
247
+			}
248
+
249
+			if (empty($this->_errors) && $this->_forceFail === false) {
250
+				$this->_success = true;
251
+			}
252
+		}
253
+
254
+		/**
255
+		 * Adds a rule to a form data validation field.
256
+		 *
257
+		 * @param string $inputField Name of the field or the data key to add a rule to
258
+		 * @param string $ruleSets PIPE seperated string of rules
273 259
 		 *
274 260
 		 * @return FormValidation Current instance of object.
275
-         */
276
-        public function setRules(array $ruleSets) {
277
-            foreach ($ruleSets as $ruleSet) {
278
-                $pipeDelimitedRules = null;
279
-                if (is_array($ruleSet['rules'])) {
280
-                    $pipeDelimitedRules = implode('|', $ruleSet['rules']);
281
-                } else {
282
-                    $pipeDelimitedRules = $ruleSet['rules'];
283
-                }
284
-                $this->setRule($ruleSet['name'], $ruleSet['label'], $pipeDelimitedRules);
285
-            }
286
-            return $this;
287
-        }
288
-
289
-        /**
290
-         * This method creates the global errors delimiter, each argument occurs once, at the beginning, and
291
-         * end of the errors block respectively.
292
-         *
293
-         * @param string $start Before block of errors gets displayed, HTML allowed.
294
-         * @param string $end After the block of errors gets displayed, HTML allowed.
295
-         *
261
+		 */
262
+		public function setRule($inputField, $inputLabel, $ruleSets) {
263
+			$this->_rules[$inputField] = $ruleSets;
264
+			$this->_labels[$inputField] = $inputLabel;
265
+			$this->logger->info('Set the field rule: name [' .$inputField. '], label [' .$inputLabel. '], rules [' .$ruleSets. ']');
266
+			return $this;
267
+		}
268
+
269
+		/**
270
+		 * Takes an array of rules and uses setRule() to set them, accepts an array
271
+		 * of rule names rather than a pipe-delimited string as well.
272
+		 * @param array $ruleSets
273
+		 *
296 274
 		 * @return FormValidation Current instance of object.
297
-         */
298
-        public function setErrorsDelimiter($start, $end) {
299
-            $this->_allErrorsDelimiter[0] = $start;
300
-            $this->_allErrorsDelimiter[1] = $end;
301
-            return $this;
302
-        }
303
-
304
-        /**
305
-         * This is the individual error delimiter, each argument occurs once before and after
306
-         * each individual error listed.
307
-         *
308
-         * @param string $start Displayed before each error.
309
-         * @param string $end Displayed after each error.
310
-         * 
275
+		 */
276
+		public function setRules(array $ruleSets) {
277
+			foreach ($ruleSets as $ruleSet) {
278
+				$pipeDelimitedRules = null;
279
+				if (is_array($ruleSet['rules'])) {
280
+					$pipeDelimitedRules = implode('|', $ruleSet['rules']);
281
+				} else {
282
+					$pipeDelimitedRules = $ruleSet['rules'];
283
+				}
284
+				$this->setRule($ruleSet['name'], $ruleSet['label'], $pipeDelimitedRules);
285
+			}
286
+			return $this;
287
+		}
288
+
289
+		/**
290
+		 * This method creates the global errors delimiter, each argument occurs once, at the beginning, and
291
+		 * end of the errors block respectively.
292
+		 *
293
+		 * @param string $start Before block of errors gets displayed, HTML allowed.
294
+		 * @param string $end After the block of errors gets displayed, HTML allowed.
295
+		 *
311 296
 		 * @return FormValidation Current instance of object.
312
-         */
313
-        public function setErrorDelimiter($start, $end) {
314
-            $this->_eachErrorDelimiter[0] = $start;
315
-            $this->_eachErrorDelimiter[1] = $end;
316
-            return $this;
317
-        }
318
-
319
-		/**
320
-		* Get the each errors delimiters
321
-		*
322
-		* @return array
323
-		*/
324
-    	public function getErrorDelimiter() {
325
-            return $this->_eachErrorDelimiter;
326
-        }
327
-
328
-		/**
329
-		* Get the all errors delimiters
330
-		*
331
-		* @return array
332
-		*/
333
-    	public function getErrorsDelimiter() {
334
-            return $this->_allErrorsDelimiter;
335
-        }
336
-
337
-        /**
338
-         * This sets a custom error message that can override the default error phrase provided
339
-         * by FormValidation, it can be used in the format of setMessage('rule', 'error phrase')
340
-         * which will globally change the error phrase of that rule, or in the format of:
341
-         * setMessage('rule', 'fieldname', 'error phrase') - which will only change the error phrase for
342
-         * that rule, applied on that field.
343
-         *
344
-         * @return boolean True on success, false on failure.
345
-         */
346
-        public function setMessage() {
347
-            $numArgs = func_num_args();
348
-            switch ($numArgs) {
349
-                default:
350
-                    return false;
351
-                // A global rule error message
352
-                case 2:
353
-                    foreach ($this->post(null) as $key => $val) {
354
-                        $this->_errorPhraseOverrides[$key][func_get_arg(0)] = func_get_arg(1);
355
-                    }
356
-                    break;
357
-                // Field specific rule error message
358
-                case 3:
359
-                    $this->_errorPhraseOverrides[func_get_arg(1)][func_get_arg(0)] = func_get_arg(2);
360
-                    break;
361
-            }
362
-            return true;
363
-        }
364
-
365
-        /**
366
-         * Adds a custom error message in the errorSet array, that will
367
-         * forcibly display it.
368
-         *
369
-         * @param string $inputName The form input name or data key
370
-         * @param string $errorMessage Error to display
371
-		 *
372
-         * @return formValidation Current instance of the object
373
-         */
374
-        public function setCustomError($inputName, $errorMessage) {
375
-            $errorMessage = str_replace('%1', $this->_labels[$inputName], $errorMessage);
376
-            $this->_errors[$inputName] = $errorMessage;
377
-            return $this;
378
-        }
379
-
380
-        /**
381
-         * Allows for an accesor to any/all post values, if a value of null is passed as the key, it
382
-         * will recursively find all keys/values of the $_POST array or data array. It also automatically trims
383
-         * all values.
384
-         *
385
-         * @param string $key Key of $this->data to be found, pass null for all Key => Val pairs.
386
-         * @param boolean $trim Defaults to true, trims all $this->data values.
387
-         * @return string|array Array of post or data values if null is passed as key, string if only one key is desired.
388
-         */
389
-        public function post($key = null, $trim = true) {
390
-            $returnValue = null;
391
-            if (is_null($key)) {
392
-                $returnValue = array();
393
-                foreach ($this->getData()  as $key => $val) {
394
-                    $returnValue[$key] = $this->post($key, $trim);
395
-                }
396
-            } else {
397
-                $returnValue = (array_key_exists($key, $this->getData())) ? (($trim) ? trim($this->data[$key]) : $this->data[$key]) : null;
398
-            }
399
-            return $returnValue;
400
-        }
401
-
402
-        /**
403
-         * Gets all errors from errorSet and displays them, can be echo out from the
404
-         * function or just returned.
405
-         *
406
-         * @param boolean $limit number of error to display or return
407
-         * @param boolean $echo Whether or not the values are to be returned or displayed
408
-		 *
409
-         * @return string Errors formatted for output
410
-         */
411
-        public function displayErrors($limit = null, $echo = true) {
412
-            list($errorsStart, $errorsEnd) = $this->_allErrorsDelimiter;
413
-            list($errorStart, $errorEnd) = $this->_eachErrorDelimiter;
414
-            $errorOutput = $errorsStart;
415
-    		$i = 0;
416
-            if (!empty($this->_errors)) {
417
-                foreach ($this->_errors as $fieldName => $error) {
418
-        	    	if ($i === $limit) { 
419
-                        break; 
420
-                    }
421
-                    $errorOutput .= $errorStart;
422
-                    $errorOutput .= $error;
423
-                    $errorOutput .= $errorEnd;
424
-                    $i++;
425
-                }
426
-            }
427
-            $errorOutput .= $errorsEnd;
428
-            echo ($echo) ? $errorOutput : '';
429
-            return (! $echo) ? $errorOutput : null;
430
-        }
431
-
432
-        /**
433
-         * Returns raw array of errors in no format instead of displaying them
434
-         * formatted.
435
-         *
436
-         * @return array
437
-         */
438
-        public function returnErrors() {
439
-            return $this->_errors;
440
-        }
441
-
442
-        /**
443
-         * Breaks up a PIPE seperated string of rules, and puts them into an array.
444
-         *
445
-         * @param string $ruleString String to be parsed.
446
-		 *
447
-         * @return array Array of each value in original string.
448
-         */
449
-        protected function _parseRuleString($ruleString) {
450
-            $ruleSets = array();
451
-            /*
297
+		 */
298
+		public function setErrorsDelimiter($start, $end) {
299
+			$this->_allErrorsDelimiter[0] = $start;
300
+			$this->_allErrorsDelimiter[1] = $end;
301
+			return $this;
302
+		}
303
+
304
+		/**
305
+		 * This is the individual error delimiter, each argument occurs once before and after
306
+		 * each individual error listed.
307
+		 *
308
+		 * @param string $start Displayed before each error.
309
+		 * @param string $end Displayed after each error.
310
+		 * 
311
+		 * @return FormValidation Current instance of object.
312
+		 */
313
+		public function setErrorDelimiter($start, $end) {
314
+			$this->_eachErrorDelimiter[0] = $start;
315
+			$this->_eachErrorDelimiter[1] = $end;
316
+			return $this;
317
+		}
318
+
319
+		/**
320
+		 * Get the each errors delimiters
321
+		 *
322
+		 * @return array
323
+		 */
324
+		public function getErrorDelimiter() {
325
+			return $this->_eachErrorDelimiter;
326
+		}
327
+
328
+		/**
329
+		 * Get the all errors delimiters
330
+		 *
331
+		 * @return array
332
+		 */
333
+		public function getErrorsDelimiter() {
334
+			return $this->_allErrorsDelimiter;
335
+		}
336
+
337
+		/**
338
+		 * This sets a custom error message that can override the default error phrase provided
339
+		 * by FormValidation, it can be used in the format of setMessage('rule', 'error phrase')
340
+		 * which will globally change the error phrase of that rule, or in the format of:
341
+		 * setMessage('rule', 'fieldname', 'error phrase') - which will only change the error phrase for
342
+		 * that rule, applied on that field.
343
+		 *
344
+		 * @return boolean True on success, false on failure.
345
+		 */
346
+		public function setMessage() {
347
+			$numArgs = func_num_args();
348
+			switch ($numArgs) {
349
+				default:
350
+					return false;
351
+				// A global rule error message
352
+				case 2:
353
+					foreach ($this->post(null) as $key => $val) {
354
+						$this->_errorPhraseOverrides[$key][func_get_arg(0)] = func_get_arg(1);
355
+					}
356
+					break;
357
+				// Field specific rule error message
358
+				case 3:
359
+					$this->_errorPhraseOverrides[func_get_arg(1)][func_get_arg(0)] = func_get_arg(2);
360
+					break;
361
+			}
362
+			return true;
363
+		}
364
+
365
+		/**
366
+		 * Adds a custom error message in the errorSet array, that will
367
+		 * forcibly display it.
368
+		 *
369
+		 * @param string $inputName The form input name or data key
370
+		 * @param string $errorMessage Error to display
371
+		 *
372
+		 * @return formValidation Current instance of the object
373
+		 */
374
+		public function setCustomError($inputName, $errorMessage) {
375
+			$errorMessage = str_replace('%1', $this->_labels[$inputName], $errorMessage);
376
+			$this->_errors[$inputName] = $errorMessage;
377
+			return $this;
378
+		}
379
+
380
+		/**
381
+		 * Allows for an accesor to any/all post values, if a value of null is passed as the key, it
382
+		 * will recursively find all keys/values of the $_POST array or data array. It also automatically trims
383
+		 * all values.
384
+		 *
385
+		 * @param string $key Key of $this->data to be found, pass null for all Key => Val pairs.
386
+		 * @param boolean $trim Defaults to true, trims all $this->data values.
387
+		 * @return string|array Array of post or data values if null is passed as key, string if only one key is desired.
388
+		 */
389
+		public function post($key = null, $trim = true) {
390
+			$returnValue = null;
391
+			if (is_null($key)) {
392
+				$returnValue = array();
393
+				foreach ($this->getData()  as $key => $val) {
394
+					$returnValue[$key] = $this->post($key, $trim);
395
+				}
396
+			} else {
397
+				$returnValue = (array_key_exists($key, $this->getData())) ? (($trim) ? trim($this->data[$key]) : $this->data[$key]) : null;
398
+			}
399
+			return $returnValue;
400
+		}
401
+
402
+		/**
403
+		 * Gets all errors from errorSet and displays them, can be echo out from the
404
+		 * function or just returned.
405
+		 *
406
+		 * @param boolean $limit number of error to display or return
407
+		 * @param boolean $echo Whether or not the values are to be returned or displayed
408
+		 *
409
+		 * @return string Errors formatted for output
410
+		 */
411
+		public function displayErrors($limit = null, $echo = true) {
412
+			list($errorsStart, $errorsEnd) = $this->_allErrorsDelimiter;
413
+			list($errorStart, $errorEnd) = $this->_eachErrorDelimiter;
414
+			$errorOutput = $errorsStart;
415
+			$i = 0;
416
+			if (!empty($this->_errors)) {
417
+				foreach ($this->_errors as $fieldName => $error) {
418
+					if ($i === $limit) { 
419
+						break; 
420
+					}
421
+					$errorOutput .= $errorStart;
422
+					$errorOutput .= $error;
423
+					$errorOutput .= $errorEnd;
424
+					$i++;
425
+				}
426
+			}
427
+			$errorOutput .= $errorsEnd;
428
+			echo ($echo) ? $errorOutput : '';
429
+			return (! $echo) ? $errorOutput : null;
430
+		}
431
+
432
+		/**
433
+		 * Returns raw array of errors in no format instead of displaying them
434
+		 * formatted.
435
+		 *
436
+		 * @return array
437
+		 */
438
+		public function returnErrors() {
439
+			return $this->_errors;
440
+		}
441
+
442
+		/**
443
+		 * Breaks up a PIPE seperated string of rules, and puts them into an array.
444
+		 *
445
+		 * @param string $ruleString String to be parsed.
446
+		 *
447
+		 * @return array Array of each value in original string.
448
+		 */
449
+		protected function _parseRuleString($ruleString) {
450
+			$ruleSets = array();
451
+			/*
452 452
             //////////////// hack for regex rule that can contain "|"
453 453
             */
454
-            if(strpos($ruleString, 'regex') !== false){
455
-                $regexRule = array();
456
-                $rule = '#regex\[\/(.*)\/([a-zA-Z0-9]?)\]#';
457
-                preg_match($rule, $ruleString, $regexRule);
458
-                $ruleStringTemp = preg_replace($rule, '', $ruleString);
459
-                 if(isset($regexRule[0]) && !empty($regexRule[0])){
460
-                     $ruleSets[] = $regexRule[0];
461
-                 }
462
-                 $ruleStringRegex = explode('|', $ruleStringTemp);
463
-                foreach ($ruleStringRegex as $rule) {
464
-                    $rule = trim($rule);
465
-                    if($rule){
466
-                        $ruleSets[] = $rule;
467
-                    }
468
-                }
454
+			if(strpos($ruleString, 'regex') !== false){
455
+				$regexRule = array();
456
+				$rule = '#regex\[\/(.*)\/([a-zA-Z0-9]?)\]#';
457
+				preg_match($rule, $ruleString, $regexRule);
458
+				$ruleStringTemp = preg_replace($rule, '', $ruleString);
459
+				 if(isset($regexRule[0]) && !empty($regexRule[0])){
460
+					 $ruleSets[] = $regexRule[0];
461
+				 }
462
+				 $ruleStringRegex = explode('|', $ruleStringTemp);
463
+				foreach ($ruleStringRegex as $rule) {
464
+					$rule = trim($rule);
465
+					if($rule){
466
+						$ruleSets[] = $rule;
467
+					}
468
+				}
469 469
                  
470
-            }
471
-            /***********************************/
472
-            else{
473
-                if (strpos($ruleString, '|') !== FALSE) {
474
-                    $ruleSets = explode('|', $ruleString);
475
-                } else {
476
-                    $ruleSets[] = $ruleString;
477
-                }
478
-             }
479
-            return $ruleSets;
480
-        }
481
-
482
-        /**
483
-         * Returns whether or not a field obtains the rule "required".
484
-         *
485
-         * @param string $fieldName Field to check if required.
486
-		 *
487
-         * @return boolean Whether or not the field is required.
488
-         */
489
-        protected function _fieldIsRequired($fieldName) {
490
-            $rules = $this->_parseRuleString($this->_rules[$fieldName]);
491
-            return (in_array('required', $rules));
492
-        }
493
-
494
-        /**
495
-         * Takes a data input name, it's value, and the rule it's being validated against (ex: max_length[16])
496
-         * and adds an error to the errorSet if it fails validation of the rule.
497
-         *
498
-         * @param string $inputName Name or key of the validation data
499
-         * @param string $inputVal Value of the validation data
500
-         * @param string $ruleName Rule to be validated against, including args (exact_length[5])
501
-         * @return void
502
-         */
503
-        protected function _validateRule($inputName, $inputVal, $ruleName) {
504
-            $this->logger->debug('Rule validation of field [' .$inputName. '], value [' .$inputVal. '], rule [' .$ruleName. ']');
505
-            // Array to store args
506
-            $ruleArgs = array();
507
-
508
-            preg_match('/\[(.*)\]/', $ruleName, $ruleArgs);
509
-
510
-            // Get the rule arguments, realRule is just the base rule name
511
-            // Like min_length instead of min_length[3]
512
-            $ruleName = preg_replace('/\[(.*)\]/', '', $ruleName);
470
+			}
471
+			/***********************************/
472
+			else{
473
+				if (strpos($ruleString, '|') !== FALSE) {
474
+					$ruleSets = explode('|', $ruleString);
475
+				} else {
476
+					$ruleSets[] = $ruleString;
477
+				}
478
+			 }
479
+			return $ruleSets;
480
+		}
481
+
482
+		/**
483
+		 * Returns whether or not a field obtains the rule "required".
484
+		 *
485
+		 * @param string $fieldName Field to check if required.
486
+		 *
487
+		 * @return boolean Whether or not the field is required.
488
+		 */
489
+		protected function _fieldIsRequired($fieldName) {
490
+			$rules = $this->_parseRuleString($this->_rules[$fieldName]);
491
+			return (in_array('required', $rules));
492
+		}
493
+
494
+		/**
495
+		 * Takes a data input name, it's value, and the rule it's being validated against (ex: max_length[16])
496
+		 * and adds an error to the errorSet if it fails validation of the rule.
497
+		 *
498
+		 * @param string $inputName Name or key of the validation data
499
+		 * @param string $inputVal Value of the validation data
500
+		 * @param string $ruleName Rule to be validated against, including args (exact_length[5])
501
+		 * @return void
502
+		 */
503
+		protected function _validateRule($inputName, $inputVal, $ruleName) {
504
+			$this->logger->debug('Rule validation of field [' .$inputName. '], value [' .$inputVal. '], rule [' .$ruleName. ']');
505
+			// Array to store args
506
+			$ruleArgs = array();
507
+
508
+			preg_match('/\[(.*)\]/', $ruleName, $ruleArgs);
509
+
510
+			// Get the rule arguments, realRule is just the base rule name
511
+			// Like min_length instead of min_length[3]
512
+			$ruleName = preg_replace('/\[(.*)\]/', '', $ruleName);
513 513
             
514
-            if (method_exists($this, $this->_toCallCase($ruleName))) {
515
-                $methodToCall = $this->_toCallCase($ruleName);
516
-                call_user_func(array($this, $methodToCall), $inputName, $ruleName, $ruleArgs);
517
-            }
518
-            return;
519
-        }
520
-
521
-		/**
522
-		* Set error for the given field or key
523
-		*
524
-		* @param string $inputName the input or key name
525
-		* @param string $ruleName the rule name
526
-		* @param array|string $replacements
527
-		*/
528
-        protected function _setError($inputName, $ruleName, $replacements = array()) {
529
-            $rulePhraseKeyParts = explode(',', $ruleName);
530
-            $rulePhrase = null;
531
-            foreach ($rulePhraseKeyParts as $rulePhraseKeyPart) {
532
-                if (array_key_exists($rulePhraseKeyPart, $this->_errorsMessages)) {
533
-                    $rulePhrase = $this->_errorsMessages[$rulePhraseKeyPart];
534
-                } else {
535
-                    $rulePhrase = $rulePhrase[$rulePhraseKeyPart];
536
-                }
537
-            }
538
-            // Any overrides?
539
-            if (array_key_exists($inputName, $this->_errorPhraseOverrides) && array_key_exists($ruleName, $this->_errorPhraseOverrides[$inputName])) {
540
-                $rulePhrase = $this->_errorPhraseOverrides[$inputName][$ruleName];
541
-            }
542
-            // Type cast to array in case it's a string
543
-            $replacements = (array) $replacements;
514
+			if (method_exists($this, $this->_toCallCase($ruleName))) {
515
+				$methodToCall = $this->_toCallCase($ruleName);
516
+				call_user_func(array($this, $methodToCall), $inputName, $ruleName, $ruleArgs);
517
+			}
518
+			return;
519
+		}
520
+
521
+		/**
522
+		 * Set error for the given field or key
523
+		 *
524
+		 * @param string $inputName the input or key name
525
+		 * @param string $ruleName the rule name
526
+		 * @param array|string $replacements
527
+		 */
528
+		protected function _setError($inputName, $ruleName, $replacements = array()) {
529
+			$rulePhraseKeyParts = explode(',', $ruleName);
530
+			$rulePhrase = null;
531
+			foreach ($rulePhraseKeyParts as $rulePhraseKeyPart) {
532
+				if (array_key_exists($rulePhraseKeyPart, $this->_errorsMessages)) {
533
+					$rulePhrase = $this->_errorsMessages[$rulePhraseKeyPart];
534
+				} else {
535
+					$rulePhrase = $rulePhrase[$rulePhraseKeyPart];
536
+				}
537
+			}
538
+			// Any overrides?
539
+			if (array_key_exists($inputName, $this->_errorPhraseOverrides) && array_key_exists($ruleName, $this->_errorPhraseOverrides[$inputName])) {
540
+				$rulePhrase = $this->_errorPhraseOverrides[$inputName][$ruleName];
541
+			}
542
+			// Type cast to array in case it's a string
543
+			$replacements = (array) $replacements;
544 544
 			$replacementCount = count($replacements);
545
-            for ($i = 1; $i <= $replacementCount; $i++) {
546
-                $key = $i - 1;
547
-                $rulePhrase = str_replace('%' . $i, $replacements[$key], $rulePhrase);
548
-            }
549
-            if (! array_key_exists($inputName, $this->_errors)) {
550
-                $this->_errors[$inputName] = $rulePhrase;
551
-            }
552
-        }
553
-
554
-        /**
555
-         * Used to run a callback for the callback rule, as well as pass in a default
556
-         * argument of the post value. For example the username field having a rule:
557
-         * callback[userExists] will eval userExists(data[username]) - Note the use
558
-         * of eval over call_user_func is in case the function is not user defined.
559
-         *
560
-         * @param type $inputArg
561
-         * @param string $callbackFunc
562
-		 *
563
-         * @return mixed
564
-         */
565
-        protected function _runCallback($inputArg, $callbackFunc) {
545
+			for ($i = 1; $i <= $replacementCount; $i++) {
546
+				$key = $i - 1;
547
+				$rulePhrase = str_replace('%' . $i, $replacements[$key], $rulePhrase);
548
+			}
549
+			if (! array_key_exists($inputName, $this->_errors)) {
550
+				$this->_errors[$inputName] = $rulePhrase;
551
+			}
552
+		}
553
+
554
+		/**
555
+		 * Used to run a callback for the callback rule, as well as pass in a default
556
+		 * argument of the post value. For example the username field having a rule:
557
+		 * callback[userExists] will eval userExists(data[username]) - Note the use
558
+		 * of eval over call_user_func is in case the function is not user defined.
559
+		 *
560
+		 * @param type $inputArg
561
+		 * @param string $callbackFunc
562
+		 *
563
+		 * @return mixed
564
+		 */
565
+		protected function _runCallback($inputArg, $callbackFunc) {
566 566
 			return eval('return ' . $callbackFunc . '("' . $inputArg . '");');
567
-        }
568
-
569
-        /**
570
-         * Used for applying a rule only if the empty callback evaluates to true,
571
-         * for example required[funcName] - This runs funcName without passing any
572
-         * arguments.
573
-         *
574
-         * @param string $callbackFunc
575
-		 *
576
-         * @return anything
577
-         */
578
-        protected function _runEmptyCallback($callbackFunc) {
579
-            return eval('return ' . $callbackFunc . '();');
580
-        }
581
-
582
-        /**
583
-         * Gets a specific label of a specific field input name.
584
-         *
585
-         * @param string $inputName
586
-		 *
587
-         * @return string
588
-         */
589
-        protected function _getLabel($inputName) {
590
-            return (array_key_exists($inputName, $this->_labels)) ? $this->_labels[$inputName] : $inputName;
591
-        }
567
+		}
568
+
569
+		/**
570
+		 * Used for applying a rule only if the empty callback evaluates to true,
571
+		 * for example required[funcName] - This runs funcName without passing any
572
+		 * arguments.
573
+		 *
574
+		 * @param string $callbackFunc
575
+		 *
576
+		 * @return anything
577
+		 */
578
+		protected function _runEmptyCallback($callbackFunc) {
579
+			return eval('return ' . $callbackFunc . '();');
580
+		}
581
+
582
+		/**
583
+		 * Gets a specific label of a specific field input name.
584
+		 *
585
+		 * @param string $inputName
586
+		 *
587
+		 * @return string
588
+		 */
589
+		protected function _getLabel($inputName) {
590
+			return (array_key_exists($inputName, $this->_labels)) ? $this->_labels[$inputName] : $inputName;
591
+		}
592 592
 		
593
-        /**
594
-         * Peform validation for the rule "required"
595
-         * @param  string $inputName the form field or data key name used
596
-         * @param  string $ruleName  the rule name for this validation ("required")
597
-         * @param  array  $ruleArgs  the rules argument
598
-         */
593
+		/**
594
+		 * Peform validation for the rule "required"
595
+		 * @param  string $inputName the form field or data key name used
596
+		 * @param  string $ruleName  the rule name for this validation ("required")
597
+		 * @param  array  $ruleArgs  the rules argument
598
+		 */
599 599
 		protected function _validateRequired($inputName, $ruleName, array $ruleArgs) {
600
-            $inputVal = $this->post($inputName);
601
-            if(array_key_exists(1, $ruleArgs) && function_exists($ruleArgs[1])) {
602
-                $callbackReturn = $this->_runEmptyCallback($ruleArgs[1]);
603
-                if ($inputVal == '' && $callbackReturn == true) {
604
-                    $this->_setError($inputName, $ruleName, $this->_getLabel($inputName));
605
-                }
606
-            } 
600
+			$inputVal = $this->post($inputName);
601
+			if(array_key_exists(1, $ruleArgs) && function_exists($ruleArgs[1])) {
602
+				$callbackReturn = $this->_runEmptyCallback($ruleArgs[1]);
603
+				if ($inputVal == '' && $callbackReturn == true) {
604
+					$this->_setError($inputName, $ruleName, $this->_getLabel($inputName));
605
+				}
606
+			} 
607 607
 			else if($inputVal == '') {
608 608
 				$this->_setError($inputName, $ruleName, $this->_getLabel($inputName));
609
-            }
610
-        }
611
-
612
-        /**
613
-         * Perform validation for the honey pot so means for the validation to be failed
614
-         * @param  string $inputName the form field or data key name used
615
-         * @param  string $ruleName  the rule name for this validation
616
-         * @param  array  $ruleArgs  the rules argument
617
-         */
618
-        protected function _validateHoneypot($inputName, $ruleName, array $ruleArgs) {
619
-            if ($this->data[$inputName] != '') {
620
-                $this->_forceFail = true;
621
-            }
622
-        }
623
-
624
-        /**
625
-         * Peform validation for the rule "callback"
626
-         * @param  string $inputName the form field or data key name used
627
-         * @param  string $ruleName  the rule name for this validation ("callback")
628
-         * @param  array  $ruleArgs  the rules argument
629
-         */
630
-        protected function _validateCallback($inputName, $ruleName, array $ruleArgs) {
631
-            if (function_exists($ruleArgs[1]) && !empty($this->data[$inputName])) {
609
+			}
610
+		}
611
+
612
+		/**
613
+		 * Perform validation for the honey pot so means for the validation to be failed
614
+		 * @param  string $inputName the form field or data key name used
615
+		 * @param  string $ruleName  the rule name for this validation
616
+		 * @param  array  $ruleArgs  the rules argument
617
+		 */
618
+		protected function _validateHoneypot($inputName, $ruleName, array $ruleArgs) {
619
+			if ($this->data[$inputName] != '') {
620
+				$this->_forceFail = true;
621
+			}
622
+		}
623
+
624
+		/**
625
+		 * Peform validation for the rule "callback"
626
+		 * @param  string $inputName the form field or data key name used
627
+		 * @param  string $ruleName  the rule name for this validation ("callback")
628
+		 * @param  array  $ruleArgs  the rules argument
629
+		 */
630
+		protected function _validateCallback($inputName, $ruleName, array $ruleArgs) {
631
+			if (function_exists($ruleArgs[1]) && !empty($this->data[$inputName])) {
632 632
 				$result = $this->_runCallback($this->data[$inputName], $ruleArgs[1]);
633 633
 				if(! $result){
634 634
 					$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
635 635
 				}
636
-            }
637
-        }
638
-
639
-        /**
640
-         * Peform validation for the rule "depends"
641
-         * @param  string $inputName the form field or data key name used
642
-         * @param  string $ruleName  the rule name for this validation ("depends")
643
-         * @param  array  $ruleArgs  the rules argument
644
-         */
645
-        protected function _validateDepends($inputName, $ruleName, array $ruleArgs) {
646
-            if (array_key_exists($ruleArgs[1], $this->_errors)) {
647
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
648
-            }
649
-        }
650
-
651
-        /**
652
-         * Peform validation for the rule "not_equal"
653
-         * @param  string $inputName the form field or data key name used
654
-         * @param  string $ruleName  the rule name for this validation ("not_equal")
655
-         * @param  array  $ruleArgs  the rules argument
656
-         */
657
-        protected function _validateNotEqual($inputName, $ruleName, array $ruleArgs) {
658
-            $canNotEqual = explode(',', $ruleArgs[1]);
659
-            foreach ($canNotEqual as $doNotEqual) {
660
-                $inputVal = $this->post($inputName);
661
-                if (preg_match('/post:(.*)/', $doNotEqual)) {
662
-                    if ($inputVal == $this->data[str_replace('post:', '', $doNotEqual)]) {
663
-                        $this->_setError($inputName, $ruleName . ',post:key', array($this->_getLabel($inputName), $this->_getLabel(str_replace('post:', '', $doNotEqual))));
664
-                        continue;
665
-                    }
666
-                } 
636
+			}
637
+		}
638
+
639
+		/**
640
+		 * Peform validation for the rule "depends"
641
+		 * @param  string $inputName the form field or data key name used
642
+		 * @param  string $ruleName  the rule name for this validation ("depends")
643
+		 * @param  array  $ruleArgs  the rules argument
644
+		 */
645
+		protected function _validateDepends($inputName, $ruleName, array $ruleArgs) {
646
+			if (array_key_exists($ruleArgs[1], $this->_errors)) {
647
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
648
+			}
649
+		}
650
+
651
+		/**
652
+		 * Peform validation for the rule "not_equal"
653
+		 * @param  string $inputName the form field or data key name used
654
+		 * @param  string $ruleName  the rule name for this validation ("not_equal")
655
+		 * @param  array  $ruleArgs  the rules argument
656
+		 */
657
+		protected function _validateNotEqual($inputName, $ruleName, array $ruleArgs) {
658
+			$canNotEqual = explode(',', $ruleArgs[1]);
659
+			foreach ($canNotEqual as $doNotEqual) {
660
+				$inputVal = $this->post($inputName);
661
+				if (preg_match('/post:(.*)/', $doNotEqual)) {
662
+					if ($inputVal == $this->data[str_replace('post:', '', $doNotEqual)]) {
663
+						$this->_setError($inputName, $ruleName . ',post:key', array($this->_getLabel($inputName), $this->_getLabel(str_replace('post:', '', $doNotEqual))));
664
+						continue;
665
+					}
666
+				} 
667 667
 				else{
668
-                    if ($inputVal == $doNotEqual) {
669
-                        $this->_setError($inputName, $ruleName . ',string', array($this->_getLabel($inputName), $doNotEqual));
670
-                        continue;
671
-                    }
672
-                }
673
-            }
674
-        }
675
-
676
-        /**
677
-         * Peform validation for the rule "matches"
678
-         * @param  string $inputName the form field or data key name used
679
-         * @param  string $ruleName  the rule name for this validation ("matches")
680
-         * @param  array  $ruleArgs  the rules argument
681
-         */
682
-        protected function _validateMatches($inputName, $ruleName, array $ruleArgs) {
683
-            $inputVal = $this->post($inputName);
684
-            if ($inputVal != $this->data[$ruleArgs[1]]) {
685
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
686
-            }
687
-        }
688
-
689
-        /**
690
-         * Peform validation for the rule "valid_email"
691
-         * @param  string $inputName the form field or data key name used
692
-         * @param  string $ruleName  the rule name for this validation ("valid_email")
693
-         * @param  array  $ruleArgs  the rules argument
694
-         */
695
-        protected function _validateValidEmail($inputName, $ruleName, array $ruleArgs) {
696
-            $inputVal = $this->post($inputName);
697
-            if (! preg_match("/^([\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+\.)*[\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+@((((([a-z0-9]{1}[a-z0-9\-]{0,62}[a-z0-9]{1})|[a-z])\.)+[a-z]{2,6})|(\d{1,3}\.){3}\d{1,3}(\:\d{1,5})?)$/i", $inputVal)) {
698
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
699
-                    return;
700
-                }
701
-                $this->_setError($inputName, $ruleName, $this->_getLabel($inputName));
702
-            }
703
-        }
704
-
705
-        /**
706
-         * Peform validation for the rule "exact_length"
707
-         * @param  string $inputName the form field or data key name used
708
-         * @param  string $ruleName  the rule name for this validation ("exact_length")
709
-         * @param  array  $ruleArgs  the rules argument
710
-         */
711
-        protected function _validateExactLength($inputName, $ruleName, array $ruleArgs) {
712
-            $inputVal = $this->post($inputName);
713
-            if (strlen($inputVal) != $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
714
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
715
-                    return;
716
-                }
717
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
718
-            }
719
-        }
720
-
721
-        /**
722
-         * Peform validation for the rule "max_length"
723
-         * @param  string $inputName the form field or data key name used
724
-         * @param  string $ruleName  the rule name for this validation ("max_length")
725
-         * @param  array  $ruleArgs  the rules argument
726
-         */
727
-        protected function _validateMaxLength($inputName, $ruleName, array $ruleArgs) {
728
-            $inputVal = $this->post($inputName);
729
-            if (strlen($inputVal) > $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
730
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
731
-                    return;
732
-                }
733
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
734
-            }
735
-        }
736
-
737
-        /**
738
-         * Peform validation for the rule "min_length"
739
-         * @param  string $inputName the form field or data key name used
740
-         * @param  string $ruleName  the rule name for this validation ("min_length")
741
-         * @param  array  $ruleArgs  the rules argument
742
-         */
743
-        protected function _validateMinLength($inputName, $ruleName, array $ruleArgs) {
744
-            $inputVal = $this->post($inputName);
745
-            if (strlen($inputVal) < $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
746
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
747
-                    return;
748
-                }
749
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
750
-            }
751
-        }
668
+					if ($inputVal == $doNotEqual) {
669
+						$this->_setError($inputName, $ruleName . ',string', array($this->_getLabel($inputName), $doNotEqual));
670
+						continue;
671
+					}
672
+				}
673
+			}
674
+		}
675
+
676
+		/**
677
+		 * Peform validation for the rule "matches"
678
+		 * @param  string $inputName the form field or data key name used
679
+		 * @param  string $ruleName  the rule name for this validation ("matches")
680
+		 * @param  array  $ruleArgs  the rules argument
681
+		 */
682
+		protected function _validateMatches($inputName, $ruleName, array $ruleArgs) {
683
+			$inputVal = $this->post($inputName);
684
+			if ($inputVal != $this->data[$ruleArgs[1]]) {
685
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
686
+			}
687
+		}
688
+
689
+		/**
690
+		 * Peform validation for the rule "valid_email"
691
+		 * @param  string $inputName the form field or data key name used
692
+		 * @param  string $ruleName  the rule name for this validation ("valid_email")
693
+		 * @param  array  $ruleArgs  the rules argument
694
+		 */
695
+		protected function _validateValidEmail($inputName, $ruleName, array $ruleArgs) {
696
+			$inputVal = $this->post($inputName);
697
+			if (! preg_match("/^([\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+\.)*[\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+@((((([a-z0-9]{1}[a-z0-9\-]{0,62}[a-z0-9]{1})|[a-z])\.)+[a-z]{2,6})|(\d{1,3}\.){3}\d{1,3}(\:\d{1,5})?)$/i", $inputVal)) {
698
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
699
+					return;
700
+				}
701
+				$this->_setError($inputName, $ruleName, $this->_getLabel($inputName));
702
+			}
703
+		}
704
+
705
+		/**
706
+		 * Peform validation for the rule "exact_length"
707
+		 * @param  string $inputName the form field or data key name used
708
+		 * @param  string $ruleName  the rule name for this validation ("exact_length")
709
+		 * @param  array  $ruleArgs  the rules argument
710
+		 */
711
+		protected function _validateExactLength($inputName, $ruleName, array $ruleArgs) {
712
+			$inputVal = $this->post($inputName);
713
+			if (strlen($inputVal) != $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
714
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
715
+					return;
716
+				}
717
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
718
+			}
719
+		}
720
+
721
+		/**
722
+		 * Peform validation for the rule "max_length"
723
+		 * @param  string $inputName the form field or data key name used
724
+		 * @param  string $ruleName  the rule name for this validation ("max_length")
725
+		 * @param  array  $ruleArgs  the rules argument
726
+		 */
727
+		protected function _validateMaxLength($inputName, $ruleName, array $ruleArgs) {
728
+			$inputVal = $this->post($inputName);
729
+			if (strlen($inputVal) > $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
730
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
731
+					return;
732
+				}
733
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
734
+			}
735
+		}
736
+
737
+		/**
738
+		 * Peform validation for the rule "min_length"
739
+		 * @param  string $inputName the form field or data key name used
740
+		 * @param  string $ruleName  the rule name for this validation ("min_length")
741
+		 * @param  array  $ruleArgs  the rules argument
742
+		 */
743
+		protected function _validateMinLength($inputName, $ruleName, array $ruleArgs) {
744
+			$inputVal = $this->post($inputName);
745
+			if (strlen($inputVal) < $ruleArgs[1]) { // $ruleArgs[0] is [length] $rulesArgs[1] is just length
746
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
747
+					return;
748
+				}
749
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
750
+			}
751
+		}
752 752
     	
753
-        /**
754
-         * Peform validation for the rule "less_than"
755
-         * @param  string $inputName the form field or data key name used
756
-         * @param  string $ruleName  the rule name for this validation ("less_than")
757
-         * @param  array  $ruleArgs  the rules argument
758
-         */
759
-    	protected function _validateLessThan($inputName, $ruleName, array $ruleArgs) {
760
-            $inputVal = $this->post($inputName);
761
-            if ($inputVal >= $ruleArgs[1]) { 
762
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
763
-                    return;
764
-                }
765
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
766
-            }
767
-        }
753
+		/**
754
+		 * Peform validation for the rule "less_than"
755
+		 * @param  string $inputName the form field or data key name used
756
+		 * @param  string $ruleName  the rule name for this validation ("less_than")
757
+		 * @param  array  $ruleArgs  the rules argument
758
+		 */
759
+		protected function _validateLessThan($inputName, $ruleName, array $ruleArgs) {
760
+			$inputVal = $this->post($inputName);
761
+			if ($inputVal >= $ruleArgs[1]) { 
762
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
763
+					return;
764
+				}
765
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
766
+			}
767
+		}
768 768
     	
769
-        /**
770
-         * Peform validation for the rule "greater_than"
771
-         * @param  string $inputName the form field or data key name used
772
-         * @param  string $ruleName  the rule name for this validation ("greater_than")
773
-         * @param  array  $ruleArgs  the rules argument
774
-         */
775
-    	protected function _validateGreaterThan($inputName, $ruleName, array $ruleArgs) {
776
-            $inputVal = $this->post($inputName);
777
-            if ($inputVal <= $ruleArgs[1]) {
778
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
779
-                    return;
780
-                }
781
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
782
-            }
783
-        }
769
+		/**
770
+		 * Peform validation for the rule "greater_than"
771
+		 * @param  string $inputName the form field or data key name used
772
+		 * @param  string $ruleName  the rule name for this validation ("greater_than")
773
+		 * @param  array  $ruleArgs  the rules argument
774
+		 */
775
+		protected function _validateGreaterThan($inputName, $ruleName, array $ruleArgs) {
776
+			$inputVal = $this->post($inputName);
777
+			if ($inputVal <= $ruleArgs[1]) {
778
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
779
+					return;
780
+				}
781
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
782
+			}
783
+		}
784 784
     	
785
-        /**
786
-         * Peform validation for the rule "numeric"
787
-         * @param  string $inputName the form field or data key name used
788
-         * @param  string $ruleName  the rule name for this validation ("numeric")
789
-         * @param  array  $ruleArgs  the rules argument
790
-         */
791
-    	protected function _validateNumeric($inputName, $ruleName, array $ruleArgs) {
792
-            $inputVal = $this->post($inputName);
793
-            if (! is_numeric($inputVal)) {
794
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
795
-                    return;
796
-                }
797
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
798
-            }
799
-        }
785
+		/**
786
+		 * Peform validation for the rule "numeric"
787
+		 * @param  string $inputName the form field or data key name used
788
+		 * @param  string $ruleName  the rule name for this validation ("numeric")
789
+		 * @param  array  $ruleArgs  the rules argument
790
+		 */
791
+		protected function _validateNumeric($inputName, $ruleName, array $ruleArgs) {
792
+			$inputVal = $this->post($inputName);
793
+			if (! is_numeric($inputVal)) {
794
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
795
+					return;
796
+				}
797
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
798
+			}
799
+		}
800 800
 		
801
-        /**
802
-         * Peform validation for the rule "exists"
803
-         * @param  string $inputName the form field or data key name used
804
-         * @param  string $ruleName  the rule name for this validation ("exists")
805
-         * @param  array  $ruleArgs  the rules argument
806
-         */
801
+		/**
802
+		 * Peform validation for the rule "exists"
803
+		 * @param  string $inputName the form field or data key name used
804
+		 * @param  string $ruleName  the rule name for this validation ("exists")
805
+		 * @param  array  $ruleArgs  the rules argument
806
+		 */
807 807
 		protected function _validateExists($inputName, $ruleName, array $ruleArgs) {
808
-            $inputVal = $this->post($inputName);
809
-    		$obj = & get_instance();
810
-    		if(! isset($obj->database)){
811
-    			return;
812
-    		}
813
-    		list($table, $column) = explode('.', $ruleArgs[1]);
814
-    		$obj->database->from($table)
815
-    			          ->where($column, $inputVal)
816
-    			          ->get();
817
-    		$nb = $obj->database->numRows();
818
-            if ($nb == 0) {
819
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
820
-                    return;
821
-                }
822
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
823
-            }
824
-        }
825
-
826
-        /**
827
-         * Peform validation for the rule "is_unique"
828
-         * @param  string $inputName the form field or data key name used
829
-         * @param  string $ruleName  the rule name for this validation ("is_unique")
830
-         * @param  array  $ruleArgs  the rules argument
831
-         */
832
-    	protected function _validateIsUnique($inputName, $ruleName, array $ruleArgs) {
833
-            $inputVal = $this->post($inputName);
834
-    		$obj = & get_instance();
835
-    		if(! isset($obj->database)){
836
-    			return;
837
-    		}
838
-    		list($table, $column) = explode('.', $ruleArgs[1]);
839
-    		$obj->database->from($table)
840
-    			          ->where($column, $inputVal)
841
-    			          ->get();
842
-    		$nb = $obj->database->numRows();
843
-            if ($nb != 0) {
844
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
845
-                    return;
846
-                }
847
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
848
-            }
849
-        }
808
+			$inputVal = $this->post($inputName);
809
+			$obj = & get_instance();
810
+			if(! isset($obj->database)){
811
+				return;
812
+			}
813
+			list($table, $column) = explode('.', $ruleArgs[1]);
814
+			$obj->database->from($table)
815
+						  ->where($column, $inputVal)
816
+						  ->get();
817
+			$nb = $obj->database->numRows();
818
+			if ($nb == 0) {
819
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
820
+					return;
821
+				}
822
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
823
+			}
824
+		}
825
+
826
+		/**
827
+		 * Peform validation for the rule "is_unique"
828
+		 * @param  string $inputName the form field or data key name used
829
+		 * @param  string $ruleName  the rule name for this validation ("is_unique")
830
+		 * @param  array  $ruleArgs  the rules argument
831
+		 */
832
+		protected function _validateIsUnique($inputName, $ruleName, array $ruleArgs) {
833
+			$inputVal = $this->post($inputName);
834
+			$obj = & get_instance();
835
+			if(! isset($obj->database)){
836
+				return;
837
+			}
838
+			list($table, $column) = explode('.', $ruleArgs[1]);
839
+			$obj->database->from($table)
840
+						  ->where($column, $inputVal)
841
+						  ->get();
842
+			$nb = $obj->database->numRows();
843
+			if ($nb != 0) {
844
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
845
+					return;
846
+				}
847
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
848
+			}
849
+		}
850 850
     	
851
-        /**
852
-         * Peform validation for the rule "is_unique_update"
853
-         * @param  string $inputName the form field or data key name used
854
-         * @param  string $ruleName  the rule name for this validation ("is_unique_update")
855
-         * @param  array  $ruleArgs  the rules argument
856
-         */
857
-    	protected function _validateIsUniqueUpdate($inputName, $ruleName, array $ruleArgs) {
858
-            $inputVal = $this->post($inputName);
859
-    		$obj = & get_instance();
860
-    		if(! isset($obj->database)){
861
-    			return;
862
-    		}
863
-    		$data = explode(',', $ruleArgs[1]);
864
-    		if(count($data) < 2){
865
-    			return;
866
-    		}
867
-    		list($table, $column) = explode('.', $data[0]);
868
-    		list($field, $val) = explode('=', $data[1]);
869
-    		$obj->database->from($table)
870
-    			          ->where($column, $inputVal)
871
-                		  ->where($field, '!=', trim($val))
872
-                		  ->get();
873
-    		$nb = $obj->database->numRows();
874
-            if ($nb != 0) {
875
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
876
-                    return;
877
-                }
878
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
879
-            }
880
-        }
881
-
882
-        /**
883
-         * Peform validation for the rule "in_list"
884
-         * @param  string $inputName the form field or data key name used
885
-         * @param  string $ruleName  the rule name for this validation ("in_list")
886
-         * @param  array  $ruleArgs  the rules argument
887
-         */
888
-        protected function _validateInList($inputName, $ruleName, array $ruleArgs) {
889
-            $inputVal = $this->post($inputName);
890
-    		$list = explode(',', $ruleArgs[1]);
891
-            $list = array_map('trim', $list);
892
-            if (! in_array($inputVal, $list)) {
893
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
894
-                    return;
895
-                }
896
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
897
-            }
898
-        }
899
-
900
-        /**
901
-         * Peform validation for the rule "regex"
902
-         * @param  string $inputName the form field or data key name used
903
-         * @param  string $ruleName  the rule name for this validation ("regex")
904
-         * @param  array  $ruleArgs  the rules argument
905
-         */
906
-        protected function _validateRegex($inputName, $ruleName, array $ruleArgs) {
907
-            $inputVal = $this->post($inputName);
908
-    		$regex = $ruleArgs[1];
909
-            if (! preg_match($regex, $inputVal)) {
910
-                if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
911
-                    return;
912
-                }
913
-                $this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
914
-            }
915
-        }
851
+		/**
852
+		 * Peform validation for the rule "is_unique_update"
853
+		 * @param  string $inputName the form field or data key name used
854
+		 * @param  string $ruleName  the rule name for this validation ("is_unique_update")
855
+		 * @param  array  $ruleArgs  the rules argument
856
+		 */
857
+		protected function _validateIsUniqueUpdate($inputName, $ruleName, array $ruleArgs) {
858
+			$inputVal = $this->post($inputName);
859
+			$obj = & get_instance();
860
+			if(! isset($obj->database)){
861
+				return;
862
+			}
863
+			$data = explode(',', $ruleArgs[1]);
864
+			if(count($data) < 2){
865
+				return;
866
+			}
867
+			list($table, $column) = explode('.', $data[0]);
868
+			list($field, $val) = explode('=', $data[1]);
869
+			$obj->database->from($table)
870
+						  ->where($column, $inputVal)
871
+						  ->where($field, '!=', trim($val))
872
+						  ->get();
873
+			$nb = $obj->database->numRows();
874
+			if ($nb != 0) {
875
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
876
+					return;
877
+				}
878
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
879
+			}
880
+		}
881
+
882
+		/**
883
+		 * Peform validation for the rule "in_list"
884
+		 * @param  string $inputName the form field or data key name used
885
+		 * @param  string $ruleName  the rule name for this validation ("in_list")
886
+		 * @param  array  $ruleArgs  the rules argument
887
+		 */
888
+		protected function _validateInList($inputName, $ruleName, array $ruleArgs) {
889
+			$inputVal = $this->post($inputName);
890
+			$list = explode(',', $ruleArgs[1]);
891
+			$list = array_map('trim', $list);
892
+			if (! in_array($inputVal, $list)) {
893
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
894
+					return;
895
+				}
896
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName), $this->_getLabel($ruleArgs[1])));
897
+			}
898
+		}
899
+
900
+		/**
901
+		 * Peform validation for the rule "regex"
902
+		 * @param  string $inputName the form field or data key name used
903
+		 * @param  string $ruleName  the rule name for this validation ("regex")
904
+		 * @param  array  $ruleArgs  the rules argument
905
+		 */
906
+		protected function _validateRegex($inputName, $ruleName, array $ruleArgs) {
907
+			$inputVal = $this->post($inputName);
908
+			$regex = $ruleArgs[1];
909
+			if (! preg_match($regex, $inputVal)) {
910
+				if (! $this->_fieldIsRequired($inputName) && empty($this->data[$inputName])) {
911
+					return;
912
+				}
913
+				$this->_setError($inputName, $ruleName, array($this->_getLabel($inputName)));
914
+			}
915
+		}
916 916
         
917
-    }
917
+	}
Please login to merge, or discard this patch.
tests/tnhfw/classes/EventInfoTest.php 1 patch
Spacing   +4 added lines, -4 removed lines patch added patch discarded remove patch
@@ -25,7 +25,7 @@  discard block
 block discarded – undo
25 25
 
26 26
 		
27 27
 		
28
-		public function testDefaultValue(){
28
+		public function testDefaultValue() {
29 29
 			$e = new EventInfo('foo');
30 30
 			$this->assertSame($e->name, 'foo');
31 31
 			$this->assertSame($e->payload, array());
@@ -33,7 +33,7 @@  discard block
 block discarded – undo
33 33
 			$this->assertFalse($e->stop);
34 34
 		}
35 35
 		
36
-		public function testPayloadValueIsSet(){
36
+		public function testPayloadValueIsSet() {
37 37
 			$e = new EventInfo('foo', array('bar'));
38 38
 			$this->assertSame($e->name, 'foo');
39 39
 			$this->assertSame($e->payload, array('bar'));
@@ -41,7 +41,7 @@  discard block
 block discarded – undo
41 41
 			$this->assertFalse($e->stop);
42 42
 		}
43 43
 		
44
-		public function testReturnBackValueIsSetToTrue(){
44
+		public function testReturnBackValueIsSetToTrue() {
45 45
 			$e = new EventInfo('foo', array('bar'), true);
46 46
 			$this->assertSame($e->name, 'foo');
47 47
 			$this->assertSame($e->payload, array('bar'));
@@ -49,7 +49,7 @@  discard block
 block discarded – undo
49 49
 			$this->assertFalse($e->stop);
50 50
 		}
51 51
 		
52
-		public function testStopValueIsSetToTue(){
52
+		public function testStopValueIsSetToTue() {
53 53
 			$e = new EventInfo('foo', array('bar'), true, true);
54 54
 			$this->assertSame($e->name, 'foo');
55 55
 			$this->assertSame($e->payload, array('bar'));
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,52 +94,52 @@  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){
131
+	function php_exception_handler($ex) {
132 132
 		//show only and continue to help track of some error occured
133
-		echo 'TNHFW PHP Exception : '.$ex->getMessage().' | '.$ex->getFile().' | '.$ex->getLine();
133
+		echo 'TNHFW PHP Exception : ' . $ex->getMessage() . ' | ' . $ex->getFile() . ' | ' . $ex->getLine();
134 134
 	}
135 135
 	
136 136
 	
137
-	function php_error_handler($errno , $errstr, $errfile , $errline, array $errcontext = array()){
137
+	function php_error_handler($errno, $errstr, $errfile, $errline, array $errcontext = array()) {
138 138
 		//show only and continue to help track of some error occured
139
-		echo 'TNHFW PHP Error : '.$errstr.' | '.$errfile.' | '.$errline;
139
+		echo 'TNHFW PHP Error : ' . $errstr . ' | ' . $errfile . ' | ' . $errline;
140 140
 	}
141 141
 
142
-	function php_shudown_handler(){
142
+	function php_shudown_handler() {
143 143
 		return true;
144 144
 	}
145 145
 
@@ -147,11 +147,11 @@  discard block
 block discarded – undo
147 147
 	/**
148 148
 	*  @test
149 149
 	*/
150
-	function attributes_to_string(array $attributes){
150
+	function attributes_to_string(array $attributes) {
151 151
 		$str = ' ';
152 152
 		//we check that the array passed as an argument is not empty.
153
-		if(! empty($attributes)){
154
-			foreach($attributes as $key => $value){
153
+		if (!empty($attributes)) {
154
+			foreach ($attributes as $key => $value) {
155 155
 				$key = trim(htmlspecialchars($key));
156 156
 				$value = trim(htmlspecialchars($value));
157 157
 				/*
@@ -161,35 +161,35 @@  discard block
 block discarded – undo
161 161
 				* 	$attr = array('placeholder' => 'I am a "puple"')
162 162
 				* 	$str = attributes_to_string($attr); => placeholder = "I am a \"puple\""
163 163
 				 */
164
-				if($value && strpos('"', $value) !== false){
164
+				if ($value && strpos('"', $value) !== false) {
165 165
 					$value = addslashes($value);
166 166
 				}
167
-				$str .= $key.' = "'.$value.'" ';
167
+				$str .= $key . ' = "' . $value . '" ';
168 168
 			}
169 169
 		}
170 170
 		//remove the space after using rtrim()
171 171
 		return rtrim($str);
172 172
 	}
173 173
 
174
-	function stringfy_vars($var){
174
+	function stringfy_vars($var) {
175 175
 		return print_r($var, true);
176 176
 	}
177 177
 
178 178
 	/**
179 179
 	*  @test
180 180
 	*/
181
-	function clean_input($str){
182
-		if(is_array($str)){
181
+	function clean_input($str) {
182
+		if (is_array($str)) {
183 183
 			$str = array_map('clean_input', $str);
184 184
 		}
185
-		else if(is_object($str)){
185
+		else if (is_object($str)) {
186 186
 			$obj = $str;
187 187
 			foreach ($str as $var => $value) {
188 188
 				$obj->$var = clean_input($value);
189 189
 			}
190 190
 			$str = $obj;
191 191
 		}
192
-		else{
192
+		else {
193 193
 			$str = htmlspecialchars(strip_tags($str), ENT_QUOTES, 'UTF-8');
194 194
 		}
195 195
 		return $str;
@@ -198,11 +198,11 @@  discard block
 block discarded – undo
198 198
 	/**
199 199
 	*  @test
200 200
 	*/
201
-	function string_hidden($str, $startCount = 0, $endCount = 0, $hiddenChar = '*'){
201
+	function string_hidden($str, $startCount = 0, $endCount = 0, $hiddenChar = '*') {
202 202
 		//get the string length
203 203
 		$len = strlen($str);
204 204
 		//if str is empty
205
-		if($len <= 0){
205
+		if ($len <= 0) {
206 206
 			return str_repeat($hiddenChar, 6);
207 207
 		}
208 208
 		//if the length is less than startCount and endCount
@@ -210,14 +210,14 @@  discard block
 block discarded – undo
210 210
 		//or startCount is negative or endCount is negative
211 211
 		//return the full string hidden
212 212
 		
213
-		if((($startCount + $endCount) > $len) || ($startCount == 0 && $endCount == 0) || ($startCount < 0 || $endCount < 0)){
213
+		if ((($startCount + $endCount) > $len) || ($startCount == 0 && $endCount == 0) || ($startCount < 0 || $endCount < 0)) {
214 214
 			return str_repeat($hiddenChar, $len);
215 215
 		}
216 216
 		//the start non hidden string
217 217
 		$startNonHiddenStr = substr($str, 0, $startCount);
218 218
 		//the end non hidden string
219 219
 		$endNonHiddenStr = null;
220
-		if($endCount > 0){
220
+		if ($endCount > 0) {
221 221
 			$endNonHiddenStr = substr($str, - $endCount);
222 222
 		}
223 223
 		//the hidden string
@@ -226,12 +226,12 @@  discard block
 block discarded – undo
226 226
 		return $startNonHiddenStr . $hiddenStr . $endNonHiddenStr;
227 227
 	}
228 228
 	
229
-	function set_session_config(){
229
+	function set_session_config() {
230 230
 		return true;
231 231
 	}
232 232
 	
233 233
 	function & get_instance(){
234
-		if(! Controller::get_instance()){
234
+		if (!Controller::get_instance()) {
235 235
 			$c = new Controller();
236 236
 		}
237 237
 		return Controller::get_instance();
Please login to merge, or discard this patch.