Phalcon Framework 3.3.2

Phalcon\Mvc\Model\Exception: Cache didn't return a valid resultset

phalcon/mvc/model/query.zep (3348)
#0Phalcon\Mvc\Model\Query->execute()
#1Phalcon\Mvc\Model::find(Array([conditions] => group_id = :group_id:, [bind] => Array([group_id] => 1), [cache] => Array([key] => sliders, [lifetime] => 300)))
/home/congvieclamtn/library/modules/FrontEnd/Controller/LoaderController.php (44)
<?php
 
/**
 * Created by PhpStorm.
 * User: nhanphong
 * Date: 6/21/18
 * Time: 3:17 PM
 */
 
namespace FrontEnd\Controller;
 
use Admin\Model\AdminUser;
use Application\Mvc\Controller;
use Lib\Menu\Helper\Menu;
use Lib\Theme\Model\Theme as ThemeLib;
use Lib\Slider\Model\Slider as SliderLib;
 
class LoaderController extends Controller
{
    public static $menu;
    protected $theme;
    protected $auth = null;
 
    public function initialize()
    {
        $themeModel = ThemeLib::find([
            'conditons' => 'theme = :theme:',
            'bind' => [ 'theme' => THEME ],
        ]);
 
        $theme = [];
        foreach ($themeModel as $key => $value) {
            $theme[$value->key] = $value->value;
        }
        $this->theme = $theme;
        $totalUser = AdminUser::count();
        $idMenu = ($theme['menu_main']) ? $theme['menu_main'] : 1;
        $menuBase = new Menu();
        $menu = $menuBase->getMenu($idMenu);
        $auth = $this->session->get('auth');
        $this->auth = $auth;
 
        $sliders = SliderLib::find([
            'conditions' => 'group_id = :group_id:',
            'bind'      => [
                'group_id' => 1
            ],
            'cache' => [
                'key'      => 'sliders',
                'lifetime' => 300,
            ],
        ]);
        $this->view->setVars([
            'menu' => $menu,
            'mobile_device' => MOBILE_DEVICE,
            'theme' => $theme,
            'auth' => $auth,
            'base_url' => BASE_URL,
            'totalUser' => $totalUser,
            'sliders'   => $sliders
        ]);
    }
}
#2FrontEnd\Controller\LoaderController->initialize()
/home/congvieclamtn/app/themes/hotmagazine/modules/Post/Controller/IndexController.php (16)
<?php
 
namespace Post\Controller;
use FrontEnd\Controller\LoaderController;
use PhalartCMS\Plugin\Shortcode;
use Post\Model\Post;
use Lib\Category\Model\Category;
use Post\Model\Helper\PostHelper;
use Lib\Tag\Model\Tag;
use Lib\Theme\Model\Theme as ThemeBase;
 
class IndexController extends LoaderController
{
    public function initialize()
    {   
        parent::initialize();
    }
 
    public function indexAction()
    {
 
    }
 
    public function detailAction()
    {
        $this->view->bodyClass = 'home';
 
        $id = $this->dispatcher->getParam('id', array('int'), '');
        $post = Post::findFirst($id);
        $slug = $this->dispatcher->getParam('slug', array('striptags', 'trim', 'lower'), '');
 
        if(!$post) {
            $this->error404();
            return $this->response;
        }
        if (!$this->session->has('post_' . $id)) {
            $post->hits += 1;
            $post->update();
            $this->session->set('post_' . $id, 1); 
        }
        $categoryId = $post->getPostCategory()->toArray()[0]['category_id'];
        $categoryModel = Category::findFirst($categoryId);
 
        $breadcrumb = [
            [
                'title'     => 'Trang chủ',
                'url'       => '/',
                'active'    => false 
            ],
            [
                'title'     => $categoryModel->getName(),
                'url'       => $this->url->get(['for' => 'post_category', 'slug' => $categoryModel->getSlug()]),
                'active'    => false
            ],
            [
                'title'     => $post->getTitle(),
                'url'       => $this->url->get(['for' => 'post_detail', 'slug' => $post->getSlug(), 'id' => $post->getId()]),
                'active'    => true
            ]
        ];
 
        $this->helper->breadcrumb($breadcrumb, true);
        $this->view->categoryId = $categoryId;
        $this->view->post = $post;
        $this->view->domain = 'http://' . $_SERVER['SERVER_NAME'];
        $meta_title = (!empty($post->getPostContent()->meta_title)) ? $post->getPostContent()->meta_title : $post->getTitle();
        $meta_description = (!empty($post->getPostContent()->meta_description)) ? $post->getPostContent()->meta_description : $post->getTitle();
        $meta_keyword = (!empty($post->getPostContent()->meta_keyword)) ? $post->getPostContent()->meta_keyword : $post->getTitle();
        $this->helper->title()->append($meta_title);
        $this->helper->meta()->set('description',$meta_description);
        $this->helper->meta()->set('keywords', $meta_keyword);
        $this->helper->meta()->setFb('og:description',$meta_description);
        $this->helper->meta()->setFb('og:keywords', $meta_keyword);
        $this->helper->meta()->setFb('og:image', BASE_URL . '/' . $post->getImage());
        $this->helper->meta()->setFb('og:url', $this->router->getRewriteUri());
        $this->helper->meta()->setFb('og:title', $meta_title);
 
        $postHelper = new PostHelper();
        unset($params);
        $params['limit'] = 5;
        $params['conditions']['type'] = 'F';
        $tabFeaturePost = $postHelper->getList($params);
 
        unset($params);
        $params['limit'] = 5;
        $params['conditions']['type'] = 'H';
        $tabHotPost = $postHelper->getList($params);
 
        unset($params);
        $params['limit'] = 5;
        $params['order'] = 'p.hits DESC';
        $tabMostView = $postHelper->getList($params);
 
        $topTags = Tag::find([
            'limit' => 10,
            'order' => 'count DESC'
        ]);
 
        unset($params);
        $params['limit'] = 3;
        $params['conditions']['module'] = 'video';
        $videos = $postHelper->getList($params);
 
        unset($params);
        $params['limit'] = 6;
        $params['conditions']['not_id'] = $post->id;
        $params['conditions']['category_id'] = $categoryId;
        $postRelate = $postHelper->getList($params);
 
        unset($params);
        $params['conditions']['id'] = $id;
        $listPost = $postHelper->getOne($params);
 
        $sidebarPost = ThemeBase::findFirst([
            'conditions' => 'theme = :theme: AND key = :key:',
            'bind' => [
                'theme' => THEME,
                'key' => 'sidebar-post'
            ]
        ]);
        $positionSidebarPost = [];
        if ($sidebarPost) {
            $sidebarPost = unserialize($sidebarPost->value);
            foreach ($sidebarPost as $key => &$widget) {
                $tmp = explode('-', $widget);
                $origin = $tmp;
                array_pop($tmp);
                $typeWidget = implode('-', $tmp);
                $keyWidget = end($origin);
                $model = ThemeBase::findFirst([
                    'conditions' => 'key = :key: AND theme = :theme:',
                    'bind'  => [
                        'key' => $typeWidget,
                        'theme' => THEME
                    ]
                ]);
                $listTypeWidget['key'] = $keyWidget;
                $listTypeWidget['name'] = $typeWidget;
                $listTypeWidget['slug'] = $typeWidget . '-' . $keyWidget;
                $listTypeWidget['detail'] = unserialize($model->value)[$keyWidget];
                $positionSidebarPost[] = $listTypeWidget;
            }
        }
 
        $this->view->setVars([
            'tabFeaturePost' => $tabFeaturePost,
            'tabMostView' => $tabMostView,
            'tabHotPost' => $tabHotPost,
            'topTags'   => $topTags,
            'videos'    => $videos,
            'postHelper' => $listPost,
            'postRelate' => $postRelate,
            'sidebarPost' => $positionSidebarPost
        ]);
        $this->view->pick('Post/index/detail');
    }
 
