xref: /webtrees/app/Http/RequestHandlers/SelectNewFact.php (revision e3c147d0d53873311b7c137c41b4439e01d4189e)
1<?php
2
3/**
4 * webtrees: online genealogy
5 * Copyright (C) 2019 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
18declare(strict_types=1);
19
20namespace Fisharebest\Webtrees\Http\RequestHandlers;
21
22use Fisharebest\Webtrees\Tree;
23use Psr\Http\Message\ResponseInterface;
24use Psr\Http\Message\ServerRequestInterface;
25use Psr\Http\Server\RequestHandlerInterface;
26
27use function assert;
28use function is_string;
29use function redirect;
30
31/**
32 * Select a new fact to add.
33 */
34class SelectNewFact implements RequestHandlerInterface
35{
36    /**
37     * @param ServerRequestInterface $request
38     *
39     * @return ResponseInterface
40     */
41    public function handle(ServerRequestInterface $request): ResponseInterface
42    {
43        $tree = $request->getAttribute('tree');
44        assert($tree instanceof Tree);
45
46        $xref = $request->getAttribute('xref');
47        assert(is_string($xref));
48
49        $params = (array) $request->getParsedBody();
50        $fact   = $params['fact'];
51
52        return redirect(route(AddNewFact::class, [
53            'tree' => $tree->name(),
54            'xref' => $xref,
55            'fact' => $fact,
56        ]));
57    }
58}
59