Passed
Push — master ( b00cb0...46b036 )
by Greg
05:27
created

MediaFileUnused::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 1
c 1
b 0
f 0
nc 1
nop 1
dl 0
loc 3
rs 10
1
<?php
2
3
/**
4
 * webtrees: online genealogy
5
 * Copyright (C) 2020 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 <http://www.gnu.org/licenses/>.
16
 */
17
18
declare(strict_types=1);
19
20
namespace Fisharebest\Webtrees\Http\RequestHandlers;
21
22
use Fisharebest\Webtrees\Services\MediaFileService;
23
use League\Flysystem\FilesystemInterface;
24
use Psr\Http\Message\ResponseInterface;
25
use Psr\Http\Message\ServerRequestInterface;
26
use Psr\Http\Server\RequestHandlerInterface;
27
28
use function assert;
29
30
/**
31
 * Controller for the media page and displaying images.
32
 */
33
class MediaFileUnused implements RequestHandlerInterface
34
{
35
    /** @var MediaFileService */
36
    private $media_file_service;
37
38
    /**
39
     * MediaFileController constructor.
40
     *
41
     * @param MediaFileService $media_file_service
42
     */
43
    public function __construct(MediaFileService $media_file_service)
44
    {
45
        $this->media_file_service = $media_file_service;
46
    }
47
48
    /**
49
     * Generate a thumbnail for an unused media file (i.e. not used by any media object).
50
     *
51
     * @param ServerRequestInterface $request
52
     *
53
     * @return ResponseInterface
54
     */
55
    public function handle(ServerRequestInterface $request): ResponseInterface
56
    {
57
        $data_filesystem = $request->getAttribute('filesystem.data');
58
        assert($data_filesystem instanceof FilesystemInterface);
59
60
        $params = $request->getQueryParams();
61
62
        $file = $params['path'];
63
64
        return $this->media_file_service->generateImage('', $file, $data_filesystem, $params);
65
    }
66
}
67