    public function searchAction()
    {
        $keyword = $this->request->getQuery('keywork');
        var_dump('sadfsa'); die;
        if (!empty($keyword)) {
            $postHelper = new \Lib\Post\Model\Helper\PostHelper();
            $params['keyword'] = $keyword;
            $list = $postHelper->getList($params);
            var_dump($list); die;
        }
    }
 
}
#3Post\Controller\IndexController->initialize()
#4Phalcon\Dispatcher->dispatch()
/home/congvieclamtn/app/Bootstrap.php (376)
<?php
 
namespace PhalartCMS;
use Application\Cache\Manager as CacheManager;
use Cms\Model\Configuration as CmsConfiguration;
use \PhalartCMS\Plugin\CheckPoint as CheckPointPlugin;
use \PhalartCMS\Plugin\Localization as LocalizationPlugin;
use \PhalartCMS\Plugin\AdminLocalization as AdminLocalizationPlugin;
use \PhalartCMS\Plugin\Acl as AclPlugin;
use \PhalartCMS\Plugin\MobileDetect as MobileDetectPlugin;
use PhalartCMS\Plugin\Shortcode;
use \PhalartCMS\Plugin\Title as TitlePlugin;
 
/**
 * @copyright Copyright (c) 2018 Phalart
 * @author Nhan Phong <nhanphong@vinadesign.vn>
 * User: nhanphong
 * Date: 6/4/18
 * Time: 10:51 AM
 */
 
if (APPLICATION_ENV == 'development') {
    date_default_timezone_set('Asia/Bangkok');
    ini_set('display_errors', true);
    error_reporting(E_ALL);
}
define('ROOT_APP', __DIR__);
 
class Bootstrap
{
 
