. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
| Server IP : 198.54.115.242 / Your IP :
216.73.216.33 [
Web Server : LiteSpeed System : Linux server233.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64 User : imereohc ( 2529) PHP Version : 8.2.30 Disable Function : NONE Domains : 1 Domains MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/imereohc/test.imera.ai/wp-content/plugins/duplicator/ctrls/ |
Upload File : |
<?php
defined('ABSPATH') || defined('DUPXABSPATH') || exit;
// Exit if accessed directly
if (! defined('DUPLICATOR_VERSION')) exit;
require_once(DUPLICATOR_PLUGIN_PATH.'/ctrls/ctrl.base.php');
require_once(DUPLICATOR_PLUGIN_PATH.'/classes/utilities/class.u.scancheck.php');
require_once(DUPLICATOR_PLUGIN_PATH.'/classes/utilities/class.u.json.php');
require_once(DUPLICATOR_PLUGIN_PATH.'/classes/package/class.pack.php');
require_once(DUPLICATOR_PLUGIN_PATH.'/classes/package/duparchive/class.pack.archive.duparchive.state.create.php');
require_once(DUPLICATOR_PLUGIN_PATH.'/classes/package/duparchive/class.pack.archive.duparchive.php');
/* @var $package DUP_Package */
/**
* Display error if any fatal error occurs occurs while scan ajax call
*
* @return void
*/
function duplicator_package_scan_shutdown() {
$logMessage = DUP_Handler::getVarLog();
if (!empty($logMessage)) {
echo nl2br($logMessage);
}
}
/**
* DUPLICATOR_PACKAGE_SCAN
* Returns a JSON scan report object which contains data about the system
*
* @return json JSON report object
* @example to test: /wp-admin/admin-ajax.php?action=duplicator_package_scan
*/
function duplicator_package_scan()
{
DUP_Handler::init_error_handler();
DUP_Handler::setMode(DUP_Handler::MODE_VAR);
register_shutdown_function('duplicator_package_scan_shutdown');
check_ajax_referer('duplicator_package_scan', 'nonce');
DUP_Util::hasCapability('export');
header('Content-Type: application/json;');
@ob_flush();
@set_time_limit(0);
$errLevel = error_reporting();
error_reporting(E_ERROR);
DUP_Util::initSnapshotDirectory();
$package = DUP_Package::getActive();
$report = $package->runScanner();
$package->saveActiveItem('ScanFile', $package->ScanFile);
$json_response = DUP_JSON::safeEncode($report);
DUP_Package::tempFileCleanup();
error_reporting($errLevel);
die($json_response);
}
/**
* duplicator_package_build
* Returns the package result status
*
* @return json JSON object of package results
*/
function duplicator_package_build()
{
DUP_Handler::init_error_handler();
check_ajax_referer('duplicator_package_build', 'nonce');
DUP_Util::hasCapability('export');
header('Content-Type: application/json');
@set_time_limit(0);
$errLevel = error_reporting();
error_reporting(E_ERROR);
DUP_Util::initSnapshotDirectory();
$Package = DUP_Package::getActive();
$Package->save('zip');
DUP_Settings::Set('active_package_id', $Package->ID);
DUP_Settings::Save();
if (!is_readable(DUPLICATOR_SSDIR_PATH_TMP."/{$Package->ScanFile}")) {
die("The scan result file was not found. Please run the scan step before building the package.");
}
$Package->runZipBuild();
//JSON:Debug Response
//Pass = 1, Warn = 2, Fail = 3
$json = array();
$json['status'] = 1;
$json['package'] = $Package;
$json['runtime'] = $Package->Runtime;
$json['exeSize'] = $Package->ExeSize;
$json['archiveSize'] = $Package->ZipSize;
$json_response = DupLiteSnapJsonU::wp_json_encode($json);
//Simulate a Host Build Interrupt
//die(0);
error_reporting($errLevel);
die($json_response);
}
/**
* Returns the package result status
*
* @return json JSON object of package results
*/
function duplicator_duparchive_package_build()
{
DUP_Handler::init_error_handler();
DUP_Log::Info('[CTRL DUP ARCIVE] CALL TO '.__FUNCTION__);
check_ajax_referer('duplicator_duparchive_package_build', 'nonce');
DUP_Util::hasCapability('export');
header('Content-Type: application/json');
@set_time_limit(0);
$errLevel = error_reporting();
error_reporting(E_ERROR);
// The DupArchive build process always works on a saved package so the first time through save the active package to the package table.
// After that, just retrieve it.
$active_package_id = DUP_Settings::Get('active_package_id');
DUP_Log::Info('[CTRL DUP ARCIVE] CURRENT PACKAGE ACTIVE '.$active_package_id);
if ($active_package_id == -1) {
$package = DUP_Package::getActive();
$package->save('daf');
DUP_Log::Info('[CTRL DUP ARCIVE] PACKAGE AS NEW ID '.$package->ID.' SAVED | STATUS:'.$package->Status);
//DUP_Log::TraceObject("[CTRL DUP ARCIVE] PACKAGE SAVED:", $package);
DUP_Settings::Set('active_package_id', $package->ID);
DUP_Settings::Save();
} else {
if (($package = DUP_Package::getByID($active_package_id)) == null) {
DUP_Log::Info('[CTRL DUP ARCIVE] ERROR: Get package by id '.$active_package_id.' FAILED');
die('Get package by id '.$active_package_id.' FAILED');
}
DUP_Log::Info('[CTRL DUP ARCIVE] PACKAGE GET BY ID '.$active_package_id.' | STATUS:'.$package->Status);
// DUP_Log::TraceObject("getting active package by id {$active_package_id}", $package);
}
if (!is_readable(DUPLICATOR_SSDIR_PATH_TMP."/{$package->ScanFile}")) {
DUP_Log::Info('[CTRL DUP ARCIVE] ERROR: The scan result file was not found. Please run the scan step before building the package.');
die("The scan result file was not found. Please run the scan step before building the package.");
}
if ($package === null) {
DUP_Log::Info('[CTRL DUP ARCIVE] There is no active package.');
die("There is no active package.");
}
if($package->Status == DUP_PackageStatus::ERROR) {
$package->setStatus(DUP_PackageStatus::ERROR);
$hasCompleted = true;
} else {
try {
$hasCompleted = $package->runDupArchiveBuild();
}
catch(Exception $ex) {
DUP_Log::Info('[CTRL DUP ARCIVE] ERROR: caught exception');
Dup_Log::Error('[CTRL DUP ARCIVE] Caught exception', $ex->getMessage(), Dup_ErrorBehavior::LogOnly);
DUP_Log::Info('[CTRL DUP ARCIVE] ERROR: after log');
$package->setStatus(DUP_PackageStatus::ERROR);
$hasCompleted = true;
}
}
$json = array();
$json['failures'] = array_merge($package->BuildProgress->build_failures, $package->BuildProgress->validation_failures);
if (!empty($json['failures'])) {
DUP_Log::Info('[CTRL DUP ARCIVE] FAILURES', $json['failures']);
}
//JSON:Debug Response
//Pass = 1, Warn = 2, 3 = Failure, 4 = Not Done
if ($hasCompleted) {
DUP_Log::Info('[CTRL DUP ARCIVE] COMPLETED PACKAGE STATUS: '.$package->Status);
if($package->Status == DUP_PackageStatus::ERROR) {
DUP_Log::Info('[CTRL DUP ARCIVE] ERROR');
$error_message = __('Error building DupArchive package') . '<br/>';
foreach($json['failures'] as $failure) {
$error_message .= implode(',', $failure->description);
}
Dup_Log::Error("Build failed so sending back error", esc_html($error_message), Dup_ErrorBehavior::LogOnly);
DUP_Log::Info('[CTRL DUP ARCIVE] ERROR AFTER LOG 2');
$json['status'] = 3;
} else {
Dup_Log::Info("sending back success status");
$json['status'] = 1;
}
Dup_Log::Trace('#### json package');
$json['package'] = $package;
$json['runtime'] = $package->Runtime;
$json['exeSize'] = $package->ExeSize;
$json['archiveSize'] = $package->ZipSize;
DUP_Log::Trace('[CTRL DUP ARCIVE] JSON PACKAGE');
} else {
DUP_Log::Info('[CTRL DUP ARCIVE] sending back continue status PACKAGE STATUS: '.$package->Status);
$json['status'] = 4;
}
$json_response = DupLiteSnapJsonU::wp_json_encode($json);
Dup_Log::TraceObject('json response', $json_response);
error_reporting($errLevel);
die($json_response);
}
/**
* DUPLICATOR_PACKAGE_DELETE
* Deletes the files and database record entries
*
* @return json A JSON message about the action.
* Use console.log to debug from client
*/
function duplicator_package_delete()
{
DUP_Handler::init_error_handler();
check_ajax_referer('duplicator_package_delete', 'nonce');
DUP_Util::hasCapability('export');
function _unlinkFile($file) {
if (! file_exists($file)) {
return;
}
if (! @unlink($file)) {
@chmod($file, 0644);
@unlink($file);
}
}
try {
global $wpdb;
$json = array();
$post = stripslashes_deep($_POST);
$tablePrefix = DUP_Util::getTablePrefix();
$tblName = $tablePrefix.'duplicator_packages';
$postIDs = isset($post['duplicator_delid']) ? sanitize_text_field($post['duplicator_delid']) : null;
$list = explode(",", $postIDs);
$delCount = 0;
if ($postIDs != null) {
foreach ($list as $id) {
$getResult = $wpdb->get_results($wpdb->prepare("SELECT name, hash FROM `{$tblName}` WHERE id = %d", $id), ARRAY_A);
if ($getResult) {
$row = $getResult[0];
$nameHash = "{$row['name']}_{$row['hash']}";
$delResult = $wpdb->query($wpdb->prepare("DELETE FROM `{$tblName}` WHERE id = %d", $id));
if ($delResult != 0) {
//TMP FILES
$globTmpFiles = glob(DUP_Util::safePath(DUPLICATOR_SSDIR_PATH_TMP."/{$nameHash}*"));
foreach ($globTmpFiles as $globTmpFile) {
_unlinkFile($globTmpFile);
}
//WP-SNAPSHOT FILES
$globSnapshotFiles = glob(DUP_Util::safePath(DUPLICATOR_SSDIR_PATH."/{$nameHash}*"));
foreach ($globSnapshotFiles as $globSnapshotFile) {
_unlinkFile($globSnapshotFile);
}
// _unlinkFile(DUP_Util::safePath(DUPLICATOR_SSDIR_PATH."/{$nameHash}.log"));
//Unfinished Zip files
/*
$tmpZip = DUPLICATOR_SSDIR_PATH_TMP."/{$nameHash}_archive.zip.*";
if ($tmpZip !== false) {
array_map('unlink', glob($tmpZip));
}
*/
$delCount++;
}
}
}
}
} catch (Exception $e) {
$json['error'] = "{$e}";
die(DupLiteSnapJsonU::wp_json_encode($json));
}
$json['ids'] = "{$postIDs}";
$json['removed'] = $delCount;
echo DupLiteSnapJsonU::wp_json_encode($json);
die();
}
/**
* Active package info
* Returns a JSON scan report active package info or
* active_package_present == false if no active package is present.
*
* @return json
*/
function duplicator_active_package_info()
{
ob_start();
try {
DUP_Handler::init_error_handler();
DUP_Util::hasCapability('export', DUP_Util::SECURE_ISSUE_THROW);
if (!check_ajax_referer('duplicator_active_package_info', 'nonce', false)) {
throw new Exception(__('An unathorized security request was made to this page. Please try again!','duplicator'));
}
global $wpdb;
$error = false;
$result = array(
'active_package' => array(
'present' => false,
'status' => 0,
'size' => 0
),
'html' => '',
'message' => ''
);
$result['active_package']['present'] = DUP_Package::is_active_package_present();
if ($result['active_package']['present']) {
$id = DUP_Settings::Get('active_package_id');
$package = DUP_Package::getByID($id);
if (is_null($package)) {
throw new Exception(__('Active package object error','duplicator'));
}
$result['active_package']['status'] = $package->Status;
$result['active_package']['size'] = $package->getArchiveSize();
$result['active_package']['size_format'] = DUP_Util::byteSize($package->getArchiveSize());
}
} catch (Exception $e) {
$error = true;
$result['message'] = $e->getMessage();
}
$result['html'] = ob_get_clean();
if ($error) {
wp_send_json_error($result);
} else {
wp_send_json_success($result);
}
}
/**
* Controller for Tools
* @package Duplicator\ctrls
*/
class DUP_CTRL_Package extends DUP_CTRL_Base
{
/**
* Init this instance of the object
*/
function __construct()
{
add_action('wp_ajax_DUP_CTRL_Package_addQuickFilters', array($this, 'addQuickFilters'));
add_action('wp_ajax_DUP_CTRL_Package_getPackageFile', array($this, 'getPackageFile'));
add_action('wp_ajax_DUP_CTRL_Package_getActivePackageStatus', array($this, 'getActivePackageStatus'));
}
/**
* Removed all reserved installer files names
*
* @param string $_POST['dir_paths'] A semi-colon separated list of directory paths
*
* @return string Returns all of the active directory filters as a ";" separated string
*/
public function addQuickFilters($post)
{
DUP_Handler::init_error_handler();
check_ajax_referer('DUP_CTRL_Package_addQuickFilters', 'nonce');
DUP_Util::hasCapability('export');
$post = $this->postParamMerge($post);
$result = new DUP_CTRL_Result($this);
try {
//CONTROLLER LOGIC
$package = DUP_Package::getActive();
//DIRS
$dir_filters = ($package->Archive->FilterOn)
? $package->Archive->FilterDirs.';'.sanitize_text_field($post['dir_paths'])
: sanitize_text_field($post['dir_paths']);
$dir_filters = $package->Archive->parseDirectoryFilter($dir_filters);
$changed = $package->Archive->saveActiveItem($package, 'FilterDirs', $dir_filters);
//FILES
$file_filters = ($package->Archive->FilterOn)
? $package->Archive->FilterFiles.';'.sanitize_text_field($post['file_paths'])
: sanitize_text_field($post['file_paths']);
$file_filters = $package->Archive->parseFileFilter($file_filters);
$changed = $package->Archive->saveActiveItem($package, 'FilterFiles', $file_filters);
if (!$package->Archive->FilterOn && !empty($package->Archive->FilterExts)) {
$changed = $package->Archive->saveActiveItem($package, 'FilterExts', '');
}
$changed = $package->Archive->saveActiveItem($package, 'FilterOn', 1);
//Result
$package = DUP_Package::getActive();
$payload['dirs-in'] = esc_html(sanitize_text_field($post['dir_paths']));
$payload['dir-out'] = esc_html($package->Archive->FilterDirs);
$payload['files-in'] = esc_html(sanitize_text_field($post['file_paths']));
$payload['files-out'] = esc_html($package->Archive->FilterFiles);
//RETURN RESULT
$test = ($changed) ? DUP_CTRL_Status::SUCCESS : DUP_CTRL_Status::FAILED;
$result->process($payload, $test);
} catch (Exception $exc) {
$result->processError($exc);
}
}
/**
* Download the requested package file
*
* @param string $_POST['which']
* @param string $_POST['package_id']
*
* @return downloadable file
*/
function getPackageFile($post)
{
DUP_Handler::init_error_handler();
check_ajax_referer('DUP_CTRL_Package_getPackageFile', 'nonce' );
DUP_Util::hasCapability('export');
$params = $this->postParamMerge($post);
$params = $this->getParamMerge($params);
$result = new DUP_CTRL_Result($this);
try {
//CONTROLLER LOGIC
$request = stripslashes_deep($_REQUEST);
$which = (int) $request['which'];
$packageId = (int) $request['package_id'];
$package = DUP_Package::getByID($packageId);
$isBinary = ($which != DUP_PackageFileType::Log);
$filePath = $package->getLocalPackageFile($which);
//OUTPUT: Installer, Archive, SQL File
if ($isBinary) {
@session_write_close();
// @ob_flush();
//flush seems to cause issues on some PHP version where the download prompt
//is no longer called but the contents of the installer are dumped to the browser.
//@flush();
header("Pragma: public");
header("Expires: 0");
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Cache-Control: private", false);
header("Content-Transfer-Encoding: binary");
if ($filePath != null) {
$fp = fopen($filePath, 'rb');
if ($fp !== false) {
if ($which == DUP_PackageFileType::Installer) {
$fileName = 'installer.php';
} else {
$fileName = basename($filePath);
}
header("Content-Type: application/octet-stream");
header("Content-Disposition: attachment; filename=\"{$fileName}\";");
DUP_LOG::trace("streaming $filePath");
while(!feof($fp)) {
$buffer = fread($fp, 2048);
print $buffer;
}
fclose($fp);
exit;
} else {
header("Content-Type: text/plain");
header("Content-Disposition: attachment; filename=\"error.txt\";");
$message = "Couldn't open $filePath.";
DUP_Log::Trace($message);
echo esc_html($message);
}
} else {
$message = __("Couldn't find a local copy of the file requested.", 'duplicator');
header("Content-Type: text/plain");
header("Content-Disposition: attachment; filename=\"error.txt\";");
// Report that we couldn't find the file
DUP_Log::Trace($message);
echo esc_html($message);
}
//OUTPUT: Log File
} else {
if ($filePath != null) {
header("Content-Type: text/plain");
$text = file_get_contents($filePath);
die($text);
} else {
$message = __("Couldn't find a local copy of the file requested.", 'duplicator');
echo esc_html($message);
}
}
} catch (Exception $exc) {
$result->processError($exc);
}
}
/**
* Get active package status
*
* <code>
* //JavaScript Ajax Request
* Duplicator.Package.getActivePackageStatus()
* </code>
*/
public function getActivePackageStatus($post)
{
DUP_Handler::init_error_handler();
check_ajax_referer('DUP_CTRL_Package_getActivePackageStatus', 'nonce');
DUP_Util::hasCapability('export');
$post = $this->postParamMerge($post);
$result = new DUP_CTRL_Result($this);
try
{
//CONTROLLER LOGIC
$post = stripslashes_deep($_POST);
$active_package_id = DUP_Settings::Get('active_package_id');
$package = DUP_Package::getByID($active_package_id);
$payload = array();
if($package != null) {
$test = DUP_CTRL_Status::SUCCESS;
$payload['status'] = $package->Status;
} else {
$test = DUP_CTRL_Status::FAILED;
}
//RETURN RESULT
return $result->process($payload, $test);
}
catch (Exception $exc)
{
$result->processError($exc);
}
}
}