403Webshell
Server IP : 192.64.118.117  /  Your IP : 3.148.113.167
Web Server : LiteSpeed
System : Linux premium56.web-hosting.com 4.18.0-513.24.1.lve.1.el8.x86_64 #1 SMP Thu May 9 15:10:09 UTC 2024 x86_64
User : thecgapy ( 1160)
PHP Version : 7.4.33
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /home/thecgapy/mobilecreationz.com/wp-content/plugins/duplicator/classes/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /home/thecgapy/mobilecreationz.com/wp-content/plugins/duplicator/classes/package.database.php
<?php
if ( ! defined( 'DUPLICATOR_VERSION' ) ) exit; // Exit if accessed directly

class DUP_Database {
	
	//PUBLIC
	public $Type = 'MySQL';
	public $Size;
	public $File;
	public $Path;
	public $FilterTables;
	public $FilterOn;
	public $Name;
	public $Compatible;
	
	//PROTECTED
	protected $Package;
	
	//PRIVATE
	private $dbStorePath;
	private $EOFMarker;
	private $networkFlush;

	//CONSTRUCTOR
	function __construct($package) {
		 $this->Package = $package;
		 $this->EOFMarker = "";
		 $package_zip_flush  = DUP_Settings::Get('package_zip_flush');
		 $this->networkFlush = empty($package_zip_flush) ? false : $package_zip_flush;
	}
	
	public function Build($package) {
		try {
			
			$this->Package = $package;
			
			$time_start = DUP_Util::GetMicrotime();
			$this->Package->SetStatus(DUP_PackageStatus::DBSTART);
			$this->dbStorePath  = "{$this->Package->StorePath}/{$this->File}";
			
			$package_mysqldump	= DUP_Settings::Get('package_mysqldump');
			$package_phpdump_qrylimit = DUP_Settings::Get('package_phpdump_qrylimit');
			
			$mysqlDumpPath = self::GetMySqlDumpPath();
			$mode = ($mysqlDumpPath && $package_mysqldump) ? 'MYSQLDUMP' : 'PHP';
			$reserved_db_filepath = DUPLICATOR_WPROOTPATH . 'database.sql';

			
			$log  = "\n********************************************************************************\n";
			$log .= "DATABASE:\n";
			$log .= "********************************************************************************\n";
			$log .= "BUILD MODE:   {$mode}";
			$log .= ($mode == 'PHP') ? "(query limit - {$package_phpdump_qrylimit})\n" : "\n";
			$log .= "MYSQLTIMEOUT: " . DUPLICATOR_DB_MAX_TIME . "\n";
			$log .= "MYSQLDUMP:    ";
			$log .= ($mysqlDumpPath) ? "Is Supported" : "Not Supported";
			DUP_Log::Info($log);
			$log = null;
			
			//Reserved file found
			if (file_exists($reserved_db_filepath)) {
				DUP_Log::Error("Reserverd SQL file detected", 
						"The file database.sql was found at [{$reserved_db_filepath}].\n"
						. "\tPlease remove/rename this file to continue with the package creation.");
			}
			
			switch ($mode) {
				case 'MYSQLDUMP': $this->mysqlDump($mysqlDumpPath); 	break;
				case 'PHP' :	  $this->phpDump();	break;	
			}
			
			DUP_Log::Info("SQL CREATED: {$this->File}");
			$time_end = DUP_Util::GetMicrotime();
			$time_sum = DUP_Util::ElapsedTime($time_end, $time_start);
			
			//File below 10k will be incomplete
			$sql_file_size = filesize($this->dbStorePath);
			DUP_Log::Info("SQL FILE SIZE: " . DUP_Util::ByteSize($sql_file_size) . " ({$sql_file_size})");
			if ($sql_file_size < 10000) {
				DUP_Log::Error("SQL file size too low.", "File does not look complete.  Check permission on file and parent directory at [{$this->dbStorePath}]");
			}
			
			DUP_Log::Info("SQL FILE TIME: " . date("Y-m-d H:i:s"));
			DUP_Log::Info("SQL RUNTIME: {$time_sum}");
			
			$this->Size = @filesize($this->dbStorePath);
			$this->Package->SetStatus(DUP_PackageStatus::DBDONE);
			
		} catch (Exception $e) {
			DUP_Log::Error("Runtime error in DUP_Database::Build","Exception: {$e}");
		}
	}
	