    public function run()
    {
        $di = new \Phalcon\DI\FactoryDefault();
 
        $application = include_once APPLICATION_PATH . '/config/environment/' . APPLICATION_ENV . '.php';
 
        $config_default = [
            'base_path' => (isset($application['base_path'])) ? $application['base_path'] : null,
            'base_uri' => (isset($application['base_uri'])) ? $application['base_uri'] : null,
            'database'  => (isset($application['database'])) ? $application['database'] : null,
            'cache'     => (isset($application['cache'])) ? $application['cache'] : null,
            'memcache'  => (isset($application['memcache'])) ? $application['memcache'] : null,
            'memcached'  => (isset($application['memcached'])) ? $application['memcached'] : null,
            'assets'    => (isset($application['assets'])) ? $application['assets'] : null,
        ];
        $config = new \Phalcon\Config($config_default);
 
        // Database
        $db = new \Phalcon\Db\Adapter\Pdo\Mysql([
            "host"     => $config->database->host,
            "username" => $config->database->username,
            "password" => $config->database->password,
            "dbname"   => $config->database->dbname,
            "charset"  => $config->database->charset,
        ]);
        $di->set('db', $db);
 
        // Config
 
        $result = $db->fetchOne(
            "SELECT * FROM `cms_configuration` WHERE `key` = 'THEME'"
        );
        $theme = $result['value'];
        define('THEME', $theme);
        define('THEME_PATH', __DIR__ . '/themes/' . $theme);
        require_once LIBRARY_PATH . '/modules/Cms/ConfigApp.php';
        $config2 = \Cms\ConfigApp::get();
        $config->merge($config2);
        $di->set('config', $config);
 
        // Registry
        $registry = new \Phalcon\Registry();
        $di->set('registry', $registry);
 
        // Loader
        $loader = new \Phalcon\Loader();
        $loader->registerNamespaces($config->loader->namespaces->toArray());
        $loader->registerDirs([LIBRARY_PATH . "/plugins/"]);
        $loader->registerFiles([APPLICATION_PATH . '/../vendor/autoload.php']);
        $loader->register();
 
 
        // Get Option setting
        $di->set('options', new \PhalartCMS\Plugin\Options());
        // Get Option setting
 
        // View
        $this->initView($di);
        $this->initSimpleView($di);
 
        // URL
        $url = new \Phalcon\Mvc\Url();
        $url->setBasePath($config->base_path);
        $url->setBaseUri($config->base_path);
        $di->set('url', $url);
 
        // Cache
        $this->initCache($di);
 
        // CMS
        $cmsModel = new CmsConfiguration();
        $registry->cms = $cmsModel->getConfig(); // Отправляем в Registry
 
        // Application
        $application = new \Phalcon\Mvc\Application();
        $application->registerModules($config->modules->toArray());
 
        // Events Manager, Dispatcher
        $this->initEventManager($di);
 
        // Session
        $session = new \Phalcon\Session\Adapter\Files();
        $session->start();
        $di->set('session', $session);
 
        $acl = new \Application\Acl\DefaultAcl();
        $di->set('acl', $acl);
 
        // JS Assets
        $this->initAssetsManager($di);
 
        // Flash helper
        $flash = new \Phalcon\Flash\Session([
            'error'   => 'alert alert-danger',
            'success' => 'alert alert-success',
            'notice'  => 'alert alert-info',
            'warning' => 'alert alert-warning',
        ]);
        $flash->setAutoescape(false);
        $di->set('flash', $flash);
 
        $di->set('helper', new \Application\Mvc\Helper());
 
        // Routing
        $this->initRouting($application, $di);
 
        $application->setDI($di);
        $di->setShared('shortcode', new Shortcode($application));
 
        // Main dispatching process
        $response = $this->dispatch($di);
        $response->send();
 
    }
 
    private function initRouting($application, $di)
    {
        $router = new \Application\Mvc\Router\DefaultRouter();
        $router->setDi($di);
        foreach ($application->getModules() as $module) {
            $routesClassName = str_replace('Module', 'Routes', $module['className']);
            if (class_exists($routesClassName)) {
                $routesClass = new $routesClassName();
                $router = $routesClass->init($router);
            }
            $initClassName = str_replace('Module', 'Init', $module['className']);
            if (class_exists($initClassName)) {
                new $initClassName();
            }
        }
        $di->set('router', $router);
    }
 
    private function initAssetsManager($di)
    {
        $config = $di->get('config');
        $assetsManager = new \Application\Assets\Manager();
        $js_collection = $assetsManager->collection('js')
            ->setLocal(true)
            ->addFilter(new \Phalcon\Assets\Filters\Jsmin())
            ->setTargetPath(ROOT . '/assets/js.js')
            ->setTargetUri('assets/js.js')
            ->join(true);
        if ($config->assets->js) {
            foreach ($config->assets->js as $js) {
                $js_collection->addJs(ROOT . '/' . $js);
            }
        }
 
        // Admin JS Assets
        $assetsManager->collection('modules-admin-js')
            ->setLocal(true)
            ->addFilter(new \Phalcon\Assets\Filters\Jsmin())
            ->setTargetPath(ROOT . '/assets/modules-admin.js')
            ->setTargetUri('assets/modules-admin.js')
            ->join(true);
 
        // Admin LESS Assets
        $assetsManager->collection('modules-admin-less')
            ->setLocal(true)
            ->addFilter(new \Application\Assets\Filter\Less())
            ->setTargetPath(ROOT . '/assets/modules-admin.less')
            ->setTargetUri('assets/modules-admin.less')
            ->join(true)
            ->addCss(APPLICATION_PATH . '/modules/Admin/assets/admin.less');
 
        $di->set('assets', $assetsManager);
    }
 
    private function initEventManager($di)
    {
        $eventsManager = new \Phalcon\Events\Manager();
        $dispatcher = new \Phalcon\Mvc\Dispatcher();
 
        $eventsManager->attach("dispatch:beforeDispatchLoop", function ($event, $dispatcher) use ($di) {
            new CheckPointPlugin($di->get('request'));
            new LocalizationPlugin($dispatcher);
            new AdminLocalizationPlugin($di->get('config'));
            new AclPlugin($di->get('acl'), $dispatcher, $di->get('view'));
            new MobileDetectPlugin($di->get('session'), $di->get('view'), $di->get('request'));
        });
 
        $eventsManager->attach("dispatch:afterDispatchLoop", function ($event, $dispatcher) use ($di) {
            new \Seo\Plugin\SeoManager($dispatcher, $di->get('request'), $di->get('router'), $di->get('view'));
            new TitlePlugin($di);
        });
 
        // Profiler
        $registry = $di->get('registry');
        if ($registry->cms['PROFILER']) {
            $profiler = new \Phalcon\Db\Profiler();
            $di->set('profiler', $profiler);
 
            $eventsManager->attach('db', function ($event, $db) use ($profiler) {
                if ($event->getType() == 'beforeQuery') {
                    $profiler->startProfile($db->getSQLStatement());
                }
                if ($event->getType() == 'afterQuery') {
                    $profiler->stopProfile();
                }
            });
        }
 
        $db = $di->get('db');
        $db->setEventsManager($eventsManager);
 
        $dispatcher->setEventsManager($eventsManager);
        $di->set('dispatcher', $dispatcher);
    }
 
