Completed
Push — develop ( 0a2331...1eea26 )
by Greg
15:40 queued 07:01
created

EditNoteAction   A

Complexity

Total Complexity 1

Size/Duplication

Total Lines 38
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 15
dl 0
loc 38
rs 10
c 0
b 0
f 0
wmc 1

1 Method

Rating   Name   Duplication   Size   Complexity  
A handle() 0 29 1
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\Auth;
23
use Fisharebest\Webtrees\Registry;
24
use Fisharebest\Webtrees\Tree;
25
use Psr\Http\Message\ResponseInterface;
26
use Psr\Http\Message\ServerRequestInterface;
27
use Psr\Http\Server\RequestHandlerInterface;
28
29
use function assert;
30
31
/**
32
 * Edit note objects.
33
 */
34
class EditNoteAction implements RequestHandlerInterface
35
{
36
    /**
37
     * Show a form to create a new note object.
38
     *
39
     * @param ServerRequestInterface $request
40
     *
41
     * @return ResponseInterface
42
     */
43
    public function handle(ServerRequestInterface $request): ResponseInterface
44
    {
45
        $tree = $request->getAttribute('tree');
46
        assert($tree instanceof Tree);
47
48
        $xref = $request->getAttribute('xref');
49
50
        $note = Registry::noteFactory()->make($xref, $tree);
51
        $note = Auth::checkNoteAccess($note, true);
52
53
        $params = (array) $request->getParsedBody();
54
55
        $NOTE = $params['NOTE'];
56
57
        // Convert HTML line endings to GEDCOM continuations
58
        $NOTE = strtr($NOTE, ["\r\n" => "\n1 CONT "]);
59
60
        // "\" and "$" are significant in preg replacement strings, so escape them.
61
        $NOTE = str_replace(['\\', '$'], ['\\\\', '\\$'], $NOTE);
62
63
        $gedrec = preg_replace(
64
            '/^0 @' . $note->xref() . '@ NOTE.*(\n1 CONT.*)*/',
65
            '0 @' . $note->xref() . '@ NOTE ' . $NOTE,
66
            $note->gedcom()
67
        );
68
69
        $note->updateRecord($gedrec, true);
70
71
        return redirect($note->url());
72
    }
73
}
74