SchedulerRunCommand::execute()   A
last analyzed

Complexity

Conditions 3
Paths 3

Size

Total Lines 18
Code Lines 9

Duplication

Lines 0
Ratio 0 %

Importance

Changes 3
Bugs 0 Features 0
Metric Value
cc 3
eloc 9
c 3
b 0
f 0
nc 3
nop 0
dl 0
loc 18
rs 9.9666
1
<?php
2
3
/**
4
 * Platine Framework
5
 *
6
 * Platine Framework is a lightweight, high-performance, simple and elegant
7
 * PHP Web framework
8
 *
9
 * This content is released under the MIT License (MIT)
10
 *
11
 * Copyright (c) 2020 Platine Framework
12
 *
13
 * Permission is hereby granted, free of charge, to any person obtaining a copy
14
 * of this software and associated documentation files (the "Software"), to deal
15
 * in the Software without restriction, including without limitation the rights
16
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
17
 * copies of the Software, and to permit persons to whom the Software is
18
 * furnished to do so, subject to the following conditions:
19
 *
20
 * The above copyright notice and this permission notice shall be included in all
21
 * copies or substantial portions of the Software.
22
 *
23
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
24
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
26
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
28
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
29
 * SOFTWARE.
30
 */
31
32
/**
33
 *  @file SchedulerRunCommand.php
34
 *
35
 *  The scheduler run command class
36
 *
37
 *  @package    Platine\Framework\Task\Command
38
 *  @author Platine Developers team
39
 *  @copyright  Copyright (c) 2020
40
 *  @license    http://opensource.org/licenses/MIT  MIT License
41
 *  @link   https://www.platine-php.com
42
 *  @version 1.0.0
43
 *  @filesource
44
 */
45
46
declare(strict_types=1);
47
48
namespace Platine\Framework\Task\Command;
49
50
use Platine\Config\Config;
51
use Platine\Framework\App\Application;
52
use Platine\Framework\Task\SchedulerInterface;
53
54
/**
55
 * @class SchedulerRunCommand
56
 * @package Platine\Framework\Task\Command
57
 * @template T
58
 * @extends AbstractCommand<T>
59
 */
60
class SchedulerRunCommand extends AbstractCommand
61
{
62
    /**
63
     * Create new instance
64
     * @param SchedulerInterface $scheduler
65
     * @param Application $application
66
     * @param Config<T> $config
67
     */
68
    public function __construct(
69
        SchedulerInterface $scheduler,
70
        Application $application,
71
        Config $config
72
    ) {
73
        parent::__construct($scheduler, $application, $config);
74
75
        $this->setName('scheduler:run')
76
             ->setDescription('Execute the scheduled tasks');
77
78
        $this->addArgument('name', 'the name of task to execute instead of all', null, false);
79
    }
80
81
    /**
82
     * {@inheritdoc}
83
     */
84
    public function execute(): mixed
85
    {
86
        //Load the task
87
        $this->loadTasks();
88
89
        $name = $this->getArgumentValue('name');
90
        if (!empty($name)) {
91
            $task = $this->scheduler->get($name);
92
            if ($task !== null) {
93
                $this->scheduler->execute($task);
94
95
                return true;
96
            }
97
        }
98
99
        $this->scheduler->run();
100
101
        return true;
102
    }
103
}
104