Passed
Push — main ( 85ca24...4cc369 )
by Greg
08:32
created

LinkChildToFamilyAction::handle()   C

Complexity

Conditions 11
Paths 180

Size

Total Lines 59
Code Lines 41

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 11
eloc 41
c 1
b 0
f 0
nc 180
nop 1
dl 0
loc 59
rs 6.65

How to fix   Long Method    Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

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 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...
23
use Fisharebest\Webtrees\Elements\PedigreeLinkageType;
0 ignored issues
show
Bug introduced by
The type Fisharebest\Webtrees\Elements\PedigreeLinkageType 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\Registry;
25
use Fisharebest\Webtrees\Validator;
26
use Psr\Http\Message\ResponseInterface;
27
use Psr\Http\Message\ServerRequestInterface;
28
use Psr\Http\Server\RequestHandlerInterface;
29
30
use function redirect;
31
32
/**
33
 * Link an existing individual as child in an existing family.
34
 */
35
class LinkChildToFamilyAction implements RequestHandlerInterface
36
{
37
    /**
38
     * @param ServerRequestInterface $request
39
     *
40
     * @return ResponseInterface
41
     */
42
    public function handle(ServerRequestInterface $request): ResponseInterface
43
    {
44
        $tree       = Validator::attributes($request)->tree();
45
        $xref       = Validator::attributes($request)->isXref()->string('xref');
46
        $individual = Registry::individualFactory()->make($xref, $tree);
47
        $individual = Auth::checkIndividualAccess($individual, true);
48
        $famid      = Validator::parsedBody($request)->isXref()->string('famid');
49
        $PEDI       = Validator::parsedBody($request)->string('PEDI');
50
51
        $family = Registry::familyFactory()->make($famid, $tree);
52
        $family = Auth::checkFamilyAccess($family, true);
53
54
        // Replace any existing child->family link (we may be changing the PEDI);
55
        $fact_id = '';
56
        foreach ($individual->facts(['FAMC']) as $fact) {
57
            if ($family === $fact->target()) {
58
                $fact_id = $fact->id();
59
                break;
60
            }
61
        }
62
63
        switch ($PEDI) {
64
            case '':
65
                $gedcom = "1 FAMC @$famid@";
66
                break;
67
            case PedigreeLinkageType::VALUE_ADOPTED:
68
                $gedcom = "1 FAMC @$famid@\n2 PEDI $PEDI\n1 ADOP\n2 FAMC @$famid@\n3 ADOP BOTH";
69
                break;
70
            case PedigreeLinkageType::VALUE_SEALING:
71
                $gedcom = "1 FAMC @$famid@\n2 PEDI $PEDI\n1 SLGC\n2 FAMC @$famid@";
72
                break;
73
            case PedigreeLinkageType::VALUE_FOSTER:
74
                $gedcom = "1 FAMC @$famid@\n2 PEDI $PEDI\n1 EVEN\n2 TYPE $PEDI";
75
                break;
76
            default:
77
                $gedcom = "1 FAMC @$famid@\n2 PEDI $PEDI";
78
                break;
79
        }
80
81
        if ($fact_id === '') {
82
            $individual->createFact($gedcom, true);
83
        } else {
84
            $individual->updateFact($fact_id, $gedcom, true);
85
        }
86
87
        // Only set the family->child link if it does not already exist
88
        $chil_link_exists = false;
89
        foreach ($family->facts(['CHIL']) as $fact) {
90
            if ($individual === $fact->target()) {
91
                $chil_link_exists = true;
92
                break;
93
            }
94
        }
95
96
        if (!$chil_link_exists) {
97
            $family->createFact('1 CHIL @' . $individual->xref() . '@', true);
98
        }
99
100
        return redirect($individual->url());
101
    }
102
}
103