TaskStatusAction   A
last analyzed

Complexity

Total Complexity 6

Size/Duplication

Total Lines 63
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 31
dl 0
loc 63
rs 10
c 0
b 0
f 0
wmc 6

2 Methods

Rating   Name   Duplication   Size   Complexity  
A handle() 0 42 5
A __construct() 0 4 1
1
<?php
2
3
/**
4
 * webtrees-lib: MyArtJaub library for webtrees
5
 *
6
 * @package MyArtJaub\Webtrees
7
 * @subpackage AdminTasks
8
 * @author Jonathan Jaubart <[email protected]>
9
 * @copyright Copyright (c) 2020-2022, Jonathan Jaubart
10
 * @license http://www.gnu.org/licenses/gpl.html GNU General Public License, version 3
11
 */
12
13
declare(strict_types=1);
14
15
namespace MyArtJaub\Webtrees\Module\AdminTasks\Http\RequestHandlers;
16
17
use Fisharebest\Webtrees\FlashMessages;
18
use Fisharebest\Webtrees\I18N;
19
use Fisharebest\Webtrees\Log;
20
use Fisharebest\Webtrees\Registry;
21
use Fisharebest\Webtrees\Validator;
22
use Fisharebest\Webtrees\Services\ModuleService;
23
use MyArtJaub\Webtrees\Module\AdminTasks\AdminTasksModule;
24
use MyArtJaub\Webtrees\Module\AdminTasks\Services\TaskScheduleService;
25
use Psr\Http\Message\ResponseInterface;
26
use Psr\Http\Message\ServerRequestInterface;
27
use Psr\Http\Server\RequestHandlerInterface;
28
29
/**
30
 * Request handler for updating the status of task schedules
31
 */
32
class TaskStatusAction implements RequestHandlerInterface
33
{
34
    private ?AdminTasksModule $module;
35
    private TaskScheduleService $taskschedules_service;
36
37
    /**
38
     * Constructor for TaskStatusAction Request Handler
39
     *
40
     * @param ModuleService $module_service
41
     * @param TaskScheduleService $taskschedules_service
42
     */
43
    public function __construct(ModuleService $module_service, TaskScheduleService $taskschedules_service)
44
    {
45
        $this->module = $module_service->findByInterface(AdminTasksModule::class)->first();
46
        $this->taskschedules_service = $taskschedules_service;
47
    }
48
49
    /**
50
     * {@inheritDoc}
51
     * @see \Psr\Http\Server\RequestHandlerInterface::handle()
52
     */
53
    public function handle(ServerRequestInterface $request): ResponseInterface
54
    {
55
        if ($this->module === null) {
56
            FlashMessages::addMessage(
57
                I18N::translate('The attached module could not be found.'),
58
                'danger'
59
            );
60
            return Registry::responseFactory()->redirect(AdminConfigPage::class);
61
        }
62
63
        $task_sched_id = Validator::attributes($request)->integer('task', -1);
64
        $task_schedule = $this->taskschedules_service->find($task_sched_id);
65
66
        if ($task_schedule === null) {
67
            FlashMessages::addMessage(
68
                I18N::translate('The task shedule with ID “%s” does not exist.', I18N::number($task_sched_id)),
69
                'danger'
70
            );
71
            return Registry::responseFactory()->redirect(AdminConfigPage::class);
72
        }
73
74
        Validator::attributes($request)->boolean('enable', false) ?
75
            $task_schedule->enable() :
76
            $task_schedule->disable();
77
78
        if ($this->taskschedules_service->update($task_schedule) > 0) {
79
            FlashMessages::addMessage(
80
                I18N::translate('The scheduled task has been successfully updated.'),
81
                'success'
82
            );
83
            //phpcs:ignore Generic.Files.LineLength.TooLong
84
            Log::addConfigurationLog('Module ' . $this->module->title() . ' : Task Schedule “' . $task_schedule->id() . '” has been updated.');
85
        } else {
86
            FlashMessages::addMessage(
87
                I18N::translate('An error occured while updating the scheduled task.'),
88
                'danger'
89
            );
90
            //phpcs:ignore Generic.Files.LineLength.TooLong
91
            Log::addConfigurationLog('Module ' . $this->module->title() . ' : Task Schedule “' . $task_schedule->id() . '” could not be updated. See error log.');
92
        }
93
94
        return Registry::responseFactory()->redirect(AdminConfigPage::class);
95
    }
96
}
97