Phalcon Framework 2.0.13

Phalcon\Cache\Exception: Cache file /var/www/html/ciss/cis.edu.vn/public/../app/../data/cache/backend/6fcc41a110bc1ba333e7304a6006218c59dd825fff21 could not be written

/var/www/html/ciss/cis.edu.vn/app/modules/Application/Mvc/Model/Model.php (191)
#0Phalcon\Cache\Backend\File->save(6fcc41a110bc1ba333e7304a6006218c59dd825fff21, Object(Phalcon\Mvc\Model\Resultset\Simple), 300)
/var/www/html/ciss/cis.edu.vn/app/modules/Application/Mvc/Model/Model.php (191)
<?php
 
/**
 * Model
 * @copyright Copyright (c) 2011 - 2014 Aleksandr Torosh (http://wezoom.com.ua)
 * @author Aleksandr Torosh <webtorua@gmail.com>
 */
namespace Application\Mvc\Model;
 
use Cms\Model\Language;
 
class Model extends \Phalcon\Mvc\Model
{
  const CACHE_LIFETIME = 300;
 
  protected $translations_array = []; // Translation array
 
  public $translations = [];
  public $fields = [];
 
  public static $lang = 'en'; // Language default
  public static $custom_lang = ''; // Used to create a sitemap
  private static $translateCache = true; // Translation cache usage flag
 
  /**
   * Translate. In order to implement a multilingual scheme, you need to copy your model of the following methods:
   * Start Copy:
   */
  protected $translateModel; // translate //The name of the class associated with the translations, for example = 'Page\Model\Translate\PageTranslate'
 
 
  public function initialize ()
  {
    $this->hasMany("id", $this->translateModel, "foreign_id"); // translate
  }
  //End Copy
 
  /**
   * This method is invoked after removal of all the fields in the Model
   */
  public function afterFetch ()
  {
    if ($this->translateModel && defined('LANG')) {
      // If there is an array of translation and is set constant active language or other language
      if (self::$custom_lang) {
        self::setLang(self::$custom_lang);
      } else {
        self::setLang(LANG); // Set the current language
      }
 
      $this->initTranslationsArray(); // Extract translated from the associated translation table
      $this->initTranslations();
    }
  }
 
  /**
   * Cleansing translation cache
   * The method is called after updating values in the model
   */
  public function afterUpdate ()
  {
    $this->deleteTranslateCache();
  }
 
  /**
   * Setting the language
   */
  public static function setLang ($lang)
  {
    self::$lang = $lang;
  }
 
  /**
   * Installing another language sitemap
   */
  public static function setCustomLang ($lang)
  {
    self::$custom_lang = $lang;
  }
 
  /**
   * Setting the cache usage of the flag.
   * It should be set up to call other method's model.
   * Example:
   *
   * ModelName::setTranslateCache(false); // We set the flag. Disabling the cache is necessary when working with models in the admin
   * $entries = ModelName::find(); // Retrieve data
   */
  public static function setTranslateCache ($value)
  {
    self::$translateCache = (bool)$value;
  }
 
  /**
   * Extracting money transfers on behalf of a variable
   */
  public function getMLVariable ($key)
  {
    $r = [];
    if (array_key_exists($key, $this->translations)) {
      $r = $this->translations[$key];
    }
 
    if (!$r) {
      $defaultLang = Language::findFirstByPrimary(1);
      $this->initTranslationsArray($defaultLang->getIso());
      $this->initTranslations();
      if (array_key_exists($key, $this->translations)) {
        $r = $this->translations[$key];
      } else {
        $r = false;
      }
      $this->initTranslationsArray();
      $this->initTranslations();
    }
    return $r;
  }
 
  public function setMLVariable ($key, $value, $lang = null)
  {
    if (!$this->getId()) {
      return false;
    }
    $model = new $this->translateModel();
    if (!$lang) {
      $lang = self::$lang;
    }
    $conditions = "foreign_id = :foreign_id: AND lang = :lang: AND key = :key:";
    $parameters = [
      'foreign_id' => $this->getId(),
      'lang' => $lang,
      'key' => $key
    ];
    $entity = $model->findFirst([
      $conditions,
      'bind' => $parameters]);
    if (!$entity) {
      $entity = new $this->translateModel();
      $entity->setForeignId($this->getId());
      $entity->setLang($lang);
      $entity->setKey($key);
    }
    $entity->setValue($value);
    $entity->save();
  }
 
  public function translateCacheKey ($lang = null)
  {
    if (!$lang) {
      $lang = self::$lang;
    }
    if (!$this->getId()) {
      return false;
    }
    $query = 'foreign_id = ' . $this->getId() . ' AND lang = "' . $lang . '"';
    $key = HOST_HASH . md5($this->getSource() . '_translate ' . $query);
    return $key;
  }
 
