/** * Construct the URL Writer helper * * Extract string from server configuration */ private function __construct() { // Set server address $this->server_app_root = Request::server()['SERVER_NAME']; $ar_domain = explode('.', Request::server()['SERVER_NAME']); if (count($ar_domain) >= 3) { $start = strlen($ar_domain[0]) + 1; $this->server_main_root = substr(Request::server()['SERVER_NAME'], $start); } else { $this->server_main_root = Request::server()['SERVER_NAME']; } if (!Request::is_https() && Request::get_request_port() != 80 || Request::is_https() && Request::get_request_port() != 443) { $this->server_app_root .= ":" . Request::get_request_port(); $this->server_main_root .= ":" . Request::get_request_port(); } if (isset(Request::request()['request'])) { $ar_path = explode('/', Request::request()['request']); array_shift($ar_path); $this->session_path = implode('/', $ar_path); } else { $this->session_path = ''; } $webroot = Application::get_instance()->get_webroot(); if (!is_null($webroot) && !empty($webroot)) { $this->server_app_root .= "/" . $webroot; $this->server_main_root .= "/" . $webroot; } }
/** * Set HTTP Response Code Header * * @param integer $code * @return integer */ public final function set_response_code($code) { if ($code !== NULL) { switch ($code) { case 100: $text = 'Continue'; break; case 101: $text = 'Switching Protocols'; break; case 200: $text = 'OK'; break; case 201: $text = 'Created'; break; case 202: $text = 'Accepted'; break; case 203: $text = 'Non-Authoritative Information'; break; case 204: $text = 'No Content'; break; case 205: $text = 'Reset Content'; break; case 206: $text = 'Partial Content'; break; case 300: $text = 'Multiple Choices'; break; case 301: $text = 'Moved Permanently'; break; case 302: $text = 'Moved Temporarily'; break; case 303: $text = 'See Other'; break; case 304: $text = 'Not Modified'; break; case 305: $text = 'Use Proxy'; break; case 400: $text = 'Bad Request'; break; case 401: $text = 'Unauthorized'; break; case 402: $text = 'Payment Required'; break; case 403: $text = 'Forbidden'; break; case 404: $text = 'Not Found'; break; case 405: $text = 'Method Not Allowed'; break; case 406: $text = 'Not Acceptable'; break; case 407: $text = 'Proxy Authentication Required'; break; case 408: $text = 'Request Time-out'; break; case 409: $text = 'Conflict'; break; case 410: $text = 'Gone'; break; case 411: $text = 'Length Required'; break; case 412: $text = 'Precondition Failed'; break; case 413: $text = 'Request Entity Too Large'; break; case 414: $text = 'Request-URI Too Large'; break; case 415: $text = 'Unsupported Media Type'; break; case 418: $text = 'I\'m a teapot'; break; case 500: $text = 'Internal Server Error'; break; case 501: $text = 'Not Implemented'; break; case 502: $text = 'Bad Gateway'; break; case 503: $text = 'Service Unavailable'; break; case 504: $text = 'Gateway Time-out'; break; case 505: $text = 'HTTP Version not supported'; break; default: exit('Unknown http status code "' . htmlentities($code) . '"'); break; } $protocol = isset(Request::server()['SERVER_PROTOCOL']) ? Request::server()['SERVER_PROTOCOL'] : 'HTTP/1.0'; $this->set_header_rule($protocol . ' ' . $code . ' ' . $text); $GLOBALS['http_response_code'] = $code; } else { $code = isset($GLOBALS['http_response_code']) ? $GLOBALS['http_response_code'] : 200; } return $code; }
/** * Redirect to another end point of the application * using a full query string * * @param string $a_request * @param integer $a_protocol * @return Apine\MVC\RedirectionView */ function apine_internal_redirect($a_request, $a_protocol = APINE_PROTOCOL_DEFAULT) { $new_view = new RedirectionView(); $protocol = isset(Request::server()['SERVER_PROTOCOL']) ? Request::server()['SERVER_PROTOCOL'] : 'HTTP/1.0'; if (!empty(Request::get()['request']) && $a_request == Request::get()['request']) { $new_view->set_header_rule($protocol . ' 302 Moved Temporarily'); } // Remove Trailing slash $request = trim($a_request, '/'); $new_view->set_header_rule('Location: ' . URLHelper::path($request, $a_protocol)); return $new_view; }
/** * Test Database Connection * * @param array $params * @throws GenericException */ public function test_database($params) { try { if (Request::is_ajax()) { $body = json_decode(Request::get_request_body()); $database = new Database($body->type, $body->host, $body->name, $body->user, $body->pass, $body->char); } else { throw new GenericException('Invalid Request', 400); } } catch (DatabaseException $e) { $protocol = isset(Request::server()['SERVER_PROTOCOL']) ? Request::server()['SERVER_PROTOCOL'] : 'HTTP/1.0'; header($protocol . ' 404 Not Found'); } }
/** * Log a user in * * Look up in database for a matching row with a username and a * password * * @param string $a_user_name * Username of the user * @param string $a_password * Password of the user * @return boolean */ public function login($a_user_name, $a_password) { if (!$this->is_logged_in()) { if (Apine\User\Factory\UserFactory::is_name_exist($a_user_name) || Apine\User\Factory\UserFactory::is_email_exist($a_user_name)) { $encode_pass = Apine\Core\Encryption::hash_password($a_password); } else { return false; } $user_id = Apine\User\Factory\UserFactory::authentication($a_user_name, $encode_pass); $request_server = Apine\Core\Request::server(); if ($user_id) { $referer = isset($request_server['REMOTE_ADDR']) ? $request_server['REMOTE_ADDR'] : ''; $agent = isset($request_server['HTTP_USER_AGENT']) ? $request_server['HTTP_USER_AGENT'] : ''; $creation_time = time(); $new_user_token = new Apine\User\UserToken(); $new_user_token->set_user($user_id); $new_user_token->set_token(Apine\Core\Encryption::hash_api_user_token($a_user_name, $a_password, $creation_time)); $new_user_token->set_origin($referer . $agent); $new_user_token->set_creation_date($creation_time); $new_user_token->save(); $this->token = $new_user_token; $this->set_session_type($this->token->get_user()->get_type()); $this->logged_in = true; return true; } else { return false; } } else { return false; } }
/** * Run the application * * @param int $a_runtime Runtime mode */ public function run($a_runtime = APINE_RUNTIME_HYBRID) { if ($a_runtime !== APINE_RUNTIME_HYBRID && $a_runtime !== APINE_RUNTIME_API && $a_runtime !== APINE_RUNTIME_APP) { $a_runtime = APINE_RUNTIME_HYBRID; } if ($this->use_composer && !strstr($this->apine_folder, 'vendor/youmy001')) { require_once 'vendor/autoload.php'; } /** * Main Execution */ try { // Make sure application runs with a valid execution mode if ($this->mode !== APINE_MODE_DEVELOPMENT && $this->mode !== APINE_MODE_PRODUCTION) { throw new GenericException('Invalid Execution Mode \\"' . $this->mode . '"', 418); } if (!file_exists('.htaccess') || !file_exists('config.ini')) { $protocol = isset(Request::server()['SERVER_PROTOCOL']) ? Request::server()['SERVER_PROTOCOL'] : 'HTTP/1.0'; header($protocol . ' 503 Service Unavailable'); die("Critical Error : Framework Installation Not Completed"); } if (!Request::is_api_call() && (!empty(Request::get()['request']) && Request::get()['request'] != '/')) { $request = Request::get()['request']; } else { if (!Request::is_api_call()) { $request = '/index'; } else { $request = Request::get()['request']; } } // Verify is the protocol is allowed if (Request::is_https() && !$this->use_https) { apine_internal_redirect($request, APINE_PROTOCOL_HTTP); } if (is_null($this->config)) { $this->config = new Config('config.ini'); } // Find a timezone for the user // using geoip library and its local database if (function_exists('geoip_open')) { $gi = geoip_open($this->apine_folder . "/GeoLiteCity.dat", GEOIP_STANDARD); $record = GeoIP_record_by_addr($gi, $_SERVER['REMOTE_ADDR']); //$record = geoip_record_by_addr($gi, "24.230.215.89"); //var_dump($record); if (isset($record)) { $timezone = get_time_zone($record->country_code, $record->region != '' ? $record->region : 0); } else { if (!is_null($this->config->get('dateformat', 'timezone'))) { $timezone = $this->config->get('dateformat', 'timezone'); } else { $timezone = 'America/New_York'; } } date_default_timezone_set($timezone); } else { if (!is_null($this->config->get('dateformat', 'timezone'))) { date_default_timezone_set($this->config->get('dateformat', 'timezone')); } } // If a user is logged in; redirect to the allowed protocol // Secure session only work when Use HTTPS is set to "yes" if (SessionManager::is_logged_in()) { if ($this->secure_session) { if (!Request::is_https() && $this->use_https) { die(apine_internal_redirect($request, APINE_PROTOCOL_HTTPS)->draw()); } else { if (Request::is_https() && !$this->use_https) { die(apine_internal_redirect($request, APINE_PROTOCOL_HTTP)->draw()); } } } else { if (Request::is_https()) { die(apine_internal_redirect($request, APINE_PROTOCOL_HTTP)->draw()); } } } unset($request); if (!Request::is_api_call()) { if ($a_runtime == APINE_RUNTIME_API) { throw new GenericException('Web Application calls are not implemented', 501); } Engine::instance()->add_rule(new Rule('apine_data_loop', 'loopdata', '<?php foreach ($this->data as $element): $this->wrap($element); ?>')); Engine::instance()->add_rule(new Rule('apine_config', 'apine_config:(\\w+),(\\w+)', '<?php echo \\Apine\\Application\\Application::get_instance()->get_config()->get(\'$1\',\'$2\');?>')); Engine::instance()->add_rule(new Rule('apine_translate', 'apine_translate:(\\w+),(\\w+)', '<?php echo \\Apine\\Application\\Translator::get_instance()->translate(\'$1\',\'$2\');?>')); Engine::instance()->add_rule(new Rule('apine_format_date', 'apine_format_date:(\\w+),(\\w+)', '<?php echo \\Apine\\Application\\Translator::get_instance()->translation()->get_locale()->format_date("$1", Apine\\Application\\Translator::get_instance()->translation()->get_locale()->$2());?>')); Engine::instance()->add_rule(new Rule('apine_format_date_array', 'apine_format_date:(\\w+)\\[(\\w+)\\],(\\w+)', '<?php echo \\Apine\\Application\\Translator::get_instance()->translation()->get_locale()->format_date($this->data[\'$1\'][\'$2\'], Apine\\Application\\Translator::get_instance()->translation()->get_locale()->$3());?>')); Engine::instance()->add_rule(new Rule('apine_language', 'apine_language:(code|short|name)', '<?php switch("$1"){case "code": echo Apine\\Application\\Translator::get_instance()->translation()->get("language","code");break;case "short": echo Apine\\Application\\Translator::get_instance()->translation()->get("language","shortcode");break;case "name": echo Apine\\Application\\Translator::get_instance()->translation()->get("language","name");break;}?>')); Engine::instance()->add_rule(new Rule('apine_execution', 'apine_execution_time', '<?php echo apine_execution_time();?>')); Engine::instance()->add_rule(new Rule('apine_version', 'apine_version:(framework|application)', '<?php echo \\Apine\\Application\\Application::get_instance()->get_version()->$1();?>')); Engine::instance()->add_rule(new Rule('apine_url', 'apine_url_(path|resource):(([^\\/\\s]+\\/)?([^\\{\\}]*))', '<?php echo \\Apine\\MVC\\URLHelper::get_instance()->$1("$2");?>')); Engine::instance()->add_rule(new Rule('apine_url_secure', 'apine_url_(path|resource)_secure:(([^\\/\\s]+\\/)?([^\\{\\}]*))', '<?php echo Apine\\MVC\\URLHelper::get_instance()->$1("$2", APINE_PROTOCOL_HTTPS);?>')); Engine::instance()->add_rule(new Rule('apine_view_apply_meta', 'apine_apply_meta', '<?php echo Apine\\MVC\\HTMLView::apply_meta($data["apine_view_metatags"]);?>')); Engine::instance()->add_rule(new Rule('apine_view_apply_scripts', 'apine_apply_scripts', '<?php echo Apine\\MVC\\HTMLView::apply_scripts($data["apine_view_scripts"]);?>')); Engine::instance()->add_rule(new Rule('apine_view_apply_stylesheets', 'apine_apply_stylesheets', '<?php echo Apine\\MVC\\HTMLView::apply_stylesheets($data["apine_view_stylesheets"]);?>')); Engine::instance()->add_rule(new Rule('apine_user_has_group', 'if:apine_user\\[groups\\]==([0-9]+)', '<?php if (\\Apine\\Session\\SessionManager::get_user()->has_group($1)) : ?>')); Engine::instance()->add_rule(new Rule('apine_user_group', 'apine_user\\[groups\\]\\[([0-9]+)\\]', '<?php echo (\\Apine\\Session\\SessionManager::get_user()->has_group($1)) : \\Apine\\Session\\SessionManager::get_user()->get_group()->get_item($1)->get_name() : ""; ?>')); if (!empty(Request::get()['request']) && Request::get()['request'] != '/') { $request = Request::get()['request']; } else { $request = '/index'; } $router = new WebRouter($this->routes_path, $this->routes_type); } else { if ($a_runtime == APINE_RUNTIME_APP) { throw new GenericException('RESTful API calls are not implemented', 501); } $request = Request::get()['request']; $router = new APIRouter(); } // Fetch and execute the route $route = $router->route($request); $view = $router->execute($route->controller, $route->action, $route->args); // Draw the output is a view is returned if (!is_null($view) && is_a($view, 'Apine\\MVC\\View')) { $view->draw(); } else { throw new GenericException('Empty Apine View', 488); } } catch (GenericException $e) { // Handle application errors try { $error = new Controllers\ErrorController(); if ($this->mode == APINE_MODE_PRODUCTION) { if ($error_name = $error->method_for_code($e->getCode())) { $view = $error->{$error_name}(); } else { $view = $error->server(); } } else { $view = $error->custom($e->getCode(), $e->getMessage(), $e); } $view->draw(); } catch (Exception $e2) { var_dump($e2->getTraceAsString()); $protocol = isset(Request::server()['SERVER_PROTOCOL']) ? Request::server()['SERVER_PROTOCOL'] : 'HTTP/1.0'; header($protocol . ' 500 Internal Server Error'); die("Critical Error : " . $e->getMessage()); } } catch (Exception $e) { // Handle PHP exceptions try { $error = new Controllers\ErrorController(); $view = $error->custom(500, $e->getMessage(), $e); $view->draw(); } catch (Exception $e2) { $protocol = isset(Request::server()['SERVER_PROTOCOL']) ? Request::server()['SERVER_PROTOCOL'] : 'HTTP/1.0'; header($protocol . ' 500 Internal Server Error'); die("Critical Error : " . $e->getMessage()); } } }