HEX
Server: Apache
System: Linux server2.voipitup.com.au 4.18.0-553.109.1.lve.el8.x86_64 #1 SMP Thu Mar 5 20:23:46 UTC 2026 x86_64
User: posscale (1027)
PHP: 8.2.30
Disabled: exec,passthru,shell_exec,system
Upload Files
File: /home/posscale/subdomains/xibo/lib/Entity/Upgrade.php
<?php
/*
 * Spring Signage Ltd - http://www.springsignage.com
 * Copyright (C) 2015 Spring Signage Ltd
 * (Upgrade.php)
 */


namespace Xibo\Entity;


use Slim\Helper\Set;
use Xibo\Helper\Install;
use Xibo\Service\ConfigServiceInterface;
use Xibo\Service\LogServiceInterface;
use Xibo\Storage\StorageServiceInterface;
use Xibo\Upgrade\Step;

/**
 * Class Upgrade
 * @package Xibo\Entity
 */
class Upgrade implements \JsonSerializable
{
    use EntityTrait;

    public $stepId;
    public $dbVersion;

    public $requestDate;
    public $lastTryDate;
    public $complete;

    public $appVersion;
    public $step;
    public $action;
    public $type;

    /** @var  Set */
    private $container;

    /** @var  ConfigServiceInterface */
    private $config;

    /**
     * Entity constructor.
     * @param StorageServiceInterface $store
     * @param LogServiceInterface $log
     * @param Set $container
     * @param ConfigServiceInterface $config
     */
    public function __construct($store, $log, $container, $config)
    {
        $this->setCommonDependencies($store, $log);
        $this->container = $container;
        $this->config = $config;
    }

    /**
     * Do the upgrade step
     * @param string $connectionName The connection name to use for this step
     */
    public function doStep($connectionName = 'upgrade')
    {
        // SQL or not?
        switch ($this->type) {

            case 'sql':

                // Split the statement and run
                // DDL doesn't rollback, so ideally we'd only have 1 statement
                $dbh = $this->getStore()->getConnection($connectionName);

                // Run the SQL to create the necessary tables
                $statements = Install::remove_remarks($this->action);
                $statements = Install::split_sql_file($statements, ';');

                foreach ($statements as $sql) {
                    $dbh->exec($sql);
                }

                break;

            case 'php':

                // Instantiate the class provided in Action.
                $class = $this->action;

                if (!class_exists($class))
                    throw new \InvalidArgumentException(__('PHP step class does not exist'));

                $object = new $class($this->store, $this->log, $this->config);
                /* @var Step $object */
                $object->doStep($this->container);

                break;

            default:
                throw new \InvalidArgumentException(__('Unknown Request Type'));
        }
    }

    public function save()
    {
        if ($this->stepId == 0)
            $this->add();
        else
            $this->edit();
    }

    private function add()
    {
        $this->stepId = $this->getStore()->insert('
            INSERT INTO `upgrade` (appVersion, dbVersion, step, `action`, `type`, `requestDate`)
            VALUES (:appVersion, :dbVersion, :step, :action, :type, :requestDate)
        ', [
            'appVersion' => $this->appVersion,
            'dbVersion' => $this->dbVersion,
            'step' => $this->step,
            'action' => $this->action,
            'type' => $this->type,
            'requestDate' => $this->requestDate
        ]);
    }

    private function edit()
    {
        $this->getStore()->update('
            UPDATE `upgrade` SET
              `complete` = :complete,
              `lastTryDate` = :lastTryDate
             WHERE stepId = :stepId
        ', [
            'stepId' => $this->stepId,
            'complete' => $this->complete,
            'lastTryDate' => $this->lastTryDate
        ]);
    }

    public function createTable()
    {
        // Insert the table.
        $this->getStore()->update('
                CREATE TABLE IF NOT EXISTS `upgrade` (
                  `stepId` int(11) NOT NULL AUTO_INCREMENT,
                  `appVersion` varchar(20) NOT NULL,
                  `dbVersion` int(11) NOT NULL,
                  `step` varchar(254) NOT NULL,
                  `type` varchar(50) NOT NULL,
                  `action` text NOT NULL,
                  `complete` tinyint(4) NOT NULL DEFAULT \'0\',
                  `requestDate` int(11) NULL,
                  `lastTryDate` int(11) NULL,
                  PRIMARY KEY (`stepId`)
                ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;
            ', []);
    }
}