/install/cli_install.php
PHP | 362 lines | 278 code | 63 blank | 21 comment | 24 complexity | 70c48573c1624d6e573e1671855ca26c MD5 | raw 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.0') {
- $error = 'Warning: You need to use PHP5 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('mcrypt_encrypt')) {
- $error = 'Warning: mCrypt 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'], $data['db_hostname'], $data['db_username'], $data['db_password'], $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_url'");
- $db->query("INSERT INTO `" . $data['db_prefix'] . "setting` SET `code` = 'config', `key` = 'config_url', value = '" . $db->escape(HTTP_OPENCART) . "'");
- $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 name = '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 .= 'define(\'HTTP_ADMIN\', \'' . $options['http_server'] . 'admin/\');' . "\n\n";
- $output .= '// HTTPS' . "\n";
- $output .= 'define(\'HTTPS_SERVER\', \'' . $options['http_server'] . '\');' . "\n";
- $output .= '// DIR' . "\n";
- $output .= 'define(\'DIR_APPLICATION\', \'' . DIR_OPENCART . 'catalog/\');' . "\n";
- $output .= 'define(\'DIR_SYSTEM\', \'' . DIR_OPENCART . 'system/\');' . "\n";
- $output .= 'define(\'DIR_DATABASE\', \'' . DIR_OPENCART . 'system/database/\');' . "\n";
- $output .= 'define(\'DIR_LANGUAGE\', \'' . DIR_OPENCART . 'catalog/language/\');' . "\n";
- $output .= 'define(\'DIR_TEMPLATE\', \'' . DIR_OPENCART . 'catalog/view/theme/\');' . "\n";
- $output .= 'define(\'DIR_CONFIG\', \'' . DIR_OPENCART . 'system/config/\');' . "\n";
- $output .= 'define(\'DIR_IMAGE\', \'' . DIR_OPENCART . 'image/\');' . "\n";
- $output .= 'define(\'DIR_CACHE\', \'' . DIR_OPENCART . 'system/storage/cache/\');' . "\n";
- $output .= 'define(\'DIR_DOWNLOAD\', \'' . DIR_OPENCART . 'system/storage/download/\');' . "\n";
- $output .= 'define(\'DIR_UPLOAD\', \'' . DIR_OPENCART . 'system/storage/upload/\');' . "\n";
- $output .= 'define(\'DIR_MODIFICATION\', \'' . DIR_OPENCART . 'system/storage/modification/\');' . "\n";
- $output .= 'define(\'DIR_LOGS\', \'' . DIR_OPENCART . 'system/storage/logs/\');' . "\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 .= '?>';
- $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\', \'' . DIR_OPENCART . 'admin/\');' . "\n";
- $output .= 'define(\'DIR_SYSTEM\', \'' . DIR_OPENCART . 'system/\');' . "\n";
- $output .= 'define(\'DIR_DATABASE\', \'' . DIR_OPENCART . 'system/database/\');' . "\n";
- $output .= 'define(\'DIR_LANGUAGE\', \'' . DIR_OPENCART . 'admin/language/\');' . "\n";
- $output .= 'define(\'DIR_TEMPLATE\', \'' . DIR_OPENCART . 'admin/view/template/\');' . "\n";
- $output .= 'define(\'DIR_CONFIG\', \'' . DIR_OPENCART . 'system/config/\');' . "\n";
- $output .= 'define(\'DIR_IMAGE\', \'' . DIR_OPENCART . 'image/\');' . "\n";
- $output .= 'define(\'DIR_CACHE\', \'' . DIR_OPENCART . 'system/storage/cache/\');' . "\n";
- $output .= 'define(\'DIR_DOWNLOAD\', \'' . DIR_OPENCART . 'system/storage/download/\');' . "\n";
- $output .= 'define(\'DIR_UPLOAD\', \'' . DIR_OPENCART . 'system/storage/upload/\');' . "\n";
- $output .= 'define(\'DIR_LOGS\', \'' . DIR_OPENCART . 'system/storage/logs/\');' . "\n";
- $output .= 'define(\'DIR_MODIFICATION\', \'' . DIR_OPENCART . 'system/storage/modification/\');' . "\n";
- $output .= 'define(\'DIR_CATALOG\', \'' . DIR_OPENCART . 'catalog/\');' . "\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 .= '?>';
- $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();
- }