    private function initView($di)
    {
        $view = new \Phalcon\Mvc\View();
        $theme = THEME;
        define('MAIN_VIEW_PATH', ROOT_APP . "/themes/{$theme}/views/");
 
        /*$view->setViewsDir(MAIN_VIEW_PATH);
        $view->setPartialsDir(MAIN_VIEW_PATH . "/partials/");
        $view->setRenderLevel(\Phalcon\Mvc\View::LEVEL_ACTION_VIEW);*/
 
        // Volt
        $volt = new \Application\Mvc\View\Engine\Volt($view, $di);
        $volt->setOptions([
            'compiledPath' => APPLICATION_PATH . '/../data/cache/volt/',
            'compileAlways'     => !(APPLICATION_ENV == 'development'),
        ]);
        $volt->initCompiler();
 
 
        $phtml = new \Phalcon\Mvc\View\Engine\Php($view, $di);
        $viewEngines = [
            ".volt"  => $volt,
            ".phtml" => $phtml,
        ];
 
        $view->registerEngines($viewEngines);
 
        $ajax = $di->get('request')->getQuery('_ajax');
        if ($ajax) {
            $view->setRenderLevel(\Phalcon\Mvc\View::LEVEL_LAYOUT);
        }
 
        $di->set('view', $view);
 
        return $view;
    }
 
    private function initSimpleView($di)
    {
        $view = new \Phalcon\Mvc\View\Simple();
 
        // Volt
        $volt = new \Application\Mvc\View\Engine\Volt($view, $di);
        $volt->setOptions(['compiledPath' => APPLICATION_PATH . '/../data/cache/volt/']);
        $volt->initCompiler();
 
        $phtml = new \Phalcon\Mvc\View\Engine\Php($view, $di);
        $viewEngines = [
            ".volt"  => $volt,
            ".phtml" => $phtml,
        ];
 
        $view->registerEngines($viewEngines);
        $di->set('simpleView', $view);
 
        return $view;
    }
 
    private function initCache($di)
    {
        $config = $di->get('config');
 
        $cacheFrontend = new \Phalcon\Cache\Frontend\Data([
            "lifetime" => 60,
            "prefix"   => HOST_HASH,
        ]);
 
        $cache = null;
        switch ($config->cache) {
            case 'file':
                $cache = new \Phalcon\Cache\Backend\File($cacheFrontend, [
                    "cacheDir" => APPLICATION_PATH . "/../data/cache/backend/"
                ]);
                break;
            case 'memcache':
                $cache = new \Phalcon\Cache\Backend\Memcache(
                    $cacheFrontend, [
                    "host" => $config->memcache->host,
                    "port" => $config->memcache->port,
                ]);
                break;
            case 'memcached':
                $cache = new \Phalcon\Cache\Backend\Libmemcached(
                    $cacheFrontend, [
                    "host" => $config->memcached->host,
                    "port" => $config->memcached->port,
                ]);
                break;
        }
        $di->set('cache', $cache, true);
        $di->set('modelsCache', $cache, true);
 
        \Application\Widget\Proxy::$cache = $cache; // Modules Widget System
 
        $modelsMetadata = new \Phalcon\Mvc\Model\Metadata\Memory();
        $di->set('modelsMetadata', $modelsMetadata);
 
        $di->set('cacheManager', new CacheManager());
    }
 
    private function dispatch($di)
    {
        $router = $di['router'];
 
        $router->handle();
 
        $view = $di['view'];
 
        $dispatcher = $di['dispatcher'];
 
        $response = $di['response'];
 
        $dispatcher->setModuleName($router->getModuleName());
        $dispatcher->setControllerName($router->getControllerName());
        $dispatcher->setActionName($router->getActionName());
        $dispatcher->setParams($router->getParams());
 
        $moduleName = \Application\Utils\ModuleName::camelize($router->getModuleName());
 
        $ModuleClassName = $moduleName . '\Module';
        
        if (class_exists($ModuleClassName)) {
            $module = new $ModuleClassName;
            $module->registerAutoloaders();
            $module->registerServices($di);
        }
 
        $view->start();
 
        $registry = $di['registry'];
        if ($registry->cms['DEBUG_MODE']) {
            $debug = new \Phalcon\Debug();
            $debug->listen();
 
            $dispatcher->dispatch();
        } else {
            try {
                $dispatcher->dispatch();
            } catch (\Phalcon\Exception $e) {
                // Errors catching
 
                $view->setViewsDir(__DIR__ . '/modules/Index/views/');
                $view->setPartialsDir('');
                $view->e = $e;
 
                if ($e instanceof \Phalcon\Mvc\Dispatcher\Exception) {
                    $response->setStatusCode(404, 'Not Found');
                    $view->partial('error/error404');
                } else {
                    $response->setStatusCode(503, 'Service Unavailable');
                    $view->partial('error/error503');
                }
 
                return $response;
            }
        }
 
        $view->render(
            $dispatcher->getControllerName(),
            $dispatcher->getActionName(),
            $dispatcher->getParams()
        );
 
        $view->finish();
 
        // AJAX
        $request = $di['request'];
        $_ajax = $request->getQuery('_ajax');
        if ($_ajax) {
            $contents = $view->getContent();
 
            $return = new \stdClass();
            $return->html = $contents;
            $return->title = $di->get('helper')->title()->get();
            $return->success = true;
 
            if ($view->bodyClass) {
                $return->bodyClass = $view->bodyClass;
            }
 
            $headers = $response->getHeaders()->toArray();
            if (isset($headers[404]) || isset($headers[503])) {
                $return->success = false;
            }
            $response->setContentType('application/json', 'UTF-8');
            $response->setContent(json_encode($return));
        } else {
            $response->setContent($view->getContent());
        }
 
        return $response;
    }
 
}
#5PhalartCMS\Bootstrap->dispatch(Object(Phalcon\Di\FactoryDefault))
/home/congvieclamtn/app/Bootstrap.php (142)
<?php
 
