uawdijnntqw1x1x1
IP : 18.189.188.136
Hostname : ns1.eurodns.top
Kernel : Linux ns1.eurodns.top 4.18.0-553.5.1.lve.1.el7h.x86_64 #1 SMP Fri Jun 14 14:24:52 UTC 2024 x86_64
Disable Function : mail,sendmail,exec,passthru,shell_exec,system,popen,curl_multi_exec,parse_ini_file,show_source,eval,open_base,symlink
OS : Linux
PATH:
/
home
/
sudancam
/
.
/
www
/
..
/
.
/
.
/
.trash
/
install.1
/
controller
/
upgrade
/
upgrade_1.php
/
/
<?php namespace Opencart\Install\Controller\Upgrade; class Upgrade1 extends \Opencart\System\Engine\Controller { public function index(): void { $this->load->language('upgrade/upgrade'); $json = []; if (isset($this->request->get['version'])) { $version = $this->request->get['version']; } else { $version = ''; } if (isset($this->request->get['admin'])) { $admin = basename($this->request->get['admin']); } else { $admin = 'admin'; } // Config and file structure changes $file = DIR_OPENCART . 'config.php'; if (!is_file($file)) { $json['error'] = sprintf($this->language->get('error_file'), $file); } if (!is_writable($file)) { $json['error'] = sprintf($this->language->get('error_writable'), $file); } if (!$json) { $capture = [ 'APPLICATION', 'HOST_NAME', 'HTTP_SERVER', 'HTTPS_SERVER', 'HTTP_CATALOG', 'HTTPS_CATALOG', 'DIR_OPENCART', 'DIR_APPLICATION', 'DIR_EXTENSION', 'DIR_IMAGE', 'DIR_SYSTEM', 'DIR_CATALOG', 'DIR_STORAGE', 'DIR_LANGUAGE', 'DIR_TEMPLATE', 'DIR_CONFIG', 'DIR_CACHE', 'DIR_DOWNLOAD', 'DIR_LOGS', 'DIR_SESSION', 'DIR_UPLOAD', 'DB_DRIVER', 'DB_HOSTNAME', 'DB_USERNAME', 'DB_PASSWORD', 'DB_DATABASE', 'DB_PORT', 'DB_PREFIX', 'OPENCART_SERVER' ]; $config = []; // Catalog $lines = file($file); // Capture values foreach ($lines as $number => $line) { if (preg_match('/define\(\'(.*)\',\s+\'(.*)\'\)/', $line, $match, PREG_OFFSET_CAPTURE)) { $config[$match[1][0]] = $match[2][0]; } } if (!isset($config['HTTP_SERVER'])) { $json['error'] = $this->language->get('error_server'); } if (!defined('DB_DRIVER')) { $json['error'] = $this->language->get('error_db_driver'); } if (!defined('DB_HOSTNAME')) { $json['error'] = $this->language->get('error_db_hostname'); } if (!defined('DB_USERNAME')) { $json['error'] = $this->language->get('error_db_username'); } if (!defined('DB_PASSWORD')) { $json['error'] = $this->language->get('error_db_password'); } if (!defined('DB_DATABASE')) { $json['error'] = $this->language->get('error_db_database'); } if (!defined('DB_PREFIX')) { $json['error'] = $this->language->get('error_db_prefix'); } } if (!$json) { // Catalog config.php $output = '<?php' . "\n"; $output .= '// APPLICATION' . "\n"; $output .= 'define(\'APPLICATION\', \'Catalog\');' . "\n\n"; $output .= '// HTTP' . "\n"; if (!empty($config['HOST_NAME'])) { $output .= 'define(\'HOST_NAME\', getenv(\'HOST_NAME\', true));' . "\n"; $output .= 'define(\'HTTP_SERVER\', HOST_NAME . \'/\');' . "\n\n"; } else { if (!empty($config['HTTPS_SERVER'])) { $output .= 'define(\'HTTP_SERVER\', \'' . $config['HTTPS_SERVER'] . '\');' . "\n\n"; } else { $output .= 'define(\'HTTP_SERVER\', \'' . $config['HTTP_SERVER'] . '\');' . "\n\n"; } } $output .= '// DIR' . "\n"; $output .= 'define(\'DIR_OPENCART\', \'' . DIR_OPENCART . '\');' . "\n"; $output .= 'define(\'DIR_APPLICATION\', DIR_OPENCART . \'catalog/\');' . "\n"; $output .= 'define(\'DIR_EXTENSION\', DIR_OPENCART . \'extension/\');' . "\n"; $output .= 'define(\'DIR_IMAGE\', DIR_OPENCART . \'image/\');' . "\n"; $output .= 'define(\'DIR_SYSTEM\', DIR_OPENCART . \'system/\');' . "\n"; if (isset($config['DIR_STORAGE'])) { $output .= 'define(\'DIR_STORAGE\', \'' . $config['DIR_STORAGE'] . '\');' . "\n"; } else { $output .= 'define(\'DIR_STORAGE\', DIR_SYSTEM . \'storage/\');' . "\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_SESSION\', DIR_STORAGE . \'session/\');' . "\n"; $output .= 'define(\'DIR_UPLOAD\', DIR_STORAGE . \'upload/\');' . "\n\n"; $output .= '// DB' . "\n"; $output .= 'define(\'DB_DRIVER\', \'' . DB_DRIVER . '\');' . "\n"; $output .= 'define(\'DB_HOSTNAME\', \'' .DB_HOSTNAME . '\');' . "\n"; $output .= 'define(\'DB_USERNAME\', \'' . DB_USERNAME . '\');' . "\n"; $output .= 'define(\'DB_PASSWORD\', \'' . DB_PASSWORD . '\');' . "\n"; $output .= 'define(\'DB_DATABASE\', \'' . DB_DATABASE . '\');' . "\n"; if (defined('DB_PORT')) { $output .= 'define(\'DB_PORT\', \'' . DB_PORT . '\');' . "\n"; } else { $output .= 'define(\'DB_PORT\', \'3306\');' . "\n"; } $output .= 'define(\'DB_PREFIX\', \'' . DB_PREFIX . '\');' . "\n\n"; // Save file file_put_contents($file, $output); } //************************************* // Admin $file = DIR_OPENCART . $admin . '/config.php'; if (!is_file($file)) { $json['error'] = sprintf($this->language->get('error_file'), $file); } if (!is_writable($file)) { $json['error'] = sprintf($this->language->get('error_writable'), $file); } if (!$json) { $config = []; $lines = file($file); // Capture values foreach ($lines as $number => $line) { if (preg_match('/define\(\'(.*)\',\s+\'(.*)\'\)/', $line, $match, PREG_OFFSET_CAPTURE)) { $config[$match[1][0]] = $match[2][0]; } } if (!isset($config['HTTP_SERVER'])) { $json['error'] = $this->language->get('error_server'); } if (!defined('DB_DRIVER')) { $json['error'] = $this->language->get('error_db_driver'); } if (!defined('DB_HOSTNAME')) { $json['error'] = $this->language->get('error_db_hostname'); } if (!defined('DB_USERNAME')) { $json['error'] = $this->language->get('error_db_username'); } if (!defined('DB_PASSWORD')) { $json['error'] = $this->language->get('error_db_password'); } if (!defined('DB_DATABASE')) { $json['error'] = $this->language->get('error_db_database'); } if (!defined('DB_PREFIX')) { $json['error'] = $this->language->get('error_db_prefix'); } } if (!$json) { // Admin config.php $output = '<?php' . "\n"; $output .= '// APPLICATION' . "\n"; $output .= 'define(\'APPLICATION\', \'Admin\');' . "\n\n"; $output .= '// HTTP' . "\n"; if (!empty($config['HTTPS_SERVER'])) { $output .= 'define(\'HTTP_SERVER\', \'' . $config['HTTPS_SERVER'] . '\');' . "\n"; } else { $output .= 'define(\'HTTP_SERVER\', \'' . $config['HTTP_SERVER'] . '\');' . "\n"; } if (!empty($config['HTTPS_CATALOG'])) { $output .= 'define(\'HTTP_CATALOG\', \'' . $config['HTTPS_CATALOG'] . '\');' . "\n\n"; } else { $output .= 'define(\'HTTP_CATALOG\', \'' . $config['HTTP_CATALOG'] . '\');' . "\n\n"; } $output .= '// DIR' . "\n"; $output .= 'define(\'DIR_OPENCART\', \'' . DIR_OPENCART . '\');' . "\n"; $output .= 'define(\'DIR_APPLICATION\', DIR_OPENCART . \'' . $admin . '/\');' . "\n"; $output .= 'define(\'DIR_EXTENSION\', DIR_OPENCART . \'extension/\');' . "\n"; $output .= 'define(\'DIR_IMAGE\', DIR_OPENCART . \'image/\');' . "\n"; $output .= 'define(\'DIR_SYSTEM\', DIR_OPENCART . \'system/\');' . "\n"; $output .= 'define(\'DIR_CATALOG\', DIR_OPENCART . \'catalog/\');' . "\n"; if (isset($config['DIR_STORAGE'])) { $output .= 'define(\'DIR_STORAGE\', ' . $config['DIR_STORAGE'] . ');' . "\n"; } else { $output .= 'define(\'DIR_STORAGE\', DIR_SYSTEM . \'storage/\');' . "\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_SESSION\', DIR_STORAGE . \'session/\');' . "\n"; $output .= 'define(\'DIR_UPLOAD\', DIR_STORAGE . \'upload/\');' . "\n\n"; $output .= '// DB' . "\n"; $output .= 'define(\'DB_DRIVER\', \'' . DB_DRIVER . '\');' . "\n"; $output .= 'define(\'DB_HOSTNAME\', \'' .DB_HOSTNAME . '\');' . "\n"; $output .= 'define(\'DB_USERNAME\', \'' . DB_USERNAME . '\');' . "\n"; $output .= 'define(\'DB_PASSWORD\', \'' . DB_PASSWORD . '\');' . "\n"; $output .= 'define(\'DB_DATABASE\', \'' . DB_DATABASE . '\');' . "\n"; if (defined('DB_PORT')) { $output .= 'define(\'DB_PORT\', \'' . DB_PORT . '\');' . "\n"; } else { $output .= 'define(\'DB_PORT\', \'3306\');' . "\n"; } $output .= 'define(\'DB_PREFIX\', \'' . DB_PREFIX . '\');' . "\n\n"; $output .= '// OpenCart API' . "\n"; $output .= 'define(\'OPENCART_SERVER\', \'https://www.opencart.com/\');' . "\n"; // Save file file_put_contents($file, $output); } // If create any missing storage directories $directories = [ 'backup', 'cache', 'download', 'logs', 'marketplace', 'session', 'upload' ]; foreach ($directories as $directory) { if (!is_dir(DIR_STORAGE . $directory)) { mkdir(DIR_STORAGE . $directory, '0644'); $handle = fopen(DIR_STORAGE . $directory . '/index.html', 'w'); fclose($handle); } } // Merge system/upload to system/storage/upload if (is_dir(DIR_SYSTEM . 'upload')) { $this->recursive_move(DIR_SYSTEM . 'upload', DIR_STORAGE . 'upload'); } if (is_dir(DIR_SYSTEM . 'download')) { $this->recursive_move(DIR_SYSTEM . 'download', DIR_STORAGE . 'download'); } // Cleanup files in old directories $directories = [ DIR_SYSTEM . 'logs/', DIR_SYSTEM . 'cache/', ]; $files = []; foreach ($directories as $dir) { if (is_dir($dir)) { // Make path into an array $path = [$dir . '*']; // While the path array is still populated keep looping through while (count($path) != 0) { $next = array_shift($path); foreach (glob($next) as $file) { // If directory add to path array if (is_dir($file)) { $path[] = $file . '/*'; } // Add the file to the files to be deleted array $files[] = $file; } // Reverse sort the file array rsort($files); // Clear all modification files foreach ($files as $file) { if ($file != $dir . 'index.html') { // If file just delete if (is_file($file)) { @unlink($file); // If directory use the remove directory function } elseif (is_dir($file)) { @rmdir($file); } } } } } } if (!$json) { $json['text'] = sprintf($this->language->get('text_progress'), 1, 1, 8); $url = ''; if (isset($this->request->get['version'])) { $url .= '&version=' . $this->request->get['version']; } if (isset($this->request->get['admin'])) { $url .= '&admin=' . $this->request->get['admin']; } $json['next'] = $this->url->link('upgrade/upgrade_2', $url, true); } $this->response->addHeader('Content-Type: application/json'); $this->response->setOutput(json_encode($json)); } private function recursive_move($src, $dest) { // If source is not a directory stop processing if (!is_dir($src)) return false; // If the destination directory does not exist create it if (!is_dir($dest)) { if (!@mkdir($dest)) { // If the destination directory could not be created stop processing return false; } } // Open the source directory to read in files $i = new \DirectoryIterator($src); foreach ($i as $f) { if ($f->isFile() && !file_exists("$dest/" . $f->getFilename())) { @rename($f->getRealPath(), "$dest/" . $f->getFilename()); } elseif (!$f->isDot() && $f->isDir()) { $this->recursive_move($f->getRealPath(), "$dest/$f"); @unlink($f->getRealPath()); } } // Remove source folder after move @unlink($src); } }
/home/sudancam/./www/../././.trash/install.1/controller/upgrade/upgrade_1.php