Server IP : 127.0.0.1 / Your IP : 3.15.203.246 [ Web Server : nginx/1.20.1 System : Linux dropship.kaosunisex.com 3.10.0-1160.95.1.el7.x86_64 #1 SMP Mon Jul 24 13:59:37 UTC 2023 x86_64 User : kaosunisex ( 1000) PHP Version : 7.3.33 Disable Function : NONE Domains : 1 Domains MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /home/kaosunisex/dropship.kaosunisex.com/install/ |
Upload File : |
<?php // // Command line tool for installing opencart // Author: Vineet Naik <vineet.naik@kodeplay.com> <naikvin@gmail.com> // // (Currently tested on linux only) // // Usage: // // cd install // php cli_install.php install --db_hostname localhost \ // --db_username root \ // --db_password pass \ // --db_database opencart \ // --db_driver mysqli \ // --db_port 3306 \ // --username admin \ // --password admin \ // --email youremail@example.com \ // --http_server http://localhost/opencart/ // ini_set('display_errors', 1); error_reporting(E_ALL); // DIR define('DIR_APPLICATION', str_replace('\\', '/', realpath(dirname(__FILE__))) . '/'); define('DIR_SYSTEM', str_replace('\\', '/', realpath(dirname(__FILE__) . '/../')) . '/system/'); define('DIR_OPENCART', str_replace('\\', '/', realpath(DIR_APPLICATION . '../')) . '/'); define('DIR_DATABASE', DIR_SYSTEM . 'database/'); define('DIR_LANGUAGE', DIR_APPLICATION . 'language/'); define('DIR_TEMPLATE', DIR_APPLICATION . 'view/template/'); define('DIR_CONFIG', DIR_SYSTEM . 'config/'); define('DIR_MODIFICATION', DIR_SYSTEM . 'modification/'); // Startup require_once(DIR_SYSTEM . 'startup.php'); // Registry $registry = new Registry(); // Loader $loader = new Loader($registry); $registry->set('load', $loader); function handleError($errno, $errstr, $errfile, $errline, array $errcontext) { // error was suppressed with the @-operator if (0 === error_reporting()) { return false; } throw new ErrorException($errstr, 0, $errno, $errfile, $errline); } set_error_handler('handleError'); function usage() { echo "Usage:\n"; echo "======\n"; echo "\n"; $options = implode(" ", array( '--db_hostname', 'localhost', '--db_username', 'root', '--db_password', 'pass', '--db_database', 'opencart', '--db_driver', 'mysqli', '--db_port', '3306', '--username', 'admin', '--password', 'admin', '--email', 'youremail@example.com', '--http_server', 'http://localhost/opencart/' )); echo 'php cli_install.php install ' . $options . "\n\n"; } function get_options($argv) { $defaults = array( 'db_hostname' => 'localhost', 'db_database' => 'opencart', 'db_prefix' => 'oc_', 'db_driver' => 'mysqli', 'db_port' => '3306', 'username' => 'admin', ); $options = array(); $total = count($argv); for ($i=0; $i < $total; $i=$i+2) { $is_flag = preg_match('/^--(.*)$/', $argv[$i], $match); if (!$is_flag) { throw new Exception($argv[$i] . ' found in command line args instead of a valid option name starting with \'--\''); } $options[$match[1]] = $argv[$i+1]; } return array_merge($defaults, $options); } function valid($options) { $required = array( 'db_hostname', 'db_username', 'db_password', 'db_database', 'db_prefix', 'db_port', 'username', 'password', 'email', 'http_server', ); $missing = array(); foreach ($required as $r) { if (!array_key_exists($r, $options)) { $missing[] = $r; } } if (!preg_match('#/$#', $options['http_server'])) { $options['http_server'] = $options['http_server'] . '/'; } $valid = count($missing) === 0; return array($valid, $missing); } function install($options) { $check = check_requirements(); if ($check[0]) { setup_db($options); write_config_files($options); dir_permissions(); } else { echo 'FAILED! Pre-installation check failed: ' . $check[1] . "\n\n"; exit(1); } } function check_requirements() { $error = null; if (phpversion() < '5.4') { $error = 'Warning: You need to use PHP5.4+ or above for OpenCart to work!'; } if (!ini_get('file_uploads')) { $error = 'Warning: file_uploads needs to be enabled!'; } if (ini_get('session.auto_start')) { $error = 'Warning: OpenCart will not work with session.auto_start enabled!'; } if (!extension_loaded('mysqli')) { $error = 'Warning: MySQLi extension needs to be loaded for OpenCart to work!'; } if (!extension_loaded('gd')) { $error = 'Warning: GD extension needs to be loaded for OpenCart to work!'; } if (!extension_loaded('curl')) { $error = 'Warning: CURL extension needs to be loaded for OpenCart to work!'; } if (!function_exists('openssl_encrypt')) { $error = 'Warning: OpenSSL extension needs to be loaded for OpenCart to work!'; } if (!extension_loaded('zlib')) { $error = 'Warning: ZLIB extension needs to be loaded for OpenCart to work!'; } return array($error === null, $error); } function setup_db($data) { $db = new DB($data['db_driver'], htmlspecialchars_decode($data['db_hostname']), htmlspecialchars_decode($data['db_username']), htmlspecialchars_decode($data['db_password']), htmlspecialchars_decode($data['db_database']), $data['db_port']); $file = DIR_APPLICATION . 'opencart.sql'; if (!file_exists($file)) { exit('Could not load sql file: ' . $file); } $lines = file($file); if ($lines) { $sql = ''; foreach ($lines as $line) { if ($line && (substr($line, 0, 2) != '--') && (substr($line, 0, 1) != '#')) { $sql .= $line; if (preg_match('/;\s*$/', $line)) { $sql = str_replace("DROP TABLE IF EXISTS `oc_", "DROP TABLE IF EXISTS `" . $data['db_prefix'], $sql); $sql = str_replace("CREATE TABLE `oc_", "CREATE TABLE `" . $data['db_prefix'], $sql); $sql = str_replace("INSERT INTO `oc_", "INSERT INTO `" . $data['db_prefix'], $sql); $db->query($sql); $sql = ''; } } } $db->query("SET CHARACTER SET utf8"); $db->query("SET @@session.sql_mode = 'MYSQL40'"); $db->query("DELETE FROM `" . $data['db_prefix'] . "user` WHERE user_id = '1'"); $db->query("INSERT INTO `" . $data['db_prefix'] . "user` SET user_id = '1', user_group_id = '1', username = '" . $db->escape($data['username']) . "', salt = '" . $db->escape($salt = token(9)) . "', password = '" . $db->escape(sha1($salt . sha1($salt . sha1($data['password'])))) . "', firstname = 'John', lastname = 'Doe', email = '" . $db->escape($data['email']) . "', status = '1', date_added = NOW()"); $db->query("DELETE FROM `" . $data['db_prefix'] . "setting` WHERE `key` = 'config_email'"); $db->query("INSERT INTO `" . $data['db_prefix'] . "setting` SET `code` = 'config', `key` = 'config_email', value = '" . $db->escape($data['email']) . "'"); $db->query("DELETE FROM `" . $data['db_prefix'] . "setting` WHERE `key` = 'config_encryption'"); $db->query("INSERT INTO `" . $data['db_prefix'] . "setting` SET `code` = 'config', `key` = 'config_encryption', value = '" . $db->escape(token(1024)) . "'"); $db->query("UPDATE `" . $data['db_prefix'] . "product` SET `viewed` = '0'"); $db->query("INSERT INTO `" . $data['db_prefix'] . "api` SET username = 'Default', `key` = '" . $db->escape(token(256)) . "', status = 1, date_added = NOW(), date_modified = NOW()"); $api_id = $db->getLastId(); $db->query("DELETE FROM `" . $data['db_prefix'] . "setting` WHERE `key` = 'config_api_id'"); $db->query("INSERT INTO `" . $data['db_prefix'] . "setting` SET `code` = 'config', `key` = 'config_api_id', value = '" . (int)$api_id . "'"); } } function write_config_files($options) { $output = '<?php' . "\n"; $output .= '// HTTP' . "\n"; $output .= 'define(\'HTTP_SERVER\', \'' . $options['http_server'] . '\');' . "\n"; $output .= '// HTTPS' . "\n"; $output .= 'define(\'HTTPS_SERVER\', \'' . $options['http_server'] . '\');' . "\n"; $output .= '// DIR' . "\n"; $output .= 'define(\'DIR_APPLICATION\', \'' . addslashes(DIR_OPENCART) . 'catalog/\');' . "\n"; $output .= 'define(\'DIR_SYSTEM\', \'' . addslashes(DIR_OPENCART) . 'system/\');' . "\n"; $output .= 'define(\'DIR_IMAGE\', \'' . addslashes(DIR_OPENCART) . 'image/\');' . "\n"; $output .= 'define(\'DIR_STORAGE\', DIR_SYSTEM . \'storage/\');' . "\n"; $output .= 'define(\'DIR_LANGUAGE\', DIR_APPLICATION . \'language/\');' . "\n"; $output .= 'define(\'DIR_TEMPLATE\', DIR_APPLICATION . \'view/theme/\');' . "\n"; $output .= 'define(\'DIR_CONFIG\', DIR_SYSTEM . \'config/\');' . "\n"; $output .= 'define(\'DIR_CACHE\', DIR_STORAGE . \'cache/\');' . "\n"; $output .= 'define(\'DIR_DOWNLOAD\', DIR_STORAGE . \'download/\');' . "\n"; $output .= 'define(\'DIR_LOGS\', DIR_STORAGE . \'logs/\');' . "\n"; $output .= 'define(\'DIR_MODIFICATION\', DIR_STORAGE . \'modification/\');' . "\n"; $output .= 'define(\'DIR_SESSION\', DIR_STORAGE . \'session/\');' . "\n"; $output .= 'define(\'DIR_UPLOAD\', DIR_STORAGE . \'upload/\');' . "\n\n"; $output .= '// DB' . "\n"; $output .= 'define(\'DB_DRIVER\', \'' . addslashes($options['db_driver']) . '\');' . "\n"; $output .= 'define(\'DB_HOSTNAME\', \'' . addslashes($options['db_hostname']) . '\');' . "\n"; $output .= 'define(\'DB_USERNAME\', \'' . addslashes($options['db_username']) . '\');' . "\n"; $output .= 'define(\'DB_PASSWORD\', \'' . addslashes($options['db_password']) . '\');' . "\n"; $output .= 'define(\'DB_DATABASE\', \'' . addslashes($options['db_database']) . '\');' . "\n"; $output .= 'define(\'DB_PREFIX\', \'' . addslashes($options['db_prefix']) . '\');' . "\n"; $output .= 'define(\'DB_PORT\', \'' . addslashes($options['db_port']) . '\');' . "\n"; $file = fopen(DIR_OPENCART . 'config.php', 'w'); fwrite($file, $output); fclose($file); $output = '<?php' . "\n"; $output .= '// HTTP' . "\n"; $output .= 'define(\'HTTP_SERVER\', \'' . $options['http_server'] . 'admin/\');' . "\n"; $output .= 'define(\'HTTP_CATALOG\', \'' . $options['http_server'] . '\');' . "\n"; $output .= '// HTTPS' . "\n"; $output .= 'define(\'HTTPS_SERVER\', \'' . $options['http_server'] . 'admin/\');' . "\n"; $output .= 'define(\'HTTPS_CATALOG\', \'' . $options['http_server'] . '\');' . "\n"; $output .= '// DIR' . "\n"; $output .= 'define(\'DIR_APPLICATION\', \'' . addslashes(DIR_OPENCART) . 'admin/\');' . "\n"; $output .= 'define(\'DIR_SYSTEM\', \'' . addslashes(DIR_OPENCART) . 'system/\');' . "\n"; $output .= 'define(\'DIR_IMAGE\', \'' . addslashes(DIR_OPENCART) . 'image/\');' . "\n"; $output .= 'define(\'DIR_STORAGE\', DIR_SYSTEM . \'storage/\');' . "\n"; $output .= 'define(\'DIR_CATALOG\', \'' . addslashes(DIR_OPENCART) . 'catalog/\');' . "\n"; $output .= 'define(\'DIR_LANGUAGE\', DIR_APPLICATION . \'language/\');' . "\n"; $output .= 'define(\'DIR_TEMPLATE\', DIR_APPLICATION . \'view/template/\');' . "\n"; $output .= 'define(\'DIR_CONFIG\', DIR_SYSTEM . \'config/\');' . "\n"; $output .= 'define(\'DIR_CACHE\', DIR_STORAGE . \'cache/\');' . "\n"; $output .= 'define(\'DIR_DOWNLOAD\', DIR_STORAGE . \'download/\');' . "\n"; $output .= 'define(\'DIR_LOGS\', DIR_STORAGE . \'logs/\');' . "\n"; $output .= 'define(\'DIR_MODIFICATION\', DIR_STORAGE . \'modification/\');' . "\n"; $output .= 'define(\'DIR_SESSION\', DIR_STORAGE . \'session/\');' . "\n"; $output .= 'define(\'DIR_UPLOAD\', DIR_STORAGE . \'upload/\');' . "\n\n"; $output .= '// DB' . "\n"; $output .= 'define(\'DB_DRIVER\', \'' . addslashes($options['db_driver']) . '\');' . "\n"; $output .= 'define(\'DB_HOSTNAME\', \'' . addslashes($options['db_hostname']) . '\');' . "\n"; $output .= 'define(\'DB_USERNAME\', \'' . addslashes($options['db_username']) . '\');' . "\n"; $output .= 'define(\'DB_PASSWORD\', \'' . addslashes($options['db_password']) . '\');' . "\n"; $output .= 'define(\'DB_DATABASE\', \'' . addslashes($options['db_database']) . '\');' . "\n"; $output .= 'define(\'DB_PREFIX\', \'' . addslashes($options['db_prefix']) . '\');' . "\n"; $output .= 'define(\'DB_PORT\', \'' . addslashes($options['db_port']) . '\');' . "\n"; $output .= '// OpenCart API' . "\n"; $output .= 'define(\'OPENCART_SERVER\', \'https://www.opencart.com/\');' . "\n"; $file = fopen(DIR_OPENCART . 'admin/config.php', 'w'); fwrite($file, $output); fclose($file); } function dir_permissions() { $dirs = array( DIR_OPENCART . 'image/', DIR_OPENCART . 'system/storage/download/', DIR_OPENCART . 'system/storage/upload/', DIR_OPENCART . 'system/storage/cache/', DIR_OPENCART . 'system/storage/logs/', DIR_OPENCART . 'system/storage/modification/', ); exec('chmod o+w -R ' . implode(' ', $dirs)); } $argv = $_SERVER['argv']; $script = array_shift($argv); $subcommand = array_shift($argv); switch ($subcommand) { case "install": try { $options = get_options($argv); define('HTTP_OPENCART', $options['http_server']); $valid = valid($options); if (!$valid[0]) { echo "FAILED! Following inputs were missing or invalid: "; echo implode(', ', $valid[1]) . "\n\n"; exit(1); } install($options); echo "SUCCESS! Opencart successfully installed on your server\n"; echo "Store link: " . $options['http_server'] . "\n"; echo "Admin link: " . $options['http_server'] . "admin/\n\n"; } catch (ErrorException $e) { echo 'FAILED!: ' . $e->getMessage() . "\n"; exit(1); } break; case "usage": default: echo usage(); }