Uname: Linux premium294.web-hosting.com 4.18.0-553.45.1.lve.el8.x86_64 #1 SMP Wed Mar 26 12:08:09 UTC 2025 x86_64
Software: LiteSpeed
PHP version: 8.1.32 [ PHP INFO ] PHP os: Linux
Server Ip: 104.21.16.1
Your Ip: 216.73.216.223
User: mjbynoyq (1574) | Group: mjbynoyq (1570)
Safe Mode: OFF
Disable Function:
NONE

name : ctrl.base.php
<?php

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


//Enum used to define the various test statues
final class DUP_PRO_CTRL_Status
{
    const ERROR     = -2;
    const FAILED    = -1;
    const UNDEFINED = 0;
    const SUCCESS   = 1;
}

/**
 * Base class for all controllers
 *
 * @package    Duplicator
 * @subpackage classes/ctrls
 */
class DUP_PRO_CTRL_Base
{
    /** @var string  The return type valiad options: PHP, JSON-AJAX, JSON */
    public $returnType = 'JSON-AJAX';

    /**
     * Sets the response type
     *
     * @param string $type The return type valiad options: PHP, JSON-AJAX, JSON
     *
     * @return void
     */
    public function setResponseType($type)
    {
        $opts = array(
            'PHP',
            'JSON-AJAX',
            'JSON',
        );
        if (!in_array($type, $opts)) {
            throw new Exception('The $type param must be one of the following: ' . implode(',', $opts) . ' for the following function [' . __FUNCTION__ . ']');
        }
        $this->returnType = $type;
    }

    /**
     * Merges $_POST params with custom parameters.
     *
     * @param array<string,mixed> $params custom parameters
     *
     * @return array<string,mixed>
     */
    public function postParamMerge($params = array())
    {
        $params = is_array($params) ? $params : array();
        return array_merge($_POST, $params);
    }

    /**
     * Merges $_GET params with custom parameters.
     *
     * @param array<string,mixed> $params custom parameters
     *
     * @return array<string,mixed>
     */
    public function getParamMerge($params)
    {
        $params = is_array($params) ? $params : array();
        return array_merge($_GET, $params);
    }
}

/**
 * A class structure used to report on controller methods
 *
 * @package    Duplicator
 * @subpackage classes/ctrls
 */
class DUP_PRO_CTRL_Report
{
    /** @var float */
    public $runTime = 0.0;
    /** @var string */
    public $returnType = '';
    /** @var int */
    public $results;
    /** @var int */
    public $status;
}

/**
 * A class used format all controller responses in a consistent format.  Every controller response will
 * have a Report and Payload structure.  The Payload is an array of the result responses.  The Report is used to
 * report on the overall status of the controller method
 *
 * Standard: PSR-2
 *
 * @link http://www.php-fig.org/psr/psr-2
 *
 * @package    Duplicator
 * @subpackage classes/ctrls
 * @copyright  (c) 2017, Snap Creek LLC
 */
class DUP_PRO_CTRL_Result
{
    /** @var ?DUP_PRO_CTRL_Report */
    public $report;
    /** @var null|array<string,mixed>|object */
    public $payload = null;
    /** @var float */
    private $timeStart = 0.0;
    /** @var float */
    private $timeEnd = 0.0;
    /** @var ?DUP_PRO_CTRL_Base */
    private $CTRL = null;

    public function __construct(DUP_PRO_CTRL_Base $CTRL_OBJ)
    {
        $this->timeStart = microtime(true);
        $this->CTRL      = $CTRL_OBJ;
    //Report Data
        $this->report             = new DUP_PRO_CTRL_Report();
        $this->report->returnType = $CTRL_OBJ->returnType;
    }

    /**
     * Used to process a controller request
     *
     * @param null|array<string,mixed>|object $payload The response object that will be returned
     * @param int                             $status  Enum $status The status of a response
     *
     * @return string|self Returns a PHP object or json encoded object
     */
    public function process($payload, $status = DUP_PRO_CTRL_Status::UNDEFINED)
    {
        if (is_array($this->payload)) {
            $this->payload[]       = $payload;
            $this->report->results = count($this->payload);
        } else {
            $this->payload         = $payload;
            $this->report->results = (is_array($payload)) ? count($payload) : 1;
        }

        $this->report->status = $status;
        $this->getProcessTime();
        switch ($this->CTRL->returnType) {
            case 'JSON':
                return json_encode($this);
            case 'PHP':
                return $this;
            default:
                if (!headers_sent()) {
                    if ($status === DUP_PRO_CTRL_Status::ERROR) {
                        header($_SERVER['SERVER_PROTOCOL'] . ' 500 Internal Server Error', true, 500);
                        die();
                    } else {
                        header('Content-Type: application/json');
                    }
                }
                die(json_encode($this));
        }
    }

    /**
     * Used to process an error response
     *
     * @param object $exception The PHP exception object
     *
     * @return void
     */
    public function processError($exception)
    {
        $payload            = array();
        $payload['Message'] = $exception->getMessage();
        $payload['File']    = $exception->getFile();
        $payload['Line']    = $exception->getLine();
        $payload['Trace']   = $exception->getTraceAsString();
        $this->process($payload, DUP_PRO_CTRL_Status::ERROR);
        die(json_encode($this));
    }


    /**
     * Set process time
     *
     * @return float
     */
    private function getProcessTime()
    {
        $this->timeEnd         = microtime(true);
        $this->report->runTime = $this->timeEnd - $this->timeStart;
        return $this->report->runTime;
    }
}
© 2025 XylotrechusZ