HEX
Server: LiteSpeed
System: Linux server484.bertina.biz 4.18.0-553.34.1.lve.el8.x86_64 #1 SMP Thu Jan 9 16:30:32 UTC 2025 x86_64
User: alvnails (1268)
PHP: 8.2.29
Disabled: mail
Upload Files
File: /home/alvnails/public_html/wp-content/plugins/duplicator-pro/addons/wpcliaddon/src/BackupBuild.php
<?php

/**
 * @package   Duplicator
 * @copyright (c) 2022, Snap Creek LLC
 */

namespace Duplicator\Addons\WpCliAddon;

use DUP_PRO_Log;
use DUP_PRO_Package;
use Duplicator\Package\AbstractPackage;
use Duplicator\Ajax\ServicesPackage;
use Duplicator\Libs\Snap\SnapUtil;
use Duplicator\Models\Storages\StoragesUtil;
use Exception;
use WP_CLI;

class BackupBuild
{
    /**
     * Process schedules by cron
     *
     * @param DUP_PRO_Package $package Package to process
     *
     * @return void
     */
    public static function process(DUP_PRO_Package $package): void
    {
        StoragesUtil::getDefaultStorage()->initStorageDirectory(true);

        if (SnapUtil::isIniValChangeable('memory_limit')) {
            @ini_set('memory_limit', -1);
        }

        $start_time = time();
        DUP_PRO_Log::trace("PACKAGE {$package->getId()}:PROCESSING");

        if ($package->getStatus() < AbstractPackage::STATUS_AFTER_SCAN) {
            // Scan step built into package build - used by schedules - NOT manual build where scan is done in web service.
            DUP_PRO_Log::trace("PACKAGE {$package->getId()}:SCANNING");
            //After scanner runs.  Save FilterInfo (unreadable, warnings, globals etc)
            if (!$package->Archive->scanFiles(true)) {
                while ($package->Archive->scanFiles() !== true) {
                    DUP_PRO_Log::trace("CONTINUE SCANNING");
                }
            }
            $scan_report = $package->createScanReport();
            $package->setStatus(AbstractPackage::STATUS_AFTER_SCAN);

            $end_time  = time();
            $scan_time = $end_time - $start_time;
            DUP_PRO_Log::trace("SCAN TIME=$scan_time seconds");
            WP_CLI::debug("Scan result\n" . json_encode($scan_report, JSON_PRETTY_PRINT));
            if ($scan_report['Status'] > ServicesPackage::EXEC_STATUS_PASS) {
                if (empty($scan_report['Message'])) {
                    $scan_report['Message'] = 'Scan failed';
                }
                throw new Exception("Scan failed, Status: {$scan_report['Status']}, Message: {$scan_report['Message']}");
            } else {
                WP_CLI::success("Scan success");
            }
        } elseif ($package->getStatus() < AbstractPackage::STATUS_COPIEDPACKAGE) {
            DUP_PRO_Log::trace("PACKAGE {$package->getId()}:BUILDING");
            $package->runBuild(false);
            $end_time   = time();
            $build_time = $end_time - $start_time;
            DUP_PRO_Log::trace("BUILD TIME=$build_time seconds");
            if ($package->build_progress->hasCompleted()) {
                if ($package->build_progress->failed) {
                    throw new Exception("Build failed");
                }
            }
        } elseif ($package->getStatus() < AbstractPackage::STATUS_COMPLETE) {
            DUP_PRO_Log::trace("PACKAGE {$package->getId()}:STORAGE PROCESSING");
            $package->setStatus(AbstractPackage::STATUS_STORAGE_PROCESSING);
            $package->processStorages();
            $end_time   = time();
            $build_time = $end_time - $start_time;
            DUP_PRO_Log::trace("STORAGE CHUNK PROCESSING TIME=$build_time seconds");
            if ($package->getStatus() == AbstractPackage::STATUS_COMPLETE) {
                DUP_PRO_Log::trace("PACKAGE {$package->getId()} COMPLETE");
            } elseif ($package->getStatus() == AbstractPackage::STATUS_ERROR) {
                DUP_PRO_Log::trace("PACKAGE {$package->getId()} IN ERROR STATE");
            }

            $packageCompleteStatuses = [
                AbstractPackage::STATUS_COMPLETE,
                AbstractPackage::STATUS_ERROR,
            ];
            if (in_array($package->getStatus(), $packageCompleteStatuses)) {
                $info  = "\n";
                $info .= "********************************************************************************\n";
                $info .= "********************************************************************************\n";
                $info .= "DUPLICATOR PRO PACKAGE CREATION OR MANUAL STORAGE TRANSFER END: " . @date("Y-m-d H:i:s") . "\n";
                $info .= "NOTICE: Do NOT post to public sites or forums \n";
                $info .= "********************************************************************************\n";
                $info .= "********************************************************************************\n";
                DUP_PRO_Log::infoTrace($info);
            }

            if ($package->getStatus() == AbstractPackage::STATUS_ERROR) {
                throw new Exception("Storage failed");
            }
        }
    }
}