Current File : //var/www/vinorea/modules/autoupgrade/classes/Task/Runner/AllRestoreTasks.php
<?php

/**
 * Copyright since 2007 PrestaShop SA and Contributors
 * PrestaShop is an International Registered Trademark & Property of PrestaShop SA
 *
 * NOTICE OF LICENSE
 *
 * This source file is subject to the Academic Free License version 3.0
 * that is bundled with this package in the file LICENSE.md.
 * It is also available through the world-wide-web at this URL:
 * https://opensource.org/licenses/AFL-3.0
 * If you did not receive a copy of the license and are unable to
 * obtain it through the world-wide-web, please send an email
 * to license@prestashop.com so we can send you a copy immediately.
 *
 * @author    PrestaShop SA and Contributors <contact@prestashop.com>
 * @copyright Since 2007 PrestaShop SA and Contributors
 * @license   https://opensource.org/licenses/AFL-3.0 Academic Free License version 3.0
 */

namespace PrestaShop\Module\AutoUpgrade\Task\Runner;

use InvalidArgumentException;
use PrestaShop\Module\AutoUpgrade\Task\TaskName;

/**
 * Execute the whole upgrade process in a single request.
 */
class AllRestoreTasks extends ChainedTasks
{
    const initialTask = TaskName::TASK_RESTORE_INITIALIZATION;

    /**
     * @var string
     */
    protected $step = self::initialTask;

    /**
     * Customize the execution context with several options
     * > action: Replace the initial step to run
     * > channel: Makes a specific upgrade (minor, major etc.)
     * > data: Loads an encoded array of data coming from another request.
     *
     * @param array<string, string> $options
     *
     * @throws \Exception
     */
    public function setOptions(array $options): void
    {
        $restoreConfiguration = $this->container->getRestoreConfiguration();
        $restoreConfigurationValidator = $this->container->getRestoreConfigurationValidator();

        $errors = $restoreConfigurationValidator->validate($options);

        if (!empty($errors)) {
            throw new InvalidArgumentException(reset($errors)['message']);
        }

        $restoreConfiguration->merge($options);

        $this->container->getConfigurationStorage()->save($restoreConfiguration);
    }

    /**
     * Set default config on first run.
     */
    public function init(): void
    {
        // Do nothing
    }
}