  public function deleteTranslateCache ()
  {
    if (!$this->getId()) {
      return false;
    }
    $cache = $this->getDi()->get('cache');
    $cache->delete($this->translateCacheKey());
  }
 
  /**
   * Removing the transfer array
   */
  private function initTranslationsArray ($lang = null)
  {
    if (!$lang) {
      $lang = self::$lang;
    }
 
    if (!$this->getId()) {
      return false;
    }
    $model = new $this->translateModel();
    $query = 'foreign_id = ' . $this->getId() . ' AND lang = "' . $lang . '"';
    $params = ['conditions' => $query];
 
    if (self::$translateCache) {
      $cache = $this->getDi()->get('cache');
      $data = $cache->get($this->translateCacheKey($lang));
      if (!$data) {
        $data = $model->find($params);
        if ($data) {
          $cache->save($this->translateCacheKey($lang), $data, self::CACHE_LIFETIME);
        }
      }
    } else {
      $data = $model->find($params);
    }
 
    $this->translations_array = $data;
  }
 
  public function initTranslations ()
  {
    if (!empty($this->translations_array)) {
      foreach ($this->translations_array as $translation) {
        $this->translations[$translation->getKey()] = $translation->getValue();
      }
    }
  }
 
  public function getImgFolder ($attr = null)
  {
    if ($attr) {
      return $this->getSource() . '_' . $attr;
    }
    return $this->getSource();
  }
 
  /**
   * @return string
   */
  public function getNameOfClass ()
  {
    return get_called_class();
  }
 
  public function indexBy ($arrData, $column = 'id')
  {
    $result = [];
    foreach ($arrData as $item) {
      $result[$column] = $item;
    }
    return $result;
  }
 
}
#1Application\Mvc\Model\Model->initTranslationsArray()
/var/www/html/ciss/cis.edu.vn/app/modules/Application/Mvc/Model/Model.php (51)
<?php
 
/**
 * Model
 * @copyright Copyright (c) 2011 - 2014 Aleksandr Torosh (http://wezoom.com.ua)
 * @author Aleksandr Torosh <webtorua@gmail.com>
 */
namespace Application\Mvc\Model;
 
use Cms\Model\Language;
 
class Model extends \Phalcon\Mvc\Model
{
  const CACHE_LIFETIME = 300;
 
  protected $translations_array = []; // Translation array
 
  public $translations = [];
  public $fields = [];
 
  public static $lang = 'en'; // Language default
  public static $custom_lang = ''; // Used to create a sitemap
  private static $translateCache = true; // Translation cache usage flag
 
  /**
   * Translate. In order to implement a multilingual scheme, you need to copy your model of the following methods:
   * Start Copy:
   */
  protected $translateModel; // translate //The name of the class associated with the translations, for example = 'Page\Model\Translate\PageTranslate'
 
 
  public function initialize ()
  {
    $this->hasMany("id", $this->translateModel, "foreign_id"); // translate
  }
  //End Copy
 
  /**
   * This method is invoked after removal of all the fields in the Model
   */
  public function afterFetch ()
  {
    if ($this->translateModel && defined('LANG')) {
      // If there is an array of translation and is set constant active language or other language
      if (self::$custom_lang) {
        self::setLang(self::$custom_lang);
      } else {
        self::setLang(LANG); // Set the current language
      }
 
      $this->initTranslationsArray(); // Extract translated from the associated translation table
      $this->initTranslations();
    }
  }
 
  /**
   * Cleansing translation cache
   * The method is called after updating values in the model
   */
  public function afterUpdate ()
  {
    $this->deleteTranslateCache();
  }
 
  /**
   * Setting the language
   */
  public static function setLang ($lang)
  {
    self::$lang = $lang;
  }
 
  /**
   * Installing another language sitemap
   */
  public static function setCustomLang ($lang)
  {
    self::$custom_lang = $lang;
  }
 
  /**
   * Setting the cache usage of the flag.
   * It should be set up to call other method's model.
   * Example:
   *
   * ModelName::setTranslateCache(false); // We set the flag. Disabling the cache is necessary when working with models in the admin
   * $entries = ModelName::find(); // Retrieve data
   */
  public static function setTranslateCache ($value)
  {
    self::$translateCache = (bool)$value;
  }
 