namespace PhalartCMS;
use Application\Cache\Manager as CacheManager;
use Cms\Model\Configuration as CmsConfiguration;
use \PhalartCMS\Plugin\CheckPoint as CheckPointPlugin;
use \PhalartCMS\Plugin\Localization as LocalizationPlugin;
use \PhalartCMS\Plugin\AdminLocalization as AdminLocalizationPlugin;
use \PhalartCMS\Plugin\Acl as AclPlugin;
use \PhalartCMS\Plugin\MobileDetect as MobileDetectPlugin;
use PhalartCMS\Plugin\Shortcode;
use \PhalartCMS\Plugin\Title as TitlePlugin;
 
/**
 * @copyright Copyright (c) 2018 Phalart
 * @author Nhan Phong <nhanphong@vinadesign.vn>
 * User: nhanphong
 * Date: 6/4/18
 * Time: 10:51 AM
 */
 
if (APPLICATION_ENV == 'development') {
    date_default_timezone_set('Asia/Bangkok');
    ini_set('display_errors', true);
    error_reporting(E_ALL);
}
define('ROOT_APP', __DIR__);
 
class Bootstrap
{
 
    public function run()
    {
        $di = new \Phalcon\DI\FactoryDefault();
 
        $application = include_once APPLICATION_PATH . '/config/environment/' . APPLICATION_ENV . '.php';
 
        $config_default = [
            'base_path' => (isset($application['base_path'])) ? $application['base_path'] : null,
            'base_uri' => (isset($application['base_uri'])) ? $application['base_uri'] : null,
            'database'  => (isset($application['database'])) ? $application['database'] : null,
            'cache'     => (isset($application['cache'])) ? $application['cache'] : null,
            'memcache'  => (isset($application['memcache'])) ? $application['memcache'] : null,
            'memcached'  => (isset($application['memcached'])) ? $application['memcached'] : null,
            'assets'    => (isset($application['assets'])) ? $application['assets'] : null,
        ];
        $config = new \Phalcon\Config($config_default);
 
        // Database
        $db = new \Phalcon\Db\Adapter\Pdo\Mysql([
            "host"     => $config->database->host,
            "username" => $config->database->username,
            "password" => $config->database->password,
            "dbname"   => $config->database->dbname,
            "charset"  => $config->database->charset,
        ]);
        $di->set('db', $db);
 
        // Config
 
        $result = $db->fetchOne(
            "SELECT * FROM `cms_configuration` WHERE `key` = 'THEME'"
        );
        $theme = $result['value'];
        define('THEME', $theme);
        define('THEME_PATH', __DIR__ . '/themes/' . $theme);
        require_once LIBRARY_PATH . '/modules/Cms/ConfigApp.php';
        $config2 = \Cms\ConfigApp::get();
        $config->merge($config2);
        $di->set('config', $config);
 
        // Registry
        $registry = new \Phalcon\Registry();
        $di->set('registry', $registry);
 
        // Loader
        $loader = new \Phalcon\Loader();
        $loader->registerNamespaces($config->loader->namespaces->toArray());
        $loader->registerDirs([LIBRARY_PATH . "/plugins/"]);
        $loader->registerFiles([APPLICATION_PATH . '/../vendor/autoload.php']);
        $loader->register();
 
 
        // Get Option setting
        $di->set('options', new \PhalartCMS\Plugin\Options());
        // Get Option setting
 
        // View
        $this->initView($di);
        $this->initSimpleView($di);
 
        // URL
        $url = new \Phalcon\Mvc\Url();
        $url->setBasePath($config->base_path);
        $url->setBaseUri($config->base_path);
        $di->set('url', $url);
 
        // Cache
        $this->initCache($di);
 
        // CMS
        $cmsModel = new CmsConfiguration();
        $registry->cms = $cmsModel->getConfig(); // Отправляем в Registry
 
        // Application
        $application = new \Phalcon\Mvc\Application();
        $application->registerModules($config->modules->toArray());
 
        // Events Manager, Dispatcher
        $this->initEventManager($di);
 
        // Session
        $session = new \Phalcon\Session\Adapter\Files();
        $session->start();
        $di->set('session', $session);
 
        $acl = new \Application\Acl\DefaultAcl();
        $di->set('acl', $acl);
 
        // JS Assets
        $this->initAssetsManager($di);
 
        // Flash helper
        $flash = new \Phalcon\Flash\Session([
            'error'   => 'alert alert-danger',
            'success' => 'alert alert-success',
            'notice'  => 'alert alert-info',
            'warning' => 'alert alert-warning',
        ]);
        $flash->setAutoescape(false);
        $di->set('flash', $flash);
 
        $di->set('helper', new \Application\Mvc\Helper());
 
        // Routing
        $this->initRouting($application, $di);
 
        $application->setDI($di);
        $di->setShared('shortcode', new Shortcode($application));
 
        // Main dispatching process
        $response = $this->dispatch($di);
        $response->send();
 
    }
 
    private function initRouting($application, $di)
    {
        $router = new \Application\Mvc\Router\DefaultRouter();
        $router->setDi($di);
        foreach ($application->getModules() as $module) {
            $routesClassName = str_replace('Module', 'Routes', $module['className']);
            if (class_exists($routesClassName)) {
                $routesClass = new $routesClassName();
                $router = $routesClass->init($router);
            }
            $initClassName = str_replace('Module', 'Init', $module['className']);
            if (class_exists($initClassName)) {
                new $initClassName();
            }
        }
        $di->set('router', $router);
    }
 