	/**
	 *  Get the database stats
	 */
	public function Stats() {
		
		global $wpdb;
		$filterTables  = isset($this->FilterTables) ? explode(',', $this->FilterTables) : null;
		$tblCount = 0;
	
		$tables	 = $wpdb->get_results("SHOW TABLE STATUS", ARRAY_A);
		$info = array();
		$info['Status']['Success'] = is_null($tables) ? false : true;
		//DB_Case for the database name is never checked on
		$info['Status']['DB_Case']    = 'Good';
		$info['Status']['DB_Rows']    = 'Good';
		$info['Status']['DB_Size']    = 'Good';
		$info['Status']['TBL_Case']   = 'Good';
		$info['Status']['TBL_Rows']   = 'Good';
		$info['Status']['TBL_Size']   = 'Good';
		
		$info['Size']   = 0;
		$info['Rows']   = 0;
		$info['TableCount'] = 0;
		$info['TableList']	= array();
		$tblCaseFound = 0;
		$tblRowsFound = 0;
		$tblSizeFound = 0;
		
		//Grab Table Stats
		foreach ($tables as $table) 
		{
			$name = $table["Name"];
			if ($this->FilterOn  && is_array($filterTables)) 
			{
				if (in_array($name, $filterTables)) {
					continue;
				}
			}
			
			$size = ($table["Data_length"] +  $table["Index_length"]);
			$rows = empty($table["Rows"]) ? '0' : $table["Rows"];
			
			$info['Size'] += $size;
			$info['Rows'] += ($table["Rows"]);
			$info['TableList'][$name]['Case']   = preg_match('/[A-Z]/', $name) ? 1 : 0;
			$info['TableList'][$name]['Rows']	= number_format($rows);
			$info['TableList'][$name]['Size']	= DUP_Util::ByteSize($size);
			$tblCount++;
			
			//Table Uppercase
			if ($info['TableList'][$name]['Case']) {
				if (! $tblCaseFound) {
					$tblCaseFound = 1;
				}
			}
			
			//Table Row Count
			if ($rows > DUPLICATOR_SCAN_DB_TBL_ROWS) {
				if (! $tblRowsFound) {
					$tblRowsFound = 1;
				}
			}
			
			//Table Size
			if ($size  > DUPLICATOR_SCAN_DB_TBL_SIZE) {
				if (! $tblSizeFound) {
					$tblSizeFound = 1;
				}
			}
		}
		
		$info['Status']['DB_Case']   = preg_match('/[A-Z]/', $wpdb->dbname) ? 'Warn' : 'Good';
		$info['Status']['DB_Rows']   = ($info['Rows'] > DUPLICATOR_SCAN_DB_ALL_ROWS) ? 'Warn' : 'Good';
		$info['Status']['DB_Size']   = ($info['Size'] > DUPLICATOR_SCAN_DB_ALL_SIZE) ? 'Warn' : 'Good';
		
		
		$info['Status']['TBL_Case']   = ($tblCaseFound) ? 'Warn' : 'Good';
		$info['Status']['TBL_Rows']   = ($tblRowsFound) ? 'Warn' : 'Good';
		$info['Status']['TBL_Size']   = ($tblSizeFound) ? 'Warn' : 'Good';
		
		$info['Size']		= DUP_Util::ByteSize($info['Size'])	or "unknown";
		$info['Rows']		= number_format($info['Rows'])		or "unknown";
		$info['TableList']	= $info['TableList']				or "unknown";
		$info['TableCount'] = $tblCount;
	
		return $info;
	}	