  /**
   * Extracting money transfers on behalf of a variable
   */
  public function getMLVariable ($key)
  {
    $r = [];
    if (array_key_exists($key, $this->translations)) {
      $r = $this->translations[$key];
    }
 
    if (!$r) {
      $defaultLang = Language::findFirstByPrimary(1);
      $this->initTranslationsArray($defaultLang->getIso());
      $this->initTranslations();
      if (array_key_exists($key, $this->translations)) {
        $r = $this->translations[$key];
      } else {
        $r = false;
      }
      $this->initTranslationsArray();
      $this->initTranslations();
    }
    return $r;
  }
 
  public function setMLVariable ($key, $value, $lang = null)
  {
    if (!$this->getId()) {
      return false;
    }
    $model = new $this->translateModel();
    if (!$lang) {
      $lang = self::$lang;
    }
    $conditions = "foreign_id = :foreign_id: AND lang = :lang: AND key = :key:";
    $parameters = [
      'foreign_id' => $this->getId(),
      'lang' => $lang,
      'key' => $key
    ];
    $entity = $model->findFirst([
      $conditions,
      'bind' => $parameters]);
    if (!$entity) {
      $entity = new $this->translateModel();
      $entity->setForeignId($this->getId());
      $entity->setLang($lang);
      $entity->setKey($key);
    }
    $entity->setValue($value);
    $entity->save();
  }
 
  public function translateCacheKey ($lang = null)
  {
    if (!$lang) {
      $lang = self::$lang;
    }
    if (!$this->getId()) {
      return false;
    }
    $query = 'foreign_id = ' . $this->getId() . ' AND lang = "' . $lang . '"';
    $key = HOST_HASH . md5($this->getSource() . '_translate ' . $query);
    return $key;
  }
 
  public function deleteTranslateCache ()
  {
    if (!$this->getId()) {
      return false;
    }
    $cache = $this->getDi()->get('cache');
    $cache->delete($this->translateCacheKey());
  }
 
  /**
   * Removing the transfer array
   */
  private function initTranslationsArray ($lang = null)
  {
    if (!$lang) {
      $lang = self::$lang;
    }
 
    if (!$this->getId()) {
      return false;
    }
    $model = new $this->translateModel();
    $query = 'foreign_id = ' . $this->getId() . ' AND lang = "' . $lang . '"';
    $params = ['conditions' => $query];
 
    if (self::$translateCache) {
      $cache = $this->getDi()->get('cache');
      $data = $cache->get($this->translateCacheKey($lang));
      if (!$data) {
        $data = $model->find($params);
        if ($data) {
          $cache->save($this->translateCacheKey($lang), $data, self::CACHE_LIFETIME);
        }
      }
    } else {
      $data = $model->find($params);
    }
 
    $this->translations_array = $data;
  }
 
  public function initTranslations ()
  {
    if (!empty($this->translations_array)) {
      foreach ($this->translations_array as $translation) {
        $this->translations[$translation->getKey()] = $translation->getValue();
      }
    }
  }
 
  public function getImgFolder ($attr = null)
  {
    if ($attr) {
      return $this->getSource() . '_' . $attr;
    }
    return $this->getSource();
  }
 
  /**
   * @return string
   */
  public function getNameOfClass ()
  {
    return get_called_class();
  }
 
  public function indexBy ($arrData, $column = 'id')
  {
    $result = [];
    foreach ($arrData as $item) {
      $result[$column] = $item;
    }
    return $result;
  }
 
}
#2Application\Mvc\Model\Model->afterFetch()
#3Phalcon\Mvc\Model::cloneResultMap(Object(Staff\Model\Staff: [translations] => Array(), [fields] => Array()), Array([id] => 477, [name] => Nguyễn Thị Bảo Ngọc, [photo] => img/original/staff_photo/0/477.jpg, [type_id] => 10, [slug] => nguyen-thi-bao-ngoc, [sort_order] => 4, [created_at] => 1570161595, [updated_at] => 1570177722), null, 0, false)
#4Phalcon\Mvc\Model\Resultset\Simple->current()
#5Phalcon\Paginator\Adapter\Model->getPaginate()
/var/www/html/ciss/cis.edu.vn/app/modules/Staff/Controller/IndexController.php (49)
<?php
 
namespace Staff\Controller;
 
use Application\Mvc\Controller;
use Page\Model\Page;
use Phalcon\Exception;
use Staff\Model\Staff;
use Staff\Model\Type;
 
class IndexController extends Controller
{
 