    private function initAssetsManager($di)
    {
        $config = $di->get('config');
        $assetsManager = new \Application\Assets\Manager();
        $js_collection = $assetsManager->collection('js')
            ->setLocal(true)
            ->addFilter(new \Phalcon\Assets\Filters\Jsmin())
            ->setTargetPath(ROOT . '/assets/js.js')
            ->setTargetUri('assets/js.js')
            ->join(true);
        if ($config->assets->js) {
            foreach ($config->assets->js as $js) {
                $js_collection->addJs(ROOT . '/' . $js);
            }
        }
 
        // Admin JS Assets
        $assetsManager->collection('modules-admin-js')
            ->setLocal(true)
            ->addFilter(new \Phalcon\Assets\Filters\Jsmin())
            ->setTargetPath(ROOT . '/assets/modules-admin.js')
            ->setTargetUri('assets/modules-admin.js')
            ->join(true);
 
        // Admin LESS Assets
        $assetsManager->collection('modules-admin-less')
            ->setLocal(true)
            ->addFilter(new \Application\Assets\Filter\Less())
            ->setTargetPath(ROOT . '/assets/modules-admin.less')
            ->setTargetUri('assets/modules-admin.less')
            ->join(true)
            ->addCss(APPLICATION_PATH . '/modules/Admin/assets/admin.less');
 
        $di->set('assets', $assetsManager);
    }
 
    private function initEventManager($di)
    {
        $eventsManager = new \Phalcon\Events\Manager();
        $dispatcher = new \Phalcon\Mvc\Dispatcher();
 
        $eventsManager->attach("dispatch:beforeDispatchLoop", function ($event, $dispatcher) use ($di) {
            new CheckPointPlugin($di->get('request'));
            new LocalizationPlugin($dispatcher);
            new AdminLocalizationPlugin($di->get('config'));
            new AclPlugin($di->get('acl'), $dispatcher, $di->get('view'));
            new MobileDetectPlugin($di->get('session'), $di->get('view'), $di->get('request'));
        });
 
        $eventsManager->attach("dispatch:afterDispatchLoop", function ($event, $dispatcher) use ($di) {
            new \Seo\Plugin\SeoManager($dispatcher, $di->get('request'), $di->get('router'), $di->get('view'));
            new TitlePlugin($di);
        });
 
        // Profiler
        $registry = $di->get('registry');
        if ($registry->cms['PROFILER']) {
            $profiler = new \Phalcon\Db\Profiler();
            $di->set('profiler', $profiler);
 
            $eventsManager->attach('db', function ($event, $db) use ($profiler) {
                if ($event->getType() == 'beforeQuery') {
                    $profiler->startProfile($db->getSQLStatement());
                }
                if ($event->getType() == 'afterQuery') {
                    $profiler->stopProfile();
                }
            });
        }
 
        $db = $di->get('db');
        $db->setEventsManager($eventsManager);
 
        $dispatcher->setEventsManager($eventsManager);
        $di->set('dispatcher', $dispatcher);
    }
 
    private function initView($di)
    {
        $view = new \Phalcon\Mvc\View();
        $theme = THEME;
        define('MAIN_VIEW_PATH', ROOT_APP . "/themes/{$theme}/views/");
 
        /*$view->setViewsDir(MAIN_VIEW_PATH);
        $view->setPartialsDir(MAIN_VIEW_PATH . "/partials/");
        $view->setRenderLevel(\Phalcon\Mvc\View::LEVEL_ACTION_VIEW);*/
 
        // Volt
        $volt = new \Application\Mvc\View\Engine\Volt($view, $di);
        $volt->setOptions([
            'compiledPath' => APPLICATION_PATH . '/../data/cache/volt/',
            'compileAlways'     => !(APPLICATION_ENV == 'development'),
        ]);
        $volt->initCompiler();
 
 
        $phtml = new \Phalcon\Mvc\View\Engine\Php($view, $di);
        $viewEngines = [
            ".volt"  => $volt,
            ".phtml" => $phtml,
        ];
 
        $view->registerEngines($viewEngines);
 
        $ajax = $di->get('request')->getQuery('_ajax');
        if ($ajax) {
            $view->setRenderLevel(\Phalcon\Mvc\View::LEVEL_LAYOUT);
        }
 
        $di->set('view', $view);
 
        return $view;
    }
 
    private function initSimpleView($di)
    {
        $view = new \Phalcon\Mvc\View\Simple();
 
        // Volt
        $volt = new \Application\Mvc\View\Engine\Volt($view, $di);
        $volt->setOptions(['compiledPath' => APPLICATION_PATH . '/../data/cache/volt/']);
        $volt->initCompiler();
 
        $phtml = new \Phalcon\Mvc\View\Engine\Php($view, $di);
        $viewEngines = [
            ".volt"  => $volt,
            ".phtml" => $phtml,
        ];
 
        $view->registerEngines($viewEngines);
        $di->set('simpleView', $view);
 
        return $view;
    }
 
    private function initCache($di)
    {
        $config = $di->get('config');
 
        $cacheFrontend = new \Phalcon\Cache\Frontend\Data([
            "lifetime" => 60,
            "prefix"   => HOST_HASH,
        ]);
 
        $cache = null;
        switch ($config->cache) {
            case 'file':
                $cache = new \Phalcon\Cache\Backend\File($cacheFrontend, [
                    "cacheDir" => APPLICATION_PATH . "/../data/cache/backend/"
                ]);
                break;
            case 'memcache':
                $cache = new \Phalcon\Cache\Backend\Memcache(
                    $cacheFrontend, [
                    "host" => $config->memcache->host,
                    "port" => $config->memcache->port,
                ]);
                break;
            case 'memcached':
                $cache = new \Phalcon\Cache\Backend\Libmemcached(
                    $cacheFrontend, [
                    "host" => $config->memcached->host,
                    "port" => $config->memcached->port,
                ]);
                break;
        }
        $di->set('cache', $cache, true);
        $di->set('modelsCache', $cache, true);
 
        \Application\Widget\Proxy::$cache = $cache; // Modules Widget System
 
        $modelsMetadata = new \Phalcon\Mvc\Model\Metadata\Memory();
        $di->set('modelsMetadata', $modelsMetadata);
 
        $di->set('cacheManager', new CacheManager());
    }
 
