write("ERROR: cli $cli_action call missing configuration."); http_response_code(400); exit; } // Startup require_once(DIR_SYSTEM . 'startup.php'); // Application Classes if (version_compare(VERSION, '2.2', '>=')) { require_once(DIR_SYSTEM . 'library/cart/currency.php'); require_once(DIR_SYSTEM . 'library/cart/user.php'); require_once(DIR_SYSTEM . 'library/cart/weight.php'); require_once(DIR_SYSTEM . 'library/cart/length.php'); } else { require_once(DIR_SYSTEM . 'library/currency.php'); require_once(DIR_SYSTEM . 'library/user.php'); require_once(DIR_SYSTEM . 'library/weight.php'); require_once(DIR_SYSTEM . 'library/length.php'); } // Registry $registry = new Registry(); // Loader $loader = new Loader($registry); $registry->set('load', $loader); // Config $config = new Config(); $registry->set('config', $config); // Database $db = new DB(DB_DRIVER, DB_HOSTNAME, DB_USERNAME, DB_PASSWORD, DB_DATABASE); $registry->set('db', $db); // Settings $query = $db->query("SELECT * FROM " . DB_PREFIX . "setting WHERE store_id = '0'"); foreach ($query->rows as $setting) { if (!$setting['serialized']) { $config->set($setting['key'], $setting['value']); } else { if (version_compare(VERSION, '2.2', '>=')) $config->set($setting['key'], json_decode($setting['value']), true); else $config->set($setting['key'], unserialize($setting['value'])); } } // Url $url = new Url(HTTP_SERVER, HTTPS_SERVER); $registry->set('url', $url); // Log $log = new Log($config->get('config_error_filename')); $registry->set('log', $log); // Event if (version_compare(VERSION, '2.2', '>=')) { $event = new Event($registry); $registry->set('event', $event); } function error_handler($errno, $errstr, $errfile, $errline) { global $log, $config; switch ($errno) { case E_NOTICE: case E_USER_NOTICE: $error = 'Notice'; break; case E_WARNING: case E_USER_WARNING: $error = 'Warning'; break; case E_ERROR: case E_USER_ERROR: $error = 'Fatal Error'; break; default: $error = 'Unknown'; break; } if ($config->get('config_error_display')) { echo "\n".'PHP ' . $error . ': ' . $errstr . ' in ' . $errfile . ' on line ' . $errline."\n"; } if ($config->get('config_error_log')) { $log->write('PHP ' . $error . ': ' . $errstr . ' in ' . $errfile . ' on line ' . $errline); } return true; } set_error_handler('error_handler'); $request = new Request(); $registry->set('request', $request); $response = new Response(); $response->addHeader('Content-Type: text/html; charset=utf-8'); $cache = new Cache('file'); $registry->set('cache', $cache); $registry->set('response', $response); $session = new Session(); $registry->set('session', $session); $languages = array(); $query = $db->query("SELECT * FROM " . DB_PREFIX . "language"); foreach ($query->rows as $result) { $languages[$result['code']] = $result; } $adminLanguageCode = $config->get('config_admin_language'); $config->set('config_language_id', $languages[$adminLanguageCode]['language_id']); $language = new Language($languages[$adminLanguageCode]['directory']); if(isset($languages[$adminLanguageCode]['filename'])) { $language->load($languages[$adminLanguageCode]['filename']); } else { $language->load($languages[$adminLanguageCode]['directory']); } $registry->set('language', $language); $document = new Document(); $registry->set('document', $document); if (version_compare(VERSION, '2.2', '>=')) { $registry->set('currency', new Cart\Currency($registry)); $registry->set('weight', new Cart\Weight($registry)); $registry->set('length', new Cart\Length($registry)); $registry->set('user', new Cart\User($registry)); } else { $registry->set('currency', new Currency($registry)); $registry->set('weight', new Weight($registry)); $registry->set('length', new Length($registry)); $registry->set('user', new User($registry)); } $controller = new Front($registry); $action = new Action($cli_action); $controller->dispatch($action, new Action('error/not_found')); // Output $response->output();