  public function indexAction ()
  {
    $this->view->bodyClass = 'page staffs';
 
    $type = $this->dispatcher->getParam('type', 'string');
    $page_num = $this->request->getQuery('page', 'int', 1);
 
    $page = Page::findCachedBySlug($type);
    if (!$page) {
      throw new Exception("Page '$type.html' not found");
    }
    $this->view->page = $page;
 
    $typeModel = \Staff\Model\Type::findFirstById($page->getModuleCategory());
    if (!$typeModel) {
      throw new Exception("Staff hasn't type = '$page->getModuleCategory()'");
    }
 
    $limit = $this->request->getQuery('limit', 'string', $this->registry['cms']['PAGE_LIMIT']);
    if ($limit != 'all') {
      $paginatorLimit = (int)$limit;
    } else {
      $paginatorLimit = 9999;
    }
 
    $staffs = Staff::find(array(
      "type_id = {$typeModel->getId()}",
      "order" => "sort_order ASC"
    ));
 
    $paginator = new \Phalcon\Paginator\Adapter\Model(array(
      "data" => $staffs,
      "limit" => $paginatorLimit,
      "page" => $page_num
    ));
    $this->view->paginate = $paginator->getPaginate();
 
    $this->helper->title()->append($page->getMetaTitle());
    $this->helper->activeMenu()->setActive($page->getId() . $type);
    $this->setPageMeta($page);
  }
 
  public function staffAction ()
  {
    $this->view->bodyClass = 'page staffs staff';
 
    $slug = $this->dispatcher->getParam('slug', 'string');
    $module_category = $this->dispatcher->getParam('type', 'string');
 
    $page_slug = $module_category;
    $page = Page::findCachedBySlug($page_slug);
    if (!$page) {
      throw new Exception("Page '$slug.html' not found");
    }
    $this->view->page = $page;
 
    $staff = Staff::findCachedBySlug($slug);
    if (!$staff) {
      throw new Exception("Staff '$slug.html' not found");
    }
 
    $this->helper->title()->append($staff->getMetaTitle());
    $this->view->staff = $staff;
    $this->helper->activeMenu()->setActive($page->getId() . $page_slug);
    $this->setPageMeta($page);
  }
}
#6Staff\Controller\IndexController->indexAction(bcis-secondary-teachers)
#7Phalcon\Dispatcher->dispatch()
/var/www/html/ciss/cis.edu.vn/app/Bootstrap.php (357)
<?php
 
namespace YonaCMS;
 
/**
 * Bootstrap
 *
 * @copyright Copyright (c) 2011 - 2014 Aleksandr Torosh (http://wezoom.com.ua)
 * @author    Aleksandr Torosh <webtorua@gmail.com>
 */
class Bootstrap
{
 
  public function run()
  {
    $di = new \Phalcon\DI\FactoryDefault();
 
    // Config
    require_once APPLICATION_PATH . '/modules/Cms/Config.php';
    $config = \Cms\Config::get();
    $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([APPLICATION_PATH . "/plugins/"]);
    $loader->register();
    require_once APPLICATION_PATH . '/../vendor/autoload.php';
 
    // 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);
 
    // View
    $this->initView($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 \Cms\Model\Configuration();
    $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',
    ]);
    $di->set('flash', $flash);
 
    $di->set('helper', new \Application\Mvc\Helper());
 
 
    /**
     * Custom DI
     */
    $di->set('email', function () {
      return new \Application\Mvc\EmailHelper();
    });
 
    // Routing
    $this->initRouting($application, $di);
 
    $application->setDI($di);
 
