1<?php 2 3/** 4 * webtrees: online genealogy 5 * 'Copyright (C) 2023 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 18declare(strict_types=1); 19 20namespace Fisharebest\Webtrees\Http\RequestHandlers; 21 22use Fisharebest\Webtrees\Auth; 23use Fisharebest\Webtrees\Elements\PedigreeLinkageType; 24use Fisharebest\Webtrees\Registry; 25use Fisharebest\Webtrees\Validator; 26use Psr\Http\Message\ResponseInterface; 27use Psr\Http\Message\ServerRequestInterface; 28use Psr\Http\Server\RequestHandlerInterface; 29 30use function redirect; 31 32/** 33 * Link an existing individual as child in an existing family. 34 */ 35class 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 $individual->updateFact($fact_id, $gedcom, true); 82 83 // Only set the family->child link if it does not already exist 84 $chil_link_exists = false; 85 foreach ($family->facts(['CHIL']) as $fact) { 86 if ($individual === $fact->target()) { 87 $chil_link_exists = true; 88 break; 89 } 90 } 91 92 if (!$chil_link_exists) { 93 $family->createFact('1 CHIL @' . $individual->xref() . '@', true); 94 } 95 96 return redirect($individual->url()); 97 } 98} 99