SubmissionPage   A
last analyzed

Complexity

Total Complexity 3

Size/Duplication

Total Lines 33
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 24
dl 0
loc 33
rs 10
c 0
b 0
f 0
wmc 3

1 Method

Rating   Name   Duplication   Size   Complexity  
A handle() 0 29 3
1
<?php
2
3
/**
4
 * webtrees: online genealogy
5
 * Copyright (C) 2025 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
18
declare(strict_types=1);
19
20
namespace Fisharebest\Webtrees\Http\RequestHandlers;
21
22
use Fig\Http\Message\StatusCodeInterface;
23
use Fisharebest\Webtrees\Auth;
0 ignored issues
show
Bug introduced by
The type Fisharebest\Webtrees\Auth was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
24
use Fisharebest\Webtrees\Http\ViewResponseTrait;
25
use Fisharebest\Webtrees\Registry;
26
use Fisharebest\Webtrees\Validator;
27
use Illuminate\Support\Collection;
28
use Psr\Http\Message\ResponseInterface;
29
use Psr\Http\Message\ServerRequestInterface;
30
use Psr\Http\Server\RequestHandlerInterface;
31
32
use function redirect;
33
34
final class SubmissionPage implements RequestHandlerInterface
35
{
36
    use ViewResponseTrait;
37
38
    public function handle(ServerRequestInterface $request): ResponseInterface
39
    {
40
        $tree   = Validator::attributes($request)->tree();
41
        $xref   = Validator::attributes($request)->isXref()->string('xref');
42
        $slug   = Validator::attributes($request)->string('slug', '');
43
        $record = Registry::submissionFactory()->make($xref, $tree);
44
        $record = Auth::checkSubmissionAccess($record, false);
45
46
        // Redirect to correct xref/slug
47
        if ($record->xref() !== $xref || Registry::slugFactory()->make($record) !== $slug) {
48
            return redirect($record->url(), StatusCodeInterface::STATUS_MOVED_PERMANENTLY);
49
        }
50
51
        return $this->viewResponse('record-page', [
52
            'clipboard_facts'      => new Collection(),
53
            'linked_families'      => null,
54
            'linked_individuals'   => null,
55
            'linked_locations'     => null,
56
            'linked_media_objects' => null,
57
            'linked_notes'         => null,
58
            'linked_repositories'  => null,
59
            'linked_sources'       => null,
60
            'linked_submitters'    => null,
61
            'meta_description'     => '',
62
            'meta_robots'          => 'index,follow',
63
            'record'               => $record,
64
            'title'                => $record->fullName(),
65
            'tree'                 => $tree,
66
        ])->withHeader('Link', '<' . $record->url() . '>; rel="canonical"');
67
    }
68
}
69