    // Main dispatching process
    $this->dispatch($di);
 
  }
 
  private function initView($di)
  {
    $view = new \Phalcon\Mvc\View();
 
    $theme = $di->get('config')['theme'];
    if ($theme) {
      $themePath = __DIR__ . '/themes/' . $di->get('config')['theme'] . '/';
      if (file_exists($themePath)) {
        define('MAIN_VIEW_PATH', '../../../themes/' . $theme . '/');
      }
    } else {
      define('MAIN_VIEW_PATH', '../../../views/');
    }
 
    $view->setMainView(MAIN_VIEW_PATH . 'main');
    $view->setLayoutsDir(MAIN_VIEW_PATH . '/layouts/');
    $view->setLayout('main');
    $view->setPartialsDir(MAIN_VIEW_PATH . '/partials/');
 
    // 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);
 
    $ajax = $di->get('request')->getQuery('_ajax');
    if ($ajax) {
      $view->setRenderLevel(\Phalcon\Mvc\View::LEVEL_LAYOUT);
    }
 
    $di->set('view', $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;
    }
    $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);
  }
 
  private function initEventManager($di)
  {
    $eventsManager = new \Phalcon\Events\Manager();
    $dispatcher = new \Phalcon\Mvc\Dispatcher();
 
    $eventsManager->attach("dispatch:beforeDispatchLoop", function ($event, $dispatcher) use ($di) {
      new \YonaCMS\Plugin\CheckPoint($di->get('request'));
      new \YonaCMS\Plugin\Localization($dispatcher);
      new \YonaCMS\Plugin\AdminLocalization($di->get('config'));
      new \YonaCMS\Plugin\Acl($di->get('acl'), $dispatcher, $di->get('view'));
      new \YonaCMS\Plugin\MobileDetect($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 \YonaCMS\Plugin\Title($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 initAssetsManager($di)
  {
    $config = $di->get('config');
    $isProductionEnv = (APPLICATION_ENV == "production") || (APPLICATION_ENV == "stagging");
    $locator = $isProductionEnv ? ROOT . '/' : '/';
    $jsMin = $isProductionEnv ? new \Phalcon\Assets\Filters\Jsmin() : new \Phalcon\Assets\Filters\None();
    $cssMin = $isProductionEnv ? new \Phalcon\Assets\Filters\Cssmin() : new \Phalcon\Assets\Filters\None();
 
    $assetsManager = new \Application\Assets\Manager();
    if ($isProductionEnv) {
      $js_collection = $assetsManager->collection('js')
        ->setLocal(true)
        ->addFilter($jsMin)
        ->setTargetPath(ROOT . '/assets/main.js')
        ->setTargetUri('assets/main.js')
        ->join($isProductionEnv);
    } else {
      $js_collection = $assetsManager->collection('js')->setLocal(true);
    }
    if ($config->assets->js) {
      foreach ($config->assets->js as $js) {
        $js_collection->addJs($locator . $js);
      }
    }
 
    if ($isProductionEnv) {
      $css_collection = $assetsManager->collection('css')
        ->setLocal(true)
        ->addFilter($cssMin)
        ->setTargetPath(ROOT . '/assets/main.min.css')
        ->setTargetUri('/assets/main.min.css')
        ->join($isProductionEnv);
    } else {
      $css_collection = $assetsManager->collection('css')->setLocal(true);
    }
    if ($config->assets->css) {
      foreach ($config->assets->css as $css) {
        $css_collection->addCss($locator . $css);
      }
    }
 
    // 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);
    $admin_js_collection = $assetsManager->collection('admin_js')->join($isProductionEnv);
    if ($config->assets->admin_js) {
      foreach ($config->assets->admin_js as $js) {
        $admin_js_collection->addJs('/' . $js);
      }
    }
 
    $admin_css_collection = $assetsManager->collection('admin_css')->setLocal(true);
    if ($config->assets->admin_css) {
      foreach ($config->assets->admin_css as $css) {
        $admin_css_collection->addCss('/' . $css);
      }
    }
  }
 
  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 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);
 
      $theme = $di->get('config')['theme'];
      if ($theme) {
        $themePath = '/themes/' . $di->get('config')['theme'] . '/' . $moduleName . '/';
        if (file_exists($themePath)) {
          $view->setViewsDir(__DIR__ . $themePath);
        }
      }
    }
 
    $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->setHeader(404, 'Not Found');
          $view->partial('error/error404');
        } else {
          $response->setHeader(503, 'Service Unavailable');
          $view->partial('error/error503');
        }
        $response->sendHeaders();
        echo $response->getContent();
 
        return;
 
      }
    }
 
    $view->render(
      $dispatcher->getControllerName(),
      $dispatcher->getActionName(),
      $dispatcher->getParams()
    );
 
    $view->finish();
 
    $response = $di['response'];
 
    // 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());
    }
 
    $response->sendHeaders();
 
    echo $response->getContent();
  }
 
}
#8YonaCMS\Bootstrap->dispatch(Object(Phalcon\Di\FactoryDefault))
/var/www/html/ciss/cis.edu.vn/app/Bootstrap.php (103)
<?php
 
namespace YonaCMS;
 
/**
 * Bootstrap
 *
 * @copyright Copyright (c) 2011 - 2014 Aleksandr Torosh (http://wezoom.com.ua)
 * @author    Aleksandr Torosh <webtorua@gmail.com>
 */
class Bootstrap
{
 
  public function run()
  {
    $di = new \Phalcon\DI\FactoryDefault();
 
    // Config
    require_once APPLICATION_PATH . '/modules/Cms/Config.php';
    $config = \Cms\Config::get();
    $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([APPLICATION_PATH . "/plugins/"]);
    $loader->register();
    require_once APPLICATION_PATH . '/../vendor/autoload.php';
 
    // 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);
 
    // View
    $this->initView($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 \Cms\Model\Configuration();
    $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',
    ]);
    $di->set('flash', $flash);
 
    $di->set('helper', new \Application\Mvc\Helper());
 
 
    /**
     * Custom DI
     */
    $di->set('email', function () {
      return new \Application\Mvc\EmailHelper();
    });
 
    // Routing
    $this->initRouting($application, $di);
 
