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/Upgrade/ScheduleConvertStep.php
<?php
/*
 * Spring Signage Ltd - http://www.springsignage.com
 * Copyright (C) 2015 Spring Signage Ltd
 * (ScheduleConvertStep.php)
 */


namespace Xibo\Upgrade;


use Xibo\Service\ConfigServiceInterface;
use Xibo\Service\LogServiceInterface;
use Xibo\Storage\StorageServiceInterface;

/**
 * Class ScheduleConvertStep
 * @package Xibo\Upgrade
 */
class ScheduleConvertStep implements  Step
{
    /** @var  StorageServiceInterface */
    private $store;

    /** @var  LogServiceInterface */
    private $log;

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

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

    /**
     * @param \Slim\Helper\Set $container
     * @throws \Xibo\Exception\NotFoundException
     */
    public function doStep($container)
    {
        // Get all events and their Associated display group id's
        foreach ($this->store->select('SELECT eventId, displayGroupIds FROM `schedule`', []) as $event) {
            // Ping open the displayGroupIds
            $displayGroupIds = explode(',', $event['displayGroupIds']);

            // Construct some SQL to add the link
            $sql = 'INSERT INTO `lkscheduledisplaygroup` (eventId, displayGroupId) VALUES ';

            foreach ($displayGroupIds as $id) {
                $sql .= '(' . $event['eventId'] . ',' . $id . '),';
            }

            $sql = rtrim($sql, ',');

            $this->store->update($sql, []);
        }
    }
}