private function loadNavigation() { $arr = array('NAME' => $_SERVER['PHP_AUTH_USER']); $arr['NODES'] = View::load(array('engine', 'adminNavigationNode'), array('HREF' => '/' . __CLASS__, 'alias' => 'Статистика', 'img' => View::img('chart', 'icons'))); $files = Engine::loadControllers(); $permissions = Users::getAdminPermissions($_SERVER['PHP_AUTH_USER']); if (count($permissions) == 1 && empty($permissions[0]['controller'])) { $permissions = false; } foreach ($files as $row) { if ($permissions && !in_array($row['name'], $permissions)) { continue; } if (strstr($row['name'], strtolower(__CLASS__))) { $row['name'] = 'admin'; } $row['HREF'] = '/' . __CLASS__ . '/' . $row['name']; $row['img'] = View::img($row['img'], 'icons'); $arr['NODES'] .= View::load(array('engine', 'adminNavigationNode'), $row); } View::setTitle('Страница статистики'); View::css('engine'); View::css('admin'); View::js('engine'); View::js('admin'); View::loadContent('adminNavigation', $arr, 'engine'); }
/** * Loads a page object into the current view, if the page exists. Otherwise 404 error is returned. * * Route: page/:slug * * @param string $slug The slug of the page to get. */ public static function view($slug) { $page = Page::page()->find($slug); if ($page) { View::setTitle($page->title); View::data('page', $page); return; } return ERROR_404; }
static function render404() { View::setTitle('Страница не найдена'); View::css('engine'); View::loadContent('error', array('ERROR_NUM' => '404', 'ERROR_DESC' => 'Стрпница не найдена'), 'engine'); View::render(true); }
function admin() { View::setTitle('Админка авторизации'); View::loadContent('loginAdmin', null, 'engine'); }
function admin() { View::setTitle('Админка главной страницы'); View::loadContent('error', array('ERROR_NUM' => '404'), 'engine'); }
static function start() { try { Session::start(); //загрузка параметров движка Settings::$ENGINE = Engine::loadSettings(); //проверка закрыт сайт или нет if (Settings::$ENGINE['site'] == 0) { View::renderClosed('Извините, доступ на сайт закрыт'); } View::$template = Settings::$ENGINE['template']; Controller::$lang = Settings::$ENGINE['default_lang']; $route = urldecode(parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH)); //считываем из сессии id пользователя (-1 назначаем неавторизованным пользователям) $user_id = -1; if (isset($_SESSION['uid']) && !empty($_SESSION['uid']) && is_numeric($_SESSION['uid'])) { $user_id = $_SESSION['uid']; } /*$pwd = "ruh"; $hash = Crypt::password_hash($pwd); if(Crypt::password_verify($pwd,$hash)) echo "true"; else echo "false"; exit;*/ /*print_r(AclModel::getRoles()); exit;*/ //проверяем, не был ли передан тип запроса (например при ajax запросе) $request_type = null; if (isset($_POST["request_type"]) && is_numeric($_POST["request_type"])) { $request_type = $_POST["request_type"]; ini_set('display_errors', 0); } else { $page = PageManager::findPage($route == '/' ? '/main' : $route); if (!$page) { throw new Exception404(); } View::setTitle($page['title']); View::css(explode('|', $page['css'])); View::js(explode('|', $page['js'])); //TODO: замутить парсер META $args = json_decode($page['content'], true); foreach ($args as $key => $val) { $class = new $args[$key]['c'](); View::$args[$key] = $class->{$args}[$key]['m'](!empty($args[$key]['a']) ? $args[$key]['a'] : null); } //print_r(View::$args); View::render('index', Settings::$ENGINE['template']); } //Если страницы не были найдены, то обращаемся напрямую к контроллеру $routes = explode('/', $route); array_shift($routes); if ($routes) { //задаем контроллер и его метод по умолчанию $controller_name = Settings::$DEFAULT_CONTROLLER; $action = 'index'; //распарсиваем адресную строку //определяем имя контроллера if (!empty($routes[0])) { $controller_name = $routes[0]; } //его метод if (!empty($routes[1])) { $action = $routes[1]; } //все остальные параметры адресной строки преобразуем в аргументы $i = 2; $arg = array(); while (!empty($routes[$i])) { $arg[] = $routes[$i++]; } //создаем объект для работы контроллером if (!class_exists($controller_name)) { throw new Exception404(); } $controller = new $controller_name(); //проверяем, если это пост запрос c request_type, обрабатываем его соответственно if ($request_type != null) { //проверяем, есть ли данный метод у контроллера if (method_exists($controller_name, $action)) { //если метод есть, то //запускаем главную функцию обработки запроса $res = $controller->{$action}(isset($arg) ? $arg : NULL); //выводим результат echo json_encode(array('answer' => $res)); } else { //если функция не видна, то выдаем сответствующюю инфу echo json_encode(array("error" => 'Не найдена функция для обработки запроса (' . $controller_name . '::' . $action . ')!')); } exit; } //если это не запрос, просто вызываем метод $controller->{$action}(isset($arg) ? $arg : NULL); unset($routes); } else { throw new Exception404(); } } catch (mysqli_sql_exception $e) { if (Settings::$DEBUG) { echo '<br>DEBUG: mysqli_sql_exception: ' . $e->getMessage() . ' => ' . $e->getCode() . '<br>'; } Log::writeLog($e->getMessage() . ' ' . $e->getCode()); } catch (Exception404 $e) { // Здесь сделаем так, что бы 404 выдавалось в контент или куда-то еще, что бы не нарушать целостность сайта // View::render404(); echo '404'; } catch (Exception $e) { if (Settings::$DEBUG) { echo '<br>DEBUG: Exception: ' . $e->getMessage() . ' => ' . $e->getCode() . '<br>'; } } //// проверка на запрещенные или разрешенные IP-адреса // if(Settings::$ENGINE['checkIP'] > 0) // { // $ip = Engine::checkIp($_SERVER['REMOTE_ADDR']); // // if($ip && Settings::$ENGINE['checkIP'] == 1) // View::renderClosed($ip['reason'], $ip['date']); // else // if(!$ip && Settings::$ENGINE['checkIP'] == 2) // View::renderClosed('Доступ к сайту с Вашего IP-адреса запрещен'); // } // // /** // * проверка на запрещенные или разрешенные ОС, браузеры или их версии // * TODO: тут, по-хороошему, нужно поближе рассмотреть этот мехвнизм, обточить // */ // if(Settings::$ENGINE['checkFStuff'] > 0) // { // $r = Engine::checkForbiddenStuff(self::getUserBrowser()); // if($r && Settings::$ENGINE['checkFStuff'] == 1) // View::renderClosed($r); // else // if(!$r && Settings::$ENGINE['checkFStuff'] == 2) // View::renderClosed('Сайт не поддерживает работу с Вашими устройствами'); // } // // //// проверка включена ли мультиязычность или нет, по умолчанию используется только русский язык // if(Settings::$ENGINE['multiLang']) // if(!empty($_COOKIE['lang'])) // Controller::$lang = $_COOKIE['lang']; }
<?php return array('configs' => array('view.cache_js' => false, 'view.cache_css' => false, 'view.index' => 'index' . EXT, 'view.dir' => 'views/'), 'routes' => array('view/js/:any' => array('callback' => array('view', 'js')), 'view/css/:any' => array('callback' => array('view', 'css'))), 'events' => array('router.data' => function ($currentRoute, $routeData) { if (isset($routeData['title'])) { View::setTitle($routeData['title']); } }));