    $application->setDI($di);
 
    // Main dispatching process
    $this->dispatch($di);
 
  }
 
  private function initView($di)
  {
    $view = new \Phalcon\Mvc\View();
 
    $theme = $di->get('config')['theme'];
    if ($theme) {
      $themePath = __DIR__ . '/themes/' . $di->get('config')['theme'] . '/';
      if (file_exists($themePath)) {
        define('MAIN_VIEW_PATH', '../../../themes/' . $theme . '/');
      }
    } else {
      define('MAIN_VIEW_PATH', '../../../views/');
    }
 
    $view->setMainView(MAIN_VIEW_PATH . 'main');
    $view->setLayoutsDir(MAIN_VIEW_PATH . '/layouts/');
    $view->setLayout('main');
    $view->setPartialsDir(MAIN_VIEW_PATH . '/partials/');
 
    // 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);
 
    $ajax = $di->get('request')->getQuery('_ajax');
    if ($ajax) {
      $view->setRenderLevel(\Phalcon\Mvc\View::LEVEL_LAYOUT);
    }
 
    $di->set('view', $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;
    }
    $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);
  }
 
  private function initEventManager($di)
  {
    $eventsManager = new \Phalcon\Events\Manager();
    $dispatcher = new \Phalcon\Mvc\Dispatcher();
 
    $eventsManager->attach("dispatch:beforeDispatchLoop", function ($event, $dispatcher) use ($di) {
      new \YonaCMS\Plugin\CheckPoint($di->get('request'));
      new \YonaCMS\Plugin\Localization($dispatcher);
      new \YonaCMS\Plugin\AdminLocalization($di->get('config'));
      new \YonaCMS\Plugin\Acl($di->get('acl'), $dispatcher, $di->get('view'));
      new \YonaCMS\Plugin\MobileDetect($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 \YonaCMS\Plugin\Title($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 initAssetsManager($di)
  {
    $config = $di->get('config');
    $isProductionEnv = (APPLICATION_ENV == "production") || (APPLICATION_ENV == "stagging");
    $locator = $isProductionEnv ? ROOT . '/' : '/';
    $jsMin = $isProductionEnv ? new \Phalcon\Assets\Filters\Jsmin() : new \Phalcon\Assets\Filters\None();
    $cssMin = $isProductionEnv ? new \Phalcon\Assets\Filters\Cssmin() : new \Phalcon\Assets\Filters\None();
 
    $assetsManager = new \Application\Assets\Manager();
    if ($isProductionEnv) {
      $js_collection = $assetsManager->collection('js')
        ->setLocal(true)
        ->addFilter($jsMin)
        ->setTargetPath(ROOT . '/assets/main.js')
        ->setTargetUri('assets/main.js')
        ->join($isProductionEnv);
    } else {
      $js_collection = $assetsManager->collection('js')->setLocal(true);
    }
    if ($config->assets->js) {
      foreach ($config->assets->js as $js) {
        $js_collection->addJs($locator . $js);
      }
    }
 
    if ($isProductionEnv) {
      $css_collection = $assetsManager->collection('css')
        ->setLocal(true)
        ->addFilter($cssMin)
        ->setTargetPath(ROOT . '/assets/main.min.css')
        ->setTargetUri('/assets/main.min.css')
        ->join($isProductionEnv);
    } else {
      $css_collection = $assetsManager->collection('css')->setLocal(true);
    }
    if ($config->assets->css) {
      foreach ($config->assets->css as $css) {
        $css_collection->addCss($locator . $css);
      }
    }
 
    // 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);
    $admin_js_collection = $assetsManager->collection('admin_js')->join($isProductionEnv);
    if ($config->assets->admin_js) {
      foreach ($config->assets->admin_js as $js) {
        $admin_js_collection->addJs('/' . $js);
      }
    }
 
    $admin_css_collection = $assetsManager->collection('admin_css')->setLocal(true);
    if ($config->assets->admin_css) {
      foreach ($config->assets->admin_css as $css) {
        $admin_css_collection->addCss('/' . $css);
      }
    }
  }
 
  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 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);
 
      $theme = $di->get('config')['theme'];
      if ($theme) {
        $themePath = '/themes/' . $di->get('config')['theme'] . '/' . $moduleName . '/';
        if (file_exists($themePath)) {
          $view->setViewsDir(__DIR__ . $themePath);
        }
      }
    }
 
    $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->setHeader(404, 'Not Found');
          $view->partial('error/error404');
        } else {
          $response->setHeader(503, 'Service Unavailable');
          $view->partial('error/error503');
        }
        $response->sendHeaders();
        echo $response->getContent();
 
        return;
 
      }
    }
 
    $view->render(
      $dispatcher->getControllerName(),
      $dispatcher->getActionName(),
      $dispatcher->getParams()
    );
 
    $view->finish();
 
    $response = $di['response'];
 
    // 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());
    }
 
    $response->sendHeaders();
 
    echo $response->getContent();
  }
 
}
#9YonaCMS\Bootstrap->run()
/var/www/html/ciss/cis.edu.vn/public/index.php (22)
<?php
chdir(dirname(__DIR__));
 
