[5136] | 1 | <?php |
---|
[6328] | 2 | /** |
---|
| 3 | * |
---|
| 4 | * Copyright (C) 2012 Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br) |
---|
| 5 | * |
---|
| 6 | * This program is free software; you can redistribute it and/or modify it under |
---|
| 7 | * the terms of the GNU Affero General Public License version 3 as published by |
---|
| 8 | * the Free Software Foundation with the addition of the following permission |
---|
| 9 | * added to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED |
---|
| 10 | * WORK IN WHICH THE COPYRIGHT IS OWNED BY FUNAMBOL, FUNAMBOL DISCLAIMS THE |
---|
| 11 | * WARRANTY OF NON INFRINGEMENT OF THIRD PARTY RIGHTS. |
---|
| 12 | * |
---|
| 13 | * This program is distributed in the hope that it will be useful, but WITHOUT |
---|
| 14 | * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS |
---|
| 15 | * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more |
---|
| 16 | * details. |
---|
| 17 | * |
---|
| 18 | * You should have received a copy of the GNU Affero General Public License |
---|
| 19 | * along with this program; if not, see www.gnu.org/licenses or write to |
---|
| 20 | * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, |
---|
| 21 | * MA 02110-1301 USA. |
---|
| 22 | * |
---|
| 23 | * This code is based on the OpenXchange Connector and on the Prognus pSync |
---|
| 24 | * Connector both developed by the community and licensed under the GPL |
---|
| 25 | * version 2 or above as published by the Free Software Foundation. |
---|
| 26 | * |
---|
| 27 | * You can contact Prognus Software Livre headquarters at Av. Tancredo Neves, |
---|
| 28 | * 6731, PTI, Edifício do Saber, 3º floor, room 306, Foz do Iguaçu - PR - Brasil or at |
---|
| 29 | * e-mail address prognus@prognus.com.br. |
---|
| 30 | * |
---|
[6115] | 31 | * Classe de controle que faz manipulações de fluxo de informações para toda |
---|
[6328] | 32 | * a API a partir de vários métodos. |
---|
| 33 | * |
---|
| 34 | * @package Prototype |
---|
| 35 | * @license http://www.gnu.org/copyleft/gpl.html GPL |
---|
| 36 | * @author Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br) |
---|
| 37 | * @version 2.4 |
---|
| 38 | * @sponsor Caixa Econômica Federal |
---|
| 39 | * @since Arquivo disponibilizado na versão 2.4 |
---|
[6115] | 40 | */ |
---|
[5136] | 41 | |
---|
[5341] | 42 | if( !defined( 'ROOTPATH' ) ) |
---|
| 43 | define( 'ROOTPATH', dirname(__FILE__).'/..' ); |
---|
[5136] | 44 | |
---|
[5399] | 45 | require_once(ROOTPATH.'/api/config.php'); |
---|
[6528] | 46 | use prototype\api\Config as Config; |
---|
[5341] | 47 | /** |
---|
| 48 | TODO list: |
---|
| 49 | |
---|
| 50 | * definir de forma centralizada os caminhos e as constantes necessárias; |
---|
| 51 | * criar um User Agent detect e um OS server detect para customizações espeçÃficas de cada browser / servidor; |
---|
| 52 | * criar um registrador para fallback handlers; |
---|
| 53 | * criar um dependency manager na configuração dos serviços, para poder gerenciar os imports corretamente |
---|
| 54 | * criar um login e a recuperação da sessão; |
---|
| 55 | |
---|
| 56 | */ |
---|
| 57 | |
---|
[6328] | 58 | /** |
---|
[6132] | 59 | * |
---|
[6328] | 60 | * @package Prototype |
---|
| 61 | * @license http://www.gnu.org/copyleft/gpl.html GPL |
---|
| 62 | * @author Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br) |
---|
| 63 | * @version 2.4 |
---|
| 64 | * @sponsor Caixa Econômica Federal |
---|
| 65 | * @since Classe disponibilizada na versão 2.4 |
---|
[6132] | 66 | */ |
---|
[5136] | 67 | class Controller { |
---|
| 68 | |
---|
[5341] | 69 | static $cache; |
---|
| 70 | static $services = array(); |
---|
| 71 | static $interceptors = array(); |
---|
| 72 | static $config = array(); |
---|
| 73 | static $includes = array(); |
---|
| 74 | static $tx = array(); |
---|
[5514] | 75 | static $isConcept = array(); |
---|
[5715] | 76 | static $hasOne = array(); |
---|
[5905] | 77 | static $fallbackHandlers = array(); |
---|
[5341] | 78 | static $txID = 0; |
---|
| 79 | static $wallet; |
---|
[5136] | 80 | |
---|
[5341] | 81 | public function __destruct() |
---|
[5136] | 82 | { |
---|
[5341] | 83 | // if( $this->service ) |
---|
| 84 | // $this->service->close(); |
---|
| 85 | // else |
---|
| 86 | self::closeAll(); |
---|
[5136] | 87 | } |
---|
| 88 | |
---|
[5341] | 89 | public static function closeAll() |
---|
[5136] | 90 | { |
---|
[5341] | 91 | if( self::$services ) |
---|
| 92 | foreach( self::$services as $serviceName => $service ) |
---|
| 93 | if( self::$config[ $serviceName ]['type'] === 'service' ) |
---|
| 94 | $service->close(); |
---|
| 95 | } |
---|
[5136] | 96 | |
---|
[5341] | 97 | public static function clearAll() |
---|
[5136] | 98 | { |
---|
[5341] | 99 | return self::$cache->clearAll(); |
---|
[5136] | 100 | } |
---|
| 101 | |
---|
[5341] | 102 | public static function clear( $id ) |
---|
| 103 | { |
---|
| 104 | return self::$cache->clear( $id ); |
---|
| 105 | } |
---|
[5136] | 106 | |
---|
[5341] | 107 | public static function check( $id ) |
---|
| 108 | { |
---|
| 109 | return self::$cache->get( $id ); |
---|
| 110 | } |
---|
[5136] | 111 | |
---|
[5341] | 112 | public static function store( $id, $data, $expires, $compressed ) |
---|
| 113 | { |
---|
| 114 | return self::$cache->put( $id, $data, $expires, $compressed ); |
---|
| 115 | } |
---|
[5136] | 116 | |
---|
[5341] | 117 | public static function find( $URI, $params = false, $criteria = false ) |
---|
| 118 | { |
---|
| 119 | if( isset($URI['id']) && $URI['id'] ) |
---|
| 120 | return self::read( $URI, $params, $criteria ); |
---|
[5136] | 121 | |
---|
[5341] | 122 | return self::call( 'find', $URI, $params, $criteria ); |
---|
| 123 | } |
---|
[5136] | 124 | |
---|
[5341] | 125 | public static function read( $URI, $params = false, $criteria = false ) |
---|
| 126 | { |
---|
| 127 | if( !isset($URI['id']) || !$URI['id'] ) |
---|
| 128 | return self::find( $URI, $params, $criteria ); |
---|
[5136] | 129 | |
---|
[5341] | 130 | return self::call( 'read', $URI, $params, $criteria ); |
---|
[5136] | 131 | } |
---|
| 132 | |
---|
[5341] | 133 | public static function deleteAll( $URI, $params = false, $criteria = false ) |
---|
[5136] | 134 | { |
---|
[5341] | 135 | if( isset($URI['id']) && $URI['id'] ) |
---|
| 136 | return self::delete( $URI, $params, $criteria ); |
---|
| 137 | |
---|
| 138 | return self::call( 'deleteAll', $URI, $params, $criteria ); |
---|
[5136] | 139 | } |
---|
| 140 | |
---|
[5341] | 141 | public static function delete( $URI, $params = false, $criteria = false ) |
---|
[5136] | 142 | { |
---|
[5341] | 143 | if( !isset($URI['id']) || !$URI['id'] ) |
---|
| 144 | return self::deleteAll( $URI, $params, $criteria ); |
---|
| 145 | |
---|
| 146 | return self::call( 'delete', $URI, $params, $criteria ); |
---|
[5136] | 147 | } |
---|
| 148 | |
---|
[5341] | 149 | public static function replace( $URI, $params, $criteria = false ) |
---|
[5136] | 150 | { |
---|
[5341] | 151 | if( isset($URI['id']) && $URI['id'] ) |
---|
| 152 | return self::update( $URI, $params, $criteria ); |
---|
| 153 | |
---|
| 154 | return self::call( 'replace', $URI, $params, $criteria ); |
---|
[5136] | 155 | } |
---|
| 156 | |
---|
[5341] | 157 | public static function update( $URI, $params, $criteria = false ) |
---|
[5136] | 158 | { |
---|
[5341] | 159 | if( !isset($URI['id']) || !$URI['id'] ) |
---|
| 160 | return self::replace( $URI, $params, $criteria ); |
---|
| 161 | |
---|
| 162 | return self::call( 'update', $URI, $params, $criteria ); |
---|
[5136] | 163 | } |
---|
| 164 | |
---|
[5341] | 165 | public static function create( $URI, $params, $criteria = false ) |
---|
[5136] | 166 | { |
---|
[5341] | 167 | return self::call( 'create', $URI, $params, $criteria ); |
---|
| 168 | } |
---|
[5136] | 169 | |
---|
[5341] | 170 | public static function begin( $URI, $params = false, $criteria = false ) |
---|
| 171 | { |
---|
| 172 | return self::call( 'begin', $URI, $params, $criteria ); |
---|
| 173 | } |
---|
[5136] | 174 | |
---|
[5341] | 175 | public static function commit( $URI, $criteria = false ) |
---|
[5136] | 176 | { |
---|
[5341] | 177 | return self::call( 'commit', $URI, false, $criteria ); |
---|
| 178 | } |
---|
[5136] | 179 | |
---|
[5341] | 180 | public static function rollback( $URI, $criteria = false ) |
---|
| 181 | { |
---|
[6328] | 182 | if( isset( $URI['service'] ) ) |
---|
| 183 | unset( self::$tx[ $URI['service'] ] ); |
---|
| 184 | |
---|
| 185 | self::$txID--; |
---|
| 186 | |
---|
[5341] | 187 | return self::call( 'rollback', $URI, false, $criteria ); |
---|
| 188 | } |
---|
[5136] | 189 | |
---|
[5341] | 190 | public static function format( $URI, $params, $criteria = false ) |
---|
| 191 | { |
---|
| 192 | return self::call( 'format', $URI, $params, $criteria ); |
---|
| 193 | } |
---|
[5136] | 194 | |
---|
[5341] | 195 | public static function parse( $URI, $data, $criteria = false ) |
---|
| 196 | { |
---|
| 197 | return self::call( 'parse', $URI, $data, $criteria ); |
---|
[5136] | 198 | } |
---|
| 199 | |
---|
[5341] | 200 | public static function URI( $className, $id = false, $service = false ) |
---|
| 201 | { |
---|
| 202 | return array( 'concept' => $className, |
---|
| 203 | 'service' => $service ? $service : false, |
---|
| 204 | 'id' => $id ? $id : '' ); |
---|
[5136] | 205 | } |
---|
| 206 | |
---|
[5399] | 207 | //TODO: Compatibilizar as configs relativas aos modulos, adicionando os mesmo nos parametros passados |
---|
[5514] | 208 | public static function links( $concept = false, $linkage = false ) |
---|
[5136] | 209 | { |
---|
[5514] | 210 | |
---|
| 211 | |
---|
[5341] | 212 | if( !isset(self::$config[ $concept ]) ) |
---|
| 213 | self::$config[ $concept ] = self::loadConfig( $concept ); |
---|
[5136] | 214 | |
---|
[5514] | 215 | $links = array(); |
---|
| 216 | self::$isConcept[ $concept ] = array(); |
---|
[5715] | 217 | self::$hasOne[ $concept ] = array(); |
---|
[5514] | 218 | |
---|
| 219 | if( isset(self::$config[ $concept ][ 'model.hasOne' ]) ) |
---|
| 220 | foreach( self::$config[ $concept ][ 'model.hasOne' ] as $linkName => $linkTarget ) |
---|
| 221 | { |
---|
| 222 | list( $target, $link ) = explode( '.', $linkTarget ); |
---|
| 223 | |
---|
| 224 | if( $linkage === $linkName ) |
---|
| 225 | $return = $link; |
---|
| 226 | |
---|
| 227 | $links[$linkName] = $target; |
---|
[5715] | 228 | self::$hasOne[ $concept ][ $linkName ] = true; |
---|
[5514] | 229 | } |
---|
| 230 | if( isset(self::$config[ $concept ][ 'model.depends' ]) ) |
---|
| 231 | foreach( self::$config[ $concept ][ 'model.depends' ] as $linkName => $linkTarget ) |
---|
| 232 | { |
---|
| 233 | list( $target, $link ) = explode( '.', $linkTarget ); |
---|
| 234 | |
---|
| 235 | if( $linkage === $linkName ) |
---|
| 236 | $return = $link; |
---|
| 237 | |
---|
| 238 | $links[$linkName] = $target; |
---|
[5715] | 239 | self::$hasOne[ $concept ][ $linkName ] = true; |
---|
[5514] | 240 | self::$isConcept[ $concept ][ $linkName ] = true; |
---|
| 241 | } |
---|
| 242 | if( isset(self::$config[ $concept ][ 'model.hasMany' ]) ) |
---|
| 243 | foreach( self::$config[ $concept ][ 'model.hasMany' ] as $linkName => $linkTarget ) |
---|
| 244 | { |
---|
| 245 | list( $target, $link ) = explode( '.', $linkTarget ); |
---|
| 246 | |
---|
| 247 | if( $linkage === $linkName ) |
---|
| 248 | $return = $link; |
---|
| 249 | |
---|
| 250 | $links[$linkName] = $target; |
---|
| 251 | } |
---|
| 252 | |
---|
| 253 | return( isset($return) ? $return : $links ); |
---|
[5341] | 254 | } |
---|
[5136] | 255 | |
---|
[5514] | 256 | public static function isConcept( $concept, $linkName ) |
---|
[5399] | 257 | { |
---|
[5514] | 258 | if( !isset( self::$isConcept[ $concept ] ) ) |
---|
| 259 | self::links( $concept ); |
---|
| 260 | |
---|
| 261 | return( isset(self::$isConcept[ $concept ][ $linkName ]) ); |
---|
[5341] | 262 | } |
---|
[5136] | 263 | |
---|
[5715] | 264 | public static function hasOne( $concept, $linkName ) |
---|
| 265 | { |
---|
| 266 | if( !isset( self::$hasOne[ $concept ] ) ) |
---|
| 267 | self::links( $concept ); |
---|
| 268 | |
---|
| 269 | return( isset(self::$hasOne[ $concept ][ $linkName ]) ); |
---|
| 270 | } |
---|
| 271 | |
---|
[5399] | 272 | public static function getConcept( $concept, $moduleName = false ) |
---|
[5341] | 273 | { |
---|
| 274 | if( isset( self::$config[ $concept ] ) ) |
---|
| 275 | return( self::$config[ $concept ] ); |
---|
| 276 | |
---|
[5399] | 277 | return( self::$config[ $concept ] = self::loadConfig( $concept, $moduleName ) ); |
---|
| 278 | } |
---|
[5136] | 279 | |
---|
[5341] | 280 | public static function loadCache( $cacheType = 'Memory' ) |
---|
| 281 | { |
---|
| 282 | include_once( "cache/MemoryCache.php" ); |
---|
| 283 | return new MemoryCache(); |
---|
| 284 | } |
---|
[5136] | 285 | |
---|
[5399] | 286 | //TODO: Compatibilizar as configs relativas aos modulos, adicionando os mesmo nos parametros passados |
---|
| 287 | public static function loadConfig( $className, $isService = false) |
---|
[5341] | 288 | { |
---|
| 289 | $fileName = $className.'.'.($isService ? 'srv' : 'ini'); |
---|
[5136] | 290 | |
---|
[5341] | 291 | $config = self::$cache->get( $fileName ); |
---|
[5399] | 292 | |
---|
[5341] | 293 | if( !$config ) |
---|
| 294 | { |
---|
[5399] | 295 | $config = parse_ini_file( ROOTPATH.'/config/'.$fileName, true ); |
---|
[5341] | 296 | |
---|
| 297 | self::$cache->put( $fileName, $config ); |
---|
| 298 | } |
---|
| 299 | |
---|
| 300 | return( $config ); |
---|
[5136] | 301 | } |
---|
| 302 | |
---|
[5341] | 303 | public static function import( $path, $ext = ".php" ) |
---|
| 304 | { |
---|
| 305 | if( !isset(self::$includes[$path]) ) |
---|
[5136] | 306 | { |
---|
[5341] | 307 | require_once( ROOTPATH.'/'.$path.$ext ); |
---|
| 308 | self::$includes[$path] = false; |
---|
| 309 | } |
---|
[5136] | 310 | |
---|
[5341] | 311 | return( self::$includes[$path] ); |
---|
| 312 | } |
---|
[5136] | 313 | |
---|
[5341] | 314 | public static function load( $path, $class = false ) |
---|
[5136] | 315 | { |
---|
[5341] | 316 | if( $return = self::import( $path, "" ) ) |
---|
| 317 | return( $return ); |
---|
[5136] | 318 | |
---|
[5341] | 319 | if( !$class ){ |
---|
| 320 | preg_match( '/^\/?.*\/([^\/]+).php$/', $path, $class ); |
---|
| 321 | $class = $class[1]; |
---|
[5136] | 322 | } |
---|
| 323 | |
---|
[5341] | 324 | $object = self::$cache->get( $class ); |
---|
[5136] | 325 | |
---|
[5341] | 326 | if( !$object ) |
---|
| 327 | { |
---|
| 328 | $object = new $class(); |
---|
| 329 | self::$cache->put( $class, $object ); |
---|
| 330 | } |
---|
[5136] | 331 | |
---|
[5341] | 332 | self::$includes[$path] = $object; |
---|
| 333 | |
---|
| 334 | return( $object ); |
---|
[5136] | 335 | } |
---|
| 336 | |
---|
[5341] | 337 | public static function wallet( $serviceName ) |
---|
[5136] | 338 | { |
---|
[5341] | 339 | if( !isset( self::$wallet ) ) |
---|
| 340 | { |
---|
| 341 | //// Hack //// TODO: passar o init da sessão no login do expresso |
---|
| 342 | Config::init(); |
---|
| 343 | |
---|
| 344 | if(isset($_SESSION['wallet'])) |
---|
| 345 | self::$wallet = $_SESSION['wallet']; |
---|
| 346 | ///////////// |
---|
| 347 | } |
---|
| 348 | |
---|
| 349 | return isset( self::$wallet[ $serviceName ] )? self::$wallet[ $serviceName ] : false; |
---|
| 350 | } |
---|
[5136] | 351 | |
---|
[5341] | 352 | public static function connect( $service, $config ) |
---|
[5136] | 353 | { |
---|
[5341] | 354 | $result = $service->open( $config ); |
---|
[5136] | 355 | |
---|
[5341] | 356 | if( is_string( $result ) ) |
---|
| 357 | throw new Exception( $result ); |
---|
| 358 | |
---|
| 359 | return( true ); |
---|
| 360 | } |
---|
| 361 | |
---|
| 362 | public static function configure( $config, $newConfig ) |
---|
| 363 | { |
---|
| 364 | foreach( $newConfig as $key => $value ) |
---|
| 365 | $config[$key] = $value; |
---|
| 366 | |
---|
| 367 | return( $config ); |
---|
[5136] | 368 | } |
---|
| 369 | |
---|
[5341] | 370 | public static function dispatch( $dispatcher, $data, $optionsMap = false ) |
---|
| 371 | { |
---|
| 372 | // if( $mappedTo ) |
---|
| 373 | // $data = array( $mappedTo => $data ); |
---|
| 374 | // |
---|
| 375 | // foreach( $data as $method => $params ) |
---|
| 376 | // { |
---|
| 377 | // // foreach( $data[ $method ] as $name => $value ) |
---|
| 378 | // } |
---|
| 379 | // |
---|
| 380 | // self::import( "$dispatcher.php" ); |
---|
| 381 | } |
---|
| 382 | |
---|
[5399] | 383 | //TODO: Compatibilizar as configs relativas aos modulos, adicionando os mesmo nos parametros passados |
---|
[5341] | 384 | public static function service( $serviceName, $concept = false ) |
---|
| 385 | { |
---|
| 386 | if( isset( self::$services[ $serviceName ] ) ) |
---|
| 387 | return self::$services[ $serviceName ]; |
---|
| 388 | |
---|
| 389 | if( !isset(self::$config[ $serviceName ]) ) |
---|
| 390 | self::$config[ $serviceName ] = self::loadConfig( $serviceName, true ); |
---|
| 391 | |
---|
| 392 | if( !isset(self::$config[ $serviceName ]) ) |
---|
[5136] | 393 | return( false ); |
---|
| 394 | |
---|
[5341] | 395 | if( !isset(self::$config[ $serviceName ]['type']) ) |
---|
| 396 | self::$config[ $serviceName ]['type'] = 'service'; |
---|
[5136] | 397 | |
---|
[5399] | 398 | self::import( 'api/'.self::$config[ $serviceName ]['type'] ); //TODO: Item 4 |
---|
[5341] | 399 | |
---|
| 400 | $service = self::load( self::$config[ $serviceName ]['path'], |
---|
| 401 | self::$config[ $serviceName ]['class'] ); |
---|
| 402 | |
---|
| 403 | $srvConfig = array(); |
---|
| 404 | |
---|
| 405 | if( isset(self::$config[ $serviceName ][ 'config' ]) ) |
---|
| 406 | $srvConfig = self::configure( $srvConfig, self::$config[ $serviceName ][ 'config' ] ); |
---|
| 407 | if( $wallet = self::wallet( $serviceName ) ) |
---|
| 408 | $srvConfig = self::configure( $srvConfig, $wallet ); |
---|
| 409 | if( $concept && isset(self::$config[ $concept ]['service.config']) ) |
---|
| 410 | $srvConfig = self::configure( $srvConfig, self::$config[ $concept ]['service.config'] ); |
---|
| 411 | |
---|
| 412 | if( empty( $srvConfig ) ) |
---|
| 413 | $srvConfig = false; |
---|
| 414 | |
---|
| 415 | if( $service && self::$config[ $serviceName ]['type'] === 'service' ) |
---|
| 416 | self::connect( $service, $srvConfig ); |
---|
| 417 | |
---|
| 418 | return( self::$services[ $serviceName ] = $service ); |
---|
| 419 | } |
---|
| 420 | |
---|
[5399] | 421 | //TODO: Compatibilizar as configs relativas aos modulos, adicionando os mesmo nos parametros passados |
---|
[5341] | 422 | public static function interceptor( $method, $concept = false, $serviceName = false, $isService = false ) |
---|
| 423 | { |
---|
| 424 | if( $concept && !isset(self::$config[ $concept ]) ) |
---|
| 425 | self::$config[ $concept ] = self::loadConfig( $concept ); |
---|
| 426 | |
---|
| 427 | if( !$concept ) $concept = 'global'; |
---|
| 428 | if( !$isService || !$serviceName ) $serviceName = 'global'; |
---|
| 429 | |
---|
| 430 | if( !isset( self::$interceptors[ $concept ] ) ) |
---|
| 431 | self::$interceptors[ $concept ] = array(); |
---|
| 432 | |
---|
| 433 | if( !isset( self::$interceptors[ $concept ][ $serviceName ] ) ) |
---|
| 434 | self::$interceptors[ $concept ][ $serviceName ] = array(); |
---|
| 435 | |
---|
| 436 | if( !isset( self::$interceptors[ $concept ][ $serviceName ][ $method ] ) ) |
---|
| 437 | { |
---|
| 438 | $events = array( 'before', 'after' ); |
---|
| 439 | $interceptors = array(); |
---|
| 440 | |
---|
| 441 | $prefix = ( $isService )? "$serviceName." : ""; |
---|
| 442 | |
---|
| 443 | foreach( $events as $i => $event ) |
---|
| 444 | { |
---|
| 445 | $interceptors[$event] = array(); |
---|
| 446 | |
---|
| 447 | if( !isset(self::$config[$concept]["$prefix$event.$method"]) ) |
---|
| 448 | continue; |
---|
| 449 | |
---|
| 450 | foreach( self::$config[$concept]["$prefix$event.$method"] as $intercept => $interceptor ) |
---|
| 451 | $interceptors[$event][$intercept] = self::load( $interceptor ); |
---|
| 452 | } |
---|
| 453 | |
---|
| 454 | self::$interceptors[ $concept ][ $serviceName ][ $method ] = $interceptors; |
---|
| 455 | } |
---|
| 456 | |
---|
| 457 | return( self::$interceptors[ $concept ][ $serviceName ][ $method ] ); |
---|
| 458 | } |
---|
| 459 | |
---|
| 460 | public static function interceptorCommit( $eventType, $commitList, $isService = false ) |
---|
| 461 | { |
---|
| 462 | $result = array( $eventType => array() ); |
---|
| 463 | |
---|
[5437] | 464 | if( is_array( $commitList ) ) |
---|
[5341] | 465 | foreach( $commitList as $i => $tx ) |
---|
| 466 | { |
---|
| 467 | $interceptors = self::interceptor( 'commit', $tx['concept'], $tx['service'], $isService ); |
---|
| 468 | |
---|
| 469 | $result[$eventType] = array_merge( $result[$eventType], $interceptors[$eventType] ); |
---|
| 470 | } |
---|
| 471 | |
---|
[5136] | 472 | return( $result ); |
---|
| 473 | } |
---|
| 474 | |
---|
[5341] | 475 | public static function fire( $eventType, $method, &$params, $original, $isService = false ) |
---|
[5136] | 476 | { |
---|
[5341] | 477 | if( $method === 'commit' ) |
---|
| 478 | $interceptors = self::interceptorCommit( $eventType, $params['criteria'], $isService ); |
---|
| 479 | |
---|
| 480 | else |
---|
| 481 | $interceptors = self::interceptor( $method, |
---|
| 482 | isset($original['URI']['concept']) ? $original['URI']['concept'] : false, |
---|
| 483 | isset($params['URI']['service']) ? $params['URI']['service'] : false, $isService ); |
---|
| 484 | |
---|
| 485 | if( $interceptors && isset($interceptors[ $eventType ]) ) |
---|
| 486 | foreach( $interceptors[ $eventType ] as $intercept => $interceptor ) |
---|
| 487 | { |
---|
[5539] | 488 | $return = $interceptor->$intercept( $params['URI'], $params['properties'], $params['criteria'], $original /*, $params['service'] */); |
---|
[5341] | 489 | |
---|
| 490 | if( $return === false ) |
---|
[6384] | 491 | return( false ); |
---|
[5136] | 492 | |
---|
[5341] | 493 | if( isset($return) ) |
---|
| 494 | $params['properties'] = $return; |
---|
| 495 | } |
---|
| 496 | |
---|
| 497 | return( $params ); |
---|
| 498 | } |
---|
| 499 | |
---|
| 500 | /* |
---|
| 501 | * ex: array |
---|
| 502 | * ( |
---|
| 503 | * [0] array( 'OR', array( array( '=', 'campo', 'valor' ), |
---|
| 504 | array( 'OR', array( array( '=', 'campo', 'valor' ) ) ) ) |
---|
| 505 | * [1] array( '=', 'campo' , 'valor' ) |
---|
| 506 | * [2] array( 'OR' , array( array( '=' , campo', 'valor' ) ) ) |
---|
| 507 | * [3] array( 'IN', 'campo', array( '1' , '2' , '3' ) ) |
---|
| 508 | * ) |
---|
| 509 | * OR |
---|
| 510 | * array( '=' , 'campo' , 'valor' ) |
---|
| 511 | */ |
---|
[5399] | 512 | |
---|
| 513 | //TODO: Compatibilizar as configs relativas aos modulos, adicionando os mesmo nos parametros passados |
---|
[5341] | 514 | public static function serviceName( $URI, $original = false ) |
---|
| 515 | { |
---|
| 516 | $concept = ""; |
---|
| 517 | |
---|
| 518 | if( $original && isset($original['concept']) && $original['concept'] ) |
---|
| 519 | $concept = $original['concept']; |
---|
| 520 | elseif( isset($URI['concept']) && $URI['concept'] ) |
---|
| 521 | $concept = $URI['concept']; |
---|
| 522 | |
---|
| 523 | if( ( !isset($URI['service']) || !$URI['service'] ) && $concept ) |
---|
| 524 | { |
---|
| 525 | if( !isset(self::$config[ $concept ]) ) |
---|
| 526 | self::$config[ $concept ] = self::loadConfig( $concept ); |
---|
| 527 | |
---|
| 528 | $URI['service'] = self::$config[ $concept ][ 'service' ]; |
---|
| 529 | } |
---|
| 530 | |
---|
| 531 | if( !isset($URI['service']) ) |
---|
| 532 | throw new Exception( "CONFIGURATION ERROR: service name from concept '$concept' not found" ); |
---|
| 533 | |
---|
| 534 | return( $URI ); |
---|
| 535 | } |
---|
[6373] | 536 | |
---|
[6384] | 537 | public static function finalizeCommit( $method, $params, $original, $TX = array() ) |
---|
[6373] | 538 | { |
---|
[6384] | 539 | if( $TX !== false ) |
---|
| 540 | { |
---|
| 541 | $TX['rollback'] = !!!$params['properties']; |
---|
[5341] | 542 | |
---|
[6384] | 543 | if( $params['properties'] && is_array($params['properties']) && isset($params['properties']['id']) ) |
---|
| 544 | $TX['id'] = $params['properties']['id']; |
---|
[6373] | 545 | |
---|
[6384] | 546 | self::$tx[ $params['URI']['service'] ][] = array_merge( $TX, $original['URI'], array( 'service' => $params['URI']['service'], 'method' => $method ) ); |
---|
[6373] | 547 | } |
---|
| 548 | |
---|
| 549 | return( empty($params['properties']) ? false : $params['properties'] ); |
---|
| 550 | } |
---|
| 551 | |
---|
[5399] | 552 | //TODO: Compatibilizar as configs relativas aos modulos, adicionando os mesmos nas options passadas |
---|
[5437] | 553 | public static function call( $method, $URI, $properties = false, $options = false, $service = false ) |
---|
[5341] | 554 | { |
---|
| 555 | try |
---|
| 556 | { |
---|
| 557 | if( !isset($URI['concept']) ) $URI['concept'] = false; |
---|
| 558 | |
---|
| 559 | $original = $params = array( 'properties' => $properties, |
---|
| 560 | 'criteria' => $options, |
---|
| 561 | 'URI' => $URI, |
---|
| 562 | 'service' => $service ); |
---|
| 563 | |
---|
| 564 | if( isset($params['URI']['concept']) && !self::fire( 'before', $method, $params, $original ) ) |
---|
[6384] | 565 | return( self::finalizeCommit( $method, $params, $original ) ); |
---|
[5341] | 566 | |
---|
| 567 | if( $params && !$params['service'] ) |
---|
| 568 | { |
---|
| 569 | $params['URI'] = self::serviceName( $params['URI'], $original['URI'] ); |
---|
| 570 | |
---|
| 571 | $params['service'] = self::service( $params['URI']['service'], $params['URI']['concept'] ); |
---|
| 572 | } |
---|
| 573 | |
---|
| 574 | if( isset($params['URI']['service']) ) |
---|
| 575 | { |
---|
[5437] | 576 | if( $method === 'create' || $method === 'update' || $method === 'delete' ) |
---|
[5341] | 577 | { |
---|
[5437] | 578 | if( $commit = !isset(self::$tx[ $params['URI']['service'] ]) ) |
---|
| 579 | { |
---|
| 580 | self::call( 'begin', $params['URI'] ); |
---|
| 581 | } |
---|
| 582 | |
---|
| 583 | $TX = array(); |
---|
[5341] | 584 | } |
---|
| 585 | |
---|
| 586 | if( !self::fire( 'before', $method, $params, $original, true ) ) |
---|
[6384] | 587 | return( self::finalizeCommit( $method, $params, $original, isset($TX) ? $TX : false ) ); |
---|
[5341] | 588 | } |
---|
| 589 | |
---|
| 590 | if( $params['service'] ) |
---|
| 591 | switch( $method ) |
---|
[5437] | 592 | { |
---|
[5341] | 593 | case 'find': $return = $params['service']->find( $params['URI'], $params['properties'], $params['criteria'] ); break; |
---|
[5136] | 594 | |
---|
[5637] | 595 | case 'read': $return = $params['service']->read( $params['URI'], $params['properties'] , $params['criteria'] ); break; |
---|
[5341] | 596 | |
---|
| 597 | case 'create': $return = $params['service']->create( $params['URI'], $params['properties']/*, $criteria*/ ); break; |
---|
| 598 | |
---|
[5971] | 599 | case 'delete': $return = $params['service']->delete( $params['URI'], $params['properties'], $params['criteria'] ); break; |
---|
[5341] | 600 | |
---|
| 601 | case 'deleteAll': $return = $params['service']->deleteAll( $params['URI'], $params['properties'], $params['criteria'] ); break; |
---|
| 602 | |
---|
[6023] | 603 | case 'update': $return = $params['service']->update( $params['URI'], $params['properties'], $params['criteria'] ); break; |
---|
[5341] | 604 | |
---|
| 605 | case 'replace': $return = $params['service']->replace( $params['URI'], $params['properties'], $params['criteria'] ); break; |
---|
| 606 | |
---|
| 607 | case 'begin': $return = $params['service']->begin( $params['URI'] ); break; |
---|
| 608 | |
---|
| 609 | case 'commit': $return = $params['service']->commit( $params['URI'], $params['criteria'] ); break; |
---|
| 610 | |
---|
| 611 | case 'rollback': $return = $params['service']->rollback( $params['URI'], $params['criteria'] ); break; |
---|
| 612 | |
---|
| 613 | case 'parse': $return = $params['service']->parse( $params['properties'], $params['criteria'] ); break; |
---|
| 614 | |
---|
[5437] | 615 | case 'analize': $return = $params['service']->analize( $params['properties'], $params['criteria'] ); break; |
---|
| 616 | |
---|
[5341] | 617 | case 'format': $return = $params['service']->format( $params['properties'], $params['criteria'] ); break; |
---|
[5136] | 618 | |
---|
[5437] | 619 | default : $return = $params['service']->$method( $params['properties'], $params['criteria'] ); |
---|
| 620 | } |
---|
| 621 | |
---|
[5341] | 622 | if( isset($return) && $return !== false ) |
---|
| 623 | $params['properties'] = $return; |
---|
| 624 | |
---|
| 625 | if( isset($params['URI']['service']) ) |
---|
| 626 | if( !self::fire( 'after', $method, $params, $original, true ) ) |
---|
[6384] | 627 | return( self::finalizeCommit( $method, $params, $original, isset($TX) ? $TX : false ) ); |
---|
[5341] | 628 | |
---|
[5437] | 629 | if( isset($URI['concept']) ) |
---|
| 630 | self::fire( 'after', $method, $params, $original ); |
---|
| 631 | |
---|
| 632 | if( empty($params['properties']) ) |
---|
| 633 | $params['properties'] = false; |
---|
| 634 | |
---|
| 635 | if( isset( $TX ) ) |
---|
[6384] | 636 | { |
---|
[6419] | 637 | //self::finalizeCommit( $params, $original, $method, $TX ); |
---|
| 638 | self::finalizeCommit( $method, $params, $original, $TX ); |
---|
[6384] | 639 | if( isset($commit) && $commit ) |
---|
| 640 | { |
---|
| 641 | if( !self::call( 'commit', $params['URI'], false, self::$tx[ $params['URI']['service'] ] ) ) |
---|
| 642 | self::call( 'rollback', $params['URI'] , false, self::$tx[ $params['URI']['service'] ] ); |
---|
| 643 | |
---|
| 644 | unset( self::$tx[ $params['URI']['service'] ] ); |
---|
| 645 | } |
---|
| 646 | } |
---|
[5341] | 647 | } |
---|
| 648 | catch( Exception $e ) |
---|
| 649 | { |
---|
[6328] | 650 | if( !self::fallback( $e, $URI ) ) |
---|
[5341] | 651 | self::closeAll(); |
---|
| 652 | |
---|
[5136] | 653 | return( false ); |
---|
[5341] | 654 | } |
---|
[5136] | 655 | |
---|
[5437] | 656 | return( $params['properties'] ); |
---|
[5341] | 657 | } |
---|
[5136] | 658 | |
---|
[6328] | 659 | public static function fallback( $exception, $URI ) |
---|
[5341] | 660 | { |
---|
[5905] | 661 | $code = $exception->getCode(); |
---|
| 662 | |
---|
| 663 | if( isset( self::$fallbackHandlers[ $code ] ) ) |
---|
[5908] | 664 | { |
---|
| 665 | $fn = self::$fallbackHandlers[ $code ]; |
---|
[6328] | 666 | return $fn( $exception, $URI ); |
---|
[5908] | 667 | } |
---|
[5905] | 668 | |
---|
[5341] | 669 | error_log( $exception->getMessage() ); |
---|
| 670 | return( true ); |
---|
[5136] | 671 | } |
---|
[5905] | 672 | |
---|
| 673 | public static function addFallbackHandler( $code, $function ) |
---|
| 674 | { |
---|
| 675 | self::$fallbackHandlers[ $code ] = $function; |
---|
| 676 | } |
---|
[5811] | 677 | /* |
---|
| 678 | *NULL evita erros caso não seja passado nenhuma variavel por referência |
---|
| 679 | */ |
---|
| 680 | public static function put( $URI, $data, &$txIds = NULL ) |
---|
[5437] | 681 | { |
---|
| 682 | try |
---|
| 683 | { |
---|
| 684 | $URI = self::serviceName( $URI ); |
---|
| 685 | |
---|
| 686 | if( $commit = !$txIds ) |
---|
| 687 | $txIds = array(); |
---|
| 688 | |
---|
| 689 | if( !isset( self::$tx[ $URI['service'] ] ) ) |
---|
| 690 | { |
---|
| 691 | self::call( 'begin', $URI ); |
---|
| 692 | self::$tx[ $txIds[] = $URI['service'] ] = array(); |
---|
| 693 | } |
---|
| 694 | |
---|
| 695 | $method = $data ? isset( $data['id'] ) ? |
---|
| 696 | 'update' : 'create' : 'delete'; |
---|
| 697 | |
---|
| 698 | $links = self::links( $URI['concept'] ); |
---|
| 699 | |
---|
| 700 | $order = self::$txID++; |
---|
| 701 | |
---|
| 702 | $postpone = array(); |
---|
[5514] | 703 | $linkNames = array(); |
---|
[5437] | 704 | |
---|
| 705 | if( $data ) |
---|
| 706 | { |
---|
| 707 | $URI['id'] = isset( $data['id'] ) ? $data['id'] : false; |
---|
| 708 | |
---|
| 709 | foreach( $links as $linkName => $linkTarget ) |
---|
| 710 | { |
---|
| 711 | if( isset( $data[$linkName] ) && is_array( $data[$linkName] ) ) |
---|
| 712 | { |
---|
[5514] | 713 | if( self::isConcept( $URI['concept'], $linkName ) ) |
---|
[5773] | 714 | $data[$linkName] = self::put( array( 'concept' => $linkTarget ), $data[$linkName], $txIds ); |
---|
[5437] | 715 | else |
---|
[5514] | 716 | { |
---|
| 717 | $postpone[ $linkTarget ] = $data[$linkName]; |
---|
| 718 | $linkNames[ $linkTarget ] = $linkName; |
---|
| 719 | } |
---|
[5437] | 720 | } |
---|
| 721 | } |
---|
| 722 | } |
---|
| 723 | else |
---|
| 724 | $URI['id'] = isset( $data['id'] ) ? $data['id'] : $URI['id']; |
---|
| 725 | |
---|
| 726 | $result = Controller::call( $method, $URI, $data, false, false, true ); |
---|
| 727 | |
---|
[5539] | 728 | if( is_array( $result ) && isset( $result['id'] ) ) |
---|
[5437] | 729 | $URI['id'] = $result['id']; |
---|
| 730 | |
---|
[6384] | 731 | $index = count(self::$tx[ $URI['service'] ]) - 1; |
---|
[5437] | 732 | |
---|
[6384] | 733 | self::$tx[ $URI['service'] ][ $index ]['order'] = $order; |
---|
| 734 | self::$tx[ $URI['service'] ][ $index ]['id'] = $URI['id']; |
---|
| 735 | |
---|
| 736 | if( !isset(self::$tx[ $URI['service'] ][ $index ]['concept']) ) |
---|
| 737 | self::$tx[ $URI['service'] ][ $index ]['concept'] = $URI['concept']; |
---|
| 738 | |
---|
[5437] | 739 | foreach( $postpone as $linkTarget => $dt ) |
---|
[5715] | 740 | { |
---|
| 741 | if( Controller::hasOne( $URI['concept'], $linkNames[ $linkTarget ] ) ) |
---|
| 742 | $dt = array( $dt ); |
---|
| 743 | |
---|
[5437] | 744 | foreach( $dt as $ii => $value ) |
---|
| 745 | { |
---|
| 746 | if( !is_array( $value ) ) |
---|
| 747 | $value = array( 'id' => $value ); |
---|
| 748 | |
---|
[5514] | 749 | $value[ self::links( $URI['concept'], $linkNames[ $linkTarget ] ) ] = $URI['id']; |
---|
| 750 | |
---|
[5773] | 751 | self::put( array( 'concept' => $linkTarget ), $value, $txIds ); |
---|
[5437] | 752 | } |
---|
[5715] | 753 | } |
---|
[5437] | 754 | if( $commit ) |
---|
| 755 | { |
---|
| 756 | $result = array(); |
---|
| 757 | |
---|
| 758 | for( $i = count( $txIds ) - 1; $i >= 0; $i-- ) |
---|
| 759 | { |
---|
| 760 | $currentTx = self::$tx[ $txIds[$i] ]; |
---|
| 761 | unset( self::$tx[ $txIds[$i] ] ); |
---|
| 762 | |
---|
| 763 | if( !self::commit( array( 'service' => $txIds[$i] ), $currentTx ) ) |
---|
| 764 | { |
---|
| 765 | self::rollback( array( 'service' => $txIds[$i] ), $currentTx ); |
---|
| 766 | |
---|
| 767 | foreach( $currentTx as $i => $st ) |
---|
| 768 | $currentTx[$i][ 'rollback' ] = true; |
---|
| 769 | } |
---|
| 770 | |
---|
| 771 | $result = array_merge( $result, $currentTx ); |
---|
| 772 | } |
---|
| 773 | |
---|
| 774 | self::$txID = 0; |
---|
| 775 | |
---|
| 776 | return( $result ); |
---|
| 777 | } |
---|
| 778 | |
---|
| 779 | } |
---|
| 780 | catch( Exception $e ) |
---|
| 781 | { |
---|
[6328] | 782 | if( !self::fallback( $e, $URI ) ) |
---|
[5437] | 783 | self::closeAll(); |
---|
| 784 | |
---|
| 785 | return( false ); |
---|
| 786 | } |
---|
| 787 | |
---|
| 788 | return( $URI['id'] ); |
---|
| 789 | } |
---|
| 790 | |
---|
| 791 | public static function get() |
---|
| 792 | { |
---|
| 793 | |
---|
| 794 | } |
---|
[5136] | 795 | } |
---|
[5341] | 796 | |
---|
| 797 | Controller::$cache = Controller::loadCache(); |
---|
[6800] | 798 | |
---|
| 799 | require_once(__DIR__.'/esecurity.php'); |
---|
| 800 | $s = new ESecurity(); |
---|
| 801 | $s->valid(); |
---|
| 802 | |
---|
| 803 | |
---|
[5539] | 804 | // ?> |
---|