    private function dispatch($di)
    {
        $router = $di['router'];
 
        $router->handle();
 
        $view = $di['view'];
 
        $dispatcher = $di['dispatcher'];
 
        $response = $di['response'];
 
        $dispatcher->setModuleName($router->getModuleName());
        $dispatcher->setControllerName($router->getControllerName());
        $dispatcher->setActionName($router->getActionName());
        $dispatcher->setParams($router->getParams());
 
        $moduleName = \Application\Utils\ModuleName::camelize($router->getModuleName());
 
        $ModuleClassName = $moduleName . '\Module';
        
        if (class_exists($ModuleClassName)) {
            $module = new $ModuleClassName;
            $module->registerAutoloaders();
            $module->registerServices($di);
        }
 
        $view->start();
 
        $registry = $di['registry'];
        if ($registry->cms['DEBUG_MODE']) {
            $debug = new \Phalcon\Debug();
            $debug->listen();
 
            $dispatcher->dispatch();
        } else {
            try {
                $dispatcher->dispatch();
            } catch (\Phalcon\Exception $e) {
                // Errors catching
 
                $view->setViewsDir(__DIR__ . '/modules/Index/views/');
                $view->setPartialsDir('');
                $view->e = $e;
 
                if ($e instanceof \Phalcon\Mvc\Dispatcher\Exception) {
                    $response->setStatusCode(404, 'Not Found');
                    $view->partial('error/error404');
                } else {
                    $response->setStatusCode(503, 'Service Unavailable');
                    $view->partial('error/error503');
                }
 
                return $response;
            }
        }
 
        $view->render(
            $dispatcher->getControllerName(),
            $dispatcher->getActionName(),
            $dispatcher->getParams()
        );
 
        $view->finish();
 
        // AJAX
        $request = $di['request'];
        $_ajax = $request->getQuery('_ajax');
        if ($_ajax) {
            $contents = $view->getContent();
 
            $return = new \stdClass();
            $return->html = $contents;
            $return->title = $di->get('helper')->title()->get();
            $return->success = true;
 
            if ($view->bodyClass) {
                $return->bodyClass = $view->bodyClass;
            }
 
            $headers = $response->getHeaders()->toArray();
            if (isset($headers[404]) || isset($headers[503])) {
                $return->success = false;
            }
            $response->setContentType('application/json', 'UTF-8');
            $response->setContent(json_encode($return));
        } else {
            $response->setContent($view->getContent());
        }
 
        return $response;
    }
 
}
#6PhalartCMS\Bootstrap->run()
/home/congvieclamtn/public/index.php (42)
<?php
 
/**
 * @copyright Copyright (c) 2018 Phalart
 * @author Nhan Phong <nhanphong@vinadesign.vn>
 * User: nhanphong
 * Date: 6/4/18
 * Time: 10:51 AM
 */
chdir(dirname(__DIR__));
 
define('ROOT', __DIR__);
define('HOST_HASH', substr(md5($_SERVER['HTTP_HOST']), 0, 12));
 
if (isset($_SERVER['APPLICATION_ENV'])) {
    $applicationEnv = ($_SERVER['APPLICATION_ENV'] ? $_SERVER['APPLICATION_ENV'] : 'production');
} else {
    $applicationEnv = (getenv('APPLICATION_ENV') ? getenv('APPLICATION_ENV') : 'production');
}
 