define('ROOT', __DIR__);
define('HOST_HASH', substr(md5($_SERVER['HTTP_HOST']), 0, 12));
 
defined('APPLICATION_ENV') || define('APPLICATION_ENV', (getenv('APPLICATION_ENV') ? getenv('APPLICATION_ENV') : 'production'));
 
define('APPLICATION_PATH', __DIR__ . '/../app');
 
if (APPLICATION_ENV === 'development' || APPLICATION_ENV === 'staging') {
  //@TODO: fixed me by update docker to allow config php.ini
  error_reporting(E_ALL & ~E_NOTICE & ~E_STRICT);
 
  ini_set('display_errors', 1);
  ini_set('display_startup_errors', 1);
  ini_set('log_errors', 0);
}
 
require_once APPLICATION_PATH . '/Bootstrap.php';
$bootstrap = new YonaCMS\Bootstrap();
$bootstrap->run();
KeyValue
_url/member/bcis-secondary-teachers.html
KeyValue
REDIRECT_APPLICATION_ENVproduction
REDIRECT_downgrade-1_0
REDIRECT_STATUS200
APPLICATION_ENVproduction
downgrade-1_0
HTTP_USER_AGENTCCBot/2.0 (https://commoncrawl.org/faq/)
HTTP_ACCEPTtext/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
HTTP_ACCEPT_LANGUAGEen-US,en;q=0.5
HTTP_IF_MODIFIED_SINCEFri, 18 Oct 2019 04:17:23 GMT
HTTP_HOSTwww.cis.edu.vn
HTTP_CONNECTIONKeep-Alive
HTTP_ACCEPT_ENCODINGgzip
PATH/sbin:/usr/sbin:/bin:/usr/bin
SERVER_SIGNATURE<address>Apache/2.2.15 (CentOS) Server at www.cis.edu.vn Port 80</address>\n
SERVER_SOFTWAREApache/2.2.15 (CentOS)
SERVER_NAMEwww.cis.edu.vn
SERVER_ADDR172.16.254.4
SERVER_PORT80
REMOTE_ADDR100.26.176.182
DOCUMENT_ROOT/var/www/html/ciss/cis.edu.vn/public
SERVER_ADMINdinhhoaibao@gmail.com
SCRIPT_FILENAME/var/www/html/ciss/cis.edu.vn/public/index.php
REMOTE_PORT55222
REDIRECT_QUERY_STRING_url=/member/bcis-secondary-teachers.html
REDIRECT_URL/member/bcis-secondary-teachers.html
GATEWAY_INTERFACECGI/1.1
SERVER_PROTOCOLHTTP/1.1
REQUEST_METHODGET
QUERY_STRING_url=/member/bcis-secondary-teachers.html
REQUEST_URI/member/bcis-secondary-teachers.html
SCRIPT_NAME/index.php
PHP_SELF/index.php
REQUEST_TIME_FLOAT1576416143.925
REQUEST_TIME1576416143
#Path
0/var/www/html/ciss/cis.edu.vn/public/index.php
1/var/www/html/ciss/cis.edu.vn/app/Bootstrap.php
2/var/www/html/ciss/cis.edu.vn/app/modules/Cms/Config.php
3/var/www/html/ciss/cis.edu.vn/app/config/environment/production.php
4/var/www/html/ciss/cis.edu.vn/app/config/global.php
5/var/www/html/ciss/cis.edu.vn/app/config/modules.php
6/var/www/html/ciss/cis.edu.vn/app/modules/Application/Loader/Modules.php
7/var/www/html/ciss/cis.edu.vn/vendor/autoload.php
8/var/www/html/ciss/cis.edu.vn/vendor/composer/autoload_real.php
9/var/www/html/ciss/cis.edu.vn/vendor/composer/ClassLoader.php
10/var/www/html/ciss/cis.edu.vn/vendor/composer/autoload_static.php
11/var/www/html/ciss/cis.edu.vn/vendor/symfony/polyfill-mbstring/bootstrap.php
12/var/www/html/ciss/cis.edu.vn/vendor/donatj/phpuseragentparser/Source/UserAgentParser.php
13/var/www/html/ciss/cis.edu.vn/app/modules/Application/Mvc/View/Engine/Volt.php
14/var/www/html/ciss/cis.edu.vn/app/modules/Application/Widget/Proxy.php
15/var/www/html/ciss/cis.edu.vn/app/modules/Cms/Model/Configuration.php
16/var/www/html/ciss/cis.edu.vn/app/modules/Application/Acl/DefaultAcl.php
17/var/www/html/ciss/cis.edu.vn/app/config/acl.php
18/var/www/html/ciss/cis.edu.vn/app/modules/Application/Assets/Manager.php
19/var/www/html/ciss/cis.edu.vn/app/modules/Application/Assets/Filter/Less.php
20/var/www/html/ciss/cis.edu.vn/app/modules/Application/Mvc/Helper.php
21/var/www/html/ciss/cis.edu.vn/app/modules/Menu/Helper/Menu.php
22/var/www/html/ciss/cis.edu.vn/app/modules/Application/Mvc/Router/DefaultRouter.php
23/var/www/html/ciss/cis.edu.vn/app/modules/Index/Routes.php
24/var/www/html/ciss/cis.edu.vn/app/modules/Application/Mvc/Helper/CmsCache.php
25/var/www/html/ciss/cis.edu.vn/app/modules/Admin/Routes.php
26/var/www/html/ciss/cis.edu.vn/app/modules/Staff/Routes.php
27/var/www/html/ciss/cis.edu.vn/app/modules/Staff/Model/Type.php
28/var/www/html/ciss/cis.edu.vn/app/modules/Application/Mvc/Model/Model.php
29/var/www/html/ciss/cis.edu.vn/app/modules/Widget/Routes.php
30/var/www/html/ciss/cis.edu.vn/app/modules/Page/Routes.php
31/var/www/html/ciss/cis.edu.vn/app/modules/Page/Model/Page.php
32/var/www/html/ciss/cis.edu.vn/app/modules/Publication/Routes.php
33/var/www/html/ciss/cis.edu.vn/app/modules/Publication/Model/Type.php
34/var/www/html/ciss/cis.edu.vn/app/modules/Slider/Routes.php
35/var/www/html/ciss/cis.edu.vn/app/modules/Seo/Routes.php
36/var/www/html/ciss/cis.edu.vn/app/modules/Menu/Routes.php
37/var/www/html/ciss/cis.edu.vn/app/modules/Menu/Model/Type.php
38/var/www/html/ciss/cis.edu.vn/app/modules/Tree/Routes.php
39/var/www/html/ciss/cis.edu.vn/app/modules/Tree/Init.php
40/var/www/html/ciss/cis.edu.vn/app/modules/Tree/Mvc/Helper.php
41/var/www/html/ciss/cis.edu.vn/app/modules/Sitemap/Routes.php
42/var/www/html/ciss/cis.edu.vn/app/modules/Popup/Routes.php
43/var/www/html/ciss/cis.edu.vn/app/modules/Subscribe/Routes.php
44/var/www/html/ciss/cis.edu.vn/app/modules/Application/Utils/ModuleName.php
45/var/www/html/ciss/cis.edu.vn/app/modules/Staff/Module.php
46/var/www/html/ciss/cis.edu.vn/app/plugins/CheckPoint.php
47/var/www/html/ciss/cis.edu.vn/app/plugins/Localization.php
48/var/www/html/ciss/cis.edu.vn/app/modules/Cms/Model/Translate.php
49/var/www/html/ciss/cis.edu.vn/app/plugins/AdminLocalization.php
50/var/www/html/ciss/cis.edu.vn/data/translations/admin/en.php
51/var/www/html/ciss/cis.edu.vn/app/plugins/Acl.php
52/var/www/html/ciss/cis.edu.vn/app/plugins/MobileDetect.php
53/var/www/html/ciss/cis.edu.vn/vendor/mobiledetect/mobiledetectlib/Mobile_Detect.php
54/var/www/html/ciss/cis.edu.vn/app/modules/Staff/Controller/IndexController.php
55/var/www/html/ciss/cis.edu.vn/app/modules/Application/Mvc/Controller.php
56/var/www/html/ciss/cis.edu.vn/app/modules/Page/Model/Translate/PageTranslate.php
57/var/www/html/ciss/cis.edu.vn/app/modules/Application/Mvc/Model/Translate.php
58/var/www/html/ciss/cis.edu.vn/app/modules/Staff/Model/Translate/TypeTranslate.php
59/var/www/html/ciss/cis.edu.vn/app/modules/Staff/Model/Staff.php
60/var/www/html/ciss/cis.edu.vn/app/modules/Staff/Model/Translate/StaffTranslate.php
Memory
Usage2097152