Passed
Push — master ( 9b5c95...5229ea )
by Greg
06:55
created

ReorderMediaAction::handle()   A

Complexity

Conditions 3
Paths 3

Size

Total Lines 40
Code Lines 22

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 3
eloc 22
c 1
b 0
f 1
nc 3
nop 1
dl 0
loc 40
rs 9.568
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
declare(strict_types=1);
18
19
namespace Fisharebest\Webtrees\Http\RequestHandlers;
20
21
use Fisharebest\Webtrees\Auth;
22
use Fisharebest\Webtrees\Individual;
23
use Fisharebest\Webtrees\Tree;
24
use InvalidArgumentException;
25
use Psr\Http\Message\ResponseInterface;
26
use Psr\Http\Message\ServerRequestInterface;
27
use Psr\Http\Server\RequestHandlerInterface;
28
29
use function array_merge;
30
use function array_search;
31
use function assert;
32
use function implode;
33
use function is_array;
34
use function is_string;
35
use function redirect;
36
use function uksort;
37
38
/**
39
 * Reorder the media of an individual.
40
 */
41
class ReorderMediaAction implements RequestHandlerInterface
42
{
43
    /**
44
     * @param ServerRequestInterface $request
45
     *
46
     * @return ResponseInterface
47
     */
48
    public function handle(ServerRequestInterface $request): ResponseInterface
49
    {
50
        $tree = $request->getAttribute('tree');
51
        assert($tree instanceof Tree, new InvalidArgumentException());
52
53
        $xref = $request->getParsedBody()['xref'];
54
        assert(is_string($xref), new InvalidArgumentException());
55
56
        $individual = Individual::getInstance($xref, $tree);
57
        assert($individual instanceof Individual, new InvalidArgumentException());
58
59
        $order = $request->getParsedBody()['order'];
60
        assert(is_array($order), new InvalidArgumentException());
61
62
        Auth::checkIndividualAccess($individual, true);
63
64
        $dummy_facts = ['0 @' . $individual->xref() . '@ INDI'];
65
        $sort_facts  = [];
66
        $keep_facts  = [];
67
68
        // Split facts into OBJE and other
69
        foreach ($individual->facts() as $fact) {
70
            if ($fact->getTag() === 'OBJE') {
71
                $sort_facts[$fact->id()] = $fact->gedcom();
72
            } else {
73
                $keep_facts[] = $fact->gedcom();
74
            }
75
        }
76
77
        // Sort the facts
78
        uksort($sort_facts, static function ($x, $y) use ($order) {
79
            return array_search($x, $order, true) - array_search($y, $order, true);
80
        });
81
82
        // Merge the facts
83
        $gedcom = implode("\n", array_merge($dummy_facts, $sort_facts, $keep_facts));
84
85
        $individual->updateRecord($gedcom, false);
86
87
        return redirect($individual->url());
88
    }
89
}
90