Passed
Push — master ( 247434...35b016 )
by Greg
07:11
created

UpdatePlacesPage   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 57
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 34
c 1
b 0
f 0
dl 0
loc 57
rs 10
wmc 4

1 Method

Rating   Name   Duplication   Size   Complexity  
A handle() 0 48 4
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
18
declare(strict_types=1);
19
20
namespace Fisharebest\Webtrees\Http\RequestHandlers;
21
22
use Fisharebest\Webtrees\Http\ViewResponseTrait;
23
use Fisharebest\Webtrees\I18N;
24
use Fisharebest\Webtrees\Tree;
25
use Illuminate\Database\Capsule\Manager as DB;
26
use Illuminate\Support\Collection;
27
use Psr\Http\Message\ResponseInterface;
28
use Psr\Http\Message\ServerRequestInterface;
29
use Psr\Http\Server\RequestHandlerInterface;
30
31
use function assert;
32
use function e;
33
use function preg_match_all;
34
use function preg_quote;
35
36
/**
37
 * Update place names.
38
 */
39
class UpdatePlacesPage implements RequestHandlerInterface
40
{
41
    use ViewResponseTrait;
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);
52
53
        $search  = $request->getQueryParams()['search'] ?? '';
54
        $replace = $request->getQueryParams()['replace'] ?? '';
55
56
        if ($search !== '' && $replace !== '') {
57
            // This does not take into account pending changes.
58
            $union = DB::table('families')
59
                ->where('f_file', '=', $tree->id())
60
                ->whereContains('f_gedcom', $search)
61
                ->select(['f_gedcom AS gedcom']);
62
63
            $changes = DB::table('individuals')
64
                ->where('i_file', '=', $tree->id())
65
                ->whereContains('i_gedcom', $search)
66
                ->select(['i_gedcom AS gedcom'])
67
                ->unionAll($union)
68
                ->pluck('gedcom')
69
                ->mapWithKeys(static function (string $gedcom) use ($search, $replace): array {
70
                    preg_match_all('/\n2 PLAC ((?:.*, )*)' . preg_quote($search, '/') . '(\n|$)/i', $gedcom, $matches);
71
72
                    $changes = [];
73
                    foreach ($matches[1] as $prefix) {
74
                        $changes[$prefix . $search] = $prefix . $replace;
75
                    }
76
77
                    return $changes;
78
                })
79
                ->sort()
80
                ->all();
81
        } else {
82
            $changes = new Collection();
83
        }
84
85
        /* I18N: Renumber the records in a family tree */
86
        $title = I18N::translate('Update place names') . ' — ' . e($tree->title());
87
88
        $this->layout = 'layouts/administration';
89
90
        return $this->viewResponse('admin/trees-places', [
91
            'changes' => $changes,
92
            'replace' => $replace,
93
            'search'  => $search,
94
            'title'   => $title,
95
            'tree'    => $tree,
96
        ]);
97
    }
98
}
99