xref: /webtrees/app/Http/RequestHandlers/ManageMediaAction.php (revision b0b1f53350f5707e7bba4dc0fd6ffbbfc2ce61ed)
1<?php
2
3/**
4 * webtrees: online genealogy
5 * Copyright (C) 2023 webtrees development team
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <https://www.gnu.org/licenses/>.
16 */
17
18declare(strict_types=1);
19
20namespace Fisharebest\Webtrees\Http\RequestHandlers;
21
22use Fisharebest\Webtrees\Registry;
23use Fisharebest\Webtrees\Services\MediaFileService;
24use Fisharebest\Webtrees\Validator;
25use Psr\Http\Message\ResponseInterface;
26use Psr\Http\Message\ServerRequestInterface;
27use Psr\Http\Server\RequestHandlerInterface;
28
29use function redirect;
30use function route;
31
32/**
33 * Manage media from the control panel.
34 */
35class ManageMediaAction implements RequestHandlerInterface
36{
37    private MediaFileService $media_file_service;
38
39    /**
40     * @param MediaFileService $media_file_service
41     */
42    public function __construct(MediaFileService $media_file_service)
43    {
44        $this->media_file_service = $media_file_service;
45    }
46
47    /**
48     * @param ServerRequestInterface $request
49     *
50     * @return ResponseInterface
51     */
52    public function handle(ServerRequestInterface $request): ResponseInterface
53    {
54        $data_filesystem = Registry::filesystem()->data();
55        $media_folders   = $this->media_file_service->allMediaFolders($data_filesystem)->all();
56
57        return redirect(route(ManageMediaPage::class, [
58            'files'        => Validator::parsedBody($request)->string('files'),
59            'media_folder' => Validator::parsedBody($request)->isInArray($media_folders)->string('media_folder'),
60            'subfolders'   => Validator::parsedBody($request)->string('subfolders'),
61        ]));
62    }
63}
64