define('APPLICATION_ENV', $applicationEnv);
define('BASE_URL', (isset($_SERVER['HTTPS']) ? "https" : "http") . "://$_SERVER[HTTP_HOST]");
$actual_link = (isset($_SERVER['HTTPS']) ? "https" : "http") . "://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";
$parts = parse_url($actual_link);
$prefix = substr($parts['path'], 1);
$part = explode('/', $prefix);
$admin = 'admin';
$theme = 'blog';
//define('THEME', $theme);
if ($part[0] != $admin) {
    define('IS_ADMIN', false);
    define('APPLICATION_PATH', __DIR__ . '/../app');
    require_once APPLICATION_PATH . '/Bootstrap.php';
} else {
    define('IS_ADMIN', true);
    define('APPLICATION_PATH', __DIR__ . '/../admin');
    define('ADMINISTRATOR_PATH', __DIR__ . '/../admin');
    require_once ADMINISTRATOR_PATH . '/Bootstrap.php';
}
define('LIBRARY_PATH', __DIR__ . '/../library');
$bootstrap = new PhalartCMS\Bootstrap();
$bootstrap->run();
KeyValue
_url/ba-xu-huong-quan-tri-doanh-nghiep-se-noi-len-trong-thap-nien-2020-39330.html
KeyValue
USERcongvieclamtn
HOME/home/congvieclamtn
HTTP_CONNECTIONKeep-Alive
HTTP_HOSTthanhgiong.vn
HTTP_ACCEPT_ENCODINGbr,gzip
HTTP_ACCEPT_LANGUAGEen-US,en;q=0.5
HTTP_ACCEPTtext/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
HTTP_USER_AGENTCCBot/2.0 (https://commoncrawl.org/faq/)
APPLICATION_ENVproduction
SCRIPT_FILENAME/home/congvieclamtn/public/index.php
PATH_TRANSLATED/home/congvieclamtn/public
PATH_INFO
REDIRECT_STATUS200
SERVER_NAMEthanhgiong.vn
SERVER_PORT80
SERVER_ADDR210.211.116.91
REMOTE_PORT50176
REMOTE_ADDR18.232.55.175
SERVER_SOFTWAREnginx/1.12.2
GATEWAY_INTERFACECGI/1.1
SERVER_PROTOCOLHTTP/1.1
DOCUMENT_ROOT/home/congvieclamtn/public
DOCUMENT_URI/index.php
REQUEST_URI/ba-xu-huong-quan-tri-doanh-nghiep-se-noi-len-trong-thap-nien-2020-39330.html
SCRIPT_NAME/index.php
CONTENT_LENGTH
CONTENT_TYPE
REQUEST_METHODGET
QUERY_STRING_url=/ba-xu-huong-quan-tri-doanh-nghiep-se-noi-len-trong-thap-nien-2020-39330.html
FCGI_ROLERESPONDER
PHP_SELF/index.php
REQUEST_TIME_FLOAT1580255630.1579
REQUEST_TIME1580255630
#Path
0/home/congvieclamtn/public/index.php
1/home/congvieclamtn/app/Bootstrap.php
2/home/congvieclamtn/app/config/environment/production.php
3/home/congvieclamtn/library/modules/Cms/ConfigApp.php
4/home/congvieclamtn/app/config/global.php
5/home/congvieclamtn/app/config/modules.php
6/home/congvieclamtn/library/modules/Application/Loader/Modules.php
7/home/congvieclamtn/library/config/modules.php
8/home/congvieclamtn/vendor/autoload.php
9/home/congvieclamtn/vendor/composer/autoload_real.php
10/home/congvieclamtn/vendor/composer/ClassLoader.php
11/home/congvieclamtn/vendor/composer/autoload_static.php
12/home/congvieclamtn/vendor/cakephp/core/functions.php
13/home/congvieclamtn/vendor/symfony/polyfill-ctype/bootstrap.php
14/home/congvieclamtn/vendor/symfony/polyfill-mbstring/bootstrap.php
15/home/congvieclamtn/vendor/cakephp/utility/bootstrap.php
16/home/congvieclamtn/vendor/cakephp/utility/Inflector.php
17/home/congvieclamtn/vendor/cakephp/collection/functions.php
18/home/congvieclamtn/library/plugins/Options.php
19/home/congvieclamtn/library/modules/Cms/Model/Configuration.php
20/home/congvieclamtn/library/modules/Application/Mvc/View/Engine/Volt.php
21/home/congvieclamtn/library/modules/Application/Widget/Proxy.php
22/home/congvieclamtn/library/modules/Application/Cache/Manager.php
23/home/congvieclamtn/library/modules/Application/Acl/DefaultAcl.php
24/home/congvieclamtn/app/config/acl.php
25/home/congvieclamtn/library/modules/Application/Assets/Manager.php
26/home/congvieclamtn/library/modules/Application/Assets/Filter/Less.php
27/home/congvieclamtn/library/modules/Application/Mvc/Helper.php
28/home/congvieclamtn/library/modules/Menu/Helper/Menu.php
29/home/congvieclamtn/library/modules/Application/Mvc/Router/DefaultRouter.php
30/home/congvieclamtn/library/modules/Api/Routes.php
31/home/congvieclamtn/app/themes/hotmagazine/modules/Index/Routes.php
32/home/congvieclamtn/library/modules/Application/Mvc/Helper/CmsCache.php
33/home/congvieclamtn/app/themes/hotmagazine/modules/Seo/Routes.php
34/home/congvieclamtn/app/themes/hotmagazine/modules/Admin/Routes.php
35/home/congvieclamtn/app/themes/hotmagazine/modules/Post/Routes.php
36/home/congvieclamtn/app/themes/hotmagazine/modules/ShopMbn/Routes.php
37/home/congvieclamtn/app/themes/hotmagazine/modules/Search/Routes.php
38/home/congvieclamtn/app/themes/hotmagazine/modules/Contact/Routes.php
39/home/congvieclamtn/app/themes/hotmagazine/modules/Sitemap/Routes.php
40/home/congvieclamtn/app/themes/hotmagazine/modules/Product/Routes.php
41/home/congvieclamtn/app/themes/hotmagazine/modules/Cart/Routes.php
42/home/congvieclamtn/app/themes/hotmagazine/modules/Documents/Routes.php
43/home/congvieclamtn/library/plugins/Shortcode.php
44/home/congvieclamtn/library/plugins/WP/formatting.php
45/home/congvieclamtn/library/plugins/WP/shortcodes.php
46/home/congvieclamtn/library/modules/Application/Utils/ModuleName.php
47/home/congvieclamtn/app/themes/hotmagazine/modules/Post/Module.php
48/home/congvieclamtn/library/plugins/CheckPoint.php
49/home/congvieclamtn/library/plugins/Localization.php
50/home/congvieclamtn/library/modules/Cms/Model/Translate.php
51/home/congvieclamtn/library/plugins/AdminLocalization.php
52/home/congvieclamtn/data/translations/admin/en.php
53/home/congvieclamtn/library/plugins/Acl.php
54/home/congvieclamtn/library/plugins/MobileDetect.php
55/home/congvieclamtn/vendor/mobiledetect/mobiledetectlib/Mobile_Detect.php
56/home/congvieclamtn/app/themes/hotmagazine/modules/Post/Controller/IndexController.php
57/home/congvieclamtn/library/modules/FrontEnd/Controller/LoaderController.php
58/home/congvieclamtn/library/modules/Application/Mvc/Controller.php
59/home/congvieclamtn/library/modules/Theme/Model/Theme.php
60/home/congvieclamtn/library/modules/Application/Mvc/Model/Model.php
61/home/congvieclamtn/app/themes/hotmagazine/modules/Admin/Model/AdminUser.php
62/home/congvieclamtn/library/modules/Admin/Model/AdminUser.php
63/home/congvieclamtn/library/modules/Menu/Model/Menu.php
64/home/congvieclamtn/library/modules/Slider/Model/Slider.php
Memory
Usage2097152