	/**
	 * Returns the mysqldump path if the server is enabled to execute it
	 * @return boolean|string
	 */	
	public static function GetMySqlDumpPath() {
		
		//Is shell_exec possible
		if (! DUP_Util::IsShellExecAvailable()) {
			return false;
		}

		$custom_mysqldump_path	= DUP_Settings::Get('package_mysqldump_path');
		$custom_mysqldump_path = (strlen($custom_mysqldump_path)) ? $custom_mysqldump_path : '';
		
		//Common Windows Paths
		if (DUP_Util::IsOSWindows()) {
			$paths = array(
				$custom_mysqldump_path,
				'C:/xampp/mysql/bin/mysqldump.exe',
				'C:/Program Files/xampp/mysql/bin/mysqldump',
				'C:/Program Files/MySQL/MySQL Server 6.0/bin/mysqldump',
				'C:/Program Files/MySQL/MySQL Server 5.5/bin/mysqldump',
				'C:/Program Files/MySQL/MySQL Server 5.4/bin/mysqldump',
				'C:/Program Files/MySQL/MySQL Server 5.1/bin/mysqldump',
				'C:/Program Files/MySQL/MySQL Server 5.0/bin/mysqldump',
			);	
			
		//Common Linux Paths			
		} else {
			$path1 = '';
			$path2 = '';
			$mysqldump = `which mysqldump`;
			if (@is_executable($mysqldump)) 
				$path1 = (!empty($mysqldump)) ? $mysqldump : '';
			
			$mysqldump = dirname(`which mysql`) . "/mysqldump";
			if (@is_executable($mysqldump)) 
				$path2 = (!empty($mysqldump)) ? $mysqldump : '';
			
			$paths = array(
				$custom_mysqldump_path,
				$path1,
				$path2,
				'/usr/local/bin/mysqldump',
				'/usr/local/mysql/bin/mysqldump',
				'/usr/mysql/bin/mysqldump',
				'/usr/bin/mysqldump',
				'/opt/local/lib/mysql6/bin/mysqldump',
				'/opt/local/lib/mysql5/bin/mysqldump',
				'/opt/local/lib/mysql4/bin/mysqldump',
			);
		}

		// Find the one which works
		foreach ( $paths as $path ) {
		    if ( @is_executable($path))
	 	    	return $path;
		}
		
		return false;
	}

	
	private function mysqlDump($exePath) {
		
		global $wpdb;
		
		$host = explode(':', DB_HOST);
		$host = reset($host);
		$port = strpos(DB_HOST, ':') ? end(explode( ':', DB_HOST ) ) : '';
		$name = DB_NAME;
		$mysqlcompat_on  = isset($this->Compatible) && strlen($this->Compatible);
		
		//Build command
		$cmd = escapeshellarg($exePath);
		$cmd .= ' --no-create-db';
		$cmd .= ' --single-transaction';
		$cmd .= ' --hex-blob';
		$cmd .= ' --skip-add-drop-table';
		
		//Compatibility mode
		if ($mysqlcompat_on) {
			DUP_Log::Info("COMPATIBLE: [{$this->Compatible}]");	
			$cmd .= " --compatible={$this->Compatible}";	
		}
		
		//Filter tables
		$tables			= $wpdb->get_col('SHOW TABLES');
		$filterTables	= isset($this->FilterTables) ? explode(',', $this->FilterTables) : null;
		$tblAllCount	= count($tables);
		$tblFilterOn	= ($this->FilterOn) ? 'ON' : 'OFF';

		if (is_array($filterTables) && $this->FilterOn) {
			foreach ($tables as $key => $val) {
				if (in_array($tables[$key], $filterTables)) {
					$cmd .= " --ignore-table={$name}.{$tables[$key]} ";
					unset($tables[$key]);
				}
			}
		}
		
		$cmd .= ' -u ' . escapeshellarg(DB_USER);
		$cmd .= (DB_PASSWORD) ? 
				' -p'  . escapeshellarg(DB_PASSWORD) : '';
		$cmd .= ' -h ' . escapeshellarg($host);
		$cmd .= ( ! empty($port) && is_numeric($port) ) ?
				' -P ' . $port : '';
		$cmd .= ' -r ' . escapeshellarg($this->dbStorePath);
		$cmd .= ' ' . escapeshellarg(DB_NAME);
		$cmd .= ' 2>&1';		

		$output = shell_exec($cmd);

		// Password bug > 5.6 (@see http://bugs.mysql.com/bug.php?id=66546)
		if ( trim( $output ) === 'Warning: Using a password on the command line interface can be insecure.' ) {
			$output = '';
		}
		$output = (strlen($output)) ? $output : "Ran from {$exePath}";
		
		$tblCreateCount = count($tables);
		$tblFilterCount = $tblAllCount - $tblCreateCount;
		
		//DEBUG
		//DUP_Log::Info("COMMAND: {$cmd}");
		DUP_Log::Info("FILTERED: [{$this->FilterTables}]");	
		DUP_Log::Info("RESPONSE: {$output}");
		DUP_Log::Info("TABLES: total:{$tblAllCount} | filtered:{$tblFilterCount} | create:{$tblCreateCount}");
	
		$sql_footer  = "\n\n/* Duplicator WordPress Timestamp: " . date("Y-m-d H:i:s") . "*/\n";
		$sql_footer .= "/* " . DUPLICATOR_DB_EOF_MARKER . " */\n";
		file_put_contents($this->dbStorePath, $sql_footer, FILE_APPEND);
	
		return ($output) ?  false : true;
	}


	private function phpDump() {

		global $wpdb;

		$wpdb->query("SET session wait_timeout = " . DUPLICATOR_DB_MAX_TIME);
		$handle		= fopen($this->dbStorePath, 'w+');
		$tables		= $wpdb->get_col('SHOW TABLES');

		$filterTables   = isset($this->FilterTables) ? explode(',', $this->FilterTables) : null;
		$tblAllCount	= count($tables);
		$tblFilterOn	= ($this->FilterOn) ? 'ON' : 'OFF';
		$qryLimit	    = DUP_Settings::Get('package_phpdump_qrylimit');

		if (is_array($filterTables) && $this->FilterOn) {
			foreach ($tables as $key => $val) {
				if (in_array($tables[$key], $filterTables)) {
					unset($tables[$key]);
				}
			}
		}
		$tblCreateCount = count($tables);
		$tblFilterCount = $tblAllCount - $tblCreateCount;

		DUP_Log::Info("TABLES: total:{$tblAllCount} | filtered:{$tblFilterCount} | create:{$tblCreateCount}");
		DUP_Log::Info("FILTERED: [{$this->FilterTables}]");	

		$sql_header = "/* DUPLICATOR MYSQL SCRIPT CREATED ON : " . @date("Y-m-d H:i:s") . " */\n\n";
		$sql_header .= "SET FOREIGN_KEY_CHECKS = 0;\n\n";
		fwrite($handle, $sql_header);

		//BUILD CREATES:
		//All creates must be created before inserts do to foreign key constraints
		foreach ($tables as $table) {
			//$sql_del = ($GLOBALS['duplicator_opts']['dbadd_drop']) ? "DROP TABLE IF EXISTS {$table};\n\n" : "";
			//@fwrite($handle, $sql_del);
			$create = $wpdb->get_row("SHOW CREATE TABLE `{$table}`", ARRAY_N);
			@fwrite($handle, "{$create[1]};\n\n");
		}

		//BUILD INSERTS: 
		//Create Insert in 100 row increments to better handle memory
		foreach ($tables as $table) {

			$row_count = $wpdb->get_var("SELECT Count(*) FROM `{$table}`");
			//DUP_Log::Info("{$table} ({$row_count})");

			if ($row_count > $qryLimit) {
				$row_count = ceil($row_count / $qryLimit);
			} else if ($row_count > 0) {
				$row_count = 1;
			}

			if ($row_count >= 1) {
				fwrite($handle, "\n/* INSERT TABLE DATA: {$table} */\n");
			}

			for ($i = 0; $i < $row_count; $i++) {
				$sql = "";
				$limit = $i * $qryLimit;
				$query = "SELECT * FROM `{$table}` LIMIT {$limit}, {$qryLimit}";
				$rows = $wpdb->get_results($query, ARRAY_A);
				if (is_array($rows)) {
					foreach ($rows as $row) {
						$sql .= "INSERT INTO `{$table}` VALUES(";
						$num_values = count($row);
						$num_counter = 1;
						foreach ($row as $value) {
							if ( is_null( $value ) || ! isset( $value ) ) {
								($num_values == $num_counter) 	? $sql .= 'NULL' 	: $sql .= 'NULL, ';
							} else {
								($num_values == $num_counter) 
									? $sql .= '"' . @esc_sql($value) . '"' 
									: $sql .= '"' . @esc_sql($value) . '", ';
							}
							$num_counter++;
						}
						$sql .= ");\n";
					}
					fwrite($handle, $sql);
				}
			}
			
			//Flush buffer if enabled
			if ($this->networkFlush) {
				DUP_Util::FcgiFlush();
			}
			$sql = null;
			$rows = null;
		}
		
		$sql_footer = "\nSET FOREIGN_KEY_CHECKS = 1; \n\n";
		$sql_footer .= "/* Duplicator WordPress Timestamp: " . date("Y-m-d H:i:s") . "*/\n";
		$sql_footer .= "/* " . DUPLICATOR_DB_EOF_MARKER . " */\n";
		fwrite($handle, $sql_footer);
		$wpdb->flush();
		fclose($handle);
	}
}
?>

Youez - 2016 - github.com/yon3